HarmonyOS开发环境搭建

一 鸿蒙简介:

1.1 HarmonyOS是华为自研的一款分布式操作系统,兼容Android,但又区别Android,不仅仅定位于手机系统。更侧重于万物物联和智能终端,目前已更新到4.0版本。

1.2 HarmonyOS软件编程语言是ArkTS,是基于TypeScript的拓展,而TypeScript又是JavaScript的拓展,所以有过JavaScript经验会更容易些。

e758bcf1c81e4a05803554c1b2944c52.png

二 HarmonyOS编程环境搭建

2.1 HarmonyOS软件编程工具是DevEco Studio,下载官网链接:https://developer.harmonyos.com/cn/develop/deveco-studio

25d6cf4c5e3b45afaca3d4364f986144.png

2.2 下载后点击安装

544dc3ad0481455c8216a0cadabc0ed1.png

2.3 安装好运行

5fa65d6024014e9c8aff423d928fff16.png

2.4  点击同意进入配置

df87eed0b4134d24b94c81e0074f4fb9.png

2.5 进入DevEco Studio配置页面,首先需要进行基础配置,包括Node.js与Ohpm的安装路径设置,选择从华为镜像下载至合适的路径

5a07748f6026442e9418f252e10ecee0.png

2.6 单击'Next'进入SDK配置,设置为合适的路径

e174fe9366d740059ba3f8c6da08117d.png

2.7 点击'Next'后会显示'SDK License Agreement',阅读相关协议后,勾选'Accept'。

c7b828d08b29472f9f8d0b2b956fc734.png

2.8 单击‘Next’进入配置预览页,在这里进行配置项的确认。

14b12ba2cf4248f9be720e1537b30367.png

 2.9 确认完成后,单击'Next',进入下一步。

da3aeae98b064047b461edd2531a1614.png

2.10 等待配置自动下载完成,完成后,单击'Finish',IDE会进入欢迎页,我们也就成功配置好了开发环境。9808182e08bd4bfc933009088a1b9b74.png

三 创建项目

3.1 在欢迎页中单击Create Project,进入项目创建页面。

f6d0bd1a56904723a8054b67c1fcbab1.png

3.2 选择‘Application’,然后选择‘Empty Ability’,单击‘Next’进入工程配置页。

49943d1a9c1048f3b0ae67af06de6e39.png

 3.3 配置页中,详细信息如下:

  • Project name是开发者可以自行设置的项目名称,这里根据自己选择修改为自己项目名称。
  • Bundle name是包名称,默认情况下应用ID也会使用该名称,应用发布时对应的ID需要保持一致。
  • Save location为工程保存路径,建议用户自行设置相应位置。
  • Compile SDK是编译的API版本,这里默认选择API9。
  • Model选择Stage模型,其他保持默认即可。
  • 然后单击“Finish”完成工程创建,等待工程同步完成。

3.4  进入IDE后,可以看到根大部分编辑器差不多。整个IDE的界面大致上可以分为四个部分,分别是代码编辑区、通知栏、工程目录区以及预览区。

d944e593d5cb4ded8aef877bea262f43.png

3.5 单击右上角Previewer,可以预览相应的文件UI展示效果。 

e68211318d984bb2902c4ac1cb11f730.png

四 调试

4.1  单击顶部工具栏Tools>Device Manager。

408fa10d4c0f4393a6e6d79c9bda0c5b.png

4.2 选择Local Emulator,设置合适的Local Emulator Location存储地址,然后单击’+New Emulator’

5d94af2fdfc84150bfe8b7551da2d761.png

4.3 选择Huawei_Phone手机模拟器,单击'Next',进入模拟器系统下载页。

c23e19e6b968493dbcbfe08a17d9f7a1.png

4.4  选择下载api9的系统镜像,然后单击'Next’,等待下载完成。

0652032cd82d4ed6814767224873b130.png

4.5  下载完成后,在Local Emulator页面中会出现创建的手机模拟器,点击Actions按钮,就能够启动模拟器。

9e4ad3991b4948e8a035d8720eb6f1d7.png

4.6 模拟器启动后,点击上方启动按钮,将Hello World工程运行到模拟器上。

6d7d4645b13b4d5e992e26990c55b87d.png

4.7 IDE构建完成后,即可在模拟器上看到运行效果,我们也就完成了Hello World工程在模拟器上的运行。

b7f1923b4fde41ca89b7d012d7b14b28.png

五 工程介绍

5.1 工程目录

