当前位置:   article > 正文

HarmonyOS实战开发-如何实现一个简单的电子相册应用开发

HarmonyOS实战开发-如何实现一个简单的电子相册应用开发

介绍

本篇Codelab介绍了如何实现一个简单的电子相册应用的开发,主要功能包括:

  1. 实现首页顶部的轮播效果。
  2. 实现页面跳转时共享元素的转场动画效果。
  3. 实现通过手势控制图片的放大、缩小、左右滑动查看细节等效果。

相关概念

  • Swiper:滑块视图容器,提供子组件滑动轮播显示的能力。
  • Grid:网格容器,由“行”和“列”分割的单元格所组成,通过指定“项目”所在的单元格做出各种各样的布局。
  • Navigation:Navigation组件一般作为Page页面的根容器,通过属性设置来展示页面的标题、工具栏、菜单。
  • List:列表包含一系列相同宽度的列表项。适合连续、多行呈现同类数据,例如图片和文本。
  • 组合手势:手势识别组,多种手势组合为复合手势,支持连续识别、并行识别和互斥识别。

环境搭建

软件要求

  • DevEco Studio版本:DevEco Studio 3.1 Release。
  • OpenHarmony SDK版本:API version 9。

硬件要求

  • 开发板类型:润和RK3568开发板。
  • OpenHarmony系统:3.2 Release。

环境搭建

完成本篇Codelab我们首先要完成开发环境的搭建,本示例以RK3568开发板为例,参照以下步骤进行:

  1. 获取OpenHarmony系统版本:标准系统解决方案(二进制)。以3.2 Release版本为例:

2.搭建烧录环境。

  1. 完成DevEco Device Tool的安装
  2. 完成RK3568开发板的烧录

3.搭建开发环境。

  1. 开始前请参考工具准备,完成DevEco Studio的安装和开发环境配置。
  2. 开发环境配置完成后,请参考使用工程向导创建工程(模板选择“Empty Ability”)。
  3. 工程创建完成后,选择使用真机进行调测。

代码结构解读

本篇Codelab只对核心代码进行讲解。

  1. ├──entry/src/main/ets // 代码区
  2. │ ├──common
  3. │ │ ├──constansts
  4. │ │ │ └──Constants.ets // 常量类
  5. │ │ └──utils
  6. │ │ └──Logger.ets // Logger公共类
  7. │ ├──entryability
  8. │ │ └──EntryAbility.ts // 程序入口类
  9. │ ├──pages
  10. │ │ ├──DetailListPage.ets // 图片详情页面
  11. │ │ ├──DetailPage.ets // 查看大图页面
  12. │ │ ├──IndexPage.ets // 电子相册主页面
  13. │ │ └──ListPage.ets // 图片列表页面
  14. │ └──view
  15. │ └──PhotoItem.ets // 首页相册Item组件
  16. └──entry/src/main/resources // 资源文件

构建应用页面

应用首页

应用首页用Column组件来实现纵向布局,从上到下依次是标题组件Text、轮播图Swiper、相册列表Grid。标题和轮播图均设置固定高度,底部相册列表通过layoutWeight属性实现自适应占满剩余空间。

  1. // IndexPage.ets
  2. Column() {
  3. Row() {
  4. Text($r('app.string.EntryAbility_label'))
  5. }
  6. Swiper(this.swiperController) {
  7. ForEach(Constants.BANNER_IMG_LIST, (item: Resource) => {
  8. Row() {
  9. Image(item)
  10. ...
  11. }
  12. }, (item: Resource, index: number) => JSON.stringify(item) + index)
  13. }
  14. ...
  15. Grid() {
  16. ForEach(IMG_ARR, (photoArr: Array<Resource>) => {
  17. GridItem() {
  18. PhotoItem({ photoArr })
  19. }
  20. ...
  21. .onClick(() => {
  22. router.pushUrl({
  23. url: Constants.URL_LIST_PAGE,
  24. params: { photoArr: JSON.stringify(photoArr) }
  25. }).catch((error: Error) => {
  26. Logger.error(Constants.TAG_INDEX_PAGE, JSON.stringify(error));
  27. });
  28. })
  29. }, (item: Array<Resource>, index: number) => JSON.stringify(item) + index)
  30. }
  31. ...
  32. .layoutWeight(1)
  33. }

图片列表页面

