当前位置: 首页 > news >正文

【 OpenHarmony 系统应用源码魔改 】-- Launcher 之「桌面布局定制」

前言

阅读本篇文章之前,有几个需要说明一下:

  1. 调试设备:平板,如果你是开发者手机,一样可以加 Log 调试,源码仍然是手机和平板一起分析;
  2. 文章中的 Log 信息所显示的数值可能跟你的设备不一样,以你调试的数据为准。
  3. 装个逼:目前好像 OH 社区或者其它开发者还没有针对 OH 的系统应用,比如 Launcher 写过非常深入的源码解析类文章,所以此类文章,仅供大家参考学习,如转载或引用,请标明出处
  4. 定制章节会直接定位到修改的地方,如果你不仅想知道怎么改,也想知道为什么这么改,正所谓:知其然知其所以然,探其深方得真谛!
    可以看看 "【 OpenHarmony 系统应用源码解析 】-- Launcher 桌面布局 " 这篇文章。

定制需求

  1. 行数:3
  2. 列数:7

如果你看过 "【 OpenHarmony 系统应用源码解析 】-- Launcher 桌面布局 " 这篇文章的话,应该会清除,Launcher 布局的行、列数是算出来的。

算法:

  1. 列数 = ~~(屏幕宽度 + 图标间距)/ (图标大小 + 图标间距)
  2. 行数 = ~~(可用高度 + 平均列间距)/ (图标大小 + 平均列间距)

修改代码前,我们先看下默认 Launcher 效果图(平板):

在这里插入图片描述

"【 OpenHarmony 系统应用源码解析 】-- Launcher 桌面布局 " 文章中,我们已经分析过源码,并且加了 Log 展示了很多数据,例如:

let column = ~~((realWidth + minGutter) / (itemSize + minGutter));

我们看下平板的数据:

pid-1360              I     @@@ pepsimaxin : 桌面布局边距 ==> margin = 82
pid-1360              I     @@@ pepsimaxin : 屏幕宽度 ==> this.mScreenWidth = 1280
com.ohos.launcher     D     @@@ pepsimaxin : realWidth = 1116, minGutter = 6, itemSize = 96
com.ohos.launcher     D     @@@ pepsimaxin : column = 11

OK,现在我们希望把列数改成:7列,那么:

  1. realWidth:我们不会动
  2. itemSize:图标大小,我们暂时也不动

那么显而易见了,我们只需要修改 minGutter(网格间距)即可!

所以修改成多少呢?-- 这是个基础数学计算问题,不用我教你了。

我们就拿平板为例:

(1116 + 6) / (96 + 6)= 11我们只需要保证:
(1116 + minGutter) / (96 + minGutter) = 7.00 ~ 7.99 之间即可(因为是向下取整)我比较懒,直接让 GPT 给我算了下:
minGutter 的取值范围:[49.9 ~ 74],我们取个整:[50 ~ 74]

现在我们定位到源码里面,看如何修改:

