Android中使用WebView全屏播放视频时home键不起作用的问题解决

最近几天客户有个需求:无论在什么情况下,按home键都要回到app的首页,其他情况都已经实现,但在Webview中全屏播放视频时,按home键回到app首页。这个问题困扰我很长时间,因为home键是系统按键,app中压根拦截不到home键的事件,所以没法处理。客户需求又不得不做,因此查看Browser++源码发现,全屏播放时在onShowCustomView()方法中传进来一个View,记录此时的view,按下home键时会回到launcher中的home属性的activity,此时当前apk的activity会走onPause()生命周期方法,在onPause()方法中调用onHideCustomView()方法就能实现home键回到launcher,然后在launcher中处理即可回到homepage。   (这对本人而言是难点,高手请绕道。)

下面看一下部分代码:

xml文件:
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity"
    android:id="@+id/frameLayout">

    <WebView
        android:id="@+id/webView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"/>

</FrameLayout>

activity中的处理:

	private class MyChromClient extends WebChromeClient {
		@Override
		public void onShowCustomView(View view, CustomViewCallback callback) { //This is used for Fullscreen video playback
			super.onShowCustomView(view, callback);
			if (mView != null) {
				callback.onCustomViewHidden();
				return;
			}
			mFrameLayout.removeView(mWebView);
			mFrameLayout.addView(view);
			mView = view;   //用mView保存全屏播放视频的custom view
			mCallback = callback;
		}

		@Override
		public void onHideCustomView() {  //Notify the host application that the current page would like to hide its custom view.
			super.onHideCustomView();
			if (mView == null) {
				return;
			}
			mView.setVisibility(View.GONE);
			mFrameLayout.removeView(mView);
			mView = null;
			mFrameLayout.addView(mWebView);
			mCallback.onCustomViewHidden();
		}
	}

按home键时当前activity会走onPause()方法,所以在onPause()方法中调用onHideCustomVIew()将custom view隐藏:

	@Override
	protected void onPause() {
		super.onPause();
		if (mView != null) {  //是全屏播放时调用隐藏的方法
			mChromClient.onHideCustomView();
		}
	}

以上就是在WebView中全屏播放时按home键不起作用的解决方法。类似的,如果要对home键做响应时也可以用这种方法,算是学会了一种思路吧。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值