本文实例讲述了android源码探索之定制android关机界面的方法。分享给大家供大家参考。具体如下:

在Android系统中,长按Power键默认会弹出对话框让你选择“飞行模式”,“静音”,“关机”等功能。如下图所示:

但这些功能都对Android-x86和其他终端产品就没什么必要了。本文就简单介绍下如何定制关机界面。

我的目标是长按Power键,将会关机,弹出“设备将要关机”选择对话框。如果可以选择“是”关机,和“否”返回系统。

按照android源码定制要点中提到的,首先你要对整个系统有全面的了解,找到弹出原来这个选择框的代码,它在这里:

frameworks\policies\base\phone\com\android\internal\policy\impl\PhoneWindowManager.java

显示对话框调用的代码如下:

Runnable mPowerLongPress = new Runnable() {

public void run() {

mShouldTurnOffOnKeyUp = false;

performHapticFeedbackLw(null, HapticFeedbackConstants.LONG_PRESS, false);

sendCloseSystemWindows(SYSTEM_DIALOG_REASON_GLOBAL_ACTIONS);

showGlobalActionsDialog();

}

};

调用showGlobalActionsDialog方法之后将会聚到有“飞行模式”、“静音”、“关机”等选项的对话框。

找到这里,我们就知道该做什么了!干掉它,换成我们想要的关机代码,就大功告成了!既然这样,事不宜迟,让我们赶快到showGloabalActionDialog方法中看看关机的部分在哪里!

showGlobalActionsDialog的实现部分在这里:

frameworks\policies\base\phone\com\android\internal\policy\impl\GlobalAction.java

public void showDialog(boolean keyguardShowing, boolean isDeviceProvisioned) {

mKeyguardShowing = keyguardShowing;

mDeviceProvisioned = isDeviceProvisioned;

if (mDialog == null) {

mStatusBar = (StatusBarManager)mContext.getSystemService(Context.STATUS_BAR_SERVICE);

mDialog = createDialog();

}

prepareDialog();

mStatusBar.disable(StatusBarManager.DISABLE_EXPAND);

mDialog.show();

}

我们可以很清楚的看到,这里新建了一个mDialog,然后prepare接着就show了它,那么,这个mDialog就是关键了,看看它是怎么被createDialog创建出来的吧,仍然在这个文件中:

/**

* Create the global actions dialog.

* @return A new dialog.

*/

private AlertDialog createDialog() {

mSilentModeToggle = new ToggleAction(

R.drawable.ic_lock_silent_mode,

R.drawable.ic_lock_silent_mode_off,

R.string.global_action_toggle_silent_mode,

R.string.global_action_silent_mode_on_status,

R.string.global_action_silent_mode_off_status) {

void willCreate() {

// XXX: FIXME: switch to ic_lock_vibrate_mode when available

mEnabledIconResId = (Settings.System.getInt(mContext.getContentResolver(),

Settings.System.VIBRATE_IN_SILENT, 1) == 1)

? R.drawable.ic_lock_silent_mode_vibrate

: R.drawable.ic_lock_silent_mode;

}

void onToggle(boolean on) {

if (on) {

mAudioManager.setRingerMode((Settings.System.getInt(mContext.getContentResolver(),

Settings.System.VIBRATE_IN_SILENT, 1) == 1)

? AudioManager.RINGER_MODE_VIBRATE

: AudioManager.RINGER_MODE_SILENT);

} else {

mAudioManager.setRingerMode(AudioManager.RINGER_MODE_NORMAL);

}

}

public boolean showDuringKeyguard() {

return true;

}

public boolean showBeforeProvisioning() {

return false;

}

};

mAirplaneModeOn = new ToggleAction(

R.drawable.ic_lock_airplane_mode,

R.drawable.ic_lock_airplane_mode_off,

R.string.global_actions_toggle_airplane_mode,

R.string.global_actions_airplane_mode_on_status,

R.string.global_actions_airplane_mode_off_status) {

void onToggle(boolean on) {

if (Boolean.parseBoolean(

SystemProperties.get(TelephonyProperties.PROPERTY_INECM_MODE))) {

mIsWaitingForEcmExit = true;

// Launch ECM exit dialog

Intent ecmDialogIntent =

new Intent(TelephonyIntents.ACTION_SHOW_NOTICE_ECM_BLOCK_OTHERS, null);

ecmDialogIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

mContext.startActivity(ecmDialogIntent);

} else {

changeAirplaneModeSystemSetting(on);

}

}

@Override

protected void changeStateFromPress(boolean buttonOn) {

// In ECM mode airplane state cannot be changed

if (!(Boolean.parseBoolean(

SystemProperties.get(TelephonyProperties.PROPERTY_INECM_MODE)))) {

mState = buttonOn ? State.TurningOn : State.TurningOff;

mAirplaneState = mState;

}

}

public boolean showDuringKeyguard() {

return true;

}

public boolean showBeforeProvisioning() {

return false;

}

};

mItems = Lists.newArrayList(

// silent mode

mSilentModeToggle,

// next: airplane mode

mAirplaneModeOn,

// last: power off

new SinglePressAction(

com.android.internal.R.drawable.ic_lock_power_off,

R.string.global_action_power_off) {

public void onPress() {

// shutdown by making sure radio and power are handled accordingly.

ShutdownThread.shutdown(mContext, true);

}

public boolean showDuringKeyguard() {

return true;

}

public boolean showBeforeProvisioning() {

return true;

}

});

mAdapter = new MyAdapter();

final AlertDialog.Builder ab = new AlertDialog.Builder(mContext);

ab.setAdapter(mAdapter, this)

.setInverseBackgroundForced(true)

.setTitle(R.string.global_actions);

final AlertDialog dialog = ab.create();

dialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_DIALOG);