a94ad8010fc4460c8086530a5e28a413.png

  • AppScope中存放应用全局所需要的资源文件。
  • entry是应用的主模块,存放HarmonyOS应用的代码、资源等。
  • oh_modules是工程的依赖包,存放工程依赖的源文件。
  • build-profile.json5是工程级配置信息,包括签名、产品配置等。
  • hvigorfile.ts是工程级编译构建任务脚本,hvigor是基于任务管理机制实现的一款全新的自动化构建工具,主要提供任务注册编排,工程模型管理、配置管理等核心能力。
  • oh-package.json5是工程级依赖配置文件,用于记录引入包的配置信息。

5.2 模块目录

bef0b3eee99d4a048cf0c58af23ebe88.png

entry>src目录中主要包含总的main文件夹,单元测试目录ohosTest,以及模块级的配置文件。

  • main文件夹中,ets文件夹用于存放ets代码,resources文件存放模块内的多媒体及布局文件等,module.json5文件为模块的配置文件。
  • ohosTest是单元测试目录。
  • build-profile.json5是模块级配置信息,包括编译构建配置项。
  • hvigorfile.ts文件是模块级构建脚本。
  • oh-package.json5是模块级依赖配置信息文件。

进入src>main>ets目录中,其分为entryability、pages两个文件夹。

  • entryability存放ability文件,用于当前ability应用逻辑和生命周期管理。
  • pages存放UI界面相关代码文件,初始会生成一个Index页面。

5.3 AppScope>app.json5是应用的全局的配置文件,用于存放应用公共的配置信息。

4fc860c16a7440f5a188cc45013d4309.png

  • bundleName是包名。
  • vendor是应用程序供应商。
  • versionCode是用于区分应用版本。
  • versionName是版本号。
  • icon对应于应用的显示图标。
  • label是应用名。

5.4 src/main/resources/base/profile/main_pages.json文件保存的是页面page的路径配置信息,所有需要进行路由跳转的page页面都要在这里进行配置。

321f0715832445ebbadef107712bccb6.png

六 编译问题

6.1 如果工程中配置的releaseType字段与设备(模拟器和真机)镜像版本不匹配,则运行时会报INSTALL_PARSE_FAILED_USESDK_ERROR错误,如下图所示。

6.2 解决措施:

在设备中运行应用/服务时,build.gradle(API4-7)或build-profile.json5(API8及以上版本)文件中的compileSdkVersion和compatibleSdkVersion,以及SDK Stage(Beta或Release)需要与设备的apiVersion、releaseType相互匹配才能正常运行。具体的修改方法如下

6.3,在HarmonyOS SDK存储目录下的Sdk\hmscore\{版本号}\toolchains文件下打开CMD命令行工具,执行如下命令进行查询真机设备的apiVersion和releaseType取值。

在手机/平板HarmonyOS 3.1 Release设备上:

hdc -c shell 
getprop persist.sys.ohc.apiversion
getprop persist.sys.ohc.releasetype

在手机/平板HarmonyOS 3.1 Release之前版本的设备上:

hdc -c shell
getprop hw_sc.build.os.apiversion
getprop hw_sc.build.os.releasetype

如下 

 

打开模块的build.gradle(API4-7)或打开工程的build-profile.json5(API8-9)文件,查看compileSdkVersion、compatibleSdkVersion。

在模块的build.gradle(API4-7)文件中查看compileSdkVersion、compatibleSdkVersion

在工程的build-profile.json5(API8-9)文件查看compileSdkVersion、compatibleSdkVersion

6.4,点击File > Settings > SDKs > HarmonyOS,查看compileSdkVersion对应的SDK stage。例如,下图中API Version 7对应的Stage为Release。

6.5,根据查询的设备apiversion、releaseType,以及SDK Stage的取值,再查询下表中的匹配关系,来修改compileSdkVersion和compatibleSdkVersion的值。其中compileSdkVersion需要修改工程和各模块build.gradle中的取值;compatibleSdkVersion需要修改各模块下的build.gradle中的取值。

apiVersion

releaseType

compileSdkVersion

SDK Stage

compatibleSdkVersion

4

Release

4

Release

4

4

Release

5

Release

4

5

Release

5

Release

4或5

5

Release

5

Release

4或5

5

Release

6

Release

4或5

5

Release

6

Release

4或5

6

Release

5

Release

4或5

6

Release

6

Release

4或5或6

6

Release

5

Release

4或5

6

Release

6

Release

4或5或6

7

Release

7

Release

4或5或6或7

7

Release

6

Release

4或5或6

8

Release

6

Release

4或5或6

8

Release

8

Release

8

9

Release

9

Release

9

