WebView
内にHTML <IFRAME>
をロードしたいのですが、なぜなのかわかりません。
次のコードを使用して<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
これがうまくいきました。
ログキャットが投げてきたのに気づいた
WebKit権限の問題:WebViewCoreが設定されるまで、EventHub.removeMessages(int what = 107)はサポートされません
これを修正するには、マニフェストのAndroid:hardwareAccelerated="true"
タグに<application>
を追加する必要がありました。
ICS=でこの問題が発生しており、Honeycombデバイスの後に同じ問題が発生することがわかりました。
これが誰かを助けることを願っています。
以下のコードで試してください:
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);
次のハックは、webviewにiframeをロードするために私のために働きました。
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);}
}
}