视频

2024-01-22 18:01 更新

用于播放视频文件并控制其播放状态的组件。

说明

该组件从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。

权限列表

使用网络视频时,需要申请权限ohos.permission.INTERNET。具体申请方式请参考权限申请声明

子组件

不支持子组件。

接口

Video(value: {src?: string | Resource, currentProgressRate?: number | string | PlaybackSpeed, previewUri?: string | PixelMap | Resource, controller?: VideoController})

参数:

参数名

参数类型

必填

参数描述

src

string | Resource

视频播放源的路径,支持本地视频路径和网络路径。

支持在resources下面的video或rawfile文件夹里放置媒体资源。

支持dataability://的路径前缀,用于访问通过Data Ability提供的视频路径,具体路径信息详见DataAbility说明

支持file:///data/storage路径前缀的字符串,用于读取应用沙箱路径内的资源。需要保证目录包路径下的文件有可读权限。

说明:

视频支持的格式是:mp4、mkv、webm、TS。

currentProgressRate

number | string | PlaybackSpeed8+

视频播放倍速。

说明:

number取值仅支持:0.75,1.0,1.25,1.75,2.0。

默认值:1.0 | PlaybackSpeed.Speed_Forward_1_00_X

previewUri

string | PixelMap8+ | Resource

视频未播放时的预览图片路径,默认不显示图片。

controller

VideoController

设置视频控制器,可以控制视频的播放状态。

PlaybackSpeed8+枚举说明

名称

描述

Speed_Forward_0_75_X

0.75倍速播放。

Speed_Forward_1_00_X

1倍速播放。

Speed_Forward_1_25_X

1.25倍速播放。

Speed_Forward_1_75_X

1.75倍速播放。

Speed_Forward_2_00_X

2倍速播放。

属性

除支持通用属性外,还支持以下属性:

名称

参数类型

描述

muted

boolean

是否静音。

默认值:false

autoPlay

boolean

是否自动播放。

默认值:false

controls

boolean

控制视频播放的控制栏是否显示。

默认值:true

objectFit

ImageFit

设置视频显示模式。

默认值:Cover

loop

boolean

是否单个视频循环播放。

默认值:false

事件

除支持通用事件外,还支持以下事件:

名称

功能描述

onStart(event:() => void)

播放时触发该事件。

onPause(event:() => void)

暂停时触发该事件。

onFinish(event:() => void)

播放结束时触发该事件。

onError(event:() => void)

播放失败时触发该事件。

onPrepared(callback:(event?: { duration: number }) => void)

视频准备完成时触发该事件。

duration:当前视频的时长,单位为秒(s)。

onSeeking(callback:(event?: { time: number }) => void)

操作进度条过程时上报时间信息。

time:当前视频播放的进度,单位为s。

onSeeked(callback:(event?: { time: number }) => void)

操作进度条完成后,上报播放时间信息。

time:当前视频播放的进度,单位为s。

onUpdate(callback:(event?: { time: number }) => void)

播放进度变化时触发该事件。

time:当前视频播放的进度,单位为s。

onFullscreenChange(callback:(event?: { fullscreen: boolean }) => void)

在全屏播放与非全屏播放状态之间切换时触发该事件。

fullscreen:返回值为true表示进入全屏播放状态,为false则表示非全屏播放。

VideoController

一个VideoController对象可以控制一个或多个video,可用视频播放实例请参考media.createAVPlayer

导入对象

  1. controller: VideoController = new VideoController()

start

start(): void

开始播放。

pause

pause(): void

暂停播放,显示当前帧,再次播放时从当前位置继续播放。

stop

stop(): void

停止播放,显示当前帧,再次播放时从头开始播放。

setCurrentTime

setCurrentTime(value: number)

指定视频播放的进度位置。

参数:

参数名

参数类型

必填

参数描述

value

number

视频播放进度位置,单位为s。

requestFullscreen

requestFullscreen(value: boolean)

请求全屏播放。

参数:

