Android h5全屏播放video

本文介绍了H5视频在不同操作系统上的全屏播放问题及其解决方案,重点探讨了在Android系统中实现全屏播放的技术细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

H5全屏播放,在iOS系统上基本没有什么问题,但是在android系统,却又各种各样的问题。

H5自身对全屏的支持

这个其实不难,只需在video标签加个webkit-playsinline属性即可,这个属性基本上在基于webkit内核的移动端都是没问题的,此全屏非彼全屏,它是在浏览器视窗内的全屏,并不是占居整个手机的全屏,当然我们做web端需要的就是在document的body内的视窗范围的全屏。

<video id="myvideo" src="test.mp4" webkit-playsinline="true"></video>

在ios下,视频被嵌入后,媒体的元数据加载完成后,会以全屏的形式显示出来,或者加个poster,可以看到画面。但在android下,多数机子是不显示视频画面的,要不就是显示一个黑色的还不是全屏的播放控件,即使及加个poster封面也不济于是。因为poster在android兼容的并不好,不如在视频上层加个div铺张图片,这个比较好的处理方式应该是:视频上加一层div做封面,由于android不允许视频上层有东西,所以首先将视频设为的width:1px,当播放后,上层的封面remove掉,同时width:100%或者你想要的宽。

Android支持全屏播放

public class WebVideoActivity extends Activity {
  
    private WebView webView;

    /** 视频全屏参数 */
    protected static final FrameLayout.LayoutParams COVER_SCREEN_PARAMS = new FrameLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
    private View customView;
    private FrameLayout fullscreenContainer;
    private WebChromeClient.CustomViewCallback customViewCallback;

    @Override
    protected void onCreate(Bundle bundle) {
        super.onCreate(bundle);
        setContentView(R.layout.activity_xx);
        webView = (WebView) findViewById(R.id.xx);
        initWebView();
    }

    @Override
    protected void onStop() {
        super.onStop();
        webView.reload();
    }

    /** 展示网页界面 **/
  public void initWebView() {
        WebChromeClient wvcc = new WebChromeClient();
        WebSettings webSettings = webView.getSettings();
        webSettings.setJavaScriptEnabled(true);
        webSettings.setUseWideViewPort(true); // 关键点
        webSettings.setAllowFileAccess(true); // 允许访问文件
        webSettings.setSupportZoom(true); // 支持缩放
        webSettings.setLoadWithOverviewMode(true);
        webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE); // 不加载缓存内容

        webView.setWebChromeClient(wvcc);
        WebViewClient wvc = new WebViewClient() {
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                webView.loadUrl(url);
                return true;
            }
        };
        webView.setWebViewClient(wvc);

        webView.setWebChromeClient(new WebChromeClient() {

            /*** 视频播放相关的方法 **/

            @Override
            public View getVideoLoadingProgressView() {
                FrameLayout frameLayout = new FrameLayout(WebVideoActivity.this);
                frameLayout.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT));
                return frameLayout;
            }

            @Override
            public void onShowCustomView(View view, CustomViewCallback callback) {
                showCustomView(view, callback);
            }

            @Override
            public void onHideCustomView() {
                hideCustomView();
            }
        });

        // 加载Web地址
        webView.loadUrl(webUrl);
    }

    /** 视频播放全屏 **/
    private void showCustomView(View view, CustomViewCallback callback) {
        // if a view already exists then immediately terminate the new one
        if (customView != null) {
            callback.onCustomViewHidden();
            return;
        }

        WebVideoActivity.this.getWindow().getDecorView();

        FrameLayout decor = (FrameLayout) getWindow().getDecorView();
        fullscreenContainer = new FullscreenHolder(WebVideoActivity.this);
        fullscreenContainer.addView(view, COVER_SCREEN_PARAMS);
        decor.addView(fullscreenContainer, COVER_SCREEN_PARAMS);
        customView = view;
        setStatusBarVisibility(false);
        customViewCallback = callback;
    }

    /** 隐藏视频全屏 */
    private void hideCustomView() {
        if (customView == null) {
            return;
        }

        setStatusBarVisibility(true);
        FrameLayout decor = (FrameLayout) getWindow().getDecorView();
        decor.removeView(fullscreenContainer);
        fullscreenContainer = null;
        customView = null;
        customViewCallback.onCustomViewHidden();
        webView.setVisibility(View.VISIBLE);
    }

    /** 全屏容器界面 */
    static class FullscreenHolder extends FrameLayout {

        public FullscreenHolder(Context ctx) {
            super(ctx);
            setBackgroundColor(ctx.getResources().getColor(android.R.color.black));
        }

        @Override
        public boolean onTouchEvent(MotionEvent evt) {
            return true;
        }
    }

    private void setStatusBarVisibility(boolean visible) {
        int flag = visible ? 0 : WindowManager.LayoutParams.FLAG_FULLSCREEN;
        getWindow().setFlags(flag, WindowManager.LayoutParams.FLAG_FULLSCREEN);
    }

    @Override
    public boolean onKeyUp(int keyCode, KeyEvent event) {
        switch (keyCode) {
        case KeyEvent.KEYCODE_BACK:
            /** 回退键 事件处理 优先级:视频播放全屏-网页回退-关闭页面 */
            if (customView != null) {
                hideCustomView();
            } else if (webView.canGoBack()) {
                webView.goBack();
            } else {
                finish();
            }
            return true;
        default:
            return super.onKeyUp(keyCode, event);
        }
    }
}


