android设置禁止横屏失效崩溃

2020-12-02 22:56:09

有两种方法设置android禁止横屏

1.java代码

setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);

2.xml设置

<activity android:name=".activity.HomeActivity"

             android:screenOrientation="portrait"   >

            </activity>

误区,其实这两个代码都不是禁止横屏的,可以说根本没有禁止横屏的代码,这两个代码是设置竖屏的。

并且安卓先检测xml代码,如果是竖屏就直接展示竖屏的,但是如果java代码中设置的横屏,他会先展示竖屏咱展示横屏的 。

知道了这个,我们就好解决问题了。


我的问题是,我再baseActivity统一设置了java代码竖屏的代码。

结果我是手机调成可横竖屏模式,在横屏打开的情况下,我们能清楚的看到屏幕显示由横屏然后转换到了竖屏的。

这就尴尬了。

我有一个异步操作ui的,结果就报错了。

最后我给每个xml上都加上了竖屏的代码,这样就没问题了


下面我们介绍一个操作横竖屏的方法的例子。

参考链接  Android 手动设置屏幕方向后不能自动转屏问题



如题,Android在手动设置屏幕方向后不能使用自动转屏了,这是因为手动设置屏幕方向

如:

setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);

相当于在Manifest文件中Activity节点下配置了:

android:screenOrientation="landscape"

这会导致该Activity方向锁定,不能自动转屏。But,手动转屏是可以的,所以我们只需要加上方向改变监听,然后手动转屏,也就达到了自动转屏的目的:

class OrientationEventListenerImpl extends OrientationEventListener {
        public OrientationEventListenerImpl(Context context) {
            super(context);
        }
        @Override
        public void onOrientationChanged(int rotation) {
            Log.i("旋转角度:","rotation = "+rotation);
            //以下代码可以根据具体需求去配置
            // 设置为竖屏
            if (((rotation >= 0) && (rotation <= 45)) || (rotation >= 315)) {
                setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
            }
            // 设置为横屏
           if(((rotation >= 225) && (rotation <= 315))) {
                setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
            }
            //设置为横屏(逆向)
            if(((rotation >= 45) && (rotation <= 135))) {
                setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_REVERSE_LANDSCAPE);
            }
        }
    }

然后再注册该监听器,比如在Activity的onCreate()方法中注册:

OrientationEventListenerImpl orientationEventListenerImpl = new OrientationEventListenerImpl(this);
        orientationEventListenerImpl.enable();

这样就可以实现自动转屏了。上面代码只实现了在3个方向上转屏,没有写逆向的竖直方向(一般都不会用到这个方向吧),如有需要可以自己加上,角度请自己计算,其方向常量为:

ActivityInfo.SCREEN_ORIENTATION_REVERSE_PORTRAIT

通过以上的代码,还可以再配合

@Override
public void onConfigurationChanged(Configuration newConfig) {
    super.onConfigurationChanged(newConfig);
}

就可达到自由控制屏幕显示方向的目的。


  • 2020-01-17 08:37:26

    css transition分别指定多个属性

    transition有四个属性,很多人都会遗忘,分别是transition-property,transition-duration,transition-timing-function,transition-delay,尤其是transition-delay,这个可以实现延迟动画

  • 2020-01-17 08:44:57

    vue keepalive 前进刷新后退不刷新终极解决方案

    另外,我们做路由的时候要有意的根据页面等级做出路由的长度 比如 /a是一级的页面/a/b是二级的页面,下面的文章大家也可以通过判断path的长度来计算rank值,不用有意自定了 这样做的好处有两点,一个就是前进刷新,后退不刷新,还有就是,如果我们做页面进出效果的时候也能排上用场。

  • 2020-01-17 15:28:24

    深入理解vue中的slot与slot-scope

    vue中关于插槽的文档说明很短,语言又写的很凝练,再加上其和methods,data,computed等常用选项使用频率、使用先后上的差别,这就有可能造成初次接触插槽的开发者容易产生“算了吧,回头再学,反正已经可以写基础组件了”,于是就关闭了vue说明文档。

  • 2020-01-17 21:20:06

    Nuxt重要点介绍和记录

    nuxt.js简单的说是Vue.js的通用框架,最常用的就是用来作SSR(服务器端渲染).Vue.js是开发SPA(单页应用)的,Nuxt.js这个框架,用Vue开发多页应用,并在服务端完成渲染,可以直接用命令把我们制作的vue项目生成为静态html。

  • 2020-01-17 21:21:42

    nuxtjs打包优化

    然后你再使用 npm run build 打包的时候,会弹出一个界面 当然了,它第一次出来的时候我立马关了,这啥玩意???别着急你慢慢的品,慢慢的看。 原来 这是打包后的JS,面积的大小就是体积的大小。这样我们一目了然的看到了到底那里大了

  • 2020-01-17 23:21:54

    webpack打包优化之外部扩展externals的实际应用

    使用vue-cli创建项目,使用webpack打包。其中,有一个webpack优化webpack.optimize.CommonsChunkPlugin,它会将node_modules中的必需模块提取到vendor文件中,项目开发中,增加第三方模块,比如element-ui、vue-echarts等,vendor的包都会增大。这个时候,就需要考虑减轻vendor包的大小,增加构建速度。我们可以使用webpack的外部扩展(externals)功能。

  • 2020-01-18 01:26:59

    anyProxy使用注意事项

    anyproxy-ca 运行这个命令,如果是mac电脑他会提醒你去通过证书。