当前位置:  编程技术>移动开发
本页文章导读:
    ▪关于转屏,与activity状态的封存[转]        关于转屏,与activity状态的保存[转] 比较onSaveInstanceState() 与 onRetainNonConfigurationInstance()在不同需求中的用法针对Android平台,不论出于哪种目的,都或多或少需要在多个Activities中的跳转操作.........
    ▪ 开发课程笔记完全版        开发教程笔记完全版 Android开发教程笔记完全版 ......
    ▪ 第二章:java I/O施用(二)       第二章:java I/O应用(二) 效果:main.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" .........

[1]关于转屏,与activity状态的封存[转]
    来源: 互联网  发布时间: 2014-02-18
关于转屏,与activity状态的保存[转]
比较onSaveInstanceState() 与 onRetainNonConfigurationInstance()在不同需求中的用法

针对Android平台,不论出于哪种目的,都或多或少需要在多个Activities中的跳转操作,其中包括为了获得某些系统资源和必要信息,而通过启动(startActivity()&startActivityForResult() )Child Activity来提供一个选择器或者作为用户输入信息的介质。这期间父级Activity将暂时性失去焦点,从而在这之前先通过 onSaveInstanceState() 方法临时存储一些必要的信息,当父级的Activity重新成为当前焦点后,系统将触发 onRestoreInstanceState() 恢复失去焦点前的原有数据!onRetainNonConfigurationInstance()也具有相同的目的来处理类似的请求,其主要是由于旋转设备而更改显示模式,进而触发这个方法的调用。

那么在遇到某些特定需求时,特别是针对设备旋转后所导致的显示模式发生变化后,应该依据什么条件来判断应用哪种方式才能更好的满足需要呢?做出选择之前有必要分别了解两种方法的各自特点。

onSaveInstanceState()

在当前的Activity中通过新的Intent启动其它Activities之后,它将通过这个方法自动保存自身的数据,当再次出返回时可以通过 onRestoreInstanceState()复原数据。另外一种情况也将调用这个方法,当旋转设备后屏幕显示模式发生改变时。需要注意的一点是整个过程完全由系统控制,无法通过onSaveInstanceState()返回一个自定义的数据。

另外,onSaveInstanceState()在所有Activity destroying过程中被调用,它仅仅是为了在重新回到这个特定的Activity之后,依据Activity state重新创建一个与之前状态完全相同的Activity。例如:当我们启动某些Connection时,State并不能依然保存这个连接状态。所以当调用onSaveInstanceState后,所有当前的connection将一同销毁。当第二次通过 onRestoreInstanceState()找回之前的连接设置并重新建立新的连接实体。

如果大家有更多的发现,或者有不用于以上的验证结果,非常感谢能参与这个话题的讨论。

onRetainNonConfigurationInstance()

当Device configuration发生改变时,将伴随Destroying被系统调用。通过这个方法可以像onSaveInstanceState()的方法一样保留变化前的Activity State,最大的不同在于这个方法可以返回一个包含有状态信息的Object,其中甚至可以包含Activity Instance本身。新创建的Activity可以继承大量来至于Parent Activity State信息。

用这个方法保存Activity State后,通过getLastNonConfigurationInstance()在新的Activity Instance中恢复原有状态。

这个方法最大的好处是:

* 当Activity曾经通过某个网络资源得到一些图片或者视频信息,那么当再次恢复后,无需重新通过原始资源地址获取,可以快速的加载整个Activity状态信息。

* 当Activity包含有许多线程时,在变化后依然可以持有原有线程,无需通过重新创建进程恢复原有状态。

* 当Activity包含某些Connection Instance时,同样可以在整个变化过程中保持连接状态。

下边是需要特别注意的几点:

* onRetainNonConfigurationInstance()在onSaveInstanceState()之后被调用。
* 调用顺序同样介于onStop() 和 onDestroy()之间。

接下来将通过一个例子来简单了解onRetainNonConfigurationInstance()和getLastNonConfigurationInstance()的用法。

这个例子将首先启动一个包含两个按钮的Activity。其中一个按钮用于调用本地通讯录,并将所选择的某一项作为返回值传给当前 Activity。另外一个按钮的作用是查看当前所选择的通讯信息。正常的流程是当第一次启动程序后,第二个查看信息按钮是不可用状态。当通过Pick按钮确定选择并返回某一通讯录内容时,查看信息按钮的状态切换为可操作状态。然后当改变设备的Configuration时,可以注意到即便是 Activity通过onCreate()重新构建,但是之前所保证的UI属性依然保持最后一次操作的状态。

简单建立一个包含两个按钮的UI:
?View Code XML

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
>
<Button android:id="@+id/pick"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:layout_weight="1"
    android:text="Pick"
    android:enabled="true"
