HarmonyOS第一课——DevEco Studio的使用

news/2024/11/8 21:19:45 标签: harmonyos, 华为

HarmonyOS第一课

DevEco Studio的使用

集成开发环境:

  • SDK
  • 构建插件
  • ohpm等工具

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。

Hello World:

  • Project name:HelloWorld
  • Buidle name:com.example.helloworld
  • Save location:
  • Compatible SDK:5.0.0(12)
  • Module name(模块名):entry
  • Device type:Phone Tablet 2in1 Car…

自动签名:

  • File > Project Structure, Project,Signing Configs,default:
    • Sign in 使用华为账号,登陆后签名材料会自动下载
      • Team
      • Store file(*.p12)
      • Store password
      • Key alias
      • Key password
      • Sign alg
      • Profile file(*.p7b)
      • Cerpath file(*.cer)
    • 点击OK 完成配置;

签名完成后,在本地生成密钥(.p12)、证书请求文件(.csr)、数字证书(.cer)及Profile文件(.p7b),数字证书在AppGallery Connect网站的“证书、APP ID和Profile”页签中可以查看。

之后就可以运行项目;

诊断开发环境

  • 为了您开发应用/服务的良好体验,DevEco Studio提供了开发环境诊断的功能,帮助您识别开发环境是否完备。您可以在欢迎页面单击Diagnose进行诊断。如果您已经打开了工程开发界面,也可以在菜单栏单击Help > Diagnostic Tools > Diagnose Development Environment进行诊断。
  • DevEco Studio开发环境诊断项包括电脑的配置、网络的连通情况、依赖的工具是否安装等。如果检测结果为未通过,请根据检查项的描述和修复建议进行处理。

设置中的 Plugins,支持安装插件,如去Installed“Chinese”简体中文插件,实现汉化;需要重启生效;

ArkTS应用

Application应用开发, Atomic Service对应为元服务开发

模板名称说明
Empty Ability用于Phone、Tablet、2in1、Car设备的模板,展示基础的Hello World功能。
Native C++用于Phone、Tablet、2in1、Car设备的模板,作为应用调用C++代码的示例工程,界面显示“Hello World”。
[CloudDev]Empty Ability端云一体化开发通用模板。更多信息请参见端云一体化开发。
[Lite]Empty Ability用于Lite Wearable设备的模板,展示了基础的Hello World功能。可基于此模板,修改设备类型及RuntimeOS,进行小型嵌入式设备开发。请参见创建Lite工程。
Flexible Layout Ability用于创建跨设备应用开发的三层工程结构模板。三层工程结构包含common(公共能力层)、features(基础特性层)、products(产品定制层)。
Embeddable Ability用于开发支持被其他应用嵌入式运行的元服务的工程模板。
  • 选择 Empty Ability模版
  • 配置工程界面,Compatible SDK选择“5.0.0(12)”,其他参数保持默认设置即可

项目介绍:

  • AppScope > 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包的配置信息、应用/服务在具体设备上的配置信息以及应用/服务的全局配置信息。
    • 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)等。

表示设备的类型,取值如下:

  • phone:手机
  • car:车机
  • tablet:平板
  • tv:智慧屏
  • wearable:智能穿戴
  • 2in1
第一个页面

在“Project”窗口,点击“entry > src > main > ets > pages”,打开“Index.ets”文件,进行页面的编写。

应该是类js风格的编码方式;

关于组件布局

@Entry
@Component
struct Second {}
@State
build() {}

Text()
Button()


在副一级文件夹上 右击新建 ArkTS File 或新建 Empty Page;

配置新建页面的路由:

  • 打开“entry > src > main > resources > base > profile”,在main_pages.json文件中的“src”下配置第二个页面的路由
{
  "src": [
    "pages/Index",
    "pages/Second"
  ]
}

页面间跳转:

  • 页面路由router根据页面url找到目标页面,从而实现跳转。使用页面路由请导入router模块。
  • 如果需要实现更好的转场动效,推荐使用Navigation

Ark翻译过来时“方舟”

import { router } from '@kit.ArkUI';
import { BusinessError } from '@kit.BasicServicesKit';


.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}`)
  })
})


// 返回按钮绑定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}`)
  }
})
真机调试
  • 将搭载HarmonyOS系统的真机与电脑连接
  • 进行签名:点击File > Project Structure… > Project > SigningConfigs界面勾选“Support HarmonyOS”和“Automatically generate signature”,点击界面提示的“Sign In”,使用华为账号登录。等待自动签名完成;

注:到现在还只是刷教程,回头得买台新电脑。。。


http://www.niftyadmin.cn/n/5744451.html

相关文章

itextpdf打印A5的问题

使用A5打印的时候,再生成pdf是没有问题的。下面做了一个测试,在打印机中,使用A5的纸张横向放入,因为是家用打印机,A5与A4是同一个口,因此只能这么放。 使用itextpdf生成pdf,在浏览器中预览pdf是…

微信小程序,点击bindtap事件后,没有跳转到详情页,有可能是app.json中没有正确配置页面路径

文章目录 1、index.wxml2、index.js检查点1. 确保目标页面存在2. 确保页面路径配置正确3. 检查页面接收参数productDetail.jsproductDetail.wxmlproductDetail.wxss 总结 1、index.wxml <!-- 商品搜索结果卡片容器 --><view class"search-result"><bl…

高校宿舍信息管理系统小程序

作者主页&#xff1a;编程千纸鹤 作者简介&#xff1a;Java领域优质创作者、CSDN博客专家 、CSDN内容合伙人、掘金特邀作者、阿里云博客专家、51CTO特邀作者、多年架构师设计经验、多年校企合作经验&#xff0c;被多个学校常年聘为校外企业导师&#xff0c;指导学生毕业设计并参…

OceanBase 应用实践:如何处理数据空洞,降低存储空间

问题描述 某保险行业客户的核心系统&#xff0c;从Oracle 迁移到OceanBase之后&#xff0c;发现数据存储空间出现膨胀问题&#xff0c;数据空间 datasize9857715.48M&#xff0c;实际存储占用空间17790702.00M。根据 required_mb - data_mb 值判断&#xff0c;数据空洞较为严重…

全面升级的“新清影”,给AI生成视频带来了哪些新玩法?

就在刚刚&#xff0c;智谱清言App上线了“新清影”&#xff0c;同时对外开源了智谱最新的图生视频模型CogVideoX v1.5。 3个多月前的智谱Open Day上&#xff0c;视频创作智能体清影正式在智谱清言上线&#xff0c;只需30秒即可生成时长6秒、1440x960清晰度的高精视频&#xff…

“类模板”

文章目录 一. 类模板的引入二. 类模板的格式三. 类模板的实例化注意点 一. 类模板的引入 我们曾经学习过&#xff1a;typedef STDataTy int;或者是using STDataTy int;&#xff0c;这个的作用是将使用STDataTy 的地方替换成int #include<stdio.h> using STDataTy int…

React 入门课程 - 使用CDN编程React

1. 第一个React 注意&#xff1a;在vscode里&#xff0c;使用Live Server来运行html文件。 index.html <html><head><link rel"stylesheet" href"index.css"><script crossorigin src"https://unpkg.com/react17/umd/react.de…

P11229 [CSP-J 2024] 小木棍

[CSP-J 2024] 小木棍 题目描述 小 S 喜欢收集小木棍。在收集了 n n n 根长度相等的小木棍之后&#xff0c;他闲来无事&#xff0c;便用它们拼起了数字。用小木棍拼每种数字的方法如下图所示。 现在小 S 希望拼出一个正整数&#xff0c;满足如下条件&#xff1a; 拼出这个数…