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;
}

相关推荐
南境十里·墨染春水6 分钟前
C++ 工厂模式:从入门到进阶,彻底掌握对象创建的艺术
开发语言·c++·算法
某人辛木27 分钟前
Web自动化测试
前端·python·pycharm·pytest
C+++Python1 小时前
详细介绍一下Java泛型的通配符
java·windows·python
JosieBook2 小时前
【数据库】时序预测能力的分级进化:TimechoAI如何让每一类用户都能精准预见未来
java·开发语言·数据库
加号32 小时前
【C#】 文件与目录管理:创建、删除操作的技术解析
开发语言·c#
小帅热爱难回头2 小时前
编写Skill生成AI落地项目系统架构
python
diving deep2 小时前
脚本速览-python
开发语言·python
OsDepK2 小时前
移动编程OSMDE随时命令行进行Git
ide·git
一生了无挂2 小时前
Java处理JSON技巧教学(从基础到高阶实战全覆盖)
java·开发语言·json
swordbob3 小时前
Spring 单例 Bean 是线程安全的吗?
java·开发语言