参数名

参数类型

必填

参数描述

value

boolean

是否全屏(填充满应用窗口)播放。

exitFullscreen

exitFullscreen()

退出全屏播放。

setCurrentTime8+

setCurrentTime(value: number, seekMode: SeekMode)

指定视频播放的进度位置,并指定跳转模式。

参数:

参数名

参数类型

必填

参数描述

value

number

视频播放进度位置,单位为s。

seekMode

SeekMode

跳转模式。

SeekMode8+枚举说明

名称

描述

PreviousKeyframe

跳转到前一个最近的关键帧。

NextKeyframe

跳转到后一个最近的关键帧。

ClosestKeyframe

跳转到最近的关键帧。

Accurate

精准跳转,不论是否为关键帧。

示例

  1. // xxx.ets
  2. @Entry
  3. @Component
  4. struct VideoCreateComponent {
  5. @State videoSrc: Resource = $rawfile('video1.mp4')
  6. @State previewUri: Resource = $r('app.media.poster1')
  7. @State curRate: PlaybackSpeed = PlaybackSpeed.Speed_Forward_1_00_X
  8. @State isAutoPlay: boolean = false
  9. @State showControls: boolean = true
  10. controller: VideoController = new VideoController()
  11. build() {
  12. Column() {
  13. Video({
  14. src: this.videoSrc,
  15. previewUri: this.previewUri,
  16. currentProgressRate: this.curRate,
  17. controller: this.controller
  18. }).width('100%').height(600)
  19. .autoPlay(this.isAutoPlay)
  20. .controls(this.showControls)
  21. .onStart(() => {
  22. console.info('onStart')
  23. })
  24. .onPause(() => {
  25. console.info('onPause')
  26. })
  27. .onFinish(() => {
  28. console.info('onFinish')
  29. })
  30. .onError(() => {
  31. console.info('onError')
  32. })
  33. .onPrepared((e) => {
  34. console.info('onPrepared is ' + e.duration)
  35. })
  36. .onSeeking((e) => {
  37. console.info('onSeeking is ' + e.time)
  38. })
  39. .onSeeked((e) => {
  40. console.info('onSeeked is ' + e.time)
  41. })
  42. .onUpdate((e) => {
  43. console.info('onUpdate is ' + e.time)
  44. })
  45. Row() {
  46. Button('src').onClick(() => {
  47. this.videoSrc = $rawfile('video2.mp4') // 切换视频源
  48. }).margin(5)
  49. Button('previewUri').onClick(() => {
  50. this.previewUri = $r('app.media.poster2') // 切换视频预览海报
  51. }).margin(5)
  52. Button('controls').onClick(() => {
  53. this.showControls = !this.showControls // 切换是否显示视频控制栏
  54. }).margin(5)
  55. }
  56. Row() {
  57. Button('start').onClick(() => {
  58. this.controller.start() // 开始播放
  59. }).margin(5)
  60. Button('pause').onClick(() => {
  61. this.controller.pause() // 暂停播放
  62. }).margin(5)
  63. Button('stop').onClick(() => {
  64. this.controller.stop() // 结束播放
  65. }).margin(5)
  66. Button('setTime').onClick(() => {
  67. this.controller.setCurrentTime(10, SeekMode.Accurate) // 精准跳转到视频的10s位置
  68. }).margin(5)
  69. }
  70. Row() {
  71. Button('rate 0.75').onClick(() => {
  72. this.curRate = PlaybackSpeed.Speed_Forward_0_75_X // 0.75倍速播放
  73. }).margin(5)
  74. Button('rate 1').onClick(() => {
  75. this.curRate = PlaybackSpeed.Speed_Forward_1_00_X // 原倍速播放
  76. }).margin(5)
  77. Button('rate 2').onClick(() => {
  78. this.curRate = PlaybackSpeed.Speed_Forward_2_00_X // 2倍速播放
  79. }).margin(5)
  80. }
  81. }
  82. }
  83. }
以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号