skip to Main Content

I have used this code and is working correctly (webview links and external links of website) but,

I get "ERR_UNKNOWN_URL_SCHEME" when trying to tap on html links that starts with mailto:

*So I need my website links work in webview app, other external links like facebook, instagram, all others… to open from browser android or app, and links like mailto: | tel: to send from app / phone.

Anyone can help me to fix this please?
I have little knowledge in java 🙁

Thanks.

public class MainActivity extends AppCompatActivity {

String websiteURL = "https://dwosix.com"; // sets web url
private WebView webview;
SwipeRefreshLayout mySwipeRefreshLayout;

@SuppressLint("SetJavaScriptEnabled")
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    if( ! CheckNetwork.isInternetAvailable(this)) //returns true if internet available
    {
        //if there is no internet do this
        setContentView(R.layout.activity_main);
        //Toast.makeText(this,"No Internet Connection, Chris",Toast.LENGTH_LONG).show();

        new AlertDialog.Builder(this) //alert the person knowing they are about to close
                .setTitle("No internet connection available")
                .setMessage("Please Check you're Mobile data or Wifi network.")
                .setPositiveButton("Ok", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        finish();
                    }
                })
                //.setNegativeButton("No", null)
                .show();

    }
    else
    {
        //Webview stuff
        webview = findViewById(R.id.webView);
        WebSettings webSettings = webview.getSettings();
        webSettings.setJavaScriptEnabled(true);
        webview.getSettings().setJavaScriptEnabled(true);
        webview.getSettings().setDomStorageEnabled(true);
        webview.setOverScrollMode(WebView.OVER_SCROLL_NEVER);
        webview.loadUrl(websiteURL);
        webview.setWebViewClient(new WebViewClientDemo(){
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                if (url.startsWith("mailto:") || url.startsWith("tel:")) {
                    view.getContext().startActivity(
                            new Intent(Intent.ACTION_VIEW, Uri.parse(url)));
                } else {
                    // Stay within this webview and load url
                    view.loadUrl(url);
                }
                return true;
            }
        });
    }

    //Swipe to refresh functionality
    mySwipeRefreshLayout = this.findViewById(R.id.swipeContainer);

    mySwipeRefreshLayout.setOnRefreshListener(
            new SwipeRefreshLayout.OnRefreshListener() {
                @Override
                public void onRefresh() {
                    webview.reload();
                }
            }
    );
}

private class WebViewClientDemo extends WebViewClient {

    @Override
    public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
        if((String.valueOf(request.getUrl())).contains("dwosix.com")) {
            view.loadUrl(String.valueOf(request.getUrl()));
        }
        else {
            view.getContext().startActivity(
                    new Intent(Intent.ACTION_VIEW, request.getUrl()));
        }
        return true;
    }
    @Override
    public void onPageFinished(WebView view, String url) {
        super.onPageFinished(view, url);
        mySwipeRefreshLayout.setRefreshing(false);
    }
}

//set back button functionality
@Override
public void onBackPressed() { //if user presses the back button do this
    if (webview.isFocused() && webview.canGoBack()) { //check if in webview and the user can go back
        webview.goBack(); //go back in webview
    } else { //do this if the webview cannot go back any further

        new AlertDialog.Builder(this) //alert the person knowing they are about to close
                .setTitle("EXIT")
                .setMessage("Are you sure. You want to close this app?")
                .setPositiveButton("Yes", new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        finish();
                    }
                })
                .setNegativeButton("No", null)
                .show();
    }
}

}

class CheckNetwork {

private static final String TAG = CheckNetwork.class.getSimpleName();

public static boolean isInternetAvailable(Context context)
{
    NetworkInfo info = ((ConnectivityManager)
            context.getSystemService(Context.CONNECTIVITY_SERVICE)).getActiveNetworkInfo();

    if (info == null)
    {
        Log.d(TAG,"no internet connection");
        return false;
    }
    else
    {
        if(info.isConnected())
        {
            Log.d(TAG," internet connection available...");
        }
        else
        {
            Log.d(TAG," internet connection");
        }
        return true;

    }
}

}

2

Answers


  1. Try this

    if(url.startsWith("mailto:")){
            MailTo mt = MailTo.parse(url);
            Intent i = new Intent(Intent.ACTION_SEND);
            i.setType("text/plain");
            i.putExtra(Intent.EXTRA_EMAIL, new String[]{mt.getTo()});
            i.putExtra(Intent.EXTRA_SUBJECT, mt.getSubject());
            i.putExtra(Intent.EXTRA_CC, mt.getCc());
            i.putExtra(Intent.EXTRA_TEXT, mt.getBody());
            mContext.startActivity(i);
            view.reload();
            return true;
        } 
    
    Login or Signup to reply.
  2. In your WebViewClient’s shouldOverrideUrlLoading method, try this:

    @Override
    public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) {
        String requestUrl = String.valueOf(request.getUrl())
    
        if (requestUrl.startsWith("mailto:") {
            view.getContext().startActivity(new Intent(Intent.ACTION_SENDTO, Uri.parse(requestUrl)))
        } else if (requestUrl.startsWith("tel:") {
            view.getContext().startActivity(new Intent(Intent.ACTION_DIAL, Uri.parse(requestUrl)))
        } else if(requestUrl.contains("dwosix.com")) {
            view.loadUrl(requestUrl);
        }
    
        return true;
    }
    
    Login or Signup to reply.
Please signup or login to give your own answer.
Back To Top
Search