文章出处:http://gundumw100.iteye.com/blog/1067414
AsyncTask是抽象类.AsyncTask定义了三种泛型类型 Params,Progress和Result。
◆Params 启动任务执行的输入参数,比如HTTP请求的URL。
◆Progress 后台任务执行的百分比。
◆Result 后台执行任务最终返回的结果,比如String。
AsyncTask的执行分为四个步骤,每一步都对应一个回调方法,这些方法不应该由应用程序调用,开发者需要做的就是实现这些方法。
onPreExecute(), 该方法将在执行实际的后台操作前被UI thread调用。可以在该方法中做一些准备工作,如在界面上显示一个进度条。
doInBackground(Params...), 将在onPreExecute 方法执行后马上执行,该方法运行在后台线程中。这里将主要负责执行那些很耗时的后台计算工作。可以调用 publishProgress方法来更新实时的任务进度。该方法是抽象方法,子类必须实现。
onProgressUpdate(Progress...),在publishProgress方法被调用后,UI thread将调用这个方法从而在界面上展示任务的进展情况,例如通过一个进度条进行展示。
onPostExecute(Result), 在doInBackground 执行完成后,onPostExecute 方法将被UI thread调用,后台的计算结果将通过该方法传递到UI thread.
为了正确的使用AsyncTask类,以下是几条必须遵守的准则:
1) Task的实例必须在UI thread中创建
2) execute方法必须在UI thread中调用
3) 不要手动的调用onPreExecute(), onPostExecute(Result),doInBackground(Params...), onProgressUpdate(Progress...)这几个方法
4) 该task只能被执行一次,否则多次调用时将会出现异常
下面是AsyncTask异步获取已安装程序列表的例子:
public class Screen1 extends Activity{
private static final String tag="Screen1";
private ListView listview;
private Context mContext;
private List<ResolveInfo> list;
private AppAdapter adapter;
private PackageManager pm;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
//给Activity注册界面进度条功能
requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);
setContentView(R.layout.screen_1);
mContext = this;
list=new ArrayList<ResolveInfo>();
pm = mContext.getPackageManager();
listview = (ListView)findViewById(R.id.listview);
adapter = new AppAdapter(mContext);
listview.setAdapter(adapter);
listview.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view,
int position, long id) {
// TODO Auto-generated method stub
Log.i(tag, "---------------onItemClick-----------------");
ResolveInfo info=list.get(position);
String packageName = info.activityInfo.packageName;
String className = info.activityInfo.name;
Intent intent = new Intent();
intent.setClassName(packageName, className);
startActivity(intent);
}
});
new MyTask().execute();
}
class AppAdapter extends BaseAdapter{
Context context;
AppAdapter(Context context){
this.context=context;
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return list.size();
}
@Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return list.get(position);
}
@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
if(convertView==null){
LayoutInflater inflater=getLayoutInflater().from(context);
convertView=inflater.inflate(R.layout.simple_item_2, null);
}
ImageView iv=(ImageView)convertView.findViewById(R.id.icon);
TextView tv=(TextView)convertView.findViewById(R.id.text);
ResolveInfo info=list.get(position);
iv.setBackgroundDrawable(info.activityInfo.loadIcon(pm));
tv.setText(info.activityInfo.loadLabel(pm));
return convertView;
}
}
class MyTask extends AsyncTask<String, Integer, String>{
@Override
protected void onPreExecute() {
setProgressBarIndeterminateVisibility(true);
showProgress();
}
@Override
protected void onPostExecute(String param) {
setProgressBarIndeterminateVisibility(false);
adapter.notifyDataSetChanged();
closeProgress();
}
@Override
protected void onCancelled() {
// TODO Auto-generated method stub
super.onCancelled();
}
@Override
protected void onProgressUpdate(Integer... values) {
// TODO Auto-generated method stub
super.onProgressUpdate(values);
}
@Override
protected String doInBackground(String... params) {
// TODO Auto-generated method stub
// 获取已经安装程序列表
Intent intent = new Intent(Intent.ACTION_MAIN, null);
intent.addCategory(Intent.CATEGORY_LAUNCHER);
list = pm.queryIntentActivities(intent, 0);
Collections.sort(list, new ResolveInfo.DisplayNameComparator(pm));
return null;
}
}
private Dialog dialog;
protected void showProgress() {
if(dialog == null) {
dialog = new Dialog(this, R.style.Theme_TransparentDialog);
// dialog.setContentView(R.layout.progress_dialog);
dialog.setContentView(new ProgressBar(this));
dialog.setCancelable(true);
dialog.show();
}
}
//
protected void closeProgress() {
if(dialog != null) {
dialog.cancel();
dialog = null;
}
}
public boolean isShowing(){
if(dialog != null) {
return dialog.isShowing();
}
return false;
}
}
simple_item_2.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:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="应用列表"
/>
<ListView android:id="@+id/listview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
/>
</LinearLayout>
Android得到系统已安装应用程序包列表方法 自定义ListView显示 PackageManager的使用
AyncTask 实战 模拟GridView 动态更新效果
http://www.ophonesdn.com/article/show/80
分享到:
相关推荐
我们可以通过`getInstalledPackages()`方法获取所有已安装的应用程序包信息。 4. **PackageInfo**: 当调用`getInstalledPackages()`时,返回的是一个`PackageInfo`对象的列表。每个`PackageInfo`对象包含了应用的...
PackageManager提供了一系列API,允许开发者获取安装在设备上的应用列表、应用详情、权限信息等。例如,`getInstalledPackages()`方法可以返回所有已安装应用的PackageInfo对象列表,每个PackageInfo对象包含了应用...
8. **异步处理**:考虑到性能和用户体验,获取和解析应用信息可能是在后台线程中执行,通过`AsyncTask`或者其他异步机制来实现。 总之,“ApplicationList”源码是一个深入了解Android系统应用程序管理和信息获取的...
获取设备上已安装应用的列表可以通过`PackageManager`实现。调用`getInstalledApplications()`或`getInstalledPackages()`方法,可以获取到包含应用信息的`PackageInfo`对象列表,进一步可以展示应用名称、图标、...
4. **数据获取**:应用列表的获取通常通过PackageManager服务完成,该服务提供了查询和操作设备上已安装应用的方法。例如,我们可以调用`getInstalledPackages()`方法获取所有已安装的应用信息,并根据需求筛选出...
这份"Android程序研发源码Android 获取通讯录程序源码.rar"压缩包包含了一个示例项目,教你如何在Android应用中实现这一功能。源码的分析与学习可以帮助开发者深入理解Android系统的API调用以及权限管理。 首先,...
Android提供`Environment.getExternalStorageDirectory()`方法获取外部存储根目录,并结合`Context.getExternalFilesDir()`或`getExternalCacheDir()`获得应用程序私有的外部存储路径。 3. **设置下载进度** 为了...
2. **获取已安装应用列表**:通过`PackageManager`类,可以获取设备上所有已安装的应用信息,包括应用的包名、名称、图标等。这将用于展示在卸载器的界面中供用户选择。 3. **UI设计与事件处理**:项目可能使用了...
秒装和智能安装首先需要对APK文件进行解析,获取其元数据,如包名、版本信息、权限列表等。这通常通过解析APK的`AndroidManifest.xml`文件实现。你可以使用Android提供的`PackageParser`类来完成这个任务,它可以...
6. **异步任务处理**:由于获取应用列表可能会涉及大量的IO操作,为避免阻塞UI线程,通常会使用AsyncTask或者其他异步处理机制。 7. **UI设计**:软件管理器的界面设计通常包括搜索栏、分类(按下载量、更新时间等...
在Android系统中,获取已安装应用的大小是一个常见的需求,特别是在开发涉及应用管理或资源监控的应用时。本文将深入解析如何在Android中获取已安装应用的大小,包括代码层面的实现和注意事项。 首先,我们来看两种...
或者,也可以在下载完成后延迟执行,通过`PackageManager`的`getInstalledPackages()`方法检查应用是否已安装。 7. **代码学习与调试**: 提供的压缩文件包含了代码示例,但可能需要自行调整以适应不同的环境和...
1. **获取已安装应用信息**:在Android中,可以使用`PackageManager`服务来获取已安装应用的详细信息,包括应用名称、包名、版本信息、图标等。通过`queryPackages()`方法可以获取所有已安装应用,通过`...
- **自定义下载逻辑**:也可以选择使用`AsyncTask`或其他异步处理方式,但需要自己处理暂停、恢复和错误恢复等功能。 4. **安装更新**: - **静默安装(Silent Install)**:当下载完成后,应用可以调用`...
9. **异步处理**:为了保证用户体验,通常会将下载和安装过程放在后台线程执行,例如使用`AsyncTask`或`LiveData`来实现。 以上是远程下载安装Android应用源码的基本流程,涉及到了网络编程、文件操作、权限管理、...
- 源码会使用`PackageManager`的`getInstalledPackages()`方法获取所有已安装的应用,然后将这些信息展示给用户,如应用名、图标等。 5. **用户界面设计**: - 通常,卸载器会有用户友好的界面,如ListView或...
3. **遍历应用列表**:利用`PackageManager`的`getInstalledPackages()`方法,可以获取所有已安装应用的详细信息。这些信息包括包名、应用名、图标等,是构建卸载器界面的基础。 4. **UI设计**:在安卓应用中,通常...
要在Android应用中展示系统中的所有应用程序,需要获取系统的PackageInfo对象,这些信息存储在PackageManager服务中。通过调用`getInstalledPackages()`方法,我们可以获取到所有安装应用的信息,包括包名、应用名...
此外,也可以利用AsyncTask或Loader进行异步加载和分享,避免阻塞主线程。 综上所述,实现图片分享菜单加入指定程序的关键在于理解并熟练运用Intent、Intent Filter、ShareActionProvider等核心概念,以及如何通过...