轉載:http://blog.csdn.net/qinjuning
引入: AnroidManifest.xml文件节点说明:
一、相關類別Class的介紹
PackageItemInfo類別
說明: AndroidManifest.xml檔中所有節點的基本類別,提供了這些節點的基本資訊:a label、icon、 meta-data。它不能直接使用,而是由子類別繼承然後調用對應之方法。
常用變數:
public int icon 獲得該資源圖片在R檔中的值 (對應android:icon)
public int labelRes獲得該label在R文件中的值(對應android:label)
public String name獲得該節點的name值(對應android:name)
public String packagename獲得該應用程式的包名(對應android:packagename)
常用方法:
Drawable loadIcon(PackageManager pm)獲得當前應用程式的圖像
CharSequence loadLabel(PackageManager pm)獲得當前應用程式的label
ActivityInfo類別 繼承自 PackageItemInfo
說明: 獲得應用程式中<activity/>或者 <receiver />節點的資訊 。我們可以通過它來獲取我們設置的任何屬性,包括theme 、launchMode、launchmode等
常用方法繼承至PackageItemInfo類中的loadIcon()和loadLabel()
ServiceInfo
類別
說明: 同ActivityInfo類似 ,同樣繼承自 PackageItemInfo,只不過它表示的是<service>節點資訊。
ApplicationInfo類別 繼承自
PackageItemInfo
說明:獲取一個特定引用程式中<application>節點的資訊。
field說明:
Flags:
FLAG_SYSTEM 系統應用程式
FLAG_EXTERNAL_STORAGE 表示該應用安裝在sdcard中
常用方法繼承至PackageItemInfo類中的loadIcon()和loadLabel()
ResolveInfo類別
說明:根據<intent>節點來獲取其上一層目錄的資訊,通常是<activity>、<receiver>、<service>節點資訊。
常用feild:
public ActivityInfo activityInfo 獲取 ActivityInfo物件,即<activity>或<receiver >節點資訊
public ServiceInfo serviceInfo 獲取 ServiceInfo物件,即<activity>節點資訊
常用方法:
Drawable
loadIcon(PackageManager pm) 獲得當前應用程式的圖像
CharSequence
loadLabel(PackageManager pm) 獲得當前應用程式的label
PackageInfo類別
說明:手動獲取AndroidManifest.xml檔的資訊 。
常用field:
public String packageName 包名
public ActivityInfo[] activities 所有<activity>節點資訊
public ApplicationInfo applicationInfo <application>節點資訊,只有一個
public ActivityInfo[] receivers 所有<receiver>節點資訊,多個
public ServiceInfo[] services 所有<service>節點資訊 ,多個
PackageManger
類別
說明: 獲得已安裝的應用程式資訊 。可以通過getPackageManager()方法獲得。
常用方法:
public abstract
PackageManager getPackageManager()
功能:獲得一個PackageManger物件
public abstrac tDrawable
getApplicationIcon(StringpackageName)
參數: packageName 包名
功能:返回給定包名的圖示,否則返回null
public abstract
ApplicationInfo getApplicationInfo(String
packageName, int flags)
參數:packagename 包名
flags 該ApplicationInfo是此flags標記,通常可以直接賦予常數0即可
功能:返回該ApplicationInfo對象
public abstract
List<ApplicationInfo> getInstalledApplications(int
flags)
參數:flag為一般為GET_UNINSTALLED_PACKAGES,那麼此時會返回所有ApplicationInfo。我們可以對ApplicationInfo的flags過濾,得到我們需要的。
功能:返回給定條件的所有PackageInfo
public abstract
List<PackageInfo> getInstalledPackages(int
flags)
參數如上
功能:返回給定條件的所有PackageInfo
public abstract
ResolveInfo resolveActivity(Intent
intent, int flags)
參數:
intent 查尋條件,Activity所配置的action和category
flags:
MATCH_DEFAULT_ONLY:Category必須帶有CTEGORY_DEFAULT的Activity,才匹配
GET_INTENT_FILTERS:匹配Intent條件即可
GET_RESOLVED_FILTER:匹配Intent條件即可
功能 :返回給定條件的ResolveInfo物件(本質上是Activity)
public abstract List<ResolveInfo>
queryIntentActivities(Intent intent, int
flags)
參數同上
功能:返回給定條件的所有ResolveInfo物件(本質上是Activity),集合物件
public abstract
ResolveInfo resolveService(Intent
intent, int flags)
參數同上
功能:返回給定條件的ResolveInfo物件(本質上是Service)
public abstract
List<ResolveInfo> queryIntentServices(Intent
intent, int flags)
參數同上
功能 :返回給定條件的所有ResolveInfo物件(本質上是Service),集合物件
一、相關類別Class的介紹
PackageItemInfo類別
說明: AndroidManifest.xml檔中所有節點的基本類別,提供了這些節點的基本資訊:a label、icon、 meta-data。它不能直接使用,而是由子類別繼承然後調用對應之方法。
常用變數:
public int icon 獲得該資源圖片在R檔中的值 (對應android:icon)
public int labelRes獲得該label在R文件中的值(對應android:label)
public String name獲得該節點的name值(對應android:name)
public String packagename獲得該應用程式的包名(對應android:packagename)
常用方法:
Drawable loadIcon(PackageManager pm)獲得當前應用程式的圖像
CharSequence loadLabel(PackageManager pm)獲得當前應用程式的label
ActivityInfo類別 繼承自 PackageItemInfo
說明: 獲得應用程式中<activity/>或者 <receiver />節點的資訊 。我們可以通過它來獲取我們設置的任何屬性,包括theme 、launchMode、launchmode等
常用方法繼承至PackageItemInfo類中的loadIcon()和loadLabel()
ServiceInfo
類別
說明: 同ActivityInfo類似 ,同樣繼承自 PackageItemInfo,只不過它表示的是<service>節點資訊。
ApplicationInfo類別 繼承自
PackageItemInfo
說明:獲取一個特定引用程式中<application>節點的資訊。
field說明:
Flags:
FLAG_SYSTEM 系統應用程式
FLAG_EXTERNAL_STORAGE 表示該應用安裝在sdcard中
常用方法繼承至PackageItemInfo類中的loadIcon()和loadLabel()
ResolveInfo類別
說明:根據<intent>節點來獲取其上一層目錄的資訊,通常是<activity>、<receiver>、<service>節點資訊。
常用feild:
public ActivityInfo activityInfo 獲取 ActivityInfo物件,即<activity>或<receiver >節點資訊
public ServiceInfo serviceInfo 獲取 ServiceInfo物件,即<activity>節點資訊
常用方法:
Drawable
loadIcon(PackageManager pm) 獲得當前應用程式的圖像
CharSequence
loadLabel(PackageManager pm) 獲得當前應用程式的label
PackageInfo類別
說明:手動獲取AndroidManifest.xml檔的資訊 。
常用field:
public String packageName 包名
public ActivityInfo[] activities 所有<activity>節點資訊
public ApplicationInfo applicationInfo <application>節點資訊,只有一個
public ActivityInfo[] receivers 所有<receiver>節點資訊,多個
public ServiceInfo[] services 所有<service>節點資訊 ,多個
PackageManger
類別
說明: 獲得已安裝的應用程式資訊 。可以通過getPackageManager()方法獲得。
常用方法:
public abstract
PackageManager getPackageManager()
功能:獲得一個PackageManger物件
public abstrac tDrawable
getApplicationIcon(StringpackageName)
參數: packageName 包名
功能:返回給定包名的圖示,否則返回null
public abstract
ApplicationInfo getApplicationInfo(String
packageName, int flags)
參數:packagename 包名
flags 該ApplicationInfo是此flags標記,通常可以直接賦予常數0即可
功能:返回該ApplicationInfo對象
public abstract
List<ApplicationInfo> getInstalledApplications(int
flags)
參數:flag為一般為GET_UNINSTALLED_PACKAGES,那麼此時會返回所有ApplicationInfo。我們可以對ApplicationInfo的flags過濾,得到我們需要的。
功能:返回給定條件的所有PackageInfo
public abstract
List<PackageInfo> getInstalledPackages(int
flags)
參數如上
功能:返回給定條件的所有PackageInfo
public abstract
ResolveInfo resolveActivity(Intent
intent, int flags)
參數:
intent 查尋條件,Activity所配置的action和category
flags:
MATCH_DEFAULT_ONLY:Category必須帶有CTEGORY_DEFAULT的Activity,才匹配
GET_INTENT_FILTERS:匹配Intent條件即可
GET_RESOLVED_FILTER:匹配Intent條件即可
功能 :返回給定條件的ResolveInfo物件(本質上是Activity)
public abstract List<ResolveInfo>
queryIntentActivities(Intent intent, int
flags)
參數同上
功能:返回給定條件的所有ResolveInfo物件(本質上是Activity),集合物件
public abstract
ResolveInfo resolveService(Intent
intent, int flags)
參數同上
功能:返回給定條件的ResolveInfo物件(本質上是Service)
public abstract
List<ResolveInfo> queryIntentServices(Intent
intent, int flags)
參數同上
功能 :返回給定條件的所有ResolveInfo物件(本質上是Service),集合物件二、DEMO讲解
通过前面的介绍,相信您一定很了解了,本质上来讲,这些XXXInfo类不过是我们在AndroidManifest.XML文件中定义的信息,
知道到这点了,理解起来就不是很难了。
下面我透过两个简答的DEMO,来学以致用。
Demo 1: 通过queryIntentActivities()方法,查询Android系统的所有具备ACTION_MAIN和CATEGORY_LAUNCHER
的Intent的应用程序,点击后,能启动该应用,说白了就是做一个类似Home程序的简易Launcher 。
Demo 2 :通过getInstalledApplications()方法获取应用,然后对其过滤,查找出我们需要的第三方应用,系统应用,安装在sdcard的应用。
Demo1 :
图:
1 、布局文件: 主要有两个:带listview的browse_app_list.xml文件 ;listview的项browse_app_item.xml
browse_app_list.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">>
- <ListView android:id="@+id/listviewApp" android:layout_width="fill_parent"
- android:layout_height="fill_parent" ></ListView>
- </LinearLayout>
browse_app_item.xmlbrowse_app_item.xml
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent" android:layout_height="50dip">
- <ImageView android:id="@+id/imgApp" android:layout_width="wrap_content"
- android:layout_height="fill_parent" ></ImageView>
- <RelativeLayout android:layout_width="fill_parent" android:layout_marginLeft="10dip"
- android:layout_height="40dip">
- <TextView android:id="@+id/tvLabel" android:layout_width="wrap_content"
- android:layout_height="wrap_content" android:text="AppLable : "></TextView>
- <TextView android:id="@+id/tvAppLabel" android:layout_width="wrap_content"
- android:layout_toRightOf="@id/tvLabel" android:layout_height="wrap_content"
- android:layout_marginLeft="3dip" android:text="Label" android:textColor="#FFD700"></TextView>
- <TextView android:id="@+id/tvName" android:layout_width="wrap_content"
- android:layout_height="wrap_content" android:layout_below="@id/tvLabel"
- android:text="包名:"></TextView>
- <TextView android:id="@+id/tvPkgName" android:layout_width="wrap_content"
- android:layout_height="wrap_content" android:layout_below="@id/tvAppLabel"
- android:layout_alignLeft="@id/tvAppLabel" android:textColor="#FFD700"></TextView>
- </RelativeLayout>
- </LinearLayout>
2 、AppInfo.java : 保存应用程序信息的Model类
- /Model类 ,用来存储应用程序信息
- public class AppInfo {
- private String appLabel; //应用程序标签
- private Drawable appIcon ; //应用程序图像
- private Intent intent ; //启动应用程序的Intent ,一般是Action为Main和Category为Lancher的Activity
- private String pkgName ; //应用程序所对应的包名
- public AppInfo(){}
- public String getAppLabel() {
- return appLabel;
- }
- public void setAppLabel(String appName) {
- this.appLabel = appName;
- }
- public Drawable getAppIcon() {
- return appIcon;
- }
- public void setAppIcon(Drawable appIcon) {
- this.appIcon = appIcon;
- }
- public Intent getIntent() {
- return intent;
- }
- public void setIntent(Intent intent) {
- this.intent = intent;
- }
- public String getPkgName(){
- return pkgName ;
- }
- public void setPkgName(String pkgName){
- this.pkgName=pkgName ;
- }
- }
3、 BrowseApplicationInfoAdapter.java : 自定义适配器类,为ListView提供视图
- //自定义适配器类,提供给listView的自定义view
- public class BrowseApplicationInfoAdapter extends BaseAdapter {
- private List<AppInfo> mlistAppInfo = null;
- LayoutInflater infater = null;
- public BrowseApplicationInfoAdapter(Context context, List<AppInfo> apps) {
- infater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
- mlistAppInfo = apps ;
- }
- @Override
- public int getCount() {
- // TODO Auto-generated method stub
- System.out.println("size" + mlistAppInfo.size());
- return mlistAppInfo.size();
- }
- @Override
- public Object getItem(int position) {
- // TODO Auto-generated method stub
- return mlistAppInfo.get(position);
- }
- @Override
- public long getItemId(int position) {
- // TODO Auto-generated method stub
- return 0;
- }
- @Override
- public View getView(int position, View convertview, ViewGroup arg2) {
- System.out.println("getView at " + position);
- View view = null;
- ViewHolder holder = null;
- if (convertview == null || convertview.getTag() == null) {
- view = infater.inflate(R.layout.browse_app_item, null);
- holder = new ViewHolder(view);
- view.setTag(holder);
- }
- else{
- view = convertview ;
- holder = (ViewHolder) convertview.getTag() ;
- }
- AppInfo appInfo = (AppInfo) getItem(position);
- holder.appIcon.setImageDrawable(appInfo.getAppIcon());
- holder.tvAppLabel.setText(appInfo.getAppLabel());
- holder.tvPkgName.setText(appInfo.getPkgName());
- return view;
- }
- class ViewHolder {
- ImageView appIcon;
- TextView tvAppLabel;
- TextView tvPkgName;
- public ViewHolder(View view) {
- this.appIcon = (ImageView) view.findViewById(R.id.imgApp);
- this.tvAppLabel = (TextView) view.findViewById(R.id.tvAppLabel);
- this.tvPkgName = (TextView) view.findViewById(R.id.tvPkgName);
- }
- }
- }
4 、MainActivity.java 主工程逻辑
请仔细体会queryIntentActivities()方法,并且注意到排序,它很重要。
- <span style="font-size:13px;">public class MainActivity extends Activity implements OnItemClickListener {
- private ListView listview = null;
- private List<AppInfo> mlistAppInfo = null;
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.browse_app_list);
- listview = (ListView) findViewById(R.id.listviewApp);
- mlistAppInfo = new ArrayList<AppInfo>();
- queryAppInfo(); // 查询所有应用程序信息
- BrowseApplicationInfoAdapter browseAppAdapter = new BrowseApplicationInfoAdapter(
- this, mlistAppInfo);
- listview.setAdapter(browseAppAdapter);
- listview.setOnItemClickListener(this);
- }
- // 点击跳转至该应用程序
- public void onItemClick(AdapterView<?> arg0, View view, int position,
- long arg3) {
- // TODO Auto-generated method stub
- Intent intent = mlistAppInfo.get(position).getIntent();
- startActivity(intent);
- }
- // 获得所有启动Activity的信息,类似于Launch界面
- public void queryAppInfo() {
- PackageManager pm = this.getPackageManager(); // 获得PackageManager对象
- Intent mainIntent = new Intent(Intent.ACTION_MAIN, null);
- mainIntent.addCategory(Intent.CATEGORY_LAUNCHER);
- // 通过查询,获得所有ResolveInfo对象.
- List<ResolveInfo> resolveInfos = pm
- .queryIntentActivities(mainIntent, PackageManager.MATCH_DEFAULT_ONLY);
- // 调用系统排序 , 根据name排序
- // 该排序很重要,否则只能显示系统应用,而不能列出第三方应用程序
- Collections.sort(resolveInfos,new ResolveInfo.DisplayNameComparator(pm));
- if (mlistAppInfo != null) {
- mlistAppInfo.clear();
- for (ResolveInfo reInfo : resolveInfos) {
- String activityName = reInfo.activityInfo.name; // 获得该应用程序的启动Activity的name
- String pkgName = reInfo.activityInfo.packageName; // 获得应用程序的包名
- String appLabel = (String) reInfo.loadLabel(pm); // 获得应用程序的Label
- Drawable icon = reInfo.loadIcon(pm); // 获得应用程序图标
- // 为应用程序的启动Activity 准备Intent
- Intent launchIntent = new Intent();
- launchIntent.setComponent(new ComponentName(pkgName,
- activityName));
- // 创建一个AppInfo对象,并赋值
- AppInfo appInfo = new AppInfo();
- appInfo.setAppLabel(appLabel);
- appInfo.setPkgName(pkgName);
- appInfo.setAppIcon(icon);
- appInfo.setIntent(launchIntent);
- mlistAppInfo.add(appInfo); // 添加至列表中
- System.out.println(appLabel + " activityName---" + activityName
- + " pkgName---" + pkgName);
- }
- }
- }
- }</span>
好了,第一个Demo完成 。。
Demo 2:
demo2在布局、适配器方面和Demo1一样。只是利用了getInstalledApplications()方法,继而通过ApplicationInfo.flags来挑选
我们希望的ApplicationInfo对象。
图:
过滤应用程序如下:
- package com.qiner.appinfo;
- import java.util.ArrayList;
- import java.util.Collections;
- import java.util.List;
- import com.qiner.appinfo.R;
- import android.app.Activity;
- import android.app.Application;
- import android.content.pm.ApplicationInfo;
- import android.content.pm.PackageManager;
- import android.os.Bundle;
- import android.view.View;
- import android.view.View.OnClickListener;
- import android.widget.Button;
- import android.widget.ListView;
- public class MainActivity extends Activity {
- public static final int FILTER_ALL_APP = 0; // 所有应用程序
- public static final int FILTER_SYSTEM_APP = 1; // 系统程序
- public static final int FILTER_THIRD_APP = 2; // 第三方应用程序
- public static final int FILTER_SDCARD_APP = 3; // 安装在SDCard的应用程序
- private ListView listview = null;
- private PackageManager pm;
- private int filter = FILTER_ALL_APP;
- private List<AppInfo> mlistAppInfo ;
- private BrowseApplicationInfoAdapter browseAppAdapter = null ;
- /** Called when the activity is first created. */
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.browse_app_list);
- listview = (ListView) findViewById(R.id.listviewApp);
- if(getIntent()!=null){
- filter = getIntent().getIntExtra("filter", 0) ;
- }
- mlistAppInfo = queryFilterAppInfo(filter); // 查询所有应用程序信息
- // 构建适配器,并且注册到listView
- browseAppAdapter = new BrowseApplicationInfoAdapter(this, mlistAppInfo);
- listview.setAdapter(browseAppAdapter);
- }
- // 根据查询条件,查询特定的ApplicationInfo
- private List<AppInfo> queryFilterAppInfo(int filter) {
- pm = this.getPackageManager();
- // 查询所有已经安装的应用程序
- List<ApplicationInfo> listAppcations = pm
- .getInstalledApplications(PackageManager.GET_UNINSTALLED_PACKAGES);
- Collections.sort(listAppcations,
- new ApplicationInfo.DisplayNameComparator(pm));// 排序
- List<AppInfo> appInfos = new ArrayList<AppInfo>(); // 保存过滤查到的AppInfo
- // 根据条件来过滤
- switch (filter) {
- case FILTER_ALL_APP: // 所有应用程序
- appInfos.clear();
- for (ApplicationInfo app : listAppcations) {
- appInfos.add(getAppInfo(app));
- }
- return appInfos;
- case FILTER_SYSTEM_APP: // 系统程序
- appInfos.clear();
- for (ApplicationInfo app : listAppcations) {
- if ((app.flags & ApplicationInfo.FLAG_SYSTEM) != 0) {
- appInfos.add(getAppInfo(app));
- }
- }
- return appInfos;
- case FILTER_THIRD_APP: // 第三方应用程序
- appInfos.clear();
- for (ApplicationInfo app : listAppcations) {
- //非系统程序
- if ((app.flags & ApplicationInfo.FLAG_SYSTEM) <= 0) {
- appInfos.add(getAppInfo(app));
- }
- //本来是系统程序,被用户手动更新后,该系统程序也成为第三方应用程序了
- else if ((app.flags & ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) != 0){
- appInfos.add(getAppInfo(app));
- }
- }
- break;
- case FILTER_SDCARD_APP: // 安装在SDCard的应用程序
- appInfos.clear();
- for (ApplicationInfo app : listAppcations) {
- if ((app.flags & ApplicationInfo.FLAG_EXTERNAL_STORAGE) != 0) {
- appInfos.add(getAppInfo(app));
- }
- }
- return appInfos;
- default:
- return null;
- }
- return appInfos;
- }
- // 构造一个AppInfo对象 ,并赋值
- private AppInfo getAppInfo(ApplicationInfo app) {
- AppInfo appInfo = new AppInfo();
- appInfo.setAppLabel((String) app.loadLabel(pm));
- appInfo.setAppIcon(app.loadIcon(pm));
- appInfo.setPkgName(app.packageName);
- return appInfo;
- }
- }
你可以在此基础上,构建更多丰富的应用。比说说Settings模块中的卸载安装应用程序等。