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

相关推荐
Csvn18 小时前
🌟 LangChain 30 天保姆级教程 · Day 13|OutputParser 进阶!让 AI 输出自动转为结构化对象,并支持自动重试!
python·langchain
Wenweno0o18 小时前
0基础Go语言Eino框架智能体实战-chatModel
开发语言·后端·golang
chenjingming66618 小时前
jmeter线程组设置以及串行和并行设置
java·开发语言·jmeter
摆烂且佛系18 小时前
十分钟了解Git Cherry-Pick
git
cch891818 小时前
Python主流框架全解析
开发语言·python
不爱吃炸鸡柳18 小时前
C++ STL list 超详细解析:从接口使用到模拟实现
开发语言·c++·list
十五年专注C++开发18 小时前
RTTR: 一款MIT 协议开源的 C++ 运行时反射库
开发语言·c++·反射
Momentary_SixthSense19 小时前
设计模式之工厂模式
java·开发语言·设计模式
sg_knight19 小时前
设计模式实战:状态模式(State)
python·ui·设计模式·状态模式·state
好运的阿财19 小时前
process 工具与子agent管理机制详解
网络·人工智能·python·程序人生·ai编程