鸿蒙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);
		....
	}

}
相关推荐
一起养小猫21 分钟前
Flutter for OpenHarmony 实战:网络监控登录系统完整开发指南
网络·flutter·harmonyos
一起养小猫23 分钟前
Flutter for OpenHarmony 进阶:手势识别与碰撞检测算法深度解析
算法·flutter·harmonyos
小哥Mark23 分钟前
一篇验证Flutter框架核心接口在鸿蒙应用中的可能性
flutter·华为·harmonyos
飞羽殇情37 分钟前
基于React Native鸿蒙跨平台实现的电商客服咨询系统,支持在线客服、AI助手和电话咨询三种方式,并实现了问题分类、智能快捷回复等功能
react native·react.js·华为·harmonyos
酣大智42 分钟前
FTP--文件传输协议
运维·网络·网络协议·tcp/ip·华为
一起养小猫1 小时前
Flutter for OpenHarmony 实战:科学计算器完整开发指南
android·前端·flutter·游戏·harmonyos
果粒蹬i1 小时前
React Native鸿蒙跨平台实战:从项目初始化到开源交付完整指南
react native·开源·harmonyos
一起养小猫1 小时前
Flutter for OpenHarmony 实战:独木桥问题完整开发指南
flutter·harmonyos
weixin_443290691 小时前
【华为HCIA路由交换认证指南】第五章 静态路由
网络·华为·智能路由器
weixin_443290691 小时前
【华为HCIA路由交换认证指南】第六章 动态路由
网络·华为·智能路由器