Android项目实战--手机卫士32--给清理进程添加一个Widget

2024-06-09 15:48

本文主要是介绍Android项目实战--手机卫士32--给清理进程添加一个Widget,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!



最新实战教程,让你了解Android自动化刷量、作弊与防作弊的那些事,案例:刷友盟统计、批量注册苹果帐号




上一次,我们已经完成了当用户锁屏的时候,就清理一下内存,那么今天,人们就把清理内存的这个功能给加到Widget里面去,

首先,先给大家讲一下Widget,widget就是运行在桌面上的小部件啦,由于运行在不同桌面(Android 的桌面有很多,如launch, 还有小米的米UI还有其他的定制机的呢)上,它的生命周期都会有所不同的,所以我这里就不说出来混淆大家啦,大家可以自己重写它里面的方法,观察一下就知道的啦

但是,要告诉大家,Widget第一次创建的时候,都会调用onEnable方法,然后,当桌面上已经没有这个Widget的时候,那就会调用onDisabled方法

好,下面先来看看,我们要做成的效果

  

这个界面比较的难看,大家可以自己定义一个好看的界面,这样子,看起来变好很多的啦

要把我们一键清理这个功能做成一个Widget,其实也很简单的

首先,我们就要写一个类ProcessWidget,来继承AppWidgetProvider,其实这个AppWidgetProvider它也是继承了BroadcastReceiver的,也就是说,它也是一个广播接收者来的,既然是一个广播接收者,那么,肯定就是要到AndroidMainfest里面注册它的啦

但是在注册之前,我们还有一件事要处理的,那就是在xml目录下面,定义一个xml文件,来指定一些Widget的信息

process_widget_info.xml

<?xml version="1.0" encoding="utf-8"?>
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"android:initialLayout="@layout/process_widget"android:minHeight="72dp"android:minWidth="294dp"android:updatePeriodMillis="0"></appwidget-provider>

上面我们指定了widget的布局文件啦,这个布局文件就是Widget显示出来的模样啦,我就不粘出来啦,大家可以下载来看看,还有最小的高度啦,最小的宽度啦,还有最后一个就是刷新的时间间隔啦,这里我们写了0,但我们后面会在代码里面用一个计时器来控制刷新的

写完这个文件之后,我们就可以去AndroidMainfest文件里面注册这个Widget啦

        <receiver android:name="com.xiaobin.security.receiver.ProcessWidget"><intent-filter><action android:name="android.appwidget.action.APPWIDGET_UPDATE" /></intent-filter><meta-data android:name="android.appwidget.provider"android:resource="@xml/process_widget_info"/></receiver>

就这样子,我们的Widget就注册完成的啦,那么接下来,我们就来写一下Widget要做的事啦

因为我们的Widget是清理进程,那么,还要读取进程的东西,这是一个耗时的操作,所以我们就定义一个服务来处理这些事

com.xiaobin.security.service.UpdateWidgetService

