PackageManager安装包管理

2024-06-01 18:08

本文主要是介绍PackageManager安装包管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

常用代码:

List<PackageInfo> packageInfoList = getPackageManager().getInstalledPackages(0); //返回已安装的包信息列表 


packageInfo.applicationInfo.flags&ApplicationInfo.FLAG_SYSTEM) == 0;//判断是否为非系统应用


用获得的属性信息,保存到APP中。APP这个类,是自己定义的。

  1. APP app = new APP();  
  2.                     app.setIcon(packageInfo.applicationInfo.loadIcon(getPackageManager()));  
  3.                     app.setName(packageInfo.applicationInfo.loadLabel(getPackageManager()).toString());  
  4.                     app.setPackageName(packageInfo.packageName);  
  5.                     app.setVersionName(packageInfo.versionName);

相关的类:

一.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>节点的信息。
         字段说明:
      flags字段: FLAG_SYSTEM 系统应用程序
                   FLAG_EXTERNAL_STORAGE 表示该应用安装在sdcard中
         常用方法继承至PackageItemInfo类中的loadIcon()和loadLabel()
五.ResolveInfo类
        说明:根据<intent>节点来获取其上一层目录的信息,通常是<activity>、<receiver>、<service>节点信息。
       常用字段:
             public  ActivityInfo  activityInfo     获取 ActivityInfo对象,即<activity>或<receiver >节点信息
             public ServiceInfo   serviceInfo     获取 ServiceInfo对象,即<service>节点信息
       常用方法: 
             Drawable loadIcon(PackageManager pm)             获得当前应用程序的图像
             CharSequence loadLabel(PackageManager pm)  获得当前应用程序的label

六.PackageInfo类
       说明:手动获取AndroidManifest.xml文件的信息 。
       常用字段:
           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 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),集合对象


实例展示:

package dyingbleed.iteye;import java.util.ArrayList;
import java.util.List;import android.app.ListActivity;
import android.content.Context;
import android.content.pm.ApplicationInfo;
import android.content.pm.PackageInfo;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;public class Main extends ListActivity {private Handler handler = new Handler() {@Overridepublic void handleMessage(Message msg) {super.handleMessage(msg);int what = msg.what;switch(what) {case 0 :List<APP> data = (List<APP>) msg.obj;setListAdapter(new APPListViewAdapter(Main.this, data));break;}}};@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);new Thread(new InstalledAPPTask()).start();}private class APPListViewAdapter extends BaseAdapter {private Context context;private List<APP> data;public APPListViewAdapter(Context context, List<APP> data) {this.context = context;this.data = data;}@Overridepublic int getCount() {return data.size();}@Overridepublic Object getItem(int position) {return data.get(position);}@Overridepublic long getItemId(int position) {return position;}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {if(convertView == null) {convertView = LayoutInflater.from(context).inflate(R.layout.item, null);}ImageView icon = (ImageView) convertView.findViewById(R.id.item_IconImageView);TextView name = (TextView) convertView.findViewById(R.id.item_NameTextView);TextView packageName = (TextView) convertView.findViewById(R.id.item_PackageNameTextView);TextView versionName = (TextView) convertView.findViewById(R.id.item_VersionNameTextView);icon.setImageDrawable(data.get(position).getIcon());name.setText(data.get(position).getName());packageName.setText(data.get(position).getPackageName());versionName.setText(data.get(position).getVersionName());return convertView;}}private class InstalledAPPTask implements Runnable {@Overridepublic void run() {List<APP> appList = achieveAPPList();handler.sendMessage(handler.obtainMessage(0, appList));}private List<APP> achieveAPPList() {List<APP> result = new ArrayList<APP>();List<PackageInfo> packageInfoList = getPackageManager().getInstalledPackages(0); //返回已安装的包信息列表for(PackageInfo packageInfo : packageInfoList) {/** 判断是否为非系统应用* */if((packageInfo.applicationInfo.flags&ApplicationInfo.FLAG_SYSTEM) == 0) {APP app = new APP();app.setIcon(packageInfo.applicationInfo.loadIcon(getPackageManager()));app.setName(packageInfo.applicationInfo.loadLabel(getPackageManager()).toString());app.setPackageName(packageInfo.packageName);app.setVersionName(packageInfo.versionName);result.add(app);}}return result;}}private class APP {private String name; //应用名private String packageName; //包名private String versionName; //版本名private Drawable icon; //应用图标public String getName() {return name;}public void setName(String name) {this.name = name;}public String getPackageName() {return packageName;}public void setPackageName(String packageName) {this.packageName = packageName;}public String getVersionName() {return versionName;}public void setVersionName(String versionName) {this.versionName = versionName;}public Drawable getIcon() {return icon;}public void setIcon(Drawable icon) {this.icon = icon;}}
}


这篇关于PackageManager安装包管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1021733

相关文章

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、

IDEA中的Kafka管理神器详解

《IDEA中的Kafka管理神器详解》这款基于IDEA插件实现的Kafka管理工具,能够在本地IDE环境中直接运行,简化了设置流程,为开发者提供了更加紧密集成、高效且直观的Kafka操作体验... 目录免安装:IDEA中的Kafka管理神器!简介安装必要的插件创建 Kafka 连接第一步:创建连接第二步:选

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

禅道Docker安装包发布

禅道Docker安装包发布 大家好, 禅道Docker安装包发布。 一、下载地址 禅道开源版:   /dl/zentao/docker/docker_zentao.zip  备用下载地址:https://download.csdn.net/download/u013490585/16271485 数据库用户名: root,默认密码: 123456。运行时,可以设置 MYSQL_ROOT_P

Sentinel 高可用流量管理框架

Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应

NGINX轻松管理10万长连接 --- 基于2GB内存的CentOS 6.5 x86-64

转自:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=190176&id=4234854 一 前言 当管理大量连接时,特别是只有少量活跃连接,NGINX有比较好的CPU和RAM利用率,如今是多终端保持在线的时代,更能让NGINX发挥这个优点。本文做一个简单测试,NGINX在一个普通PC虚拟机上维护100k的HTTP

PMBOK® 第六版 规划进度管理

目录 读后感—PMBOK第六版 目录 规划进度管理主要关注为整个项目期间的进度管理提供指南和方向。以下是两个案例,展示了进度管理中的复杂性和潜在的冲突: 案例一:近期,一个长期合作的客户因政策要求,急需我们为多家医院升级一个小功能。在这个过程中出现了三个主要问题: 在双方确认接口协议后,客户私自修改接口并未通知我们,直到催进度时才发现这个问题关于UI设计的部分,后台开发人员未将其传递给