/>
<Button android:id="@+id/view"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:layout_weight="1"
    android:text="View"
    android:enabled="false"
/>
</LinearLayout>;

程序入口主程序代码如下所示(例子中包含了如何调用系统通讯录的方法):

package com.androidres.karka;

   import android.app.Activity;
   import android.content.Intent;
   import android.net.Uri;
   import android.os.Bundle;
   import android.view.View;
   import android.widget.Button;
   import android.util.Log;
   import android.provider.Contacts.People;

public class KarKa extends Activity {
static final int PICK_REQUEST=1337;
Button viewButton=null;
Uri contact=null;

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

Button btn=(Button)findViewById(R.id.pick);

btn.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
Intent i=new Intent(Intent.ACTION_PICK,
People.CONTENT_URI);

startActivityForResult(i, PICK_REQUEST);
}
});

viewButton=(Button)findViewById(R.id.view);

viewButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View view) {
startActivity(new Intent(Intent.ACTION_VIEW, contact));
}
});

restoreMe();

viewButton.setEnabled(contact!=null);
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode==PICK_REQUEST) {
if (resultCode==RESULT_OK) {
contact=data.getData();
viewButton.setEnabled(true);
}
}
}

@Override
public Object onRetainNonConfigurationInstance() {
return(contact);
}

private void restoreMe() {
contact=null;

if (getLastNonConfigurationInstance()!=null) {
contact=(Uri)getLastNonConfigurationInstance();
}
}
}

    
[2] 开发课程笔记完全版
    来源: 互联网  发布时间: 2014-02-18
开发教程笔记完全版
Android开发教程笔记完全版

    
[3] 第二章:java I/O施用(二)
    来源: 互联网  发布时间: 2014-02-18
第二章:java I/O应用(二)
效果:





main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<TextView  
	android:id="@+id/mPath"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:text="@string/hello"
    />
<ListView
    android:id="@android:id/list"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content">
</ListView>
</LinearLayout>




在res/layout/下新建一个file_row.xml
<?xml version="1.0" encoding="UTF-8"?>
<TextView
	android:id="@+id/text1"
	xmlns:android="http://schemas.android.com/apk/res/android"
	android:layout_width="wrap_content"
	android:layout_height="20px"
	android:textSize="14sp"/>




package i.o.and.listActiviy;

import java.io.File;

import java.util.ArrayList;
import java.util.List;
import android.app.AlertDialog;
import android.app.ListActivity;
import android.content.DialogInterface;
import android.os.Bundle;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;

public class IOAndListActivity extends ListActivity {
	private List<String> items=null;
	private List<String> paths=null;
	private String rootPath="/";
	private TextView mPath;
   
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        /**载入 main.xml*/
        setContentView(R.layout.main);
        /**通过id找到TextView组件*/
        mPath=(TextView)findViewById(R.id.mPath);
        getFileDir(rootPath);
    }
    /**获得文件路径构架*/
    public void getFileDir(String filePath){
    	/**当前路径*/
    	mPath.setText(filePath);
    	items=new ArrayList<String>();
    	paths=new ArrayList<String>();
    	File f=new File(filePath);
    	File[] files=f.listFiles();
    	
    	if(!filePath.equals(rootPath)){
    		/**第一条设置为会到目录*/
    		items.add("返回"+rootPath);
    		paths.add(rootPath);
    		/**返回上一层*/
    		items.add("返回../");
    		paths.add(f.getParent());
    	}
    	/**将文件名字和路径添加到List当中*/
    	if(files!=null){
    		for(int i=0;i<files.length;i++){
    		File file=files[i];
    		items.add(file.getName());
    		paths.add(file.getPath());
    		}
    	}
    	/**使用layout.file_row,items将Adapter设置给ListActivity*/
    	ArrayAdapter<String> fileList=new ArrayAdapter<String>(this,R.layout.file_row,items);
    	setListAdapter(fileList);
    }
    /**设置items被点击的事件*/
    protected void onListItemClick(ListView l,View v,int position,long id){
    	File file=new File(paths.get(position));
    	if(file.isDirectory()){
    		/**如果是文件夹就进去*/
    		getFileDir(paths.get(position));
    	}else{
    		/**如果是文件就告诉用户是文件*/
    		new AlertDialog.Builder(this).setIcon(R.drawable.icon).setTitle("["+file.getName()+"] 是文件!").setPositiveButton("OK", new DialogInterface.OnClickListener() {
				
				@Override
				public void onClick(DialogInterface dialog, int which) {
					// TODO Auto-generated method stub
					
				}
			}).show();
    	}
    }
}





    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
博客 iis7站长之家
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3