6.6,当前应用版本和设备镜像版本匹配后,如果仍然报该错误,且设备镜像版本已更新为3.1 Release版本,则说明当前使用的DevEco Studio版本与设备运行的镜像版本不匹配,请升级DevEco Studio至3.1 Release版本,在新版本DevEco Studio上进行运行/调试。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/111521.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

苹果笔值得买吗?比较好用的电容笔

在这个离不开电子产品的时代,各大数码产品竞争相当激烈。电容笔也是一款热销产品,每年都有许多商家加入这个行业,市面上的品牌就越来越多,给我们的带了更多选择。由于市面上的电容笔品牌越来越多,给小伙伴也带了困难&a…

如何利用软文推广进行SEO优化(打造优质软文,提升网站排名)

在当今的互联网时代,SEO优化成为了网站推广的关键。而软文推广作为一种有效的推广方式,其优点不仅仅局限于SEO,还可以带来更多的曝光和用户流量。本文将深入探讨如何做好软文推广,从而提升网站排名和流量。 了解目标受众群体 内容…

nacos安装和入门

Nacos是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。 一、Nacos在mac环境的服务搭建 1、首先进入Nacos官网,链接 2、点击前往Github,点击红色链接。 3、选择相应版本下载。 4、下载之后解压。 5、在终端执行以下命令启动Nacos…

python 二手车数据分析以及价格预测

二手车交易信息爬取、数据分析以及交易价格预测 引言一、数据爬取1.1 解析数据1.2 编写代码爬1.2.1 获取详细信息1.2.2 数据处理 二、数据分析2.1 统计分析2.2 可视化分析 三、价格预测3.1 价格趋势分析(特征分析)3.2 价格预测 引言 本文着眼于车辆信息,结合当下较…

java面试题记录

一、多线程、高并发: 1.1 什么是死锁,怎样解决死锁问题? 死锁指的是由于两个或两个以上的线程互相持有对方所需要的资源,同时等待获取对方释放自己所需要的资源,导致这些线程处于等待中而无法往下进行的状态。 精简描述…

第一篇------Virtual I/O Device (VIRTIO) Version 1.1

1 介绍 本文档描述了“virtio”设备系列的规格。这些设备通常出现在虚拟环境中,但按设计,它们在虚拟机内部看起来像物理设备,而本文档将其视为这样的设备。这种相似性允许虚拟机内的客户端使用标准驱动程序和发现机制。 virtio及其规格的目的…

远程计算机控制软件

远程控制软件允许您连接和控制位于不同位置的设备,对于 IT 帮助台技术人员来说,这是一个很好的工具,可以通过与用户协作、与他们聊天以及安全地访问他们的文件来轻松排除故障和修复远程设备。使用远程控制软件,距离不再是提供技术…

Kotlin变量与控制条件的基本用法

一、变量与控制条件 1、var与val var:可修改变量 val:只读变量,只读变量并非绝对只读。 编译时常量只能在函数之外定义,因为函数内常量是在运行时赋值,编译时常量要在变量赋值前存在。并且值是无法修改的。 const…

VIRTIO-SCSI代码分析(2)VIRTIO 驱动分析

QEMU模拟出VIRTIO SCSI设备后,在虚拟机中呈现SCSI设备和PCIE设备。而在虚拟机中,PCIE设备与VIRTIO PCI驱动匹配触发virtio_pci_probe()注册生成virtio设备,而virtio设备与虚拟机中的virtio驱动匹配触发对应probe函数最终注册对应的驱动。 这里…

短视频搭建矩阵源码--短视频矩阵源码搭建

短视频矩阵系统是一种通过将短视频内容进行分类、管理和展示的系统。它可以将用户上传或者选择的短视频按照不同的特定标签进行分类和管理,用户可以根据自己的兴趣和需求选择观看不同类别的短视频。 短视频矩阵源码的开发部署其实并不难,主要依托于抖音平…

uniapp微信小程序《隐私保护协议》弹窗处理流程

背景 《关于小程序隐私保护指引设置的公告》 《小程序隐私协议开发指南》 流程 1.第一步 必须设置且审核通过!!! 2.第二步 uniapp在manifest.json中添加!!! /* 在 2023年9月15号之前,在 ap…

Apinto 网关: Go语言实现 HTTP 转 gRPC

gRPC 是由 Google 开发的一个高性能、通用的开源RPC框架,主要面向移动应用开发且基于 HTTP/2 协议标准而设计,同时支持大多数流行的编程语言。 gRPC 基于 HTTP/2 协议传输, HTTP/2 相比 HTTP1.x有以下优势: 采用二进制格式传输协议&#xff…