【问题标题】:Fullscreen button of Video inside WebView not workingWebView 内视频的全屏按钮不起作用
【发布时间】:2017-05-26 18:04:48
【问题描述】:

我正在尝试实现 WebChromeClient 的子类,以便在 youtube 上拥有一个工作全屏按钮,在 WebView 内嵌入视频链接(例如:https://www.youtube.com/embed/dQw4w9WgXcQ)。

我基本上简化了this repo,这里有一些sn-ps:

VideoWebChromeClient:

public class VideoWebChromeClient extends WebChromeClient {
    private boolean isVideoFullscreen = false;
    private View activityNonVideoView;
    private ViewGroup activityVideoView;
    private View videoViewContainer;
    private CustomViewCallback videoCallback;
    private Window videoWindow;

    public VideoWebChromeClient(View activityNonVideoView, ViewGroup activityVideoView, Window window) {
        this.activityNonVideoView = activityNonVideoView;
        this.activityVideoView =  activityVideoView;
        this.videoWindow = window;
    }

    @Override
    public void onShowCustomView(View view, CustomViewCallback callback) {
        Log.w("ENTER FULLSCREEN");
        videoCallback = callback;
        videoViewContainer = view;
        videoWindow.addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN | WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
        activityNonVideoView.setVisibility(View.GONE);
        activityVideoView.addView(videoViewContainer, new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
        activityVideoView.setVisibility(View.VISIBLE);
        isVideoFullscreen = true;
    }

    @Override
    public void onHideCustomView() {
        if (!isVideoFullscreen) {
            return;
        }
        Log.w("EXIT FULLSCREEN");
        activityVideoView.setVisibility(View.GONE);
        activityVideoView.removeView(videoViewContainer);
        activityNonVideoView.setVisibility(View.VISIBLE);
        videoWindow.clearFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN | WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
        videoViewContainer = null;
        videoCallback.onCustomViewHidden();
        isVideoFullscreen = false;
    }

    public boolean onBackPressed() {
        onHideCustomView();
        return isVideoFullscreen;
    }
  }

WebViewActivity

public class WebViewActivity extends BaseActivity {

    public static final String WEB_VIEW_URL_EXTRA = "URL";
    private boolean loadedFirstURL = true;
    private VideoWebChromeClient mWebChromeClient;

    @Bind(webview)
    WebView mWebView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(provideLayoutId());
        String url = (String) getIntent().getSerializableExtra(WEB_VIEW_URL_EXTRA);

        // Check if URL is YouTube / Vimeo
        if (RegexHelper.isVideoURL(url)){
            // Allow Fullscreen
            final View defaultLayout = findViewById(R.id.defaultLayout);
            final View fullscreenLayout = findViewById(R.id.fullscreenLayout);
            mWebChromeClient = new VideoWebChromeClient(defaultLayout, (ViewGroup) fullscreenLayout, getWindow());
            mWebView.setWebChromeClient(mWebChromeClient);

            // Block external links
            mWebView.setWebViewClient(new WebViewClient() {
                @Override
                public boolean shouldOverrideUrlLoading(WebView view, String url) {
                    if (loadedFirstURL) {
                        loadedFirstURL = false;
                        return false;
                    }
                    return true;
                }
            });
        }
        mWebView.getSettings().setJavaScriptEnabled(true);
        mWebView.loadUrl(url);
    }

        @Override
        public void onBackPressed() {
            if (!mWebChromeClient.onBackPressed())
            {
                if (mWebView.canGoBack()) {
                    mWebView.goBack();
                }
                else {
                    super.onBackPressed();
                }
            }
        }
    }

它在 KitKat 上正常工作,但在 Nougat 上不能正常工作(我只有这两个设备要测试):当我点击全屏按钮时,它有时会进入全屏,但大多数时候它会“闪烁”并保持非全屏状态。

然后,当它实际上处于全屏模式时,退出全屏的按钮不起作用(根本不调用onHideCustomView

你可以看到我放了日志,注意到当“flash”发生时,onHideCustomView实际上是在onShowCustomView之后调用的("ENTER FULLSCREEN"然后立即"EXIT FULLSCREEN"),我不明白为什么。

如果有人能指出我的解决方案,非常感谢

【问题讨论】:

  • 只是根据我的经验和研究得出的意见:忘记 webview 来处理 youtube 视频:使用适当的 Youtube API,您将摆脱每周令人惊讶的更新。
  • @statosdotcom 是的,我想要它,我可以在 YouTube 应用中打开它,但我不能,因为目标是只显示一个视频并避免推荐其他视频。
  • 也许 API 可以为您提供一些配置,允许进行一些微调。我想你应该看看它。祝你好运。
  • @statosdotcom :我并没有真正找到解决方案,所以我只是以一种更简单的方式完成了它:我全屏显示我的整个 webView,并且由于我使用 YT“嵌入”网址,它看起来像我想要它!非常感谢!
  • @statosdotcom 总是很高兴在互联网上找到好人!也祝你好运:)

标签: java android video youtube fullscreen


【解决方案1】:

我也遇到了同样的问题,但我花了几个小时解决了这个问题。

您所要做的就是设置 KitKat 设备的 UserAgent 字符串。就是这样!

private String userAgent = "Mozilla/5.0 (Linux; Android 4.4; Nexus 5 Build/_BuildID_) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/30.0.0.0 Mobile Safari/537.36";
mWebView.getSettings().setUserAgentString(userAgent);

这将修复 onShowCustomView()onHideCustomView() 在较新设备上的所有奇怪功能。 希望对您有所帮助。

【讨论】:

  • 这更像是一种解决方法,但谢谢,如果我再次处理这个问题,我会记住这一点。
猜你喜欢
  • 2012-09-14
  • 1970-01-01
  • 1970-01-01
  • 2019-09-06
  • 2016-09-07
  • 1970-01-01
  • 2014-10-26
  • 1970-01-01
相关资源
最近更新 更多