android 判斷App進(jìn)程是否存在,處在前臺,后臺,前后臺切換,service是否運行,設(shè)置為系統(tǒng)app

1.判斷進(jìn)程是否存在

//判斷是否在主進(jìn)程,這個方法判斷進(jìn)程名或者pid都可以,如果進(jìn)程名一樣那pid肯定也一樣
//true:當(dāng)前進(jìn)程是主進(jìn)程 false:當(dāng)前進(jìn)程不是主進(jìn)程
public boolean isUIProcess() {
 ActivityManager am = ((ActivityManager) getSystemService(Context.ACTIVITY_SERVICE));
 List<ActivityManager.RunningAppProcessInfo> processInfos = am.getRunningAppProcesses();
 String mainProcessName = getPackageName();
 int myPid = android.os.Process.myPid();
 for (ActivityManager.RunningAppProcessInfo info : processInfos) {
  if (info.pid == myPid && mainProcessName.equals(info.processName)) {
   return true;
  }
 }
 return false;
}

2.判斷服務(wù)是否存在

/**
 * 判斷service是否已經(jīng)運行
 * 必須判斷uid,因為可能有重名的Service,所以要找自己程序的Service,不同進(jìn)程只要是同一個程序就是同一個uid,個人理解android系統(tǒng)中一個程序就是一個用戶
 * 用pid替換uid進(jìn)行判斷強(qiáng)烈不建議,因為如果是遠(yuǎn)程Service的話,主進(jìn)程的pid和遠(yuǎn)程Service的pid不是一個值,在主進(jìn)程調(diào)用該方法會導(dǎo)致Service即使已經(jīng)運行也會認(rèn)為沒有運行
 * 如果Service和主進(jìn)程是一個進(jìn)程的話,用pid不會出錯,但是這種方法強(qiáng)烈不建議,如果你后來把Service改成了遠(yuǎn)程Service,這時候判斷就出錯了
 *
 * @param className Service的全名,例如PushService.class.getName()
 * @return true:Service已運行 false:Service未運行
 */

public boolean isServiceExisted(String className) {
 ActivityManager am = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE);
 List<ActivityManager.RunningServiceInfo> serviceList = am.getRunningServices(Integer.MAX_VALUE);
 int myUid = android.os.Process.myUid();
 for (ActivityManager.RunningServiceInfo runningServiceInfo : serviceList) {
  if (runningServiceInfo.uid == myUid && runningServiceInfo.service.getClassName().equals(className)) {
   return true;
  }
 }
 return false;
}

3.app是否在前臺

是否在前臺
 private boolean isAppForeground(String packageName) {
        ActivityManager am = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE);
        ComponentName cn = am.getRunningTasks(1).get(0).topActivity;
        String currentPackageName = cn.getPackageName();
        if (!TextUtils.isEmpty(currentPackageName) && currentPackageName.equals(packageName)) {
            return true;
        }

        return false;
    }

把應(yīng)用置為前臺
moveTaskToFront() 
moveTaskToBack()

 private void bring2Front() {
        ActivityManager activtyManager = (ActivityManager) getSystemService(Context.ACTIVITY_SERVICE);
        List<ActivityManager.RunningTaskInfo> runningTaskInfos = activtyManager.getRunningTasks(3);
        for (ActivityManager.RunningTaskInfo runningTaskInfo : runningTaskInfos) {
            if (this.getPackageName().equals(runningTaskInfo.topActivity.getPackageName())) {
                activtyManager.moveTaskToFront(runningTaskInfo.id, ActivityManager.MOVE_TASK_WITH_HOME);
                return;
            }
        }
    }

回到系統(tǒng)桌面
private void back2Home() {
        Intent home = new Intent(Intent.ACTION_MAIN);

        home.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
        home.addCategory(Intent.CATEGORY_HOME);

        startActivity(home);
    }

4.手機(jī)鎖

系統(tǒng)是否在鎖屏狀態(tài)
 private boolean isScreenLocked() {
        KeyguardManager keyguardManager = (KeyguardManager) getSystemService(Context.KEYGUARD_SERVICE);
        return keyguardManager.inKeyguardRestrictedInputMode();
    }
private void wakeAndUnlock() {
        //獲取電源管理器對象
        PowerManager pm = (PowerManager) getSystemService(Context.POWER_SERVICE);

        //獲取PowerManager.WakeLock對象,后面的參數(shù)|表示同時傳入兩個值,最后的是調(diào)試用的Tag
        PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.ACQUIRE_CAUSES_WAKEUP | PowerManager.SCREEN_BRIGHT_WAKE_LOCK, "bright");

        //點亮屏幕
        wl.acquire(1000);

        //得到鍵盤鎖管理器對象
        KeyguardManager km = (KeyguardManager) getSystemService(Context.KEYGUARD_SERVICE);
        kl = km.newKeyguardLock("unLock");

        //解鎖
        kl.disableKeyguard();

    }

 private void release() {
        if (locked && kl != null) {
            android.util.Log.d("maptrix", "release the lock");
            //得到鍵盤鎖管理器對象
            kl.reenableKeyguard();
            locked = false;
        }
    }

5.系統(tǒng)app

參考

參考
public void onclick(View view) {

        DataOutputStream dataOutputStream = null;


        BufferedReader err = null;

        try {

            //得到su權(quán)限
            Process process = Runtime.getRuntime().exec("su root");
            //輸出命令
            dataOutputStream = new DataOutputStream(process.getOutputStream());
            //獲取外部sd路徑
            File externalStorageDirectory = Environment.getExternalStorageDirectory();
            //得到apk文件路徑
            File apkFile = new File(externalStorageDirectory.getAbsoluteFile()+File.separator+"youjiayou.apk");
            //移動文件命令
            String command = "cp  " + apkFile.getAbsolutePath() + " system/app\n";
            //掛載為system可寫 不然無法寫入文件 = = 這些坑我是一點點 踩過的
            dataOutputStream.writeBytes("mount -o remount rw /system\n");
            //輸出命令
            dataOutputStream.write(command.getBytes("UTF-8"));
            //掛載為可寫不然無法生效
            dataOutputStream.writeBytes("chmod 777 /system/app/youjiayou.apk\n");
            //掛載為可讀
            dataOutputStream.writeBytes("mount -o remount ro /system\n");

            //刷新輸出
            dataOutputStream.flush();
            //重啟
            dataOutputStream.writeBytes("reboot\n");
            //退出
            dataOutputStream.writeBytes("exit\n");
            //刷新輸出
            dataOutputStream.flush();
            //等候命令結(jié)束
            process.waitFor();

            String line;

            String msg = "";

            //讀取控制臺返回的數(shù)據(jù)
            err = new BufferedReader(new InputStreamReader(process.getInputStream()));

            //讀取數(shù)據(jù)
            while ((line = err.readLine()) != null) {
                msg += line;
            }

            Log.e("Fmy", "結(jié)果 " +msg);

        } catch (Exception e) {
//          e.printStackTrace();

            Log.e("Fmy", "發(fā)生異常" + e.getMessage());
        } finally {
            try {
                if (dataOutputStream != null) {
                    dataOutputStream.close();
                }

                if (err != null) {
                    err.close();
                }

            } catch (IOException e) {
                e.printStackTrace();
            }
        }


    }

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容