#过年不停更#HarmonyOS-ETS之紧急拨号 原创 精华
春节不停更,此文正在参加「星光计划-春节更帖活动」
作者:陈龙佳
前言
一直在学习关于鸿蒙官方文档,主要是学习基于JS扩展的类web开发范式,而随着开发文档的不断更新,SDK也更新到了8,随着TS的不断广泛应用,于是我就接触了基于TS扩展的类web开发范式,也就是ArkUI。本文主要是基于ArkUI实现的一个小项目,也可以说是一个demo,主要是通过ETS的语法完成一些关于界面相关的、简单的数据通信以及交互。
效果展示
创建项目
首先打开devEco Studio编辑器,左上角找到File–>New–>New project,然后来到下面这个页面,对于第一次使用该编辑器时最令人的头疼的应该就是sdk的问题,首先ETS项目必须需要SDK7以上才可以使用,所以如果有创建失败的童鞋们请检查你们的SDK版本是否正确。
项目架构
目录 | 描述 |
---|---|
src | 项目的源码主文件夹 |
components | 公共组件的存放文件夹 |
Model | 主要数据源的存放文件夹 |
pages | 项目页面文件夹 |
app.ets | 项目的入口文件 |
resources | 应用的资源文件夹(字符串、图片、音频等) |
config.json | 应用配置文件 |
数据模型构建
1.定义一个接口来约束urgentDialList
2.构建initializeOnStartup方法来对页面数据进行初始化处理
主要涉及到的状态变量装饰器
装饰器 | 描述 |
---|---|
@State | 组件拥有的状态属性。每当@State装饰的变量更改时,组件会重新渲染更新UI |
@Link | 组件依赖于其父组件拥有的某些状态属性。每当任何一个组件中的数据更新时,另一个组件的状态都会更新,父子组件都会进行重新渲染。 |
@Prop | 工作原理类似@Link,只是子组件所做的更改不会同步到父组件上,属于单向传递。 |
在这里我想说的是关于@Link跟@Prop都可以进行组件数据的传递,但是通过@Prop修饰的变量,父组件不能进行数据的修改,因为这样会破坏数据的单向性,而@Link是双向数据绑定的,可以进行数据的重新渲染以及修改。
主要涉及功能点
- 打开弹框获取地理位置
- 紧急拨号页面的跳转
- 拨号键盘的呼入与呼出
- 手势事件滑动呼叫紧急号码
主要工具函数类
1.showToast函数
作用:主要用来展示弹框,这里需要引入鸿蒙里一个包(import prompt from ‘@system.prompt’😉
2.routerPage函数
作用:主要用来进行页面跳转,这里需要引入鸿蒙里一个包(import routerfrom ‘@system.router’😉
组件封装
keyword组件
键盘组件主要使用Grid宫格布局,对于这种类似键盘或者九宫格的布局推荐使用grid布局,
采用网格容器,二维布局,将容器划分成"行"和"列",产生单元格,然后指定"项目所在"的单元格,可以任意组合不同的网格,做出各种各样的布局。
但是要注意一点,Text组件只能用来展示字符串,因此如果是想展示数字的话得需要通过toString()转换一下,这是我之前遇到的一个小问题。
urgentList组件
该组件主要用来渲染紧急拨号列表,在ArkUI中,主要使用forEach来遍历数据,进行页面展示。
urgentListItem组件
该组件中使用了手势事件,通过PanGesture()中的onActionEnd、onActionStart、onActionUpdate三个方法来对手势所触发的距离进行控制,当this.offsetX大于某一临界值时,滑动改变菜单布局或内容布局的left偏移量,手势抬起完成偏移量进行视图的更新。
1.首先,会使用到手势事件,通过判断手势滑动的偏移量offsetX来控制滑动后颜色改变
gesture():gesture: GestureType,mask?: GestureMask
鸿蒙系统提供如下Gesture类型:
LongPressGesture | 长按手势 |
---|---|
PanGesture | 平移手势 |
PinchGesture | 捏合手势 |
RotationGesture | 旋转手势 |
2.响应手势事件
- 组件通过gesture方法绑定手势对象,可以通过手势对象提供的事件相应响应手势操作。如通过TapGesture对象的onAction事件响应点击事件。
-
当响应事件结束后,关闭定时器来关闭滑动,重置效果。
positionInfoDialog组件
功能点:询问是否自动获取地理位置,若继续,则显示当前地理位置,若取消则关闭弹框,显示初始值
总结
本文只是大致的使用ArkUI对页面进行了简单的布局以及事件的交互,没有涉及到太复杂的逻辑功能业务。
鸿蒙的路还很长,青春正好,故事还没有结束,而我们正走在探索的路上。如果想更多的了解以及深入学习鸿蒙生态的知识,可以参阅:ArkUI
项目源码
https://gitee.com/chen_longjia/ark-ui-emergency
更多原创内容请关注:中软国际 HarmonyOS 技术团队
入门到精通、技巧到案例,系统化分享HarmonyOS开发技术,欢迎投稿和订阅,让我们一起携手前行共建鸿蒙生态。
紧急拨号是一个基本不会用,但一旦用到就很重要的功能,必须好好学习