Hide WebView until JavaScript is done

后端 未结 2 922
星月不相逢
星月不相逢 2020-12-05 17:03

I have a webview

WebView wv;
wv = (WebView)findViewById(R.id.webView1);
wv.loadUrl(\"http://example.com/\");

Simply said.

at:

相关标签:
2条回答
  • 2020-12-05 17:17

    I had the same problem of @GromDroid.

    Maybe not the best solution but it works:

    public class myJavaScriptInterface {
            @JavascriptInterface
            public void setVisible(){
                runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        new Handler().postDelayed(new Runnable() {
                            @Override
                            public void run() {
                                wb.setVisibility(View.VISIBLE);
                            }
                        }, 500);
                    }
                });
            }
        }
    

    I've added a delay of half second before make the webview visible.

    0 讨论(0)
  • 2020-12-05 17:34

    Tested on API 17 emulator and it works.

    You can inject javascript from Java to the web.

    And do vice-versa, once the url is loaded call from javascript to a function on our Java code, and execute the setVisibility(). For that purpose you are going to add a JS interface.

    Here the code:

    private final static String HOST = "stackoverflow.com";
    private WebView wb;
    
    @SuppressLint("SetJavaScriptEnabled")
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.activity_home);
        wb = (WebView) findViewById(R.id.home_webview);
        //Make the webview invisible
        wb.setVisibility(View.INVISIBLE);
        WebSettings webSettings = wb.getSettings();
        webSettings.setJavaScriptEnabled(true);
        wb.setWebViewClient(new WebViewClient(){
            public void onPageFinished(WebView view, String url){
                //Inject javascript code to the url given
                //Not display the element
                wb.loadUrl("javascript:(function(){"+"document.getElementById('Id').style.display ='none';"+"})()");
                //Call to a function defined on my myJavaScriptInterface 
                wb.loadUrl("javascript: window.CallToAnAndroidFunction.setVisible()");
            }           
        });
    
        //Add a JavaScriptInterface, so I can make calls from the web to Java methods
        wb.addJavascriptInterface(new myJavaScriptInterface(), "CallToAnAndroidFunction");
        wb.loadUrl("http://"+HOST);
    }
    
     public class myJavaScriptInterface {
         @JavascriptInterface
         public void setVisible(){
             runOnUiThread(new Runnable() {
    
                @Override
                public void run() {
                    wb.setVisibility(View.VISIBLE);                 
                }
            });
         }
    
     }
    

    This functionality is going to be executed for every page. Once on the 3rd party server you have to manage what to do with every request, webClient.shouldOverrideUrlLoading() can help you.

    Updated answer:

    I could reproduce it as you commented, for the last version we should do:

    Beginning in Android 4.2, you will now have to explicitly annotate public methods with @JavascriptInterface in order to make them accessible from hosted JavaScript. Note that this also only takes effect only if you have set your app's minSdkVersion or targetSdkVersion to 17 or higher.

    I added it and imported android.webkit.JavascriptInterface

    Reference: JavascriptInterface methods in WebViews must now be annotated

    0 讨论(0)
提交回复
热议问题