DevEco Studio
DevEco Studio
简介
DevEco Studio (获取工具请单击链接下载)是基于 IntelliJ IDEA Community 开源版本打造,为运行在 HarmonyOS 系统上的应用和服务(以下简称应用/服务)提供一站式的开发平台。
作为一款开发工具,除了具有基本的代码开发、编译构建及调测等功能外,DevEco Studio 还具有如下特点:
- 高效智能代码编辑:支持 ArkTS、JS、C/C++ 等语言的代码高亮、代码智能补齐、代码错误检查、代码自动跳转、代码格式化、代码查找等功能,提升代码编写效率。
- 多端双向实时预览:支持 UI 界面代码的双向预览、实时预览、动态预览、组件预览以及多端设备预览,便于快速查看代码运行效果。
- 多端设备模拟仿真:提供 HarmonyOS 本地模拟器,支持 Phone 等设备的模拟仿真,便捷获取调试环境。
- DevEco Profiler 性能调优:提供实时监控能力和场景化调优模板,便于全方位的设备资源监测,采集数据覆盖多个维度,为开发者带来高效、直通代码行的调优体验。
开始
安装 DevEco Studio
为保证 DevEco Studio 正常运行,建议电脑配置满足如下要求:
- 操作系统:Windows 10 64 位、Windows 11 64 位
- 内存:16 GB 及以上
- 硬盘:100 GB 及以上
- 分辨率:1280*800 像素及以上
下载完成后,双击下载的 “devecostudio-xxxx.exe”,进入 DevEco Studio 安装向导。在如下界面选择安装路径,默认安装于 C:\Program Files
路径下,也可以单击 浏览(B)... 指定其他安装路径,然后单击 Next。
在如下安装选项界面勾选 DevEco Studio 后,单击 Next,直至安装完成。
安装完成后,单击 Finish 完成安装。
说明
- DevEco Studio 提供开箱即用的开发体验,将 HarmonyOS SDK、Node.js、Hvigor、OHPM、模拟器平台等进行合一打包,简化 DevEco Studio 安装配置流程。
- HarmonyOS SDK 已嵌入 DevEco Studio 中,无需额外下载配置。HarmonyOS SDK可以在 DevEco Studio 安装位置下 DevEco Studio\sdk 目录中查看。如需进行 OpenHarmony 应用开发,可通过 Settings > OpenHarmony SDK 页签下载 OpenHarmony SDK。
安装完成后,启动 DevEco Studio,可以在欢迎页面单击 Diagnose 进行诊断,识别开发环境是否完备。如果已经打开了工程开发界面,也可以在菜单栏单击 Help > Diagnostic Tools > Diagnose Development Environment 进行诊断。
DevEco Studio 开发环境诊断项包括电脑的配置、网络的连通情况、依赖的工具是否安装等。如果检测结果为未通过,请根据检查项的描述和修复建议进行处理。
构建第一个 ArkTS 应用
创建 ArkTS 工程
若首次打开 DevEco Studio,请点击 Create Project 创建工程。如果已经打开了一个工程,请在菜单栏选择 File > New > Create Project 来创建一个新工程。
选择 Application 应用开发(本文以应用开发为例,Atomic Service 对应为元服务开发),选择模板 “Empty Ability”,点击 Next 进行下一步配置。
进入配置工程界面,Compatible SDK 选择 “5.0.0(12)”,其他参数保持默认设置即可。
点击 Finish,工具会自动生成示例代码和相关资源,等待工程创建完成。
工程创建完成后,点击右上角的 Project Structure,在 Signing Configs 页面点击 Sign In,进行自动签名配置:
会跳转到浏览器进行登录,登录后进行确认,然后在 DevEco Studio 中点击 Agree:
目录结构
- AppScope > app.json5:应用的全局配置信息,详见 app.json5 配置文件。
- entry:HarmonyOS 工程模块,编译构建生成一个 HAP 包。
- src > main > ets:用于存放 ArkTS 源码。
- src > main > ets > entryability:应用/服务的入口。
- src > main > ets > entrybackupability:应用提供扩展的备份恢复能力。
- src > main > ets > pages:应用/服务包含的页面。
- src > main > resources:用于存放应用/服务所用到的资源文件,如图形、多媒体、字符串、布局文件等。关于资源文件,详见资源分类与访问。
- src > main > module.json5:模块配置文件。主要包含 HAP 包的配置信息、应用/服务在具体设备上的配置信息以及应用/服务的全局配置信息。具体的配置文件说明,详见 module.json5 配置文件。
- build-profile.json5:当前的模块信息 、编译信息配置项,包括 buildOption、targets 配置等。
- hvigorfile.ts:模块级编译构建任务脚本。
- obfuscation-rules.txt:混淆规则文件。混淆开启后,在使用 Release 模式进行编译时,会对代码进行编译、混淆及压缩处理,保护代码资产。详见开启代码混淆。
- oh-package.json5:用来描述包名、版本、入口文件(类型声明文件)和依赖项等信息。
- oh_modules:用于存放三方库依赖信息。
- build-profile.json5:工程级配置信息,包括签名 signingConfigs、产品配置 products 等。其中 products 中可配置当前运行环境,默认为 HarmonyOS。
- hvigorfile.ts:工程级编译构建任务脚本。
- oh-package.json5:主要用来描述全局配置,如:依赖覆盖(overrides)、依赖关系重写(overrideDependencyMap)和参数化配置(parameterFile)等。
构建第一个页面
使用文本组件。在 “Project” 窗口,点击 “entry > src > main > ets > pages”,打开 “Index.ets” 文件,进行页面的编写。
// Index.ets
@Entry
@Component
struct Index {
@State message: string = 'Hello World'
build() {
Row() {
Column() {
Text(this.message)
.fontSize(50)
.fontWeight(FontWeight.Bold)
}
.width('100%')
}
.height('100%')
}
}
添加按钮。在默认页面基础上,添加一个 Button 组件,作为按钮响应用户点击,从而实现跳转到另一个页面。
// Index.ets
@Entry
@Component
struct Index {
@State message: string = 'Hello World'
build() {
Row() {
Column() {
Text(this.message)
.fontSize(50)
.fontWeight(FontWeight.Bold)
// 添加按钮,以响应用户点击
Button() {
Text('Next')
.fontSize(30)
.fontWeight(FontWeight.Bold)
}
.type(ButtonType.Capsule)
.margin({
top: 20
})
.backgroundColor('#0D9FFB')
.width('40%')
.height('5%')
}
.width('100%')
}
.height('100%')
}
}
在编辑窗口右上角的侧边工具栏,点击 Previewer,打开预览器。第一个页面效果如下图所示:
构建第二个页面
新建第二个页面文件。在 “Project” 窗口,打开 “entry > src > main > ets”,右键点击 “pages” 文件夹,选择 “New > Page > Empty Page”,Page Name 为 “Second”,点击 “Finish” 完成第二个页面的创建。
会自动在 “entry > src > main > resources > base > profile” 的 main_pages.json
文件中的 “src” 下配置第二个页面的路由 “pages/Second”:
{
"src": [
"pages/Index",
"pages/Second"
]
}
可以看到文件目录结构如下:
参照第一个页面,在第二个页面添加 Text 组件、Button 组件等,并设置其样式。
// Second.ets
@Entry
@Component
struct Second {
@State message: string = 'Hi there'
build() {
Row() {
Column() {
Text(this.message)
.fontSize(50)
.fontWeight(FontWeight.Bold)
Button() {
Text('Back')
.fontSize(25)
.fontWeight(FontWeight.Bold)
}
.type(ButtonType.Capsule)
.margin({
top: 20
})
.backgroundColor('#0D9FFB')
.width('40%')
.height('5%')
}
.width('100%')
}
.height('100%')
}
}
实现页面间的跳转
在第一个页面中,跳转按钮绑定 onClick 事件,点击按钮时跳转到第二页。“Index.ets” 文件的示例如下:
// Index.ets
// 导入页面路由模块
import { router } from '@kit.ArkUI';
import { BusinessError } from '@kit.BasicServicesKit';
@Entry
@Component
struct Index {
@State message: string = 'Hello World'
build() {
Row() {
Column() {
Text(this.message)
.fontSize(50)
.fontWeight(FontWeight.Bold)
// 添加按钮,以响应用户点击
Button() {
Text('Next')
.fontSize(30)
.fontWeight(FontWeight.Bold)
}
.type(ButtonType.Capsule)
.margin({
top: 20
})
.backgroundColor('#0D9FFB')
.width('40%')
.height('5%')
// 跳转按钮绑定onClick事件,点击时跳转到第二页
.onClick(() => {
console.info(`Succeeded in clicking the 'Next' button.`)
// 跳转到第二页
router.pushUrl({ url: 'pages/Second' }).then(() => {
console.info('Succeeded in jumping to the second page.')
}).catch((err: BusinessError) => {
console.error(`Failed to jump to the second page. Code is ${err.code}, message is ${err.message}`)
})
})
}
.width('100%')
}
.height('100%')
}
}
在第二个页面中,返回按钮绑定 onClick 事件,点击按钮时返回到第一页。“Second.ets” 文件的示例如下:
// Second.ets
// 导入页面路由模块
import { router } from '@kit.ArkUI';
import { BusinessError } from '@kit.BasicServicesKit';
@Entry
@Component
struct Second {
@State message: string = 'Hi there'
build() {
Row() {
Column() {
Text(this.message)
.fontSize(50)
.fontWeight(FontWeight.Bold)
Button() {
Text('Back')
.fontSize(25)
.fontWeight(FontWeight.Bold)
}
.type(ButtonType.Capsule)
.margin({
top: 20
})
.backgroundColor('#0D9FFB')
.width('40%')
.height('5%')
// 返回按钮绑定onClick事件,点击按钮时返回到第一页
.onClick(() => {
console.info(`Succeeded in clicking the 'Back' button.`)
try {
// 返回第一页
router.back()
console.info('Succeeded in returning to the first page.')
} catch (err) {
let code = (err as BusinessError).code;
let message = (err as BusinessError).message;
console.error(`Failed to return to the first page. Code is ${code}, message is ${message}`)
}
})
}
.width('100%')
}
.height('100%')
}
}
打开 Index.ets 文件,点击预览器中的 按钮进行刷新。效果如下图所示: