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

devtools/2024/10/22 12:29:43/

前言

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

  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)

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

在这里插入图片描述


http://www.ppmy.cn/devtools/104661.html

相关文章

JavaSE-递归法解决二分查找、快速排序

704. 二分查找https://leetcode.cn/problems/binary-search/ package demo;public class BinarySearch {public static void main(String[] args) {BinarySearch brnew BinarySearch();System.out.println(br.search(new int[]{1, 2, 3, 4, 5, 6, 7, 8, 9}, 8));}public int s…

【王树森】Few-Shot Learning小样本学习 (1/3): 基本概念(个人向笔记)

前言 下面是犰狳和穿山甲的一些图片。现在要你判断右边给定的图片是犰狳和穿山甲。我相信应该不知道犰狳和穿山甲长啥样,但是在看了左边的 Support Set 之后,你就有能力从两者之间辨别出来。既然人可以通过这四张图片分辨出犰狳和穿山甲。那么计算机能不…

华为设备默认密码

‌华为设备的默认密码因设备类型和型号不同而有所差异。以下是一些常见华为设备的默认密码: ‌网络设备‌: ‌华为路由器(型号:华为HG8245H):默认用户名是root,默认密码是admin。‌1‌华为交换…

c++140namespace和ioterm

c语言只有一个全局定义域 那么可能会调错函数&#xff0c;调 错定义域 #include"iostream" using namespace std;//iostream 没有引入标准的std,需要手工写 //如果不写using namespace 需要引入std void main() {std::cout << "using test" <<…

仿BOSS招聘系统开发:构建高效、智能的在线招聘平台

在数字化时代&#xff0c;招聘行业正经历着前所未有的变革。BOSS直聘作为国内领先的招聘平台&#xff0c;以其高效的匹配机制、丰富的职位信息和便捷的用户体验&#xff0c;赢得了广泛的市场认可。本文将探讨如何开发一个仿照BOSS招聘系统的在线招聘平台&#xff0c;旨在为企业…

LVGL 控件之矩阵按钮(lv_buttonmatrix)

目录 一、矩阵按键1、组成2、创建矩阵3、按钮宽度4、按键属性5、按钮互斥6、按钮文本重着色7、按钮矩阵部件的事件8、API 函数二、例程 一、矩阵按键 1、组成 按钮矩阵部件由两个部分组成&#xff1a;主体背景和按钮&#xff0c;示意图如下&#xff1a; LV_PART_MAIN&#xf…

使用 OpenCV 组合和缩放多张图像

在图像处理领域&#xff0c;我们经常需要将多张小图像组合成一张大图。例如&#xff0c;将多张图像按一定布局排列在一起&#xff0c;或者创建一个缩略图画廊。在这篇博客中&#xff0c;我将向你展示如何使用 Python 的 OpenCV 库来完成这一任务。 代码 下面是一段完整的 Pyt…

安美数字酒店宽带运营系统-任意文件读取

漏洞描述&#xff1a; 安美数字酒店宽带运营系统 weather.php 接口存在任意文件读取漏洞&#xff0c;未经身份验证攻击者可通过该漏洞读取系统重要文件&#xff08;如数据库配置文件、系统配置文件&#xff09;、数据库配置文件等等&#xff0c;导致网站处于极度不安全状态 fo…