位置: 编程技术 - 正文

Android 4.1.2系统添加重启功能(android4.4.2升级包)

编辑:rootadmin

推荐整理分享Android 4.1.2系统添加重启功能(android4.4.2升级包),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:android os 4.1,android 4.4.2,android 4.4,安卓4.1.2,android os 4.2,android 4.4,android 4.2.2,android os 4.1,内容如对您有帮助,希望把文章链接给更多的朋友!

Android 4.1.2系统添加重启功能(android4.4.2升级包)

转自: * Create the global actions dialog. * @return A new dialog. */private GlobalActionsDialog createDialog() { // Simple toggle style if there's no vibrator, otherwise use a tri-state if (!mHasVibrator) { mSilentModeAction = new SilentModeToggleAction(); } else { mSilentModeAction = new SilentModeTriStateAction(mContext, mAudioManager, mHandler); } 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 (mHasTelephony && 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) { if (!mHasTelephony) return; // 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; } }; onAirplaneModeChanged(); mItems = new ArrayList<Action>(); // first: power off mItems.add( 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. mWindowManagerFuncs.shutdown(true); } public boolean onLongPress() { mWindowManagerFuncs.rebootSafeMode(true); return true; } public boolean showDuringKeyguard() { return true; } public boolean showBeforeProvisioning() { return true; } });我们可以看到mItems.add函数是添加一个选项,该菜单的第一个选项就是关机选项,我们可以在此之后添加重启选项,代码如下:mItems.add( new SinglePressAction( com.android.internal.R.drawable.ic_lock_power_off, R.string.global_action_reboot) { public void onPress() { // reboot mWindowManagerFuncs.reboot(); } public boolean showDuringKeyguard() { return true; } public boolean showBeforeProvisioning() { return true; } });上面的代码中使用了mWindowManagerFuncs.reboot函数和R.string.global_action_reboot资源,因此我们需要该资源并实现reboot函数。首先在frameworks/base/core/java/android/view/WindowManagerPolicy.java中添加reboot接口:/** * Interface for calling back in to the window manager that is private * between it and the policy. */public interface WindowManagerFuncs { ... /** * Switch the keyboard layout for the given device. * Direction should be &#;1 or -1 to go to the next or previous keyboard layout. */ public void switchKeyboardLayout(int deviceId, int direction); public void shutdown(); public void reboot(); public void rebootSafeMode();}然后在frameworks/base/services/java/com/android/server/wm/WindowManagerService.java中实现该接口:// Called by window manager policy. Not exposed externally.@Overridepublic void shutdown() { ShutdownThread.shutdown(mContext, true);}// Called by window manager policy. Not exposed externally.@Overridepublic void reboot() { ShutdownThread.reboot(mContext, null, true);}// Called by window manager policy. Not exposed externally. @Overridepublic void rebootSafeMode() { ShutdownThread.rebootSafeMode(mContext, true);}接下来,为了在按下重启选项之后,能出现”重启“之类的提示,还需要修改frameworks/base/services/java/com/android/server/pm/ShutdownThread.java中的shutdownInner函数和beginShutdownSequence函数:static void shutdownInner(final Context context, boolean confirm) { // ensure that only one thread is trying to power down. // any additional calls are just returned synchronized (sIsStartedGuard) { if (sIsStarted) { Log.d(TAG, "Request to shutdown already running, returning."); return; } } final int longPressBehavior = context.getResources().getInteger( com.android.internal.R.integer.config_longPressOnPowerBehavior); final int resourceId = mRebootSafeMode ? com.android.internal.R.string.reboot_safemode_confirm : (longPressBehavior == 2 ? com.android.internal.R.string.shutdown_confirm_question : (mReboot ? com.android.internal.R.string.reboot_confirm : com.android.internal.R.string.shutdown_confirm)); Log.d(TAG, "Notifying thread to start shutdown longPressBehavior=" &#; longPressBehavior); if (confirm) { final CloseDialogReceiver closer = new CloseDialogReceiver(context); final AlertDialog dialog = new AlertDialog.Builder(context) .setTitle(mRebootSafeMode ? com.android.internal.R.string.reboot_safemode_title : (mReboot ? com.android.internal.R.string.reboot : com.android.internal.R.string.power_off)) .setMessage(resourceId) .setPositiveButton(com.android.internal.R.string.yes, new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int which) { beginShutdownSequence(context); } }) .setNegativeButton(com.android.internal.R.string.no, null) .create(); closer.dialog = dialog; dialog.setOnDismissListener(closer); dialog.getWindow().setType(WindowManager.LayoutParams.TYPE_KEYGUARD_DIALOG); dialog.show(); } else { beginShutdownSequence(context); }}private static void beginShutdownSequence(Context context) { synchronized (sIsStartedGuard) { if (sIsStarted) { Log.d(TAG, "Shutdown sequence already running, returning."); return; } sIsStarted = true; } // throw up an indeterminate system dialog to indicate radio is // shutting down. ProgressDialog pd = new ProgressDialog(context); pd.setTitle(context.getText(com.android.internal.R.string.power_off)); pd.setMessage(context.getText(com.android.internal.R.string.shutdown_progress)); pd.setIndeterminate(true); pd.setCancelable(false); pd.getWindow().setType(WindowManager.LayoutParams.TYPE_KEYGUARD_DIALOG); pd.show(); sInstance.mContext = context; sInstance.mPowerManager = (PowerManager)context.getSystemService(Context.POWER_SERVICE); // make sure we never fall asleep again sInstance.mCpuWakeLock = null; try { sInstance.mCpuWakeLock = sInstance.mPowerManager.newWakeLock( PowerManager.PARTIAL_WAKE_LOCK, TAG &#; "-cpu"); sInstance.mCpuWakeLock.setReferenceCounted(false); sInstance.mCpuWakeLock.acquire(); } catch (SecurityException e) { Log.w(TAG, "No permission to acquire wake lock", e); sInstance.mCpuWakeLock = null; } // also make sure the screen stays on for better user experience sInstance.mScreenWakeLock = null; if (sInstance.mPowerManager.isScreenOn()) { try { sInstance.mScreenWakeLock = sInstance.mPowerManager.newWakeLock( PowerManager.FULL_WAKE_LOCK, TAG &#; "-screen"); sInstance.mScreenWakeLock.setReferenceCounted(false); sInstance.mScreenWakeLock.acquire(); } catch (SecurityException e) { Log.w(TAG, "No permission to acquire wake lock", e); sInstance.mScreenWakeLock = null; } } // start the thread that initiates shutdown sInstance.mHandler = new Handler() { }; sInstance.start();}至此关于代码部分的改动全部完成,接下来就需要添加使用到的资源了,就是前面用到的字符串。首先需要在frameworks/base/core/res/res/values/strings.xml中添加一下字符串:<string name="reboot">Reboot</string><string name="reboot_progress">Rebootu</string><string name="reboot_confirm" product="tablet">Your tablet will reboot.</string><string name="reboot_confirm" product="default">Your phone will reboot.</string><!-- label for item that reboot in phone options dialog --><string name="global_action_reboot">Reboot</string>而后需要在frameworks/base/core/res/res/values/public.xml中声明这些资源,否则编译的时候会出现找不到该资源的错误。<java-symbol type="string" name="reboot" /><java-symbol type="string" name="reboot_confirm" /><java-symbol type="string" name="reboot_progress" /><java-symbol type="string" name="global_action_reboot" />至此,全部修改完成,编译烧写即可。

Android设计模式之单例模式 Singleton 一.概述单例模式是设计模式中最简单的一种,但是它没有设计模式中的那种各种对象之间的抽象关系,所以有人不认为它是一种模式,而是一种实现技巧.单

Android ListViewitem滑动出现删除按钮 我自己一个人弄的公司的产品客户端,所以还是想记录下来以免忘记或者丢失...在我的上一篇博文(点击打开链接)是一个文件管理的东西,基础组件也是

Android 4.1.2为通知栏添加wifi开关 摘自:

标签: android4.4.2升级包

本文链接地址:https://www.jiuchutong.com/biancheng/379574.html 转载请保留说明!

上一篇:RecyclerView基本使用(recycleview使用)

下一篇:Android设计模式之单例模式 Singleton(android设计模式的应用场景)

  • 营业外收入需要缴纳什么税
  • 金税三期登录界面
  • 增值税专用发票抵扣期限
  • 个体户每月超过30万
  • 与收益相关的政府补助会计分录总额法
  • 回购股份进行股权激励会计分录
  • 发放股票股利增资
  • 个体户办理税务登记有什么好处
  • 补偿金申报个所税如何录入?
  • 银行结算方式包括哪些内容
  • 应收账款减值处理
  • 一般纳税人出租不动产增值税税率
  • 个税手续费返还奖励财务人员的文件
  • 公司注销了工程款还能转账吗
  • 国际收款产生的手续费账务处理
  • 航天金税服务费280怎么缴费
  • 网上申领发票怎么清卡
  • 工会财务总结报告
  • 电脑经常蓝屏修复
  • 华为手机屏幕旋转设置
  • 动产抵押交付生效还是登记生效
  • 非上市公众公司收购办法
  • 住房公积金一次性补缴
  • php获取参数值的三种方式
  • 企业以非货币性资产投资
  • 区分不同情形
  • 其他应收和其他应付可以共用吗
  • 企业购入软件会计分录
  • 今日七夕祝福语
  • php接收ajax请求
  • php使用什么开发工具
  • 其他货币资金明细科目有哪些
  • 商业预付卡可以报销吗
  • 销售费用可以开专票吗
  • php判断字符串是否为ip地址
  • 固定资产清理的含义
  • 国税申报成功未缴税
  • 所得税费用会计处理
  • 小规模0申报要做账吗
  • 代理付银行手续费合法吗
  • PostgreSQL之分区表(partitioning)
  • dedecms模版
  • 服务费的开票项目是什么
  • 出口退税在贷方,之后还交税吗
  • 无锡政府回购安置房
  • 增值税专用发票丢了怎么补救
  • 税收类型增值税有哪些
  • 个人所得税申报退税能退多少
  • 分公司注销一般要多久
  • 先给发票后付款做账
  • 工程结转成本分录
  • 房产公司结转成本的会计分录
  • 企业选择的短期调整
  • 用友t6反记账步骤
  • 工厂用的工具放计入哪个科目
  • 生产车间的保险有哪些
  • 税票名称开错了有影响么
  • 生产成本结转到本年利润吗
  • 对子公司的投资损失可以税前扣除吗
  • mysql5.7.32免安装教程
  • 微软6月24号
  • linux安装iso软件
  • linux系统关闭ftp服务
  • 电脑周边是什么
  • cgi linux
  • linux模块的概念
  • win7如何访问xp
  • pptd40nt.exe是什么进程 有什么用 pptd40nt进程查询
  • python检索文件中的内容
  • js中push和pop
  • Unity destructor Or OnDestory
  • javascript基础题目
  • JavaScript快速排序
  • 公路局有钱吗
  • 分摊费用怎么计算公式
  • 补充协议交印花税嘛
  • 车辆购置税去哪个税务局交
  • 地方税务局几点下班
  • 亦庄税务局电话号码
  • 税务延期申报最长多久
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设