解决Android横竖屏切换数据丢失问题


Android横竖屏切换时,当前的Activity会被销毁,然后Activity上面的数据将会全部丢失。

如Listview上面每个item的checkbox,横竖屏切换时,复选框就丢失所有选中信息。

解决方案1、

在Androidmanifest.xml的activity标签中加入

android:configChanges="orientation|keyboardHidden"

  1. <activity  
  2.           android:configChanges="orientation|keyboardHidden"  
  3.           android:label="sqltest"  
  4.           android:name=".SqlData"  
  5.             
  6.       </activity>  

解决方案2、

强制限制activity在横屏状态或者竖屏状态,不让activity进行横竖屏切换

landscape表示横屏

portrait表示竖屏

  1. <activity  
  2.             
  3.           android:label="sqltest"  
  4.           android:name=".SqlData"  
  5.           android:screenOrientation="landscape" >  
  6.       </activity>  

解决方案3、

在Activity里面通过复写

onConfigurationChanged方法,实现在不同的屏幕状态下的处理方式。

  1. @Override  
  2.     public void onConfigurationChanged(Configuration newConfig) {  
  3.         // TODO Auto-generated method stub   
  4.         super.onConfigurationChanged(newConfig);  
  5.         /* 
  6.          * 横竖屏检测 
  7.          */  
  8.         if (this.getResources().getConfiguration().orientation  
  9.   
  10.         == Configuration.ORIENTATION_LANDSCAPE) {  
  11.   
  12.             // 当前为横屏   
  13.             //实现代码   
  14.   
  15.         }  
  16.   
  17.         else if (this.getResources().getConfiguration().orientation  
  18.   
  19.         == Configuration.ORIENTATION_PORTRAIT) {  
  20.   
  21.             // 当前为竖屏   
  22.             //实现代码   
  23.   
  24.         }  
  25.   
  26.         /* 
  27.          *  实体键盘状态检测 
  28.          */  
  29.   
  30.         if (newConfig.hardKeyboardHidden  
  31.   
  32.         == Configuration.HARDKEYBOARDHIDDEN_NO) {  
  33.   
  34.             // 实体键盘处于推出状态   
  35.             //实现代码   
  36.   
  37.         }  
  38.   
  39.         else if (newConfig.hardKeyboardHidden  
  40.   
  41.         == Configuration.HARDKEYBOARDHIDDEN_YES) {  
  42.   
  43.             // 实体键盘处于合上状态   
  44.             //实现代码   
  45.   
  46.         }  
  47.   
  48.     }  

相关内容