百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

如何给状态栏上的时钟自定义样式或位置?(位置篇)

yuyutoo 2024-10-19 11:09 15 浏览 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鑫视界”。

本文结束,谢谢阅读!

相关推荐

MySQL中的数据类型(mysql数据类型有哪些,并举例)

MySQL中的数据类型...

mysql窗口函数over中rows_MySQL窗口函数

下面的讲解将基于这个employee2表:mysql>SELECT*FROMemployee2;+----+-----------+------+---------+---------...

别再说你精通数据库,MySQL的设计和列类型选取真的很有讲究

总想写一篇MySQL的设计和列类型选取的文章,一直挤不出时间。天天晚上都要加班,正逢5.1放假,抽了几天就有了此文。如果对朋友们能有帮助的话,关注一波不过分吧?求关!选择更优的数据类型尽量选择存储空间...

MySQL数据库知识(mysql数据库相关知识)

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

数据库:MySQL 高性能优化规范建议

数据库命令规范所有数据库对象名称必须使用小写字母并用下划线分割所有数据库对象名称禁止使用MySQL保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来)数据库对象的命名要能做到见名识意,...

MySQL实战——表结构设计之数字类型

整型不建议刻意去用unsigned属性,因为在做一些数据分析时,SQL可能返回的结果并不是想要得到的结果。比如在财务的场景下,经常会做一些加减操作。MySQL要求unsigned数值相减之...

MySQL数据库入门(四)数据类型简介

在MySQL中数据类型有以下五种:数字整数:常用的有2种,一是int型,int型最多可以表示10位数字(无符号的4开头,有符号的2开头;二是tinyintunsigned,用来表示年龄(值范围是0-...

mysql常用语句超级详细汇总(mysql常用语法)

1.连接数据库:连接本地数据库:mysql-uroot-p连接远程数据库:mysql-h192.169.22.199-uroot-p退出数据库:exit...

MYSQL——CAST()函数的用法(mysql中case)

语法为:Cast(字段名as转换的类型),其中类型可以为:CHAR[(N)]字符型DATE日期型DATETIME日期和时间型...

MySQL存储引擎背后的真相:为何InnoDB并非所有场景的最佳选择

MySQL存储引擎背后的真相:为何InnoDB并非所有场景的最佳选择引言部分你是否遇到过这样的情况:明明已经按照最佳实践选择了MySQL的InnoDB引擎,却发现某些查询依然缓慢得令人沮丧?或者当你的...

MySQL 表分区?涨知识了(mysql数据表分区)

1.什么是表分区...

《MySQL必知必会》_笔记08(mysql必知必会mobi)

第19章插入数据一、数据插入概述INSERT语句用于向数据库表中插入(添加)数据,是SQL中常用的数据操作语句之一。它可以用多种方式使用,包括插入完整的行、插入行的一部分、插入多行以及插入某些查询的...

当 SQL Server(mssql-jdbc) 遇上 BigDecimal → 精度丢失,真坑!

开心一刻  中午和哥们一起喝茶  哥们说道:晚上喝酒去啊...

MYSQL有哪些数据类型(mysql有哪些数据类型,有哪些运算符)

整理下以便查阅,还想吐槽下:这头条怎么就不能给文章分类呢?整数类型...

使用MySQL分区的注意事项(使用mysql分区的注意事项有哪些)

MySQL分区是将一个表分解成多个区块进行操作和保存,从而降低每次操作的数据量,提高性能。从逻辑上看,只有一个表,但物理上这个表可能由多个物理分区组成,每个分区都是一个独立的对象,可以进行独立处理。...

取消回复欢迎 发表评论: