Android13 Launcher3修改Workspace布局(layout)

2024-08-28 16:28

本文主要是介绍Android13 Launcher3修改Workspace布局(layout),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需求:Launcher 最基本的修改就是Workspace Hotseat AllApps的布局及出厂默认设置

修改原理:

res/xml/device_profiles.xml 图标的横竖排数量、图标大小、各种尺寸和间距主要是由device_profiles.xml这个配置文件来定义的。

DeviceProfile.java device_profiles.xml是由DeviceProfile.java来加载并计算得到布局所需要的各种size padding 等参数。

res/xml/default_workspace_6x3.xml 定义了系统默认(出厂设置)的桌面内容

Hotseat.java Hotseat ViewGroup的代码实现

修改步骤:

step1: 需要根据预览图来定义好放在Workpace/AllApps/Hotseat里的图标数量。

操作提示: 重名6_by_3,代表6行3列,复制并改名一份default_workspace_6x3.xml

<grid-option
launcher:name="6_by_3"
launcher:numRows="3"  //行数
launcher:numColumns="6" //列数
launcher:numSearchContainerColumns="3" 
launcher:numFolderRows="3" //文件夹行数
launcher:numFolderColumns="3"//文件夹列数
launcher:numHotseatIcons="5"//热座图标数量
launcher:hotseatColumnSpanLandscape="1"
launcher:numAllAppsColumns="6"//AllApps视图的列数
launcher:isScalable="true"
launcher:devicePaddingId="@xml/paddings_6x5"
launcher:dbFile="launcher_6_by_5.db"
launcher:defaultLayoutId="@xml/default_workspace_6x3"//默认配置文件
launcher:deviceCategory="tablet" >

step2:定义图标占用的Cell的大小,每个图标占用的位置叫做Cell(图标focused后的阴影部分),以下只注释几个关键的属性

<display-option
launcher:name="Tablet"
launcher:minWidthDps="900"
launcher:minHeightDps="820"
launcher:minCellHeight="120" //此处标注的是最小Cell的高度,为什么不是标注实际高度呢?
launcher:minCellWidth="102"//因为Cell是由Workspace的占用区域,根据图标数量和borderSpace边距大小算出的!
launcher:minCellHeightLandscape="104"//横屏布局用这个,其他同理
launcher:minCellWidthLandscape="120"
launcher:iconImageSize="64"//图标大小
launcher:iconTextSize="14"//文本大小
launcher:borderSpaceHorizontal="16"//水平方向Cell的边距
launcher:borderSpaceVertical="64"//垂直方向Cell的边距
launcher:borderSpaceLandscapeHorizontal="16"
launcher:borderSpaceLandscapeVertical="16"
launcher:horizontalMargin="54"
launcher:horizontalMarginLandscape="120"
launcher:allAppsCellWidth="96"
launcher:allAppsCellHeight="142"
launcher:allAppsCellWidthLandscape="126"
launcher:allAppsCellHeightLandscape="126"
launcher:allAppsIconSize="60"
launcher:allAppsIconTextSize="14"
launcher:allAppsBorderSpaceHorizontal="8"
launcher:allAppsBorderSpaceVertical="16"
launcher:allAppsBorderSpaceLandscape="16"
launcher:hotseatBorderSpace="29" //热座图标之间的边距
launcher:hotseatBorderSpaceLandscape="14"//横屏热座图标之间的边距
launcher:canBeDefault="true" />

修改Workspace的位置

step1: 在res/values/dimens.xml添加

<!--Kevin.Ye added start-->
<dimen name="workspace_padding_side">4dp</dimen>
<dimen name="workspace_padding_top">4dp</dimen>
<dimen name="workspace_padding_bottom">4dp</dimen>
<!--Kevin.Ye added end-->

step2:

在src/com/android/launcher3/config/FeatureFlags.java中定义FeatueFlag以兼容原生的代码

public static final boolean FIXED_WORKSPACE_PADDING = true;//adding for defining workspace padding

step3:DeviceProfile.java中添加定义

