介绍
短视频切换在应用开发中是一种常见场景,上下滑动可以切换视频,十分方便。本模块基于Swiper组件和Video组件实现短视频切换功能。
效果图预览
使用说明
- 上下滑动可以切换视频。
- 点击屏幕暂停视频,再次点击继续播放。
实现思路
- 使用Swiper创建一个竖直的可上下滑动的框架。
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)
- 在Swiper组件中使用Video组件承载视频。
// 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 // 视图层-短视频切换
模块依赖
- 本实例依赖common模块来实现 公共组件FunctionDescription。
为了能让大家更好的学习鸿蒙(HarmonyOS NEXT)开发技术,这边特意整理了《鸿蒙开发学习手册》(共计890页),希望对大家有所帮助:https://qr21.cn/FV7h05
《鸿蒙开发学习手册》:
如何快速入门:https://qr21.cn/FV7h05
- 基本概念
- 构建第一个ArkTS应用
- ……
开发基础知识:https://qr21.cn/FV7h05
- 应用基础知识
- 配置文件
- 应用数据管理
- 应用安全管理
- 应用隐私保护
- 三方应用调用管控机制
- 资源分类与访问
- 学习ArkTS语言
- ……
基于ArkTS 开发:https://qr21.cn/FV7h05
- Ability开发
- UI开发
- 公共事件与通知
- 窗口管理
- 媒体
- 安全
- 网络与链接
- 电话服务
- 数据管理
- 后台任务(Background Task)管理
- 设备管理
- 设备使用信息统计
- DFX
- 国际化开发
- 折叠屏系列
- ……
鸿蒙开发面试真题(含参考答案):https://qr18.cn/F781PH
鸿蒙开发面试大盘集篇(共计319页):https://qr18.cn/F781PH
1.项目开发必备面试题
2.性能优化方向
3.架构方向
4.鸿蒙开发系统底层方向
5.鸿蒙音视频开发方向
6.鸿蒙车载开发方向
7.鸿蒙南向开发方向