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

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

zhezhongyun 2025-07-15 02:06 2 浏览

时间,是状态栏必不可少的空间之一。至于它的重要性和“电量”、“信号”相比,哪个更重要。就由用户自行判断了!

(什么?你说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鑫视界”。

本文结束,谢谢阅读!

相关推荐

EU Said to Accept a 10% U.S. Universal Tariff while Seeking Exemptions for Key Sectors

TMTPOST--TheEuropeanUnionmaymakeconcessionstosecureexemptionsfromtariffsonkeysectors...

抖音品质建设 - iOS启动优化《实战篇》

前言启动是App给用户的第一印象,启动越慢,用户流失的概率就越高,良好的启动速度是用户体验不可缺少的一环。启动优化涉及到的知识点非常多,面也很广,一篇文章难以包含全部,所以拆分成两部分:原理和实战...

荷兰引进美国诗人阿曼达·戈尔曼诗作,因译者肤色遭抵制

记者|刘亚光阿曼达在拜登就职典礼上朗诵诗歌。图源:PatrickSemansky/AssociatedPress阿曼达·戈尔曼(AmandaGorman)出生于1998年,自小患有语言障碍,...

EU and U.S. Upbeat on Trade Deal Ahead of July Deadline

TMTPOST--TheEuropeanUnionandtheUnitedStatesseemupbeatontheirtradeagreementtoavoidtr...

“过期食品”英文怎么说?(过期食品)

在购买食品时,我们都会特别留意一下食物的保质期有多久,是否新鲜,以免买到过期的商品。TheafternoonteaspreadatThePeninsulaBoutiqueandCaf...

世界首富撩妹露骨短信遭曝光 网友评论亮了

原标题:世界首富如何撩妹?亚马逊创始人贝索斯给情妇的露骨短信曝光这周最大的一个瓜,可能就是亚马逊首席执行官杰夫·贝佐斯(JeffBezos)与妻子麦肯齐(MacKenzie)离婚的惊人消息。紧接...

征收熊孩子“尖叫费”不合理?店主回怼网友

爱尔兰一家很受欢迎的咖啡馆要收“孩童尖叫费”,网友们。。。爱尔兰一咖啡店店主5月4日在脸书发帖,表示要向带有吵闹孩童的顾客多收15%的额外费用,引发了大批网友的议论。原贴内容如下:图viaFaceb...

Rationality, objectivity and pragmatism win the day in Geneva to benefit of all

ApressbriefingisheldbytheChinesesidefollowingtheChina-UShigh-levelmeetingoneconomica...

Dify「模板转换」节点终极指南:动态文本生成进阶技巧(附代码)Jinja2引擎解析|6大应用场景实战

这篇文章是关于Dify「模板转换」节点的终极指南,解析了基于Jinja2模板引擎的动态文本生成技巧,涵盖多源文本整合、知识检索结构化、动态API构建及个性化内容生成等六大应用场景,助力开发者高效利用模...

微软 Edge 浏览器 96.0.4664.93 稳定版发布:修复大量安全问题

IT之家12月12日消息,据外媒mspoweruser消息,微软12月11日为Edge浏览器推出了96.0.4664.93稳定版。该版本没有增加新功能,而是修复了大量漏洞,...

HarmonyOS NEXT仓颉开发语言实战案例:健身App

各位好,今日分享一个健身app的首页:这个页面看起比之前的案例要稍微复杂一些,主要在于顶部部分,有重叠的背景,还有偏移的部分。重叠布局可以使用Stack容器实现,超出容器范围的偏移可以使用负数间距来实...

如果使用vue3.0实现一个modal,你会怎么设计?

这是个很好的问题!设计一个Vue3.0Modal时,我建议按照可复用、高扩展、简洁的原则来实现。下面我给你一个清晰的设计思路,涵盖组件拆分、使用方式以及Vue3中特性(如Telepor...

在进行APP切图的前,我们需要做什么?

切图是个技术活,小伙伴们千万不能忽视切图的重要性噢,前文介绍了设计的七大元素,那么我们现在来看看在切图之前,我们需要做什么呢?。1、和客户端的技术沟通好用不同的框架来实现的时候,图会有不一样的切法。...

独立开发问题记录-margin塌陷(独立提出历史问题)

一、概述往事如风,一周就过去了。上周在Figma里指点江山,这周在前端代码里卑微搬砖。回想上周,在Figma中排列组合,并且精确到1像素。每设计出一个页面,成就感就蹭蹭往上涨。没想到还没沾沾自喜多久,...

循序渐进Vue+Element 前端应用开发(8)—树列表组件的使用

在我前面随笔《循序渐进VUE+Element前端应用开发(6)---常规Element界面组件的使用》里面曾经介绍过一些常规的界面组件的处理,主要介绍到单文本输入框、多文本框、下拉列表,以及按钮...