图片列表页是网格状展开的图片列表,主要使用Grid组件和GridItem组件,GridItem高度通过aspectRatio属性设置为跟宽度一致。

  1. // ListPage.ets
  2. Navigation() {
  3. Grid() {
  4. ForEach(this.photoArr, (img: Resource, index: number) => {
  5. GridItem() {
  6. Image(img)
  7. .onClick(() => {
  8. this.selectedIndex = index;
  9. router.pushUrl({
  10. url: Constants.URL_DETAIL_LIST_PAGE,
  11. params: {
  12. photoArr: JSON.stringify(this.photoArr),
  13. }
  14. }).catch((error: Error) => {
  15. Logger.error(Constants.TAG_LIST_PAGE, JSON.stringify(error));
  16. });
  17. })
  18. }
  19. ...
  20. .aspectRatio(1)
  21. }, (item: Resource) => JSON.stringify(item))
  22. }
  23. .columnsTemplate(Constants.GRID_COLUMNS_TEMPLATE)
  24. .layoutWeight(1)
  25. }

图片详情页面

图片详情页由两个横向滚动的List组件完成整体布局,两个组件之间有联动的效果。滚动底部的List,上边展示的图片会随着改变,同样左右滑动上边的图片时,底部List组件也会随之改变。

  1. // DetailListPage.ets
  2. Stack({ alignContent: Alignment.Bottom }) {
  3. List({ scroller: this.bigScroller, initialIndex: this.selectedIndex }) {
  4. ForEach(this.photoArr, (img: Resource, index: number) => {
  5. ListItem() {
  6. Image(img)
  7. ...
  8. .gesture(PinchGesture({ fingers: Constants.DOUBLE_NUMBER })
  9. .onActionStart(() => this.goDetailPage()))
  10. .onClick(() => this.goDetailPage())
  11. }
  12. }, (item: Resource) => JSON.stringify(item))
  13. }
  14. ...
  15. .onScroll((scrollOffset, scrollState) => {
  16. if (scrollState === ScrollState.Fling) {
  17. this.bigScrollAction(scrollTypeEnum.SCROLL);
  18. }
  19. })
  20. .onScrollStop(() => this.bigScrollAction(scrollTypeEnum.STOP))
  21. List({ scroller: this.smallScroller, space: Constants.LIST_ITEM_SPACE, initialIndex: this.selectedIndex }) {
  22. ForEach(this.smallPhotoArr, (img: Resource, index: number) => {
  23. ListItem() {
  24. this.SmallImgItemBuilder(img, index)
  25. }
  26. }, (item: Resource, index: number) => JSON.stringify(item) + index)
  27. }
  28. ...
  29. .listDirection(Axis.Horizontal)
  30. .onScroll((scrollOffset, scrollState) => {
  31. if (scrollState === ScrollState.Fling) {
  32. this.smallScrollAction(scrollTypeEnum.SCROLL);
  33. }
  34. })
  35. .onScrollStop(() => this.smallScrollAction(scrollTypeEnum.STOP))
  36. }

查看大图页面

查看大图页面由一个横向滚动的List组件来实现图片左右滑动时切换图片的功能,和一个Row组件实现图片的缩放和拖动查看细节功能。对图片进行缩放时会从List组件切换成Row组件来实现对单张图片的操作,对单张图片进行滑动操作时,也会由Row组件转换为List组件来实现图片的切换功能。

  1. // DetailPage.ets
  2. Stack() {
  3. List({ scroller: this.scroller, initialIndex: this.selectedIndex }) {
  4. ForEach(this.photoArr, (img: Resource) => {
  5. ListItem() {
  6. Image(img)
  7. ...
  8. .onClick(() => router.back()
  9. )
  10. }
  11. .gesture(PinchGesture({ fingers: Constants.DOUBLE_NUMBER })
  12. .onActionStart(() => {
  13. this.resetImg();
  14. this.isScaling = true;
  15. this.imgOffSetX = 0;
  16. this.imgOffSetY = 0;
  17. })
  18. .onActionUpdate((event: GestureEvent) => {
  19. this.imgScale = this.currentScale * event.scale;
  20. })
  21. .onActionEnd(() => {
  22. if (this.imgScale < 1) {
  23. this.resetImg();
  24. this.imgOffSetX = 0;
  25. this.imgOffSetY = 0;
  26. } else {
  27. this.currentScale = this.imgScale;
  28. }
  29. })
  30. )
  31. }, (item: Resource) => JSON.stringify(item))
  32. }
  33. ...
  34. .onScrollStop(() => {
  35. let currentIndex = Math.round((this.scroller.currentOffset()
  36. .xOffset + (this.imageWidth / Constants.DOUBLE_NUMBER)) / this.imageWidth);
  37. this.selectedIndex = currentIndex;
  38. this.scroller.scrollTo({ xOffset: currentIndex * this.imageWidth, yOffset: 0 });
  39. })
  40. .visibility(this.isScaling ? Visibility.Hidden : Visibility.Visible)
  41. Row() {
  42. Image(this.photoArr[this.selectedIndex])
  43. ...
  44. }
  45. .visibility(this.isScaling ? Visibility.Visible : Visibility.Hidden)
  46. }

