android9.0 amlogic 遥控器POWER按键的假待机的实现

// 保留原有导入,新增需要的 IO 导入(如果没有的话)
import java.io.DataOutputStream;
import java.io.IOException;
import java.io.File; // 路径校验用
import android.util.Log;
import android.os.SystemClock;
import android.content.Context;
import android.os.PowerManager;

// 日志标签和 avmute 路径常量(放在类内)
private static final String TAG = "PhoneWindowManager";
private static final String AVMUTE_PATH = "/sys/devices/virtual/amhdmitx/amhdmitx0/avmute";

/**
* 执行 shell 命令(显式使用 java.lang.Process,避免和 android.os.Process 冲突)
* @param command 要执行的 shell 命令
* @return true 执行成功,false 执行失败
*/
private boolean executeShellCommand(String command) {
// 关键:显式声明为 java.lang.Process,而非 android.os.Process
java.lang.Process process = null;
DataOutputStream dos = null;
try {
// 启动 sh 进程(系统层默认有权限)
process = Runtime.getRuntime().exec("sh");
dos = new DataOutputStream(process.getOutputStream());
// 写入命令并执行
dos.writeBytes(command + "\n");
dos.flush();
// 发送退出命令,等待执行完成
dos.writeBytes("exit\n");
dos.flush();
// 等待进程执行完毕,获取退出码
int exitCode = process.waitFor();
boolean success = (exitCode == 0);
if (!success) {
Log.e(TAG, "执行命令失败: " + command + ", 退出码: " + exitCode);
}
return success;
} catch (IOException | InterruptedException e) {
Log.e(TAG, "执行命令异常: " + command, e);
return false;
} finally {
// 关闭流和进程,避免内存泄漏
try {
if (dos != null) {
dos.close();
}
if (process != null) {
process.destroy();
}
} catch (IOException e) {
Log.w(TAG, "关闭进程流失败", e);
}
}
}

/**
* 写入 avmute 文件(封装具体业务逻辑)
* @param value 要写入的值(如 1/0)
* @return true 写入成功,false 失败
*/
private boolean setAvMuteValue(int value) {
// 先校验文件是否存在且可写,避免无效执行
File avMuteFile = new File(AVMUTE_PATH);
if (!avMuteFile.exists() || !avMuteFile.canWrite()) {
Log.e(TAG, "avmute 文件不存在或不可写: " + AVMUTE_PATH);
return false;
}
// 拼接命令:echo [value] > [路径]
String command = "echo " + value + " > " + AVMUTE_PATH;
return executeShellCommand(command);
}

/**
* 锁屏核心函数(集成 avmute 写入逻辑)
*/
private void lockScreen() {
try {
// 获取 PowerManager 实例(确保 mContext 已初始化)
PowerManager powerManager = (PowerManager) mContext.getSystemService(Context.POWER_SERVICE);
if (powerManager != null && powerManager.isInteractive()) { // 屏幕亮着时才锁屏
// 1. 原有锁屏逻辑:熄灭屏幕
powerManager.goToSleep(SystemClock.uptimeMillis(),
PowerManager.GO_TO_SLEEP_REASON_POWER_BUTTON, 0);

// 2. 新增:写入 avmute 为 1
boolean avMuteSuccess = setAvMuteValue(1);
if (avMuteSuccess) {
Log.d(TAG, "锁屏时成功设置 avmute 为 1");
} else {
Log.w(TAG, "锁屏时设置 avmute 失败");
}
}
} catch (Exception e) {
Log.e(TAG, "锁屏逻辑执行失败", e);
}
}

// 可选:解锁时恢复 avmute 为 0
private void unlockScreen() {
PowerManager powerManager = (PowerManager) mContext.getSystemService(Context.POWER_SERVICE);
if (powerManager != null && !powerManager.isInteractive()) {
// 原有解锁逻辑:唤醒屏幕
// powerManager.wakeUp(SystemClock.uptimeMillis(),
// 1, 0);
powerManager.wakeUp(SystemClock.uptimeMillis(), "android.policy:POWER");
// 恢复 avmute 为 0
setAvMuteValue(0);
Log.d(TAG, "解锁时设置 avmute 为 0");
}
}

========================

case KeyEvent.KEYCODE_POWER: {
// Any activity on the power button stops the accessibility shortcut
cancelPendingAccessibilityShortcutAction();
// result &= ~ACTION_PASS_TO_USER;
// isWakeKey = false; // wake-up will be handled separately
// if (down) {
// interceptPowerKeyDown(event, interactive);
// } else {
// interceptPowerKeyUp(event, interactive, canceled);
// }
result &= ~ACTION_PASS_TO_USER;
isWakeKey = false; // wake-up will be handled separately
if(down){
downTime = System.currentTimeMillis();
Log.d(TAG, "=======================downtime=" + downTime);
Log.d(TAG, "onKeyDown interceptKeyTq keycode=" + keyCode);
interceptPowerKeyDown(event, interactive); // 处理按下事件
}
else
{

upTime = System.currentTimeMillis();
long timeDelay = upTime - downTime;

Log.d(TAG, "====================uptime=" + upTime + "--------------" + timeDelay);
if(timeDelay > 1200){

if(mPowerManager.isScreenOn()) {
Message msg = mHandler.obtainMessage(MSG_POWER_SHUT_DOWN);
msg.setAsynchronous(true);
mHandler.sendMessageDelayed(msg,
ViewConfiguration.get(mContext).getDeviceGlobalActionKeyTimeout());
} else {
Log.e("GO to Wakeup--------> TTTEEE","keyCode :"+keyCode);
wakeUpFromPowerKey(event.getDownTime());
}
}

else
{

//interceptPowerKeyDown(event, interactive); // 处理按下事件

// interceptPowerKeyUp(event, interactive, canceled); // 处理抬起事件,包括灭屏事件
if (mPowerManager.isScreenOn()) {
// 屏幕亮着:执行锁屏逻辑(比如电源键短按)
lockScreen();
} else {
// 屏幕灭着:执行唤醒逻辑(比如电源键短按)
unlockScreen();
}
}
}

break;
}

相关推荐
程序员小崔日记9 小时前
如何将代码轻松上传到 Gitee?Git 使用全攻略!
git·gitee·上传
哈里谢顿9 小时前
Python 高并发服务限流终极方案:从原理到生产落地(2026 实战指南)
python
用户8356290780511 天前
无需 Office:Python 批量转换 PPT 为图片
后端·python
markfeng81 天前
Python+Django+H5+MySQL项目搭建
python·django
GinoWi1 天前
Chapter 2 - Python中的变量和简单的数据类型
python
JordanHaidee1 天前
Python 中 `if x:` 到底在判断什么?
后端·python
ServBay1 天前
10分钟彻底终结冗长代码,Python f-string 让你重获编程自由
后端·python
闲云一鹤1 天前
Python 入门(二)- 使用 FastAPI 快速生成后端 API 接口
python·fastapi
Rockbean1 天前
用40行代码搭建自己的无服务器OCR
服务器·python·deepseek
曲幽1 天前
FastAPI + Ollama 实战:搭一个能查天气的AI助手
python·ai·lora·torch·fastapi·web·model·ollama·weatherapi