代码拉取完成,页面将自动刷新
短视频切换在应用开发中是一种常见场景,上下滑动可以切换视频,十分方便。本模块基于Swiper组件和Video组件实现短视频切换功能。状态保留能力弹窗案例请参考Comment。
使用说明
使用Swiper创建一个竖直的可上下滑动的框架。源码参考VideoSwiper.ets。
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组件承载视频。源码参考VideoSwiper.ets。
// 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 // 视图层-评论组件
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。