通过手势控制图片

大图浏览界面双指捏合时通过改变Image组件的scale来控制图片的缩放,单手拖动时通过改变Image的偏移量来控制图片的位置,手势操作调用组合手势GestureGroup实现。其中PinchGesture实现双指缩放手势,PanGesture实现单指拖动手势。

  1. // DetailPage.ets
  2. Row() {
  3. Image(this.photoArr[this.selectedIndex])
  4. .position({ x: this.imgOffSetX, y: this.imgOffSetY })
  5. .scale({ x: this.imgScale, y: this.imgScale })
  6. }
  7. .gesture(GestureGroup(GestureMode.Exclusive,
  8. PinchGesture({ fingers: Constants.DOUBLE_NUMBER })
  9. .onActionUpdate((event: GestureEvent) => {
  10. this.imgScale = this.currentScale * event.scale;
  11. })
  12. .onActionEnd(() => {
  13. if (this.imgScale < 1) {
  14. this.resetImg();
  15. this.imgOffSetX = 0;
  16. this.imgOffSetY = 0;
  17. } else {
  18. this.currentScale = this.imgScale;
  19. }
  20. }),
  21. PanGesture()
  22. .onActionStart(() => {
  23. this.preOffsetX = this.imgOffSetX;
  24. this.preOffsetY = this.imgOffSetY;
  25. })
  26. .onActionUpdate((event: GestureEvent) => {
  27. this.imgOffSetX = this.preOffsetX + event.offsetX;
  28. this.imgOffSetY = this.preOffsetY + event.offsetY;
  29. })
  30. .onActionEnd(() => this.handlePanEnd())
  31. ))

总结

您已经完成了本次Codelab的学习,并了解到以下知识点:

  1. 如何实现首页顶部的轮播效果。
  2. 如何实现页面跳转时共享元素的转场动画效果。
  3. 如何通过手势控制图片的放大、缩小、左右滑动查看细节等效果。

为了帮助大家更深入有效的学习到鸿蒙开发知识点,小编特意给大家准备了一份全套最新版的HarmonyOS NEXT学习资源,获取完整版方式请点击→HarmonyOS教学视频

HarmonyOS教学视频:语法ArkTS、TypeScript、ArkUI等…视频教程

鸿蒙生态应用开发白皮书V2.0PDF:

获取完整版白皮书方式请点击→《鸿蒙生态应用开发白皮书V2.0PDF

在这里插入图片描述

鸿蒙 (Harmony OS)开发学习手册

一、入门必看

  1. 应用开发导读(ArkTS)
  2. .……

在这里插入图片描述


二、HarmonyOS 概念

  1. 系统定义
  2. 技术架构
  3. 技术特性
  4. 系统安全

在这里插入图片描述

三、如何快速入门?鸿蒙基础入门学习指南

  1. 基本概念
  2. 构建第一个ArkTS应用
  3. .……

在这里插入图片描述


四、开发基础知识

  1. 应用基础知识
  2. 配置文件
  3. 应用数据管理
  4. 应用安全管理
  5. 应用隐私保护
  6. 三方应用调用管控机制
  7. 资源分类与访问
  8. 学习ArkTS语言
  9. .……

在这里插入图片描述


五、基于ArkTS 开发

  1. Ability开发
  2. UI开发
  3. 公共事件与通知
  4. 窗口管理
  5. 媒体
  6. 安全
  7. 7.网络与链接
  8. 电话服务
  9. 数据管理
  10. 后台任务(Background Task)管理
  11. 设备管理
  12. 设备使用信息统计
  13. DFX
  14. 国际化开发
  15. 折叠屏系列
  16. .……

在这里插入图片描述


更多了解更多鸿蒙开发的相关知识可以参考:《鸿蒙 (Harmony OS)开发学习手册

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/339816
推荐阅读
相关标签
  

闽ICP备14008679号