WebView с IFRAME Android - PullRequest
       17

WebView с IFRAME Android

11 голосов
/ 21 января 2012

Я хочу загрузить HTML <IFRAME> внутри WebView, но я не знаю почему, он не может этого сделать.

Я использую следующий код для загрузки <IFRAME>

webView.loadData("<iframe src=\"http://www.google.com\"></iframe>", "text/html",
                "utf-8");

Вот что я попробовал.

WebSettings webViewSettings = webView.getSettings();
webViewSettings.setJavaScriptCanOpenWindowsAutomatically(true);
webViewSettings.setJavaScriptEnabled(true);
webViewSettings.setPluginsEnabled(true);
webViewSettings.setBuiltInZoomControls(true);
webViewSettings.setPluginState(PluginState.ON);

Я упомянул интернет-разрешение:

<uses-permission android:name="android.permission.INTERNET" />

Я также попытался настроить WebViewClient с помощьюshouldOverrideUrlLoading всегда возвращает false.

Но это просто не работает.

Я пробовал это на разных сайтах, то есть на сайтах, отличных от google.com.

Я тестирую это на Samsung Nexus S под управлением ICS 4.0.3

Ответы [ 3 ]

9 голосов
/ 24 января 2012

Вот как это получилось.

Я заметил, что Бревно бросало меня

Проблема с разрешением WebKit: EventHub.removeMessages (int what = 107) не поддерживается до настройки WebViewCore

Чтобы это исправить, мне пришлось добавить android:hardwareAccelerated="true" в <application> тег Manifest.

Я испытывал это на ICS, и было обнаружено, что такая же проблема будет возникать после сотовых устройств.

Надеюсь, это поможет кому-нибудь.

7 голосов
/ 08 сентября 2015

Попробуйте с кодом ниже:

webView.setInitialScale(1);
webView.setWebChromeClient(new WebChromeClient());
webView.getSettings().setAllowFileAccess(true);
webView.getSettings().setPluginState(WebSettings.PluginState.ON);
webView.getSettings().setPluginState(WebSettings.PluginState.ON_DEMAND);
webView.setWebViewClient(new WebViewClient());
webView.getSettings().setJavaScriptEnabled(true);
webView.getSettings().setLoadWithOverviewMode(true);
webView.getSettings().setUseWideViewPort(true);
DisplayMetrics displaymetrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(displaymetrics);
int height = displaymetrics.heightPixels;
int width = displaymetrics.widthPixels;

Log.e(SimpleBillsConstants.SIMPLE_BILLS, width + "-" + height);

String data_html = "<!DOCTYPE html><html> <head> <meta charset=\"UTF-8\"><meta name=\"viewport\" content=\"target-densitydpi=high-dpi\" /> <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\"> <link rel=\"stylesheet\" media=\"screen and (-webkit-device-pixel-ratio:1.5)\" href=\"hdpi.css\" /></head> <body style=\"background:black;margin:0 0 0 0; padding:0 0 0 0;\"> <iframe style=\"background:black;\" width=' "+width+"' height='"+height+"' src=\""+VIDEO_URL+"\" frameborder=\"0\"></iframe> </body> </html> ";

webView.loadDataWithBaseURL("http://vimeo.com", data_html, "text/html", "UTF-8", null);
1 голос
/ 27 февраля 2018

следующий хак сработал для меня, чтобы загрузить iframes в webview. Надеюсь, кто-то еще может найти это полезным

    String webContent="your data to be loaded in webview"
if(webContent.contains("iframe")){
                Matcher matcher = Pattern.compile("src=\"([^\"]+)\"").matcher(webContent);
                matcher.find();
                String src = matcher.group(1);
                webContent=src;

                try {
                    URL myURL = new URL(src);
                    webView.loadUrl(src);

                } catch (MalformedURLException e) {
                    e.printStackTrace();
                }
            }else {

                webView.loadDataWithBaseURL(null, "<style>img{display: inline;height: auto;max-width: 100%;}</style>" + webContent, "text/html", "UTF-8", null);}

        }
    }
...