package com.xiaobin.security.service;import java.util.Timer;
import java.util.TimerTask;import android.app.PendingIntent;
import android.app.Service;
import android.appwidget.AppWidgetManager;
import android.content.ComponentName;
import android.content.Intent;
import android.os.IBinder;
import android.widget.RemoteViews;import com.xiaobin.security.R;
import com.xiaobin.security.receiver.ProcessClearReceiver;
import com.xiaobin.security.utils.ProcessUtil;public class UpdateWidgetService extends Service
{private Timer timer;private TimerTask timerTask;private AppWidgetManager appWidgetManager;private ComponentName componentName;private RemoteViews remoteViews;private Intent intent;private PendingIntent pendingIntent;@Overridepublic IBinder onBind(Intent intent){return null;}@Overridepublic void onCreate(){// 拿到一个AppWidgetManager对象appWidgetManager = AppWidgetManager.getInstance(getApplicationContext());// 拿到一个ComponentName对象componentName = new ComponentName("com.xiaobin.security","com.xiaobin.security.receiver.ProcessWidget");// 就是显示到桌面上的界面啦,所有布局是我们写的那个widget的布局remoteViews = new RemoteViews("com.xiaobin.security",R.layout.process_widget);// 这个intent是用来启动一个广播的,因为我们的winget是一键清理的嘛// 所以我们现在只要发送一条广播就可以调用里面的清理方法啦// 但我这里就不做啦,大家可以自己试试intent = new Intent(UpdateWidgetService.this, ProcessClearReceiver.class);// 拿到一个PendingIntent对象,来发送一条广播pendingIntent = PendingIntent.getBroadcast(getApplicationContext(), 0,intent, 0);// java传统的计时器timer = new Timer();timerTask = new TimerTask(){@Overridepublic void run(){//这里就没设置的们的process_widget这个布局文件里面的内容的啦//第一个参数就是设置的那个控件的id啦remoteViews.setTextViewText(R.id.tv_process_count, "进程数目:"+ ProcessUtil.getProcessCount(getApplicationContext()));remoteViews.setTextViewText(R.id.tv_process_memory, "可用内存:"+ ProcessUtil.getAvailMemory(getApplicationContext()));//这个就是给按钮加上点击事件啦remoteViews.setOnClickPendingIntent(R.id.bt_clear, pendingIntent);//更新widget里面的内容appWidgetManager.updateAppWidget(componentName, remoteViews);}};//开启计时器timer.scheduleAtFixedRate(timerTask, 1000, 3000);super.onCreate();}@Overridepublic void onDestroy(){//取消计时器timer.cancel();timer = null;timerTask = null;super.onDestroy();}}

上面的代码都有很详细的注释啦,大家可以看看,有不明白的可以问一下,

在这里,我要提醒一下大家,在我用的Android2.3的模拟器里面,那个Widget的显示是有问题的,所有我后来才换了4.1的模拟器来测试,所有大家发现如果Widget显示有问题,可以,换一下模拟器,

还有一个要注意的是,我们上面是通过PendingIntent来发送一个广播嘛,然后通过接收这条广播来进程清理内存,照理说我们已经有一个LockScreenReceiver的广播接收者来清理进程的啦,完全就可以发一条广播给它的,然后它就调用receiver方法来清理进程,但是,我在测试的时候发现不行的,我还在真机上,两个不同版本的模拟器上测试过,都是不行的,所以我们在这里就自己新写了一个广播接收者,它里面也很简单,就是清理一下进程而已,大家如果知道为什么发送给LockScreenReceiver不行的话,可以告诉我,我当时在这里测试了2,3个小时,都不行

com.xiaobin.security.receiver.ProcessClearReceiver

package com.xiaobin.security.receiver;import com.xiaobin.security.utils.ProcessUtil;import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;public class ProcessClearReceiver extends BroadcastReceiver
{@Overridepublic void onReceive(Context context, Intent intent){//清理内存ProcessUtil.killAllProcess(context);}}

大家不要忘记了还要注册这个广播接收者的

<receiver android:name="com.xiaobin.security.receiver.ProcessClearReceiver"></receiver>


好啦,既然我们的服务写好啦,那么,我们就要控制它的开启与关闭啦

那么我们回到我们的 ProcessWidget类里面,我们重写它的onEnable和onDelete方法

com.xiaobin.security.receiver.ProcessWidget

package com.xiaobin.security.receiver;import android.appwidget.AppWidgetProvider;
import android.content.Context;
import android.content.Intent;import com.xiaobin.security.service.UpdateWidgetService;public class ProcessWidget extends AppWidgetProvider
{private Intent intent;@Overridepublic void onEnabled(Context context){super.onEnabled(context);//开启服务intent = new Intent(context, UpdateWidgetService.class);context.startService(intent);}@Overridepublic void onDeleted(Context context, int[] appWidgetIds){super.onDeleted(context, appWidgetIds);//停止服务intent = new Intent(context, UpdateWidgetService.class);context.stopService(intent);}}

上面我说过,不同的桌面,Widget的生命周期是有可能不同的,而且我上面也说啦,在Android2.3的模拟器里面,Widget显示是有问题的,我花了很长时间,发现,其实它是没有执行onEnable这个方法的,也就是说在Android2.3这个模拟器里面,它的生命同期是没有onEnable的,这应该是模拟器的一个bug来的,一般不可能会没有onEnable方法的,所以我们就要onEnable方法开启服务,当widget删除的时候,关闭服务


好啦,就这样子,我们的这个添加Widget的功能就完成的啦,那么我们的进程管理也完成的啦,还有很多的细节和优化,大家可以自己去做一下,下一次,我们就进行的流量管理的功能啦


最后,和大家说一下

为了方便大家的交流,我创建了一个群,这样子大家有什么疑问也可以在群上交流

群号是298440981



今天源码下载





这篇关于Android项目实战--手机卫士32--给清理进程添加一个Widget的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

用Microsoft.Extensions.Hosting 管理WPF项目.

首先引入必要的包: <ItemGroup><PackageReference Include="CommunityToolkit.Mvvm" Version="8.2.2" /><PackageReference Include="Microsoft.Extensions.Hosting" Version="8.0.0" /><PackageReference Include="Serilog

Java面试八股之怎么通过Java程序判断JVM是32位还是64位

怎么通过Java程序判断JVM是32位还是64位 可以通过Java程序内部检查系统属性来判断当前运行的JVM是32位还是64位。以下是一个简单的方法: public class JvmBitCheck {public static void main(String[] args) {String arch = System.getProperty("os.arch");String dataM

eclipse运行springboot项目,找不到主类

解决办法尝试了很多种,下载sts压缩包行不通。最后解决办法如图: help--->Eclipse Marketplace--->Popular--->找到Spring Tools 3---->Installed。

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

Eclipse+ADT与Android Studio开发的区别

下文的EA指Eclipse+ADT,AS就是指Android Studio。 就编写界面布局来说AS可以边开发边预览(所见即所得,以及多个屏幕预览),这个优势比较大。AS运行时占的内存比EA的要小。AS创建项目时要创建gradle项目框架,so,创建项目时AS比较慢。android studio基于gradle构建项目,你无法同时集中管理和维护多个项目的源码,而eclipse ADT可以同时打开

android 免费短信验证功能

没有太复杂的使用的话,功能实现比较简单粗暴。 在www.mob.com网站中可以申请使用免费短信验证功能。 步骤: 1.注册登录。 2.选择“短信验证码SDK” 3.下载对应的sdk包,我这是选studio的。 4.从头像那进入后台并创建短信验证应用,获取到key跟secret 5.根据技术文档操作(initSDK方法写在setContentView上面) 6.关键:在有用到的Mo

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

Android我的二维码扫描功能发展史(完整)

最近在研究下二维码扫描功能,跟据从网上查阅的资料到自己勉强已实现扫描功能来一一介绍我的二维码扫描功能实现的发展历程: 首页通过网络搜索发现做android二维码扫描功能看去都是基于google的ZXing项目开发。 2、搜索怎么使用ZXing实现自己的二维码扫描:从网上下载ZXing-2.2.zip以及core-2.2-source.jar文件,分别解压两个文件。然后把.jar解压出来的整个c

android 带与不带logo的二维码生成

该代码基于ZXing项目,这个网上能下载得到。 定义的控件以及属性: public static final int SCAN_CODE = 1;private ImageView iv;private EditText et;private Button qr_btn,add_logo;private Bitmap logo,bitmap,bmp; //logo图标private st