提到PackageManager,就得提一下AndroidManifest.XML文件了。AndroidManifest.xml是Android应用程序中最重要的文件之一。它是Android程序的全局配置文件,是每个 android程序中必须的文件。它位于我们开发的应用程序的根目录下,描述了package中的全局数据,包括package中暴露的组件 (activities, services, 等等),以及他们各自的实现类,各种能被处理的数据和启动位置等重要信息。 因此,该文件提供了Android系统所需要的关于该应用程序的必要信息,即在该应用程序的任何代码运行之前系统所必须拥有的信息。
PackageManager获取的信息即来自AndroidManifest.XML。为了便于理解,从网上找了一张AnroidManifest.xml文件节点说明图:
一、PackageManager的功能:
1、安装,卸载应用
2、查询permission相关信息
3、查询Application相关信息(application,activity,receiver,service,provider及相应属性等)
4、查询已安装应用
5、增加,删除permission
6、清除用户数据、缓存,代码段等
二、PackageManager相关类和方法介绍:
1、PackageManager类
说明: 获得已安装的应用程序信息 。
可以通过getPackageManager()方法获得。
常用方法:
public abstract PackageManager getPackageManager()功能:获得一个PackageManger对象
public abstract Drawable getApplicationIcon(String packageName)参数: 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必须带有CATEGORY_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),集合对象
2、PackageItemInfo类说明: AndroidManifest.xml文件中所有节点的基类,提供了这些节点的基本信息:label、icon、 meta-data。它并不直接使用,而是由子类继承然后调用相应方法。
3、ApplicationInfo类 继承自 PackageItemInfo类
说明:获取一个特定引用程序中<application>节点的信息。字段说明:flags字段: FLAG_SYSTEM 系统应用程序FLAG_EXTERNAL_STORAGE 表示该应用安装在sdcard中常用方法继承至PackageItemInfo类中的loadIcon()和loadLabel()
4、ActivityInfo类 继承自 PackageItemInfo类
说明: 获得应用程序中<activity/>或者 <receiver/>节点的信息 。我们可以通过它来获取我们设置的任何属性,包括theme 、launchMode、launchmode等常用方法继承至PackageItemInfo类中的loadIcon()和loadLabel()
5、ServiceInfo类 继承自 PackageItemInfo类
说明:与ActivityInfo类似,代表<service>节点信息
6、ResolveInfo类
说明:根据<intent>节点来获取其上一层目录的信息,通常是<activity>、<receiver>、<service>节点信息。常用方法有loadIcon(PackageManager pm)和loadLabel(PackageManager pm)
三、实例讲解:
1、通过PackageManager的queryIntentActivities方法,查询系统中所有满足ACTION_MAIN和CATEGORY_LAUNCHER的应用程序,获取他们的程序名、包名、入口类名。
MainActivity.java
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
getAppInfo();
}
private void getAppInfo() {
// 获取PackageManager对象
PackageManager pm = this.getPackageManager();
// 设置<intent-filter>标签内需要满足的条件
Intent intent = new Intent(Intent.ACTION_MAIN, null);
intent.addCategory(Intent.CATEGORY_DEFAULT);
// 通过queryIntentActivities获取ResolveInfo对象
List<ResolveInfo> resolveInfos = pm.queryIntentActivities(intent,PackageManager.MATCH_DEFAULT_ONLY);
// 调用系统排序,根据name排序
// 该排序很重要,否则只能显示系统应用,不能显示第三方应用
// 其实我测试发现有没有其实是一样的,就是输出的顺序是乱的
Collections.sort(resolveInfos, new ResolveInfo.DisplayNameComparator(pm));
for (ResolveInfo resolveInfo : resolveInfos) {
String appName = resolveInfo.loadLabel(pm).toString();
// 获取应用名称
String packageName = resolveInfo.activityInfo.packageName;
// 包名
String className = resolveInfo.activityInfo.name;
// 入口类名
System.out.println("程序名:" + appName + " 包名:" + packageName43 + " 入口类名:" + className);44 }45 }46 47 }
输出结果:
2、通过PackageManager的queryInstalledApplications方法,过滤掉出系统应用、第三方应用、安装在SDCard上的应用。