手机卫士09_应用程序四种查看_ListView小标题_进程管理

Posted 抓根宝

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了手机卫士09_应用程序四种查看_ListView小标题_进程管理相关的知识,希望对你有一定的参考价值。

1.悬浮窗体的功能实现:

1.1.应用程序的卸载: 包安装器 packageInstall,包卸载packageruninstall

intent.setData(Uri.pare(“package:” + 应用程序包名))

卸载完之后记得更新list集合,更新适配器.

但是不确定用户是否点了卸载,所以要通过广播获取消息.

并且需要通过代码注册,因为这个广播只在应用管理生效.

要记得addDataSchme(“package”)

接收完广播之后,更新了集合适配器,要记得关闭广播

 

异常:ConcurrentModificationException,并发访问异常错误

因为使用增强for循环去删除集合中的元素,所以会出并发修改异常.

额外:系统应用是不允许卸载的,所以遍历用户应用集合就可以了.

 

1.2.应用程序的开启:本质是打开这个应用的入口activity.

当一个activity的清单文件中,意图过滤器有

<action  android:name=”android.intent.action.MAIN”/>

<action  android:name=”android.intent.category.LANUCHER”/>

//找关系,得到特性.

packageManager pm

Intent intent = pm.getLanuchIntentForPackage(包名)//如果对应的应用程序activity配置了上面的属性,就返回这个前门activity,如果没有activity配置这个属性,就返回为null;

 

1.3.应用程序的分享功能:打开系统的短信,给好友发送信息(或者QQ,微信,微博之类)

市面上一些即时通讯,或者社交类的应用程序,都重写了分享的action,如果是按发短信的方式分享,这些程序都会被列出来.

短信应用中,发短信的activity,ComposeMessageActivity,根据下面意图过滤器的类型,可以发送不同的信息.有图片,视频,文字.

设置完intent的属性,把要发送的文本放到intent.putExtra(intent.EXTRA_TEXT,.......);

 

1.4.应用程序的信息功能:实际上是打开系统的应用程序信息界面

setting的系统源码中配置清单的InstalledAppDetails

如果不知道怎么写意图信息,就找一个类型的软件,打开它这个功能,会在日志中出现.

Intent intent = new Intent(“android.setting.APPLICATION_DETATLS_SETTINGS”);

Intent.addCategory(intent.Category.DEFAULT)//设置默认的Category

intent.setData(Uri.parse(“package:” + 包名));

 

2.进程管理

2.1 ui界面标题参考布局

 

ActivityManager am 进程管理器

①通过进程管理器 获取当前正在运行的进程.

am.getRunningAppProcesses()//返回当前运行的 APP集合

②获取可用的内存空间

am.getMemoryInfo(MemoryInfo outinfo)//对参数保存内存信息概要,

outinfo.avaiMem(系统可用内存空间).tatalMem(系统全部的内存空间)

可用内存返回是Long类型,需要转换成mb形式formatter

③创建一个新的信息获取类(获取信息的放在engine包下):ProcessInfoProvider

获取所有进程信息的数据.(需要一个实体类保存信息)

参考方法名getRunningProcessInfos();

实体类名:ProcessInfo

需要保存的信息:应用程序名label,图标icon,内存占用大小,应用程序包名packageName.

区分是否是用户和系统进程(判断是用户程序还是系统程序即可);

//通过am得到正在运行应用程序的集合.

getRunningAppProcesses();//返回正在运行的应用程序的集合,

每一个对象info

info.importance //进程的优先级

Info.pid //进程id,进程的唯一标识

info.processName //进程名,实际上就是应用程序的包名

//其它信息就跟前面获取软件信息应用,拿到包名>>拿到包信息>>拿到想要的信息

PackageManager pm

pm.getPackageInfo(包名,0(附加可选标记))//返回一个包信息Packageinfo packinfo

Packinfo.applicationInfo.xxxx//对应的信息.

am.getProcessMemory(int[]{})//通过一个保存多个进程pid返回对应多个进程信息.