import com.android.launcher3.config.FeatureFlags;/*Kevin.Ye added start*/private int workspacePaddingTopPx = 50;private int workspacePaddingBottomPx = 50;private int workspacePaddingSidePx = 50;/*Kevin.Ye added end*/在构造函数的最后读取value//Kevin.Ye added startif(FeatureFlags.FIXED_WORKSPACE_PADDING) {workspacePaddingTopPx = res.getDimensionPixelSize(R.dimen.workspace_padding_top);workspacePaddingBottomPx = res.getDimensionPixelSize(R.dimen.workspace_padding_bottom);workspacePaddingSidePx = res.getDimensionPixelSize(R.dimen.workspace_padding_side);}//added end在updateWorkspacePadding函数中替换原来通过计算的方式得到的paddingprivate void updateWorkspacePadding() {Rect padding = workspacePadding;/*Kevin.Ye added for workspace position*/if(FeatureFlags.FIXED_WORKSPACE_PADDING) {if(isVerticalBarLayout()) {}else{padding.left = workspacePaddingSidePx;padding.right = workspacePaddingSidePx;padding.top = workspacePaddingTopPx;padding.bottom = workspacePaddingBottomPx;}insetPadding(workspacePadding, cellLayoutPaddingPx);return;}

通过调试发现,DeviceProfile并不是单例,因此需要把Resource传进来,每次调用都要重新获取resource里定义的padding值,

需要更改如下:

private void updateWorkspacePadding(Resources res) {Rect padding = workspacePadding;if (isVerticalBarLayout()) {padding.top = 0;padding.bottom = edgeMarginPx;if (isSeascape()) {padding.left = hotseatBarSizePx;padding.right = hotseatBarSidePaddingStartPx;} else {padding.left = hotseatBarSidePaddingStartPx;padding.right = hotseatBarSizePx;}} else {// Pad the bottom of the workspace with search/hotseat bar sizesif(FeatureFlags.STATIC_WORKSPACE_PADDING){//Kevin.Ye modifiedint workspacePaddingTopPx = res.getDimensionPixelSize(R.dimen.workspace_padding_top);int workspacePaddingBottomPx = res.getDimensionPixelSize(R.dimen.workspace_padding_bottom);int workspacePaddingSidePx = res.getDimensionPixelSize(R.dimen.workspace_padding_side);Log.d("profile","workspace padding top:"+workspacePaddingTopPx+" bottom:"+workspacePaddingBottomPx+" side:"+workspacePaddingSidePx);	padding.set(workspacePaddingSidePx,workspacePaddingTopPx,workspacePaddingSidePx,workspacePaddingBottomPx);}else{int hotseatTop = hotseatBarSizePx;int paddingBottom = hotseatTop + workspacePageIndicatorHeight+ workspaceBottomPadding - mWorkspacePageIndicatorOverlapWorkspace;int paddingTop = workspaceTopPadding + (isScalableGrid ? 0 : edgeMarginPx);int paddingSide = desiredWorkspaceHorizontalMarginPx;padding.set(paddingSide, paddingTop, paddingSide, paddingBottom);}}insetPadding(workspacePadding, cellLayoutPaddingPx);}

修改文字与图标之间的间隙

res/values-sw600dp/dimens.xml:39:    <dimen name="dynamic_grid_icon_drawable_padding">2px</dimen>

这篇关于Android13 Launcher3修改Workspace布局(layout)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1115285

相关文章

CSS3 最强二维布局系统之Grid 网格布局

《CSS3最强二维布局系统之Grid网格布局》CS3的Grid网格布局是目前最强的二维布局系统,可以同时对列和行进行处理,将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局,本文介... 深入学习 css3 目前最强大的布局系统 Grid 网格布局Grid 网格布局的基本认识Grid 网

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

MySQL修改密码的四种实现方式

《MySQL修改密码的四种实现方式》文章主要介绍了如何使用命令行工具修改MySQL密码,包括使用`setpassword`命令和`mysqladmin`命令,此外,还详细描述了忘记密码时的处理方法,包... 目录mysql修改密码四种方式一、set password命令二、使用mysqladmin三、修改u

使用Python在Excel中插入、修改、提取和删除超链接

《使用Python在Excel中插入、修改、提取和删除超链接》超链接是Excel中的常用功能,通过点击超链接可以快速跳转到外部网站、本地文件或工作表中的特定单元格,有效提升数据访问的效率和用户体验,这... 目录引言使用工具python在Excel中插入超链接Python修改Excel中的超链接Python

python修改字符串值的三种方法

《python修改字符串值的三种方法》本文主要介绍了python修改字符串值的三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录第一种方法:第二种方法:第三种方法:在python中,字符串对象是不可变类型,所以我们没办法直接

Mysql8.0修改配置文件my.ini的坑及解决

《Mysql8.0修改配置文件my.ini的坑及解决》使用记事本直接编辑my.ini文件保存后,可能会导致MySQL无法启动,因为MySQL会以ANSI编码读取该文件,解决方法是使用Notepad++... 目录Myhttp://www.chinasem.cnsql8.0修改配置文件my.ini的坑出现的问题

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚: