android - 安卓webview无法全屏播放iframe腾讯、优酷视频
问题描述
先上代码吧
public class MainActivity extends AppCompatActivity { static final String iframeStr = '<iframe frameborder='0' src='http://v.qq.com/iframe/player.html?vid=v0151eygqka&tiny=0&auto=0' allowfullscreen></iframe>'; private WebView videoWebView; private FrameLayout fullScreenView; private View customView; @Override protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);fullScreenView = (FrameLayout) findViewById(R.id.video_fullscreen);videoWebView = (WebView) findViewById(R.id.webView);WebSettings settings = videoWebView.getSettings();settings.setJavaScriptEnabled(true);settings.setJavaScriptCanOpenWindowsAutomatically(true);settings.setDatabaseEnabled(true);settings.setAppCacheEnabled(true);settings.setCacheMode(WebSettings.LOAD_DEFAULT);settings.setPluginState(WebSettings.PluginState.ON);settings.setAllowFileAccess(true);settings.setLoadWithOverviewMode(true);settings.setDomStorageEnabled(true);settings.setUseWideViewPort(true);videoWebView.setWebChromeClient(new MyWebChromeClient());videoWebView.setWebViewClient(new MyWebViewClient());videoWebView.loadData(iframeStr,'text/html','utf-8'); } class MyWebViewClient extends WebViewClient{@Overridepublic boolean shouldOverrideUrlLoading(WebView view, String url) { return false;} } class MyWebChromeClient extends WebChromeClient{private CustomViewCallback customViewCallback;@Overridepublic void onShowCustomView(View view, CustomViewCallback callback) { setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE); videoWebView.setVisibility(View.INVISIBLE); // 如果一个视图已经存在,那么立刻终止并新建一个 if (customView != null) {callback.onCustomViewHidden();return; } fullScreenView.addView(view); customView = view; customViewCallback = callback; fullScreenView.setVisibility(View.VISIBLE);}@Overridepublic void onHideCustomView() { if (customView == null)// 不是全屏播放状态return; setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT); customView.setVisibility(View.GONE); fullScreenView.removeView(customView); customView = null; fullScreenView.setVisibility(View.GONE); customViewCallback.onCustomViewHidden(); videoWebView.setVisibility(View.VISIBLE);} } @Override protected void onResume() {super.onResume();if (getRequestedOrientation() != ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE) { setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);}videoWebView.resumeTimers(); } @Override protected void onPause() {super.onPause();videoWebView.pauseTimers(); } @Override protected void onDestroy() {super.onDestroy();videoWebView.destroy(); }}
就是用一个webview显示一个视频(不是一个视频网页,只是一个视频),然后我使用的是iframe的链接(就是腾讯视频分享那里的通用代码)。我参照了网上很多关于全屏显示的问题,基本代码都是这样,但是并没有用,感觉没有调用到那两个函数。还有是不是跟链接里限定了大小有关系。这样的话,需要修改什么才能全屏呢?
问题解答
回答1:楼主有找到解决方法吗
相关文章:
1. javascript - 最终生成的jsBundle文件压缩问题2. android - 启动模拟器的,报“Could not automatically detect an ADB binary……”,要怎么解决?3. python - TypeError: tryMsgcode() takes exactly 2 arguments (0 given)4. 关于Java引用传递的一个困惑?5. 如何分别在Windows下用Winform项模板+C#,在MacOSX下用Cocos Application项目模板+Objective-C实现一个制作游戏的空的黑窗口?6. angular.js - angularjs的自定义过滤器如何给文字加颜色?7. 关于docker下的nginx压力测试8. android clickablespan获取选中内容9. docker安装后出现Cannot connect to the Docker daemon.10. javascript - 关于json中获取多个key-value对中多层嵌套key的name