返回的进程信息.getTotalPrivateDirty()//返回的是kb,*1024转换成byte方便计算.

 

最后把每个封装对象放到List集合中,返回给调用者.

安卓系统中的进程有的不是app应用,system,多媒体,内核应用,音频播放框架应用并不是由纯java编写的,还有c的构成,所以它们可能并没有apk的名字.

//在通过getPakcagerInfo获取包信息的时候,如果是这些进程就会出异常,根据这一点在Catch代码块中,给它设置一个名称(packname)和默认图片.

item条目参考ui

 

④其它类似应用程序管理器,拆分小集合,增加提醒小条目.holder优化,复用convert对象等.

 

3 带勾选框ListView的处理

 

List中如果有Button,Check这一类抢焦点的控件,会把焦点从条目上抢走,这样会导致ListView的条目点击事件效果失效,一般在开发中把这些抢焦点的控件CLickable = “false”,focusable=”false”

不可被点击,也不会获取到焦点

给进程应用对象封装类增加一个checkbox的布尔变量,用来判断是否被选中了(也可以保存在一个集合中,但是用户会希望这些被勾选的应用,再以后也能被默认勾选,所以封装起来比较方便)

 

在ListView的点击事件中,lv.getItemPosition(position);//得到被点击的条目对象.

//返回的对象为null

因为自定义适配器时,getItem()方法返回为null,所以获取的值也为null

所以可以在这个方法里返回被点击的对象.

 

在点击事件中,获取到这个对象,同时获取到CheckBox对象,点击之后就设置对应的参数.

但是会出现复用历史缓存的bug,在这里就需要在holder里增加一个checkbox变量,在适配器返回view的时候,对这个 checkBox进行赋值.

 

4,进程管理的进程清理

点击按钮之后清理进程.

①循环遍历集合,判断进程是否被选中.

②通过进程管理器 ActivityManager.killBackgroundProcesses(包名);

//清理完之后需要刷新界面,重新获取数据

③需要权限:KILL_BACKGROUND_PROCES

 

5,进程管理的细节

①全选和反选:

全选:遍历集合.全部设置为true,通知数据适配器更新数据

反选:遍历集合,全部设置为原来的状态取反,然后更新数据.

 

额外:无法清除的进程,系统进程,系统ui进程,前台进程,killBackgroundProcess是清理后台进程.

在开发者看来能理解,但是用户不能理解.

②一键清理的清理效果,

只要全部清理,就把所有进程在界面的显示给清理掉(傻逼用户)(市面上360的欺骗效果是比较好的,它甚至会判断你最近的清理时间,如果太近的话,就直接提示为空)

一键清理完后,把用户勾选的条目给移除掉(保存在一个集合Kill中,方便最后Toast中显示)

 

Toast:清理了kill.size()个进程,释放了Kill中元素占用内存相加之和.

更改标题,运行中进程和内存数量两个参数.可以通过两个成员变量去保存它们

然后把这两个参数与上面移除集合中的数据相减即可(减去进程数和占用内存总数).

 

从界面上移除条目,遍历kill集合,判断是属于哪个集合的,就从哪个集合去移除它,然后更新适配器.

额外:按常理来说,清理进程不应该清除自身应用的进程.

判断如果返回的View为自身应用的时候(根据包名判断),就隐藏checkBox勾选框.

点击事件里,也要做判断,如果符合就直接终止,return掉事件.全选,反选也是一样,跳过特殊选项.

 

wanandroid.com //安卓知识点总结

 

以上是关于手机卫士09_应用程序四种查看_ListView小标题_进程管理的主要内容,如果未能解决你的问题,请参考以下文章

手机卫士02_gridView,statelist.ui相关

手机卫士12_软件锁,应用程序相关

手机卫士10_widget_流量统计_手机杀毒

手机卫士11_ 自定义控件_缓存清理_病毒库更新

手机卫士03_手势动作_广播接收者应用

手机卫士13_屏幕适配_异常处理_盈利模式_混淆加密