android - 全屏播放 HTML5 视频时旋转屏幕

标签 android html5-video fullscreen screen-rotation android-fullscreen

首先,我想为我糟糕的英语水平以及我在这篇文章中可能犯的所有错误道歉。 我也是 Android 开发的“初级”(我在空闲时间做这件事),我还不够好,经验还不够 ^^ 很抱歉,如果我可能有一些困难来理解你可能给我的答案.

那我在做什么? 我正在创建一个简单的 Android 应用程序。它只是一个加载我的网站的 Webview。 我的网站只是一个随机的 Youtube 视频播放器。

首先,我在全屏播放 HTML5 视频时遇到了问题。我通过这个项目成功地做到了 VideoEnabledWebView

所以我的应用与 VideoEnabledWebView 完全一样。

我的问题是什么? 我在我的应用程序中阻止了屏幕旋转。只有“人像”模式,我才成功做到了。 但是当我以全屏模式播放视频时,我不能处于横向模式。我明白为什么,但我找不到解决方案,无法做到这一点。 所以我只想在全屏播放视频时以横向模式旋转屏幕。

首先,这是我的 MainActivity.java :

public class MainActivity extends ActionBarActivity
{
    private VideoEnabledWebView webView;
    private VideoEnabledWebChromeClient webChromeClient;

    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        this.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
        webView = (VideoEnabledWebView)findViewById(R.id.webView);

        View nonVideoLayout = findViewById(R.id.nonVideoLayout); // Your own view, read class comments
        ViewGroup videoLayout = (ViewGroup)findViewById(R.id.videoLayout);

        View loadingView = getLayoutInflater().inflate(R.layout.view_loading_video, null); // Your own view, read class comments
        webChromeClient = new VideoEnabledWebChromeClient(nonVideoLayout, videoLayout, loadingView, webView) // See all available constructors...
        {                
            @Override
            public void onProgressChanged(WebView view, int progress)
            {

            }
        };
        webChromeClient.setOnToggledFullscreen(new VideoEnabledWebChromeClient.ToggledFullscreenCallback()
        {
            @Override
            public void toggledFullscreen(boolean fullscreen)
            {
                if (fullscreen)
                {
                    WindowManager.LayoutParams attrs = getWindow().getAttributes();
                    attrs.flags |= WindowManager.LayoutParams.FLAG_FULLSCREEN;
                    attrs.flags |= WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON;
                    getWindow().setAttributes(attrs);
                    if (android.os.Build.VERSION.SDK_INT >= 14)
                    {
                        getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LOW_PROFILE);
                    }
                }
                else
                {
                    WindowManager.LayoutParams attrs = getWindow().getAttributes();
                    attrs.flags &= ~WindowManager.LayoutParams.FLAG_FULLSCREEN;
                    attrs.flags &= ~WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON;
                    getWindow().setAttributes(attrs);
                    if (android.os.Build.VERSION.SDK_INT >= 14)
                    {
                        getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_VISIBLE);
                    }
                }

            }
        });
        webView.setWebChromeClient(webChromeClient);
        webView.setWebViewClient(new myWebViewClient());

        webView.loadUrl("https://www.awesomekraken.com/fr");
    }

    public class myWebViewClient extends WebViewClient
    {
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url)
        {
            view.loadUrl(url);
            return true;
        }
    }

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

正如您在 onCreate 方法中所见,我放置了以下行:

this.setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);

我认为在这部分我可以解决我的问题:

 webChromeClient.setOnToggledFullscreen(new VideoEnabledWebChromeClient.ToggledFullscreenCallback()
        {
            @Override
            public void toggledFullscreen(boolean fullscreen)
            {
                if (fullscreen)
                {
                    WindowManager.LayoutParams attrs = getWindow().getAttributes();
                    attrs.flags |= WindowManager.LayoutParams.FLAG_FULLSCREEN;
                    attrs.flags |= WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON;
                    getWindow().setAttributes(attrs);
                    if (android.os.Build.VERSION.SDK_INT >= 14)
                    {
                        getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LOW_PROFILE);
                    }
                }
                else
                {
                    WindowManager.LayoutParams attrs = getWindow().getAttributes();
                    attrs.flags &= ~WindowManager.LayoutParams.FLAG_FULLSCREEN;
                    attrs.flags &= ~WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON;
                    getWindow().setAttributes(attrs);
                    if (android.os.Build.VERSION.SDK_INT >= 14)
                    {
                        getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_VISIBLE);
                    }
                }

            }
        });

我尝试将 setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE); 放在 if(fullscreen) 下,但这不起作用。应用横向切换半秒,webview 重新加载所有页面。

我在 Google 和 StackOverflow 上搜索了很多,但从现在开始我没有找到任何有用的东西。

只有这个post和我一样,但是他没有得到任何答复。

如果有人有解决方案、提示或建议......

当然,如果我获得更多信息或解决我的问题,我会更新这篇文章。

在此先感谢您的帮助!

最佳答案

我最终旋转了自定义 View 容器:

public class RotatedVerticalFrameLayout extends FrameLayout{

    public RotatedVerticalFrameLayout(Context context, AttributeSet attrs){
        super(context, attrs);
    }

    @SuppressWarnings("SuspiciousNameCombination")
    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec){
        super.onMeasure(heightMeasureSpec, widthMeasureSpec);
        int w = getWidth();
        int h = getHeight();

        setRotation(90.0f);
        setTranslationX((h - w) / 2);
        setTranslationY((w - h) / 2);

        ViewGroup.LayoutParams lp = getLayoutParams();
        lp.height = w;
        lp.width = h;
        requestLayout();
    }
}

如果您只显示自定义 View 而不是操作栏和其他内容,这看起来像横向模式。

关于android - 全屏播放 HTML5 视频时旋转屏幕,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29517829/

相关文章:

c# - Xamarin.Android 上的多个彩色 Activity 标签元素

node.js - Google Chrome 中的视频搜索 : How to handle continuous Partial Content requests?

javascript - Internet Explorer 和 Edge 中的视频、内存管理问题,导致页面上的许多视频显示暗/黑和/或无法播放

HTML 视频无法正常工作

android - 如何解决android中的NetworkOnMainThreadException错误?

javascript - Android - 深度链接并非在所有情况下都适用于所有浏览器

android - 保存 TouchListView 并在下次应用打开时打开它

android - 如何在水平 ScrollView 内的线性布局内制作 2 个 ImageView ,每个 ImageView 的大小都可以覆盖屏幕

android - 让 Activity 始终在堆栈顶部,还是在恶意应用启动 Activity 时保持焦点?

jquery - 未捕获的类型错误 : Object #<HTMLElement> has no method 'webkitEnterFullScreen'