鸿蒙launcher浅析

鸿蒙launcher浅析

鸿蒙launcher源码下载

下载地址如下:
https://gitee.com/openharmony/applications_launcher

鸿蒙launcher模块

下载页面已经有相关文件结构的介绍了

使用鸿蒙编辑器DevEco Studio打开,我使用的版本是渠道版本。官网版本应该也可以,不影响阅读源码。

结构如图

  • product 业务形态层:区分不同产品、不同屏幕的各形态桌面,含有桌面窗口、个性化业务,组件的配置,以及个性化资源包。

  • feature 公共特性层:抽象的公共特性组件集合,可以被各桌面形态引用。

  • common 公共能力层:基础能力集,每个桌面形态都必须依赖的模块。

    /applications/standard/launcher/
    ├── common # 公共能力层目录
    ├── docs # 开发指南
    ├── feature # 公共特性层目录
    │ └── appcenter # 应用中心
    │ └── bigfolder # 智能文件夹
    │ ├── form # 桌面卡片管理功能
    │ ├── gesturenavigation # 手势导航
    │ ├── pagedesktop # 工作区
    │ ├── recents # 最近任务
    │ ├── settings # 桌面设置
    │ ├── smartdock # dock工具栏
    ├── product # 业务形态层目录
    ├── signature # 签名证书

launcher和普通的应用ui展示的区别

之前做过Android launcher,所以对鸿蒙的launcher挺好奇的,看看和普通鸿蒙应用有何区别

新建demo,ui加载是在此生命周期onWindowStageCreate,设置的通过
windowStage.loadContent设置

ts 复制代码
export default class EntryAbility extends UIAbility{

	onWindowStageCreate(windowStage: window.WindowStage): void {

    	windowStage.loadContent('pages/Index', (err) => {
   
    	});
  	}
}

product/phone目录下

launcher的ui加载 是这样的,使用的不是UIAbility,而是没见过的ServiceExtension.,如此,添加的UI

ts 复制代码
export default class MainAbility extends ServiceExtension{
	
  	onCreate(want: Want): void {
		....
    	this.initLauncher();
 	 }
 	 
 	 async initLauncher(): Promise<void> {
 	 	....
   		// create Launcher entry view
    	windowManager.createWindow(globalThis.desktopContext, windowManager.DESKTOP_WINDOW_NAME,
     		windowManager.DESKTOP_RANK, 'pages/' + windowManager.DESKTOP_WINDOW_NAME, true, registerWinEvent);
		....
	}

}
相关推荐
zhanshuo13 分钟前
构建可扩展的状态系统:基于 ArkTS 的模块化状态管理设计与实现
harmonyos
zhanshuo18 分钟前
ArkTS 模块通信全解析:用事件总线实现页面消息联动
harmonyos
codefish7985 小时前
鸿蒙开发学习之路:从入门到实践的全面指南
harmonyos
yrjw11 小时前
一款基于react-native harmonyOS 封装的【文档】文件预览查看开源库(基于Harmony 原生文件预览服务进行封装)
harmonyos
小徐不徐说18 小时前
每日一算:华为-批萨分配问题
数据结构·c++·算法·leetcode·华为·动态规划·后端开发
搜狐技术产品小编20231 天前
搜狐新闻直播间适配HarmonyOs实现点赞动画
华为·harmonyos
zhanshuo1 天前
ArkUI 玩转水平滑动视图:超全实战教程与项目应用解析
harmonyos·arkui
zhanshuo1 天前
ArkUI Canvas 实战:快速绘制柱状图图表组件
harmonyos·arkui
zhanshuo2 天前
手把手教你用 ArkUI 写出高性能分页列表:List + onScroll 实战解析
harmonyos
zhanshuo2 天前
深入解析 ArkUI 触摸事件机制:从点击到滑动的开发全流程
harmonyos