<think>嗯,用户问的是关于Android WebView内嵌H5视频全屏播放的问题。我需要先回忆一下相关的知识点。首先,WebView默认可能不支持全屏播放,特别是H5视频元素。可能需要配置WebView的一些设置,比如启用JavaScript和DOM存储,可能还需要处理全屏请求的回调。 接下来,用户可能需要具体的步骤,比如如何设置WebChromeClient,重写onShowCustomView方法,处理全屏的进入和退出。记得要提到WebView的硬件加速,因为视频播放可能需要这个。 另外,权限问题也很重要,比如在AndroidManifest.xml中声明硬件加速,还有网络权限。H5页面方面,可能需要检查视频标签的属性,比如是否允许全屏,比如playsinline或者webkit-playsinline。 还有全屏时的自定义视图处理,比如隐藏系统UI,设置横屏模式,或者使用自定义的全屏布局。可能还需要处理返回键,退出全屏状态。 需要注意不同Android版本的兼容性,特别是从Android 5.0开始,一些API的变化。另外,第三方浏览器内核可能会有不同的表现,可能需要额外处理。 有没有遗漏的地方?比如,是否要覆盖onHideCustomView来恢复视图?或者如何处理全屏时的方向切换?还有可能提到的常见问题,比如视频不能自动播放,需要用户交互触发。 总之,结构应该是先介绍基本配置,然后详细步骤,包括Java代码示例和注意事项,最后可能给出常见问题及解决方法。确保语言简洁,步骤清晰,用户能一步步实现。</think>在 Android WebView 中实现 H5 视频全屏播放,需要处理以下几个关键步骤: ### 一、基础配置 ```java webView.settings.apply { javaScriptEnabled = true // 启用JS domStorageEnabled = true // 启用DOM存储 mediaPlaybackRequiresUserGesture = false // 允许自动播放 setSupportMultipleWindows(true) // 支持多窗口(全屏需要) } ``` ### 二、核心处理类 需自定义 `WebChromeClient` 处理全屏事件: ```java webView.webChromeClient = object : WebChromeClient() { private var customView: View? = null // 处理全屏请求 override fun onShowCustomView(view: View?, callback: CustomViewCallback?) { handleFullscreenEnter(view, callback) } // 退出全屏 override fun onHideCustomView() { handleFullscreenExit() } } ``` ### 三、全屏处理逻辑 ```java private fun handleFullscreenEnter(view: View?, callback: CustomViewCallback?) { // 隐藏系统UI window.decorView.systemUiVisibility = View.SYSTEM_UI_FLAG_FULLSCREEN or View.SYSTEM_UI_FLAG_HIDE_NAVIGATION // 添加全屏视图 (context as? Activity)?.window?.addContentView( view, FrameLayout.LayoutParams(MATCH_PARENT, MATCH_PARENT) ) customView = view } private fun handleFullscreenExit() { // 移除全屏视图 (customView?.parent as? ViewGroup)?.removeView(customView) customView = null // 恢复系统UI window.decorView.systemUiVisibility = View.SYSTEM_UI_FLAG_VISIBLE } ``` ### 四、AndroidManifest 配置 ```xml <activity android:name=".MainActivity" android:hardwareAccelerated="true" <!-- 启用硬件加速 --> android:configChanges="orientation|screenSize"/> <!-- 防止页面重载 --> ``` ### 五、H5 页面注意事项 ```html <video controls playsinline <!-- iOS兼容 --> webkit-playsinline <!-- Android兼容 --> style="width:100%; height:auto"> </video> ``` ### 六、常见问题处理 1. **黑屏问题**:检查硬件加速是否开启 2. **方向切换异常**:确保 Activity 配置了 `configChanges` 3. **全屏按钮不显示**:确认视频 `controls` 属性已添加 4. **自动播放失败**:Android 8.0+ 需要用户手势触发 ### 七、高级优化 1. 使用 `FrameLayout` 作为全屏容器 2. 监听返回键退出全屏: ```java override fun onBackPressed() { if (customView != null) { handleFullscreenExit() } else { super.onBackPressed() } } ``` 不同 Android 版本需注意: - Android 5.0+ 需要使用 `onShowCustomView` - 部分第三方内核(X5)需要特殊适配 - 建议最低兼容 API Level 19(Android 4.4)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值