📄 common/src/main/ets/default/viewmodel/LayoutViewModel.tscalculateDesktop(): any {...let itemSize = this.mLauncherLayoutStyleConfig.mAppItemSize;// 网格间距let minGutter = this.mLauncherLayoutStyleConfig.mGridGutter;let column = ~~((realWidth + minGutter) / (itemSize + minGutter));let userWidth = (realWidth + minGutter - (itemSize + minGutter) * column);let gutter = (userWidth / (column - 1)) + minGutter;let row = ~~((realHeight + gutter) / (itemSize + gutter));...}

而 minGutter 从哪读取的,就不用我说了吧?

// Phone
mGridGutter = PhonePresetStyleConstants.DEFAULT_APP_LAYOUT_MIN_GUTTER;
static readonly DEFAULT_APP_LAYOUT_MIN_GUTTER = 5;// Pad
mGridGutter = PadPresetStyleConstants.DEFAULT_APP_LAYOUT_MIN_GUTTER;
static readonly DEFAULT_APP_LAYOUT_MIN_GUTTER = 6;

到这里就有两种改法:

  1. 要么去对应的 **PresetStyleConstants 里面改 DEFAULT_APP_LAYOUT_MIN_GUTTER 值;
  2. 要么暴力点,直接改:
let minGutter = [50 ~ 74] 随便取一个值

另外,在 "【 OpenHarmony 系统应用源码解析 】-- Launcher 桌面布局 " 文章中我们也讲过,计算出来的 Column 和 Row,都是要传入 this.updateGrid(row, column) 方法,更新网格布局配置的。

所以?你猜我要干什么?更暴力的改法就是:

我不管你怎么算,直接 this.updateGrid(3, 7)

算了,不教你使坏了,我们直接看下修改后的效果:

在这里插入图片描述

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 012 MPLS技术在企业网络中的应用
  • 深度学习100问42:什么是GNMT
  • 每天五分钟计算机视觉:人脸识别网络FaceNet
  • adb大全指令(持续更新)
  • python 安装
  • LabVIEW水泵机组监控系统
  • 智能体与在线实用工具:协同并进,提升生活效率
  • 获取指定类的所有成员属性上的指定注解的属性值
  • 大数据技术之HBase 快速入门(2)
  • Parallels Desktop 19发布,无需重启即可在 Mac 上运行 Windows
  • VSCode设置复制 Ctrl+D想下复制
  • 知识社区的小程序源码系统 界面支持万能DIY装修 带源代码包以及搭建部署教程
  • 黑神话悟空-提高画质、防卡顿、修复等各种功能、各种CT表、各种存档、武器包、人物、装备替换等193+MOD合集
  • 汽车乘客热舒适度大挑战,如何利用仿真技术提高汽车环境舒适度
  • oracle11g常用基本字典和动态性能字典
  • 10个确保微服务与容器安全的最佳实践
  • 2019.2.20 c++ 知识梳理
  • 230. Kth Smallest Element in a BST
  • android高仿小视频、应用锁、3种存储库、QQ小红点动画、仿支付宝图表等源码...
  • Angular2开发踩坑系列-生产环境编译
  • co模块的前端实现
  • Fabric架构演变之路
  • flask接收请求并推入栈
  • gf框架之分页模块(五) - 自定义分页
  • JavaScript设计模式系列一:工厂模式
  • miaov-React 最佳入门
  • PHP 程序员也能做的 Java 开发 30分钟使用 netty 轻松打造一个高性能 websocket 服务...
  • php面试题 汇集2
  • Python - 闭包Closure
  • 多线程 start 和 run 方法到底有什么区别?
  • - 概述 - 《设计模式(极简c++版)》
  • 如何设计一个微型分布式架构?
  • 软件开发学习的5大技巧,你知道吗?
  • 设计模式走一遍---观察者模式
  • MPAndroidChart 教程:Y轴 YAxis
  • ​ssh-keyscan命令--Linux命令应用大词典729个命令解读
  • #define MODIFY_REG(REG, CLEARMASK, SETMASK)
  • #Linux(Source Insight安装及工程建立)
  • #pragma multi_compile #pragma shader_feature
  • $.ajax()方法详解
  • $GOPATH/go.mod exists but should not goland
  • (aiohttp-asyncio-FFmpeg-Docker-SRS)实现异步摄像头转码服务器
  • (LeetCode C++)盛最多水的容器
  • (M)unity2D敌人的创建、人物属性设置,遇敌掉血
  • (Redis使用系列) Springboot 使用Redis+Session实现Session共享 ,简单的单点登录 五
  • (zt)基于Facebook和Flash平台的应用架构解析
  • (八)c52学习之旅-中断实验
  • (大众金融)SQL server面试题(1)-总销售量最少的3个型号的车及其总销售量
  • (第61天)多租户架构(CDB/PDB)
  • (二)构建dubbo分布式平台-平台功能导图
  • (二)七种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
  • (二十六)Java 数据结构
  • (分布式缓存)Redis持久化
  • (附源码)node.js知识分享网站 毕业设计 202038
  • (回溯) LeetCode 40. 组合总和II