如何给状态栏上的时钟自定义样式或位置?(位置篇)
yuyutoo 2024-10-19 11:09 2 浏览 0 评论
时间,是状态栏必不可少的空间之一。至于它的重要性和“电量”、“信号”相比,哪个更重要。就由用户自行判断了!
(什么?你说WIFI信号最重要?我也觉得有道理!)
现如今,大多数第三方ROM都有提供或多或少的个性化自定义设置。状态栏,通知栏,导航栏,最近任务面板之类的。
比如这样!但也有相当一些ROM是不提供自定义设置的,哪怕是状态栏时间的自定义。
所以,针对这些用户,要想自定义状态栏的时钟。就得发挥极客精神。“自己动手,丰衣足食”!
我的ROM是集成自定义的。还有几个机器也是如此。突然想起来,鑫君我还有个国产杂牌机器。ROM相当原始。就动起它的主意了!
这是我的LG G2的ROM。前几篇文章评论里有不少人误认为是Nexus系列,在这里统一回复下。这是LG G2,用了两年多,后续也购买了其它机器,但还是它做主力机用着顺手!
时钟这玩意的自定义我就不追溯了。
下面扯正题。
今天扯的就俩,把时间放在状态栏左边,和把时间放在状态栏中间 居中。
这便是鑫君前几年购入的杂牌机器,720P,联发科6589,Android 4.2.2。这机器还没有第三方ROM,相当冷门。
折腾之前,为了方便救砖,去移植了一个Recovery,这东西还算好弄。不过TWRP移植失败,可能是因为官方Recovery是基于cmw编译的原因吧!
注意:4.4及以下ROM和5.0及以上ROM差距太大,本教程适用于4.4及以下ROM
这里修改的工具用到的和前两次教程用到的工具一样,只不过ApKTool版本不一样,之前我LG G2是Android 6.0,所以ApKTool用的是6.1.0。而这款机器是4.2.2,最高只能用ApKTool 5.2.0。
首先,提取SystemUI.apk,这个在根目录system/app里,安卓4.4的在system/priv_app里。
提取好之后,就是反编译了。
反编译之前导入框架的部分我就跳过不讲了,之前讲过,反编译时选择反编译资源就够了,不过我这个还没合并odex,所以反编译资源和反编译全部是一样的。
这样,就算反编译成功了。反编译成功后会生成一个文件夹。
我们直接去找状态栏的布局文件。一般情况下,都是这个status_bar.xml,不过因为我这款杂牌机是双卡双待的机器,所以实际上是gemini_status_bar.xml这个文件。
所以,我们,打开它。用第三方文本编辑器,文件管理器带的文本编辑器不是很好用,我用的这个文本编辑器叫“Quoda”。
打开它,找到第一个LinearLayout的语句,这个就是状态栏控件布局的开头了。一般都是这个,还没见过哪个ROM用相对布局或是绝对布局去写状态栏布局的。
这个LinearLayout在第6段,这是总布局的开头,第7段这个是通知图标的开头。
不用管它,记住就好,接下来我们找“时间”这个控件所在的段落。可以直接找“Clock”
就是这里了,第18段。把这一段“剪切”下来。放在刚才总布局开头的后面,通知图标布局开头的前面,也就是第6段到第7段之间。
弄好就是这样了。你也可以把这段的【android:paddingLeft="6.0dip"】改成0.0dip或是删了,这是控件左边边距大小。
这就算改好了!然后我们回编译!
单击那个反编译生成的文件夹,弹出菜单选择“编译”。编译的过程通常比反编译要漫长一些。
看到Building apk file,就算成功了!
至于上面多余的提示,是语言库的默认语言库没有这个字符串定义,可改可不改。这次我就不管它了。
底下这个就是我们修改好编译好的新的apk。
把这个新apk的gemini_status_bar.xml放到原本的apk里。
首先,我们找到它。另一个窗口是原apk同目录。
复制过去,就有了可用的新新apk。
然后我们准备替换进系统。
找到根目录。
把那个新新apk复制到根目录的system文件夹里。
把权限改成0644,就想这样。然后复制到系统systemUI.apk原本的位置。
然后重启。
生效了,现在状态栏的时间就在最左边了!
——————————————————————
接下来我们讲把如何时间放在状态栏的最中间位置。
依旧是打开刚才那个文件,原本的状态栏布局把状态栏分成两个大部分,右侧是系统图标和时间,剩下左侧的都是通知图标。
所以,我们把时间放在中间,也就等于放在这两个部分之间。所以,我们先找左侧那部分布局的结束部分!
刚才说道,第7段是通知图标的开头,线性布局是有头有尾的,一个LinearLayout开头的容器(非控件),就得有另一段</LinearLayout>结束,所以,我们可以看到第10段就是通知图标的结束部分。
依旧是找到时间这一段,剪切过去。
放到第10段下面。这样一来,状态栏就变成了“通知图标”“时间”“系统图标”这样的三个部分的布局。
但,还有一个问题,刚才说了,状态栏除了右侧,剩下的都是通知图标,也就是通知图标占了一大半,如果就这样的话,时间只会在中间偏右,不会在正中间。
通常多数的ROM都是用对齐属性,把它居中的。属性为【android:layout_gravity="center"】(没有这个括号)。
这样的话,虽然时间会强制居中,但通知图标会和它重叠,如果图标过多的话。它是会延展到状态栏中间的。
但实际上,android:layout_weight的这个属性,它在同一个容器的同一个层级下,它是同优先级的,不会向layout_width那样,纯粹的先来后到。
所以,我们用android:layout_weight这个属性,对三大部分进行空间大小调整!
控件的宽度=layout_width+(容器剩余空间/总weight)*weight
有些是把三大空间进行三等分,各占三分之一。
这次,我是把时间放中间,剩下的二等分,这样可以空间最大利用化!
刚才说了,通知图标已经是占用剩余空间了,这时候,我们把右侧的系统图标也改成占用剩余空间,这样,由于weight优先级并列,它们会平分剩下的空间。所以,我们找到时间下面的那一段,也就是系统图标开头的那一段。
把里面的android:layout_width="wrap_content"改成android:layout_width="0.0dip",再加一句android:layout_weight="1.0"就好了。
这样时间就居中了。
看下第7段,通知图标开头的那一段,也是这样的。
但实际上还有个对齐问题,布局默认都是从左往右,靠上,靠左对齐。
所以,我来个错误示范。不改对齐。直接回编译。
于是,状态栏就成了这样子,系统图标紧靠时钟。所以,我们还需要改对齐,系统图标的空间对齐方式。
还是这张图。找到第12段,系统图标的开头部分,加上android:gravity="right"
就可以了。
于是,大功告成了!
这就是今天讲的内容。后面还会有将其它的布局方式,还有控件样式的修改自定义。
再往后,可能还会讲给系统修改或添加一些功能。
其它有不懂的,可以添加QQ群99322260进行讨论。
微信公众号是有“回复关键字”功能,后续可能会在个人公众号上附加其它教程,回复教程关键字就可以获取。个人公众号是“IT鑫视界”。
本文结束,谢谢阅读!
相关推荐
- jQuery VS AngularJS 你更钟爱哪个?
-
在这一次的Web开发教程中,我会尽力解答有关于jQuery和AngularJS的两个非常常见的问题,即jQuery和AngularJS之间的区别是什么?也就是说jQueryVSAngularJS?...
- Jquery实时校验,指定长度的「负小数」,小数位未满末尾补0
-
在可以输入【负小数】的输入框获取到焦点时,移除千位分隔符,在输入数据时,实时校验输入内容是否正确,失去焦点后,添加千位分隔符格式化数字。同时小数位未满时末尾补0。HTML代码...
- 如何在pbootCMS前台调用自定义表单?pbootCMS自定义调用代码示例
-
要在pbootCMS前台调用自定义表单,您需要在后台创建表单并为其添加字段,然后在前台模板文件中添加相关代码,如提交按钮和表单验证代码。您还可以自定义表单数据的存储位置、添加文件上传字段、日期选择器、...
- 编程技巧:Jquery实时验证,指定长度的「负小数」
-
为了保障【负小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【负小数】的方法。HTML代码<inputtype="text"class="forc...
- 一篇文章带你用jquery mobile设计颜色拾取器
-
【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...
- 编程技巧:Jquery实时验证,指定长度的「正小数」
-
为了保障【正小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【正小数】的方法。HTML做成方法<inputtype="text"class="fo...
- jquery.validate检查数组全部验证
-
问题:html中有多个name[],每个参数都要进行验证是否为空,这个时候直接用required:true话,不能全部验证,只要这个数组中有一个有值就可以通过的。解决方法使用addmethod...
- Vue进阶(幺叁肆):npm查看包版本信息
-
第一种方式npmviewjqueryversions这种方式可以查看npm服务器上所有的...
- layui中使用lay-verify进行条件校验
-
一、layui的校验很简单,主要有以下步骤:1.在form表单内加上class="layui-form"2.在提交按钮上加上lay-submit3.在想要校验的标签,加上lay-...
- jQuery是什么?如何使用? jquery是什么功能组件
-
jQuery于2006年1月由JohnResig在BarCampNYC首次发布。它目前由TimmyWilson领导,并由一组开发人员维护。jQuery是一个JavaScript库,它简化了客户...
- django框架的表单form的理解和用法-9
-
表单呈现...
- jquery对上传文件的检测判断 jquery实现文件上传
-
总体思路:在前端使用jquery对上传文件做部分初步的判断,验证通过的文件利用ajaxFileUpload上传到服务器端,并将文件的存储路径保存到数据库。<asp:FileUploadI...
- Nodejs之MEAN栈开发(四)-- form验证及图片上传
-
这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能。开始之前需要源码同学可以先在git上fork:https://github.com/stoneniqiu/R...
- 大数据开发基础之JAVA jquery 大数据java实战
-
上一篇我们讲解了JAVAscript的基础知识、特点及基本语法以及组成及基本用途,本期就给大家带来了JAVAweb的第二个知识点jquery,大数据开发基础之JAVAjquery,这是本篇文章的主要...
- 推荐四个开源的jQuery可视化表单设计器
-
jquery开源在线表单拖拉设计器formBuilder(推荐)jQueryformBuilder是一个开源的WEB在线html表单设计器,开发人员可以通过拖拉实现一个可视化的表单。支持表单常用控件...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)