纯血鸿蒙APP实战开发——短视频切换实现案例

短视频切换实现案例

介绍

短视频切换在应用开发中是一种常见场景,上下滑动可以切换视频,十分方便。本模块基于Swiper组件和Video组件实现短视频切换功能。

效果图预览

使用说明

  1. 上下滑动可以切换视频。
  2. 点击屏幕暂停视频,再次点击继续播放。

实现思路

  1. 使用Swiper创建一个竖直的可上下滑动的框架。源码参考VideoSwiper.ets

    typescript 复制代码
    Swiper(this.swiperController) { 
       LazyForEach(this.data, (item: VideoData, index: number) => {
          Stack({ alignContent: Alignment.BottomEnd }) {
             Vedio()
          }, (item: VideoData) => JSON.stringify(item))
       }
     }
    .index(videoIndex)
    .autoPlay(false)
    .indicator(false)
    .loop(true)
    .duration(200)
    .vertical(true)
  2. 在Swiper组件中使用Video组件承载视频。源码参考VideoSwiper.ets

    typescript 复制代码
    // Video组件
     Video({
       src: item.video,
       controller: item.controller
     })
       .width('100%')
       .height('100%')
       .objectFit(ImageFit.Contain)
       .loop(true)
       .autoPlay(item.auto)
       .controls(false) // 控制视频播放的控制栏是否显示
    }

高性能知识点

本示例使用了LazyForEach进行数据懒加载,LazyForEach懒加载可以通过设置cachedCount属性来指定缓存数量,同时搭配组件复用能力以达到性能最优效果。

工程结构&模块类型

复制代码
shortvideo                             // har类型
|---model
|   |---BasicDataSource.ets            // 模型层-懒加载数据源
|   |---DataModel.ets                  // 数据模型层-视频数据
|---view
|   |---ShortVideo.ets                 // 视图层-主页
|   |---Side.ets                       // 视图层-视频右侧页面操作栏与左侧信息栏
|   |---VideoSwiper.ets                // 视图层-短视频切换
|   |---CommentView.ets                // 视图层-评论组件

模块依赖

  1. 本示例依赖common模块来实现日志的打印、动态路由模块来实现页面的动态加载。

参考资料

Swiper

Video

LazyForEach详细用法

鸿蒙全栈开发全新学习指南

也为了积极培养鸿蒙生态人才,让大家都能学习到鸿蒙开发最新的技术,针对一些在职人员、0基础小白、应届生/计算机专业、鸿蒙爱好者等人群,整理了一套纯血版鸿蒙(HarmonyOS Next)全栈开发技术的学习路线【包含了大APP实战项目开发】

本路线共分为四个阶段:

第一阶段:鸿蒙初中级开发必备技能

第二阶段:鸿蒙南北双向高工技能基础:gitee.com/MNxiaona/733GH

第三阶段:应用开发中高级就业技术

第四阶段:全网首发-工业级南向设备开发就业技术:https://gitee.com/MNxiaona/733GH

《鸿蒙 (Harmony OS)开发学习手册》(共计892页)

如何快速入门?

1.基本概念

2.构建第一个ArkTS应用

3.......

开发基础知识:gitee.com/MNxiaona/733GH

1.应用基础知识

2.配置文件

3.应用数据管理

4.应用安全管理

5.应用隐私保护

6.三方应用调用管控机制

7.资源分类与访问

8.学习ArkTS语言

9.......

基于ArkTS 开发

1.Ability开发

2.UI开发

3.公共事件与通知

4.窗口管理

5.媒体

6.安全

7.网络与链接

8.电话服务

9.数据管理

10.后台任务(Background Task)管理

11.设备管理

12.设备使用信息统计

13.DFX

14.国际化开发

15.折叠屏系列

16.......

鸿蒙开发面试真题(含参考答案):gitee.com/MNxiaona/733GH

鸿蒙入门教学视频:

美团APP实战开发教学:gitee.com/MNxiaona/733GH

写在最后

  • 如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙:
  • 点赞,转发,有你们的 『点赞和评论』,才是我创造的动力。
  • 关注小编,同时可以期待后续文章ing🚀,不定期分享原创知识。
  • 想要获取更多完整鸿蒙最新学习资源,请移步前往小编:gitee.com/MNxiaona/733GH
相关推荐
YWamy8 分钟前
国产视频会议核心技术解析:架构、特性与全场景落地
音视频
不爱吃糖的程序媛22 分钟前
鸿蒙PC tiny-AES-c三方库适配实践
c语言·华为·harmonyos
REDcker1 小时前
WebRTC 接收端音频流畅低延迟播放:原理与源码对照(NetEQ / Opus)
音视频·webrtc
小杰3123 小时前
ZLMediakit源码梳理
服务器·音视频·流媒体·zlmediakit
key_3_feng4 小时前
鸿蒙6.0技术解读
华为·harmonyos
想你依然心痛5 小时前
HarmonyOS 5.0物联网开发实战:基于星闪(NearLink)技术的智能家居边缘计算网关
物联网·智能家居·harmonyos
ai产品老杨5 小时前
异构计算时代的视频底座:基于 X86/ARM 与 GPU/NPU 的边缘云协同架构解析
arm开发·架构·音视频
互联网散修6 小时前
零基础鸿蒙应用开发第二十四节:商品类重构属性契约接口
harmonyos·鸿蒙
AI服务老曹6 小时前
终结碎片化:基于 GB28181 与 RTSP 的企业级视频融合网关架构设计与源码解析
音视频
EasyDSS7 小时前
企业级融媒体平台私有化视频会议系统EasyDSS私有化部署打造安全可控的校园“音视频中枢”
安全·音视频·媒体