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-04-08 22:46:28

    Element的操作方法

    Element 是一个通用性非常强的基类,所有 Document 对象下的对象都继承自它。这个接口描述了所有相同种类的元素所普遍具有的方法和属性。一些接口继承自 Element 并且增加了一些额外功能的接口描述了具体的行为。例如, HTMLElement 接口是所有 HTML 元素的基本接口,而 SVGElement 接口是所有 SVG 元素的基础。大多数功能是在这个类的更深层级(hierarchy)的接口中被进一步制定的。

  • 2020-04-12 17:42:43

    Node.js设置CORS跨域请求中多域名白名单的方法

    在Node.js中,res的响应头Header中的 Access-Control-Allow-Origin 属性不能匹配除 (*) 以外的正则表达式的,域名之间不能也用逗号分隔。也就是说, Access-Control-Allow-Origin 的属性值只允许设置为单个确定域名字符串或者 (*)。

  • 2020-04-14 09:40:59

    CSS3实现文字描边的2种方法

    首先想到去看CSS3有没有什么属性可以实现,后来被我找到了text-stroke     该属性是一个复合属性,可以设置文字宽度和文字描边颜色      该属性使用很简单:text-stroke:1px #f00;(1px是文字宽度,#ff是文字描边颜色)

  • 2020-04-14 09:42:47

    用 TypeScript 编写 npm 模块

    自从开始使用 Node.js 已经一年多,写的代码越多,越是觉得自己提高的越慢。想来应该有没有将单一功能的代码封装在一个独立模块,而导致代码稍微多一点就维护困难的原因。

  • 2020-04-14 09:46:25

    TypeScript 入门教程

    TypeScript 是 JavaScript 的超集,扩展了 JavaScript 的语法,因此现有的 JavaScript 代码可与 TypeScript 一起工作无需任何修改,TypeScript 通过类型注解提供编译时的静态类型检查。 TypeScript 可处理已有的 JavaScript 代码,并只对其中的 TypeScript 代码进行编译。

  • 2020-04-14 09:51:03

    package.json 字段说明

    package.json 有很多字段,也有很多官方字段,我们需要知道他们的具体是做什么的才能很好的运用