if (!mContext.getResources().getBoolean(

com.android.internal.R.bool.config_sf_slowBlur)) {

dialog.getWindow().setFlags(WindowManager.LayoutParams.FLAG_BLUR_BEHIND,

WindowManager.LayoutParams.FLAG_BLUR_BEHIND);

}

dialog.setOnDismissListener(this);

return dialog;

}

看看我们发现了什么!!蓝色的部分就是关机调用的函数了!!shutdown方法的第二个参数标识是否弹出询问对话框。你可以选择需要(true)或者不需要(false)。这里我保守一点,还是选个true吧,万一不小心按到关机键呢,呵呵。。。

也就是说,只要我们用

ShutdownThread.shutdown(mContext, true);

替换掉前面的

showGlobalActionsDialog();

就可以大功告成了!还等什么!我们修改

frameworks\policies\base\phone\com\android\internal\policy\impl\PhoneWindowManager.java

的源代码如下:

Runnable mPowerLongPress = new Runnable() {

public void run() {

mShouldTurnOffOnKeyUp = false;

performHapticFeedbackLw(null, HapticFeedbackConstants.LONG_PRESS, false);

sendCloseSystemWindows(SYSTEM_DIALOG_REASON_GLOBAL_ACTIONS);

//showGlobalActionsDialog();

ShutdownThread.shutdown(mContext, true);

}

};

好了,大功告成了!!

是不是就这样完了呢?发现编译不过。。。

细节很重要!!

原来ShutdownThread.shutdown(mContext, true)的引用包没加进来!!幸好有gcc。。。

import com.android.internal.app.ShutdownThread;

将上面这个包加到

frameworks\policies\base\phone\com\android\internal\policy\impl\PhoneWindowManager.java

中,再次编译,通过,YES!

看看我们的战果吧:

是不是感觉到源码定制的快感和成就感了呢?

这仅仅只是个开始,好戏还在后头呢!!哈哈

希望本文所述对大家的Android程序设计有所帮助。

