Android WebView “ 曲线救国” 实现全屏播放 – 热爱改变生活
我的GitHub GitHub |     登录
  • If you can't fly, then run; if you can't run, then walk; if you can't walk, then crawl
  • but whatever you do, you have to keep moving forward。
  • “你骗得了我有什么用,这是你自己的人生”
  • 曾有伤心之地,入梦如听 此歌

Android WebView “ 曲线救国” 实现全屏播放

Android控件 sinvader 17535℃ 0评论

目的

实现在 webview 中视频全屏播放。

遇到的问题

点击全屏按钮时没有调用 onShowCustomView。导致在代码中无法处理全屏事件。

解决方法

使用加速度传感器,监控手机的方向变化,根据手机的方向变化来判断是否应该变为横向,如果是横向的话视频会全屏。

主要代码

  • 1,首先获得 SensorManager 对象
    1. sensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);
  • 2. 在 onResume 中进行注册
    1. @Override
    2. protected void onResume() {
    3. sensorManager.registerListener(this, sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER), SensorManager.SENSOR_DELAY_FASTEST);
    4. super.onResume();
    5. }

    应为我的 activity 继承了 SensorEventListener,所以上面的代码中使用的是 this。

  • 3. 在 onSensorChanged 方法中根据 xyz 值进行判断修改横屏竖屏
    1. @Override
    2. public void onSensorChanged(SensorEvent event) {
    3. final int sensorType = event.sensor.getType();
    4. //values[0]:X轴,values[1]:Y轴,values[2]:Z轴
    5. final float[] values = event.values;
    6. float x = values[0];
    7. float y = values[1];
    8. float z = values[2];
    9. x = Math.abs(x);
    10. y = Math.abs(y);
    11. z = Math.abs(z);
    12. if ((x >= 6 && z < = 6) || (x >= 6 && y >= 6)) {
    13. Log.i(TAG, "heng" + x + "--" + y + "--" + z);
    14. if (getRequestedOrientation() != ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE) {
    15. setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE);
    16. }
    17. } else if ((x < = 3 && z <= 6) || (z <= 6 && y <= 3)) {
    18. Log.i(TAG, "shu" + x + "--" + y + "--" + z);
    19. if (getRequestedOrientation() != ActivityInfo.SCREEN_ORIENTATION_PORTRAIT) {
    20. setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
    21. }
    22. }
    23. }

    还有待解决的问题:

    这个解决的是网页内部有视频,但是没有视频都是文字呢?这样如果也横屏的话就不太好了,这个问题正在想(2015 年 8 月 31 日 12:11:25)
    想到了一个解决办法,不过可能会有点问题(网络加载慢或者重定向),下面是解决办法:

    在 WebViewClient 中的 onPageFinished 方法中获得 html 的整体代码,然后在里面寻找播放的关键词。

  • 第一步:
    1. webView.addJavascriptInterface(jsif, "local_obj");
  • 第二步
    1. webView.setWebViewClient(new WebViewClient() {
    2. @Override
    3. public void onPageFinished(WebView view, String url) {
    4. view.loadUrl("javascript:window.local_obj.showSource(''+" +
    5. "document.getElementsByTagName('html')[0].innerHTML+'');");
    6. super.onPageFinished(view, url);
    7. }
    8. });
  • 第三步
    1. @JavascriptInterface
    2. public void showSource(String html) {
    3. if (html.contains("yk-player-inner")) {
    4. Log.d("sumile", "优酷播放器");
    5. } else if (html.contains("play-view")) {
    6. Log.d("sumile", "土豆播放器");
    7. }
    8. }
    可能会有问题,这只是我的一个想法。如果有什么更好的办法请下面留言告诉我,拜谢~
    测试代码下载(AndroidStudio 版) 测试代码下载(添加播放器判断)

    里面就 4 个类,Eclipse 直接拷过去就可以了。

    ¥ 有帮助么?打赏一下~

    转载请注明:热爱改变生活.cn » Android WebView “ 曲线救国” 实现全屏播放


    本博客只要没有注明“转”,那么均为原创。 转载请注明链接:sumile.cn » Android WebView “ 曲线救国” 实现全屏播放

    喜欢 (1)
    发表我的评论
    取消评论
    表情

    如需邮件形式接收回复,请注册登录

    Hi,你需要填写昵称和邮箱~

    • 昵称 (必填)
    • 邮箱 (必填)
    • 网址