谷动谷力

标题: 如何基于 OpenHarmony 制作一个简单视频播放器? [打印本页]

作者: 鸣涧    时间: 2022-8-25 23:36
标题: 如何基于 OpenHarmony 制作一个简单视频播放器?
如何基于 OpenHarmony 制作一个简单视频播放器?
由于视频资源在项目中使用较为频繁,于是有了这个教程,本教程在最后也是实现了一个简单的播放器。



,时长00:15

[color=rgba(255, 255, 255, 0.8)]














Video
由于使用本地视频文件会影响App的包大小,所以通常我们的视频文件来源于网络地址,需要在config或者module.json对应的"abilities"中添加网络使用权限ohos.permission.INTERNET。我是为了测试方便用的本地视频,大家别嫌弃。

"abilities":[  {    "permissions": ["ohos.permission.INTERNET"],  }]
(左右移动查看全部内容)

在使用的时候一个VideoController对象可以控制一个或多个video。

//一个VideoController对象可以控制一个或多个video。controller: VideoController = new VideoController();
(左右移动查看全部内容)

接口
declare interface VideoOptions {   src?: string | Resource;
  currentProgressRate?: number | string | PlaybackSpeed;   previewUri?: string | PixelMap | Resource;
  controller?: VideoController;}
(左右移动查看全部内容)

其中仅src( 视频播放源的路径 )这个参数是必填的。

currentProgressRate:number 视频播放倍速,支持0.75,1.0,1.25,1.75,2.0。

previewUri:string 预览图片的路径,可以作为视频未播放时的封面。

controller:VideoController 控制器。一个VideoController对象可以控制一个或多个video。如果需要通过代码控制视频的播放、暂停等,可以给Video组件设置这个参数,然后通过控制器的如下接口控制视频播放状态:

这儿我需要将PlaybackSpeed和VideoController单独拎出来做一个解释。

PlaybackSpeed类型接口说明:
declare enum PlaybackSpeed {
  Speed_Forward_0_75_X,  Speed_Forward_1_00_X,  Speed_Forward_1_25_X,  Speed_Forward_1_75_X,  Speed_Forward_2_00_X,
}
(左右移动查看全部内容)

VideoController
一个VideoController对象可以控制一个或多个video。


在这儿,我同样需要将setCurrentTime单独拎出

setCurrentTime8+
setCurrentTime(value: number, seekMode: SeekMode),指定视频播放的进度位置,并指定跳转模式。

参数

SeekMode8+类型接口说明

declare enum SeekMode {
  PreviousKeyframe,  NextKeyframe,  ClosestKeyframe,  Accurate,
}
(左右移动查看全部内容)

Video属性
muted(是否静音)、autoPlay(自动播放)、controls(控制栏)、objectFit(显示模式)、loop(是否循环播放)。其中,objectFit参数设置值为ImageFit.Cover则铺满整个容器。

详细介绍:

ImageFit枚举说明

事件:

表格:

完整示例:
@Entry@Componentstruct Index {
  @State message: string = '视频预览'  @State previewUris: Resource = $r('app.media.openharmony'); //预览封面  controller: VideoController = new VideoController();  @State currentProgressRate: number = 1  @State muted: boolean = false  @State autoPlay: boolean = true  @State controls: boolean = true  @State startStatus: boolean = true  @State loop: boolean = true
  aboutToAppear() {
    this.controller.requestFullscreen(true)    this.controller.start()
  }
  build() {    Column() {      Text(this.message)
        .fontSize(50)        .fontWeight(FontWeight.Bold)
      Video({        src: $r('app.media.video'),        previewUri: this.previewUris, // 视频封面        currentProgressRate: this.currentProgressRate, // 视频播放倍速        controller: this.controller,
      })
        .muted(this.muted) // 是否静音        .autoPlay(this.autoPlay) // 是否自动播放        .controls(this.controls) // 控制视频播放的控制栏是否显示        .objectFit(ImageFit.Contain) // 视频显示模式        .loop(this.loop) // 是否单个视频循环播放        .height("60%")        .onStart(() => {
          // 播放时触发该事件          console.info('onStart');        })        .onPause(() => {          // 暂停时触发该事件          console.info('onPause');        })        .onFinish(() => {          console.info('onFinish');        })        .onError(() => {          // 播放失败时触发该事件          console.error('onError');        })        .onFullscreenChange((e) => {          console.info('视频进入和退出全屏时触发该事件:' + e.fullscreen)        })        .onPrepared((e) => {          console.info('视频准备完成时触发该事件:' + e.duration)        })        .onSeeking((e) => {          console.info('操作进度条过程时上报时间信息:' + e.time)        })        .onSeeked((e) => {          console.info('操作进度条完成后,上报播放时间信息:' + e.time)        })        .onUpdate((e) => {          console.info('播放进度变化时触发该事件:' + e.time)        })
      Row({}) {
        Flex({ wrap: FlexWrap.Wrap, justifyContent: FlexAlign.SpaceAround, alignItems: ItemAlign.Center }) {
          Button("播放")
            .onClick(() => {              this.controller.start()
            }).margin(8)
          Button("暂停")
            .onClick(() => {              this.controller.pause()
            })          Button("循环播放")
            .onClick(() => {              this.loop=!this.loop
            })          Button("2倍速")
            .onClick(() => {              this.currentProgressRate=2
            })          Button("静音")
            .onClick(() => {              this.muted=!this.muted
            })          Button("停止")
            .onClick(() => {              this.controller.stop()
            })          Button("全屏播放")
            .onClick(() => {              this.controller.requestFullscreen(true)
            })          Button("退出全屏")
            .onClick(() => {              this.controller.exitFullscreen()
            }).margin(8)          Button("控制栏是否显示")
            .onClick(() => {              this.controls = !this.controls
            }).margin(8)
          Button("指定视频播放的进度")
            .onClick(() => {              this.controller.setCurrentTime(9)
            })        }      }    }    .width('100%').height('100%')  }}
(左右移动查看全部内容)

参考文档







欢迎光临 谷动谷力 (http://bbs.sunsili.com/) Powered by Discuz! X3.2