android 自定义关机界面,android源码探索之定制android关机界面的方法相关推荐

  1. android 自定义相机源码,Android 自定义相机及分析源码

    Android 自定义相机及分析源码 使用Android 系统相机的方法: 要想让应用有相机的action,咱们就必须在清单文件中做一些声明,好让系统知道,如下 action的作用就是声明action ...

  2. 面部表情识别3:Android实现表情识别(含源码,可实时检测)

    面部表情识别3:Android实现表情识别(含源码,可实时检测) 目录 面部表情识别3:Android实现表情识别(含源码,可实时检测) 1.面部表情识别方法 2.人脸检测方法 3.面部表情识别模型训 ...

  3. Android四大组件之bindService源码实现详解

        Android四大组件之bindService源码实现详解 Android四大组件源码实现详解系列博客目录: Android应用进程创建流程大揭秘 Android四大组件之bindServic ...

  4. android类中定义颜色,自定义实现简单的Android颜色选择器(附带源码)

    在写Android App过程中需要一个简单的颜色选择器,Android自带的ColorPicker和网上的一些ColorPicker都太高端了,都实现了颜色渐变功能,我要的不需要那么复杂,只想提供几 ...

  5. android安卓智能穿戴仿苹果手表界面的源码效果

    android安卓智能穿戴&仿苹果手表界面的源码效果 苹果手表桌面.apk 为安卓上仿苹果手表的apk . 1 请安装在任何一部安卓设备上运行. 运行后出现苹果手表界面. 视频截图.gif 为 ...

  6. C++版Android实时投屏软件系统源码,安卓手机投屏软件源码,无需root权限

    QtScrcpy QtScrcpy 可以通过 USB / 网络连接Android设备,并进行显示和控制.无需root权限. 同时支持 GNU/Linux ,Windows 和 MacOS 三大主流桌面 ...

  7. Android ---- Ijkplayer阅读native层源码之IjkMediaPlayer_prepareAsync(五)

    整章目录:Android------- IjkPlayer 源码学习目录 本篇会有很多源代码,请注意阅读每行代码上面的注释. 本篇介绍的主要内容为上图红框圈起部分: IjkMediaPlayer_pr ...

  8. android输入法01:SoftKeyboard源码解析01

      本文主要介绍android自带输入法实例SoftKeyboard的源码,共分为两篇:第一篇为SoftKeyboard框架概述,第二篇为源码注释. 1.IMF简介 一个IMF结构中包含三个主要的部分 ...

  9. android 浏览器源码分析,从源码出发深入理解 Android Service

    原标题:从源码出发深入理解 Android Service 原文链接: 建议在浏览器上打开,删除了大量代码细节,:) 本文是 Android 系统学习系列文章中的第三章节的内容,介绍了 Android ...

最新文章

  1. 不能交换到解决jenkins用户的问题
  2. 实用ISA Server 2006之一: 简介
  3. 洛谷3933 Chtholly Nota Seniorious 二分答案+贪心
  4. 现代密码学8.1--密码学所涉及的数论和群论
  5. 21. 合并两个有序链表(C语言)
  6. SAP 报表程序的一些标准功能码
  7. 面向对象思想 常说的OOP五大原则就是指1、单一职责原则; 2、开放闭合原则; 3、里氏替换原则; 4、依赖倒置原则; 5、接口隔离原则。...
  8. 关于计算机网络的短文英语,英语翻译哪个心心好嘛!帮我用英语写一段关于计算机网络的100多个字的短文嘛!内容随便写!只要是关于计算机网络的!...
  9. 英语笔记:写作:Nothing succeeds without a strong will
  10. LINQ-to-SQL那点事~耳目一新的partial class 和 partial method
  11. 2 创建型模式之 - 工厂模式
  12. Dapper.net 入门demo 轻量级ORM框架
  13. Python(51)_从100打印到0
  14. 【libyuv】windows构建
  15. 计算机网络放大器的作用,运算放大器工作原理是什么?
  16. Unity导入模型贴贴图一面有贴图另一面透明的解决方法
  17. 博弈论 斯坦福game theory stanford week 2.0_
  18. 这些东西适合做什么?
  19. 现在都在考华为认证,含金量高不高呢?该如何备考?
  20. Java最新面试题及答案

热门文章

  1. Terminal解压命令
  2. 如何使用Matlab进行图像处理
  3. vue 集成epub.js
  4. 2022年奢侈品行业展望
  5. 为什么企鹅Tux是Linux的吉祥物?
  6. 从Word生成有“导航窗格”的PDF(举例说明)
  7. 《像计算机科学家一样思考Python》练习5-1
  8. 前缀和——(3)树上前缀和
  9. ENJ2005-B半导体分立器件测试系统
  10. CSS中 设置( 单行、多行 )超出显示省略号