声明
- 本文部分为转载内容注明出处:[http://blog.csdn.net/qinjuning
- 本文中的错误欢迎指正
转载部分:PackagerManager的介绍
Android系统为我们提供了很多服务管理的类,包括ActivityManager、PowerManager(电源管理)、AudioManager(音频管理)
等。除此之外,还提供了一个PackageManger管理类,它的主要职责是管理应用程序包。 通过它,我们就可以获取应用程序信息。
引入: AnroidManifest.xml文件节点说明:
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
说明: 获得应用程序中或者 节点的信息 。我们可以通过它来获取我们设置的任何属性,包括
theme 、launchmode等
常用方法继承至PackageItemInfo类中的loadIcon()和loadLabel()
ServiceInfo 类
说明: 同ActivityInfo类似 ,同样继承自 PackageItemInfo,只不过它表示的是节点信息。
ApplicationInfo类 继承自PackageItemInfo
说明:获取一个特定引用程序中节点的信息。
字段说明:
flags字段: FLAG_SYSTEM 系统应用程序
FLAG_EXTERNAL_STORAGE 表示该应用安装在sdcard中
* 常用方法*继承至PackageItemInfo类中的loadIcon()和loadLabel()
ResolveInfo类
说明:根据节点来获取其上一层目录的信息,通常是、、节点信息。
常用字段:
public ActivityInfo activityInfo 获取 ActivityInfo对象,即或节点信息
public ServiceInfo serviceInfo 获取 ServiceInfo对象,即节点信息
常用方法:
Drawable loadIcon(PackageManager pm) 获得当前应用程序的图像
CharSequence loadLabel(PackageManager pm) 获得当前应用程序的label
PackageInfo类
说明:手动获取AndroidManifest.xml文件的信息 。
常用字段:
public String packageName 包名
public ActivityInfo[] activities 所有节点信息
public ApplicationInfo applicationInfo 节点信息,只有一个
public [ActivityInfo] receivers 所有节点信息,多个
public ServiceInfo[] services 所有节点信息 ,多个
PackageManager 类
说明: 获得已安装的应用程序信息 。可以通过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**](file:///F:/android-sdk-windows/docs/reference/java/util/List.html)**<**[**PackageInfo**](file:///F:/android-sdk-windows/docs/reference/android/content/pm/PackageInfo.html)**> getInstalledPackages(int flags) **
参数如上
功能:返回给定条件的所有PackageInfo
public abstractResolveInfo 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),集合对象
关于Application中的flag的问题
这几天做一个需求,需要用到获取系统中安装的应用的问题,所以摆在我面前有两条路
PackageManager pm = context.getPackageManager();
List<ApplicationInfo> infos = pm.getInstalledApplications(0);
List<PackageInfo> infos = pm.getInstalledPackages(0);
然后当我查询了参数flag之后,我发现参数0和GET_UNINSTALLED_PACKAGES好像代表的意义不同。
参数0返回的是默认的信息列表
GET_UNINSTALLED_PACKAGES的官方注释是:
/** * Flag parameter to retrieve some information about all applications (even * uninstalled ones) which have data directories. This state could have * resulted if applications have been deleted with flag * {@code DONT_DELETE_DATA} with a possibility of being replaced or * reinstalled in future. * <p> * Note: this flag may cause less information about currently installed * applications to be returned. */ 一个flag参数用来筛选一些关于应用的信息(更加具体的翻译,大家还是看google翻译吧)
那么我们拿getInstalledPackages的方法注释来看:
/**
* Return a List of all application packages that are installed on the
* device. If flag GET_UNINSTALLED_PACKAGES has been set, a list of all
* applications including those deleted with {@code DONT_DELETE_DATA} (partially
* installed apps with data directory) will be returned.
*
* @param flags Additional option flags. Use any combination of
* {@link #GET_META_DATA}, {@link #GET_SHARED_LIBRARY_FILES},
* {@link #GET_UNINSTALLED_PACKAGES} to modify the data returned.
*
* @return Returns a List of ApplicationInfo objects, one for each application that
* is installed on the device. In the unlikely case of there being
* no installed applications, an empty list is returned.
* If flag GET_UNINSTALLED_PACKAGES is set, a list of all
* applications including those deleted with {@code DONT_DELETE_DATA}
* (partially installed apps with data directory) will be returned.
*
* @see #GET_META_DATA
* @see #GET_SHARED_LIBRARY_FILES
* @see #GET_UNINSTALLED_PACKAGES
*/
可以看到如果我们将flag设为GET_UNINSTALLED_PACKAGES的话,那么有些应用(被卸载了,但是依然保留了应用数据的应用)依然会被我们获取到,有些人可能说:什么时候我们的应用在卸载的时候会发生这样的情况呢?
其实当我们在卸载某个应用的时候,应用要求是否保留用户数据,如果保留了的话,那我们通过如上所述的flag依然可以获取到对应的包的信息,只是没有安装罢了。
想要自己实现这样的删除也很简单:
adb shell pm uninstall -k packageName
所以如果我们想要知道一个应用是否安装的话,可以采用如下的方法;
/**
* 判断一个应用是否已经安装在手机上,如果安装的话,返回当前的sourceDir,否则返回为null
*
* @param context 上下文
* @param packageName 包名
* @return 返回sourceDir
*/
public static String hasInstalled(Context context, String packageName) {
PackageManager pm = context.getPackageManager();
List<ApplicationInfo> infos = pm.getInstalledApplications(0);
for (ApplicationInfo app : infos) {
if (TextUtils.equals(packageName, app.packageName)) {
return app.sourceDir;
}
}
return null;
}