初期状態のWebViewではYouTubeのiframeを埋め込んだサイトを表示できません。
マニフェストの設定を行う
Youtubeの再生には以下の設定が必要です。
- user-permissionのInternet
- hardware accelarationの有効化
<uses-permission android:name="android.permission.INTERNET"/> <application android:allowBackup="true" android:hardwareAccelerated="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" >
WebViewのJavascriptとPluginをONにする
以下ソースを参考にJavascriptとPluginをONにします。mWebViewはWebViewのメンバ変数名です。
private void initWebView() { mWebView = (WebView) findViewById(R.id.webView); // WebViewの設定 WebSettings settings = mWebView.getSettings(); settings.setJavaScriptEnabled(true); if (Build.VERSION.SDK_INT > 7) { settings.setPluginState(PluginState.ON); } else { settings.setPluginsEnabled(true); } String html = ""; html += "<html><body>"; html += "<iframe width="560" height="315" src="http://www.youtube.com/embed/MU9Srs04sFU?rel=0" frameborder="0" allowfullscreen></iframe>"; html += "</body></html>"; mWebView.loadData(html, "text/html", null); }
再生中に他のアクティビティに移動すると再生されっぱなしになってしまう
以下のコードを追加する
@Override protected void onResume() { super.onResume(); try { WebView.class.getMethod("onResume").invoke(mWebView); } catch (Exception e) { e.printStackTrace(); } } @Override protected void onPause() { super.onPause(); try { WebView.class.getMethod("onPause").invoke(mWebView); } catch (Exception e) { e.printStackTrace(); } }
サンプルコード
GitHub上に公開してあります。
https://github.com/fly1tkg/android-youtube-webview-sample
追記) Youtube Android Player APIをつかった方法を書きました
http://blog.fly1ncu.com/2013/02/android-youtube-player-api/