Android强制设定横屏时,SurfaceView一直黑屏

 更新时间:2017年01月03日 14:07:22   作者:Joanna.Yan  
本文主要介绍了Android强制设定横屏时,SurfaceView一直黑屏的方法。具有一定的参考作用,下面跟着小编一起来看下吧

接着上一个问题,解决了SurfaceView闪屏问题之后(https://www.jb51.net/article/101909.htm),又有了一个新的问题。现在我想设置含有fragment+viewpager的activity横屏。其中一个fragment有视频播放功能,含SurfaceView.

当我横屏拿着平板时,打开程序进入到该activity,是正常的。当竖屏拿着打开程序进入到该activity时,就会一直处于黑屏的状态。原因应该还是SurfaceView。难道程序转入后台或者黑屏以后(只要是不绘制状态),屏幕方向就是系统默认的屏幕方向吗?

解决:

1.在AndroidManifest.xml的对应的activty中,设置android:screenOrientation="nosensor",即 忽略物理感应器,这样就不会随着用户旋转设备而更改了 ( "unspecified"设置除外 )

设置android:configChanges="orientation|keyboardHidden|keyboard",横竖屏切换时,不会重新加载页面。

2.在对应的Activity中设置横屏。setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);

相关详解:关于Android设置全屏和横屏

横屏设置

XML文件设置--portrait为纵向,landscape为横向

android:screenOrientation=["unspecified" | "user" | "behind" |"landscape" | "portrait" | "sensor" | "nonsensor"]

screenOrientation 用来指定Activity的在设备上显示的方向,每个值代表如下含义:

"unspecified"     默认值 由系统来判断显示方向.判定的策略是和设备相关的,所以不同的设备会有不同的显示方向.

"landscape"     横屏显示(宽比高要长)

"portrait"     竖屏显示(高比宽要长)

"user"     用户当前首选的方向

"behind"     和该Activity下面的那个Activity的方向一致(在Activity堆栈中的)

"sensor"     有物理的感应器来决定。如果用户旋转设备这屏幕会横竖屏切换。

"nosensor"     忽略物理感应器,这样就不会随着用户旋转设备而更改了 ( "unspecified"设置除外 )。

代码设置

setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);

全屏两种方法:

方法一:java代码

public void onCreate(Bundle savedInstanceState) {      
  super.onCreate(savedInstanceState);             
  //设置无标题      
  requestWindowFeature(Window.FEATURE_NO_TITLE);       
  //设置全屏      
  getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, 
WindowManager.LayoutParams.FLAG_FULLSCREEN);             
  setContentView(R.layout.main);   
}

方法二:xml布局

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
  package="com.andyidea" 
  android:versionCode="1" 
  android:versionName="1.0" > 
  <uses-sdk android:minSdkVersion="8" /> 
  <application 
    android:icon="@drawable/icon" 
    android:label="@string/app_name" > 
    <activity 
      android:name=".login.LoginActivity" 
      android:label="@string/app_name" android:theme="@android:style/android.NoTitleBar.Fullscreen" > 
      <intent-filter> 
        <action android:name="android.intent.action.MAIN" /> 
        <category android:name="android.intent.category.LAUNCHER" /> 
      </intent-filter> 
    </activity> 
  </application> 
</manifest>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

相关文章

  • Android拍照裁剪图片

    Android拍照裁剪图片

    智能手机像素非常高,完全可以当相机使用,下面一段代码给大家分享了android拍照裁剪图片的功能,对android拍照裁剪图片相关知识感兴趣的朋友一起学习吧
    2015-12-12
  • RecyclerView进阶:使用ItemTouchHelper实现拖拽和侧滑删除效果

    RecyclerView进阶:使用ItemTouchHelper实现拖拽和侧滑删除效果

    现在RecyclerView的应用越来越广泛了,本篇文章主要介绍了RecyclerView进阶:使用ItemTouchHelper实现拖拽和侧滑删除效果,具有一定的参考价值,有兴趣的可以了解一下。
    2017-02-02
  • Android文件选择器ExFilePicker的使用方法

    Android文件选择器ExFilePicker的使用方法

    这篇文章主要为大家详细介绍了Android文件选择器ExFilePicker的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • Android Drawerlayout侧拉栏事件传递问题的解决方法

    Android Drawerlayout侧拉栏事件传递问题的解决方法

    这篇文章主要为大家详细介绍了Android Drawerlayout侧拉栏事件传递问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • UI 开源组件Flutter图表范围选择器使用详解

    UI 开源组件Flutter图表范围选择器使用详解

    这篇文章主要为大家介绍了UI 开源组件Flutter图表范围选择器使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • 详解Android 在 ViewPager 中使用 Fragment 的懒加载

    详解Android 在 ViewPager 中使用 Fragment 的懒加载

    本篇文章主要介绍了Android 在 ViewPager 中使用 Fragment 的懒加载,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • 详解Android如何实现自定义的动画曲线

    详解Android如何实现自定义的动画曲线

    最近在写动画相关的篇章,经常会用到 Curve 这个动画曲线类,那这个类到底怎么实现的?如果想自己来一个自定义的动画曲线该怎么弄?本文将为大家详细解答
    2022-04-04
  • Android实现超级棒的沉浸式体验教程

    Android实现超级棒的沉浸式体验教程

    这篇文章主要给大家介绍了关于Android如何实现超级棒的沉浸式体验的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Android具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • js验证手机号码

    js验证手机号码

    本文主要分享了js验证手机号码的示例代码,具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • 分析Android App中内置换肤功能的实现方式

    分析Android App中内置换肤功能的实现方式

    这篇文章主要介绍了Android App中内置换肤功能的实现方式,文中举了一个类似QQ空间中换肤方式的例子作为说明,需要的朋友可以参考下
    2016-02-02

最新评论