> 文档中心 > 【Harmony OS】【ArkUI】ets开发 简易视频播放器

【Harmony OS】【ArkUI】ets开发 简易视频播放器

前言:这一次我们来使用ets的Swiper组件、List组件和Video组件制作一个简易的视频播放器。本篇是以HarmonyOS官网的codelab简易视频播放器(eTS)为基础进行编写。本篇最主要的内容就是一个主界面包括顶部的视频海报轮播,中部的视频播放列表,以及点击海报和播放列表进入到播放界面完成视频播放的功能。师傅领进门,修行在个人,所以本篇只讲大概的组件使用,具体的细节和更详细的属性读者自己在学习中摸索。相信通过这次的学习,你能有所收获。希望能帮助你快速了解Harmony的ETS开发,学会简单的视频播放器制作学习。本篇最后会贴上参考原文链接。

首先讲一下大致的思路,我们要在主界面顶部使用Swiper组件完成视频海报轮播,下方使用List组件完成视频播放的列表,点击海报和播放列表进入视频播放界面使用Video组件制作,其他的属性就由读者自行探索。

1.         构建主界面。

1)       在default文件夹中创建data、image、video文件夹,在data文件夹中创建VideoData.ets文件,用来定义电影轮播图数组swiperVideos和视频列表图片数组horizontalVideos。Image文件夹中添加图片,video文件夹中添加视频,代码中的文件路径替换由读者自行替换。

const localSource: string = "/common/video/video1.mp4";const webSource: string = "https://ss0.bdstatic.com/-0U0bnSm1A5BphGlnYG/cae-legoup-video-target/93be3d88-9fc2-4fbd-bd14-833bca731ca7.mp4";export const swiperVideos:any[] = [  {    "image":'/common/image/video_ad0.jpg',    "source":localSource  },  {    "image":'/common/image/video_ad1.jpg',    "source":localSource  },  {    "image":'/common/image/video_ad2.jpg',    "source":localSource  }]export const horizontalVideos:any[] = [  {    "image":'/common/image/video_list0.jpg',    "source":webSource  },  {    "image":'/common/image/video_list1.jpg',    "source":webSource  },  {    "image":'/common/image/video_list2.jpg',    "source":webSource  }]

2)       在index.ets中引入router和swiperVideos、horizontalVideos

import router from '@system.router';import {swiperVideos,horizontalVideos} from '../common/data/VideoData.ets'

3)       在index.ets中添加Swiper组件用于显示电影轮播图,使用Navigator实现页面跳转。

@Entry@Componentstruct Index {  build() {    Column() {      Swiper() { ForEach(swiperVideos, item => {   SwiperItem({ imageSrc: item.image, source: item.source }) }, item => item.image.toString())      }      .autoPlay(true)      .height(180)      .itemSpace(15)    }    .backgroundColor("#EEEEEE")    .padding({ left: 15, top: 15, right: 15, bottom: 15 })  }}@Componentstruct SwiperItem {  private imageSrc: string  private source: string  build() {    Navigator({ target: 'pages/Play', type: NavigationType.Push }) {      Image(this.imageSrc).objectFit(ImageFit.Cover)    }    .params({ source: this.source })  }}

4)       添加Flex组件用于显示电影列表上方的文本信息,添加List组件用于显示电影列表,使用router实现页面跳转。

@Entry @Component struct Index {   build() {     Column() {      ...Flex({ direction: FlexDirection.Row }) {  Text('Coming soon')    .fontSize(20).fontWeight(FontWeight.Bold).margin({ left: 10 })  Image('/common/image/next.png').height(8).width(16)}.margin({ top: 20, bottom: 15 }) List({ space: 15 }) {  ForEach(horizontalVideos, item => {    ListItem() {      HorizontalItem({ imageSrc: item.image, source: item.source })    }  }, item => item.image.toString())}// 设置列表横向排列.listDirection(Axis.Horizontal)     }     .backgroundColor("#EEEEEE")     .padding({ left: 15, top: 15, right: 15, bottom: 15 })   } } ... @Component struct HorizontalItem {   private imageSrc: string   private source: string    build() {     Image(this.imageSrc).width('80%').height('25%').onClick(() => {  router.push({    uri: 'pages/Play',    params: { source: this.source }  })})   } } 

5)       整个index.ets文件的代码如下:

import router from '@system.router';import {swiperVideos,horizontalVideos} from '../common/data/VideoData.ets'@Entry@Componentstruct Index {  build() {    Column() {      //轮播组件      Swiper(){ ForEach(swiperVideos, item => {   SwiperItem({ imageSrc: item.image, source: item.source }) }, item => item.image.toString())      }      .autoPlay(true)      .height(180)      .itemSpace(15)      //文本信息      Flex({direction:FlexDirection.Row}){ Text('Coming soon') .fontSize(20).fontWeight(FontWeight.Bold).margin({left:10}) Image('/common/image/Record.png').height(8).width(16)      }      .margin({top:20, bottom:15})      List({space:15}){ ForEach(horizontalVideos, item =>{   ListItem(){     HorizontalItem({imageSrc:item.image,source:item.source})   } },item => item.image.toString())      }      .listDirection(Axis.Horizontal)    }    .backgroundColor("#EEEEEE")    .padding({ left: 15, top: 15, right: 15, bottom: 15 })  }}@Componentstruct SwiperItem{  private imageSrc:string  private source:string  build(){    Navigator({target:'pages/Play',type:NavigationType.Push}){      Image(this.imageSrc).objectFit(ImageFit.Cover)    }    .params({source:this.source})  }}@Componentstruct HorizontalItem{  private imageSrc:string  private source:string  build(){    Image(this.imageSrc)    .width('80%')    .height('25%')    .onClick(()=>{      router.push({ uri:'pages/Play', params:{source:this.source}      })    })  }}

6)       打开预览器看一下效果:

8b08e3e8be1eb6cc5f4c38095943ae8d_433x753.gif%40900-0-90-f.gif

 

欲了解更多更全技术文章,欢迎访问https://developer.huawei.com/consumer/cn/forum/?ha_source=zzh