• WebView播放视频白屏、不能全屏问题解决


    在项目中,会有在webview嵌入的网页中播放视频的需求,会在部分手机上出现白屏或有声音无画面等问题,并且存在全屏按钮点击无效果的问题。

    此文章已收入Android偶遇杂症合集(持续更新)

    1. 播放视频白屏、无画面问题解决

    原因是WebView播放视频时可能需要硬件加速才可以正常播放视频,关闭硬件加速可能在部分手机上出现白屏、无画面、无法暂停等问题。解决方法就是开启硬件加速:

    1. 在AndroidManifest.xml的application中声明HardwareAccelerate属性
    2. 在AndroidManifest.xml的对应activity中声明HardwareAccelerate属性
    3. 在使用WebView的代码前添加如下代码:
    window.setFlags(WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED,
    		WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED)
    

    2. 视频不能全屏问题解决

    原因是WebView的视频全屏事件是需要客户端完成后续逻辑的,网页点击全屏按钮会触发WebChromeClient的onShowCustomView方法,全屏后缩回来会触发onHideCustomView方法,在这两个方法中我们要对视频进行一个全屏放大的处理。

    在我们的WebView使用之前需要添加的代码如下:

        var fullscreenContainer: FrameLayout? = null
        var customViewCallback: WebChromeClient.CustomViewCallback? = null
        val mWebChromeClient = object : WebChromeClient() {
            override fun onShowCustomView(view: View?, callback: CustomViewCallback?) {
                super.onShowCustomView(view, callback)
                showCustomView(view, callback)
            }
    
            override fun onHideCustomView() {
                super.onHideCustomView()
                hideCustomView()
            }
        }
    
        /**
         * 显示自定义控件
         */
        private fun showCustomView(view: View?, callback: WebChromeClient.CustomViewCallback?) {
            if (fullscreenContainer != null) {
                callback?.onCustomViewHidden()
                return
            }
    
            fullscreenContainer = FrameLayout(context).apply { setBackgroundColor(Color.BLACK) }
            customViewCallback = callback
            fullscreenContainer?.addView(view)
            val decorView = (context as? Activity)?.window?.decorView as? FrameLayout
            (context as? Activity)?.requestedOrientation = ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE
            decorView?.addView(fullscreenContainer)
        }
    
        /**
         * 隐藏自定义控件
         */
        private fun hideCustomView() {
            if (fullscreenContainer == null) {
                return
            }
    
            val decorView = (context as? Activity)?.window?.decorView as? FrameLayout
            (context as? Activity)?.requestedOrientation = ActivityInfo.SCREEN_ORIENTATION_PORTRAIT
            fullscreenContainer?.removeAllViews()
            decorView?.removeView(fullscreenContainer)
            fullscreenContainer = null
            customViewCallback?.onCustomViewHidden()
            customViewCallback = null
        }
    

    最终在WebView使用时,为WebView设置WebChromeClient:

    	webView.webChromeClient = mWebChromeClient
    
  • 相关阅读:
    【世界上最优秀的逆向分析工具】IDA Pro6.1绿色版
    js 在线压缩混淆工具
    [转载 js]网站开发常用的一些值得珍藏的代码
    js 和 as 保留指定小数位数
    js 在线压缩混淆工具
    DOM元素的所有子元素 .elements
    DOM元素的所有子元素 .elements
    [转载 js]网站开发常用的一些值得珍藏的代码
    关于 getElementsByTagName
    js 和 as 保留指定小数位数
  • 原文地址:https://www.cnblogs.com/hwb04160011/p/13960585.html
Copyright © 2020-2023  润新知