Video

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

说明:

该组件从API version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
Video组件只提供简单的视频播放功能,无法支撑复杂的视频播控场景。复杂开发场景推荐使用AVPlayer播控API和XComponent组件开发。
Video组件在使用expandSafeArea扩展到安全区域时,组件视频显示内容区域不支持扩展。

权限列表

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

子组件

不支持子组件。

接口

Video

Video(value: VideoOptions)

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value VideoOptions 视频信息。

VideoOptions对象说明

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

名称 类型 必填 说明
src string | Resource 视频的数据源,支持本地视频和网络视频。
Resource格式可以跨包/跨模块访问资源文件,常用于访问本地视频。
- 仅支持rawfile文件下的资源,即通过$rawfile引用视频文件。
string格式可用于加载网络视频和本地视频,常用于加载网络视频。
- 支持网络视频地址。
- 支持file://路径前缀的字符串,即应用沙箱URI:file://<bundleName>/<sandboxPath>。用于读取应用沙箱路径内的资源。需要保证目录包路径下的文件有可读权限。
说明:
视频支持的格式是:mp4、mkv、TS。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。
currentProgressRate number | string | PlaybackSpeed8+ 视频播放倍速。
说明:
number格式取值仅支持:0.75,1.0,1.25,1.75,2.0。
string格式支持number格式取值的字符串形式:"0.75","1.0","1.25","1.75","2.0"。
默认值:1.0 | PlaybackSpeed.Speed_Forward_1_00_X
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。
previewUri string | PixelMap | Resource 视频未播放时的预览图片路径,默认不显示图片。
string格式可用于加载本地图片和网络图片,
- 支持网络图片地址。
- 支持相对路径引用本地图片,例如:previewUri: “common/test.jpg”。当使用相对路径引用本地图片时,不支持跨包/跨模块调用。
- 支持file://路径前缀的字符串,即应用沙箱URI:file://<bundleName>/<sandboxPath>。用于读取应用沙箱路径内的资源。需要保证目录包路径下的文件有可读权限。
Resource格式可以跨包/跨模块访问资源文件。
- 支持rawfile文件下的资源,即通过\rawfile引用图片。<br/>−支持通过rawfile引用图片。<br/>- 支持通过\\r引用系统资源或者应用资源中的图片。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。
controller VideoController 设置视频控制器,可以控制视频的播放状态。
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。
imageAIOptions12+ ImageAIOptions 设置图像AI分析选项,可配置分析类型或绑定一个分析控制器。
原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。
posterOptions18+ PosterOptions 设置视频播放的首帧送显选项,可以控制视频是否支持首帧送显。
原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

PlaybackSpeed8+枚举说明

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

名称 说明
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

muted(value: boolean)

设置是否静音。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value boolean 是否静音。
true:开启静音;false:关闭静音。
默认值:false

说明:

Video组件在未设置静音的情况下,起播瞬间会抢占音频焦点。若用户想设置静音播放不抢占其他音频焦点,应保证静音设置在开始播放视频之前。

autoPlay

autoPlay(value: boolean)

设置是否自动播放。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value boolean 是否自动播放。
true:开启自动播放;false:关闭自动播放。
默认值:false

controls

controls(value: boolean)

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

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value boolean 控制视频播放的控制栏是否显示。
true:控制栏显示;false:控制栏不显示。
默认值:true

说明:

Video组件自带的控制器无法自定义。若有其他需求,可隐藏自带控制器,自定义控制器的样式或功能。参考视频播放

objectFit

objectFit(value: ImageFit)

设置视频显示模式。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value ImageFit 视频显示模式。
默认值:Cover

loop

loop(value: boolean)

设置是否单个视频循环播放。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value boolean 是否单个视频循环播放。
true:开启循环播放;false:关闭循环播放。
默认值:false

enableAnalyzer12+

enableAnalyzer(enable: boolean)

设置组件支持AI分析,当前支持主体识别、文字识别和对象查找等功能。 使能后,视频播放暂停时自动进入分析状态,开始分析当前画面帧,视频继续播放后自动退出分析状态。 不能和overlay属性同时使用,两者同时设置时overlayCustomBuilder属性将失效。

原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
enable boolean 是否启用AI分析功能
true:开启AI分析功能;false:关闭AI分析功能。
默认值:false

说明:

当前仅在使用自定义控制栏(controls属性设置为false)时支持该功能。 该特性依赖设备能力。

analyzerConfig12+

analyzerConfig(config: ImageAnalyzerConfig)

设置AI分析识别类型,包括主体识别、文字识别和对象查找等功能。

原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数名 类型 必填 说明
config ImageAnalyzerConfig 设置AI分析识别类型

enableShortcutKey15+

enableShortcutKey(enabled: boolean)

设置组件支持快捷键响应。

目前支持在组件获焦后响应空格键播放/暂停、上下方向键调整视频音量、左右方向键快进/快退。

原子化服务API: 从API version 15开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数名 类型 必填 说明
enabled boolean 是否启用快捷键响应。
true:开启快捷键响应;false:关闭快捷键响应。
默认值:false

事件

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

onStart

onStart(event: VoidCallback)

播放时触发该事件。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
event VoidCallback 视频播放的回调函数。

onPause

onPause(event: VoidCallback)

暂停时触发该事件。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
event VoidCallback 视频暂停的回调函数。

onFinish

onFinish(event: VoidCallback)

播放结束时触发该事件。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
event VoidCallback 视频播放结束的回调函数。

onError

onError(event: () => void)

播放失败时触发该事件。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

onStop12+

onStop(event: Callback<void>)

播放停止时触发该事件(当stop()方法被调用后触发)。

原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

onPrepared

onPrepared(callback: Callback<PreparedInfo>)

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

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
callback Callback<PreparedInfo> 当前视频的时长。

onSeeking

onSeeking(callback: Callback<PlaybackInfo>)

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

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
callback Callback<PlaybackInfo> 当前视频播放的进度。

onSeeked

onSeeked(callback: Callback<PlaybackInfo>)

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

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
callback Callback<PlaybackInfo> 当前视频播放的进度。

onUpdate

onUpdate(callback: Callback<PlaybackInfo>)

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

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
callback Callback<PlaybackInfo> 当前视频播放的进度。

onFullscreenChange

onFullscreenChange(callback: Callback<FullscreenInfo>)

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

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
callback Callback<FullscreenInfo> 当前视频是否进入全屏播放状态。

FullscreenInfo18+对象说明

用于描述当前视频是否进入全屏播放状态。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

名称 类型 只读 可选 说明
fullscreen10+ boolean 当前视频是否进入全屏播放状态。
true:进入全屏播放状态;false:未进入全屏播放状态。
默认值:false
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

PreparedInfo18+对象说明

用于描述当前视频的时长。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

名称 类型 只读 可选 说明
duration10+ number 当前视频的时长。
单位:秒
取值范围:[0,+∞)
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

PlaybackInfo18+对象说明

用于描述当前视频播放的进度。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

名称 类型 只读 可选 说明
time10+ number 当前视频播放的进度。
单位:秒
取值范围:[0,+∞)
原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

PosterOptions18+对象说明

用于描述当前视频是否配置首帧送显。

原子化服务API: 从API version 18开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

名称 类型 只读 可选 说明
showFirstFrame boolean 当前视频是否配置首帧送显。
true:开启首帧送显;false:关闭首帧送显。
默认值:false

VideoController

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

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

导入对象

let controller: VideoController = new VideoController()

constructor

constructor()

VideoController的构造函数。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

start

start()

开始播放。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

pause

pause()

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

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

stop

stop()

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

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

reset12+

reset(): void

Video组件重置AVPlayer。显示当前帧,再次播放时从头开始播放。

原子化服务API: 从API version 12开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

setCurrentTime

setCurrentTime(value: number)

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

说明:

若用户需要从视频内的某一时间点开始播放,应关闭自动播放,在视频准备完成后先跳转再播放。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value number 视频播放进度位置,取值范围:[0, duration],单位:秒。
从API version 8开始,支持设置视频的跳转模式,详见setCurrentTime8+

requestFullscreen

requestFullscreen(value: boolean)

请求全屏播放。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value boolean 是否全屏(填充满应用窗口)播放。
true:请求全屏播放;false:不请求全屏播放。
默认值:false

说明:

Video组件自带的全屏功能仅将视频内容设为全屏,显示默认控制器,无法显示自定义标题或控制器。如需其他功能,用户需自行实现全屏功能。

exitFullscreen

exitFullscreen()

退出全屏播放。

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

setCurrentTime8+

setCurrentTime(value: number, seekMode: SeekMode)

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

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

参数:

参数名 类型 必填 说明
value number 视频播放进度位置,单位:秒。
seekMode SeekMode 跳转模式。

SeekMode8+枚举说明

原子化服务API: 从API version 11开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.ArkUI.ArkUI.Full

名称 说明
PreviousKeyframe 跳转到前一个最近的关键帧。
NextKeyframe 跳转到后一个最近的关键帧。
ClosestKeyframe 跳转到最近的关键帧。
Accurate 精准跳转,不论是否为关键帧。

示例

示例1(视频播放基础用法)

基础用法包括:控制栏、预览图、自动播放、播放速度、响应快捷键、控制器(开始播放、暂停播放、停止播放、重置avPlayer、跳转等)、首帧送显以及一些状态回调方法。

// xxx.ets
@Entry
@Component
struct VideoCreateComponent {
  @State videoSrc: Resource = $rawfile('video1.mp4');
  @State previewUri: Resource = $r('app.media.poster1');
  @State curRate: PlaybackSpeed = PlaybackSpeed.Speed_Forward_1_00_X;
  @State isAutoPlay: boolean = false;
  @State showControls: boolean = true;
  @State isShortcutKeyEnabled: boolean = false;
  @State showFirstFrame: boolean = false;
  controller: VideoController = new VideoController();

  build() {
    Column() {
      Video({
        src: this.videoSrc,
        previewUri: this.previewUri,
        currentProgressRate: this.curRate,
        controller: this.controller,
        posterOptions: { showFirstFrame: this.showFirstFrame }
      })
        .width('100%')
        .height(600)
        .autoPlay(this.isAutoPlay)
        .controls(this.showControls)
        .enableShortcutKey(this.isShortcutKeyEnabled)
        .onStart(() => {
          console.info('onStart')
        })
        .onPause(() => {
          console.info('onPause')
        })
        .onFinish(() => {
          console.info('onFinish')
        })
        .onError(() => {
          console.info('onError')
        })
        .onStop(() => {
          console.info('onStop')
        })
        .onPrepared((e?: DurationObject) => {
          if (e != undefined) {
            console.info('onPrepared is ' + e.duration)
          }
        })
        .onSeeking((e?: TimeObject) => {
          if (e != undefined) {
            console.info('onSeeking is ' + e.time)
          }
        })
        .onSeeked((e?: TimeObject) => {
          if (e != undefined) {
            console.info('onSeeked is ' + e.time)
          }
        })
        .onUpdate((e?: TimeObject) => {
          if (e != undefined) {
            console.info('onUpdate is ' + e.time)
          }
        })
        .onFullscreenChange((e?: FullscreenObject) => {
          if (e != undefined) {
            console.info('onFullscreenChange is ' + e.fullscreen)
          }
        })

      Row() {
        Button('src').onClick(() => {
          this.videoSrc = $rawfile('video2.mp4') // 切换视频源
        }).margin(5)
        Button('previewUri').onClick(() => {
          this.previewUri = $r('app.media.poster2') // 切换视频预览海报
        }).margin(5)
        Button('controls').onClick(() => {
          this.showControls = !this.showControls // 切换是否显示视频控制栏
        }).margin(5)
      }

      Row() {
        Button('start').onClick(() => {
          this.controller.start() // 开始播放
        }).margin(2)
        Button('pause').onClick(() => {
          this.controller.pause() // 暂停播放
        }).margin(2)
        Button('stop').onClick(() => {
          this.controller.stop() // 结束播放
        }).margin(2)
        Button('reset').onClick(() => {
          this.controller.reset() // 重置AVPlayer
        }).margin(2)
        Button('setTime').onClick(() => {
          this.controller.setCurrentTime(10, SeekMode.Accurate) // 精准跳转到视频的10s位置
        }).margin(2)
      }

      Row() {
        Button('rate 0.75').onClick(() => {
          this.curRate = PlaybackSpeed.Speed_Forward_0_75_X // 0.75倍速播放
        }).margin(5)
        Button('rate 1').onClick(() => {
          this.curRate = PlaybackSpeed.Speed_Forward_1_00_X // 原倍速播放
        }).margin(5)
        Button('rate 2').onClick(() => {
          this.curRate = PlaybackSpeed.Speed_Forward_2_00_X // 2倍速播放
        }).margin(5)
      }
    }
  }
}

interface DurationObject {
  duration: number;
}

interface TimeObject {
  time: number;
}

interface FullscreenObject {
  fullscreen: boolean;
}

示例2(图像分析功能)

使用enableAnalyzer属性开启图像AI分析。

// xxx.ets
@Entry
@Component
struct ImageAnalyzerExample {
  @State videoSrc: Resource = $rawfile('video1.mp4');
  @State previewUri: Resource = $r('app.media.poster1');
  @State showControls: boolean = true;
  controller: VideoController = new VideoController();
  config: ImageAnalyzerConfig = {
    types: [ImageAnalyzerType.SUBJECT, ImageAnalyzerType.TEXT]
  }
  private aiController: ImageAnalyzerController = new ImageAnalyzerController();
  private options: ImageAIOptions = {
    types: [ImageAnalyzerType.SUBJECT, ImageAnalyzerType.TEXT],
    aiController: this.aiController
  }

  build() {
    Column() {
      Video({
        src: this.videoSrc,
        previewUri: this.previewUri,
        controller: this.controller,
        imageAIOptions: this.options
      })
        .width('100%')
        .height(600)
        .controls(false)
        .enableAnalyzer(true)
        .analyzerConfig(this.config)
        .onStart(() => {
          console.info('onStart')
        })
        .onPause(() => {
          console.info('onPause')
        })

      Row() {
        Button('start').onClick(() => {
          this.controller.start() // 开始播放
        }).margin(5)
        Button('pause').onClick(() => {
          this.controller.pause() // 暂停播放
        }).margin(5)
        Button('getTypes').onClick(() => {
            this.aiController.getImageAnalyzerSupportTypes()
        }).margin(5)
      }
    }
  }
}

示例3(播放拖入的视频)

以下示例展示了如何使Video组件能够播放拖入的视频。

// xxx.ets
import { unifiedDataChannel, uniformTypeDescriptor } from '@kit.ArkData';

@Entry
@Component
struct Index {
  @State videoSrc: Resource | string = $rawfile('video1.mp4');
  private controller: VideoController = new VideoController();

  build() {
    Column() {
      Video({
        src: this.videoSrc,
        controller: this.controller
      })
        .width('100%')
        .height(600)
        .onPrepared(() => {
          // 在onPrepared回调中执行controller的start方法,确保视频源更换后直接开始播放。
          this.controller.start();
        })
        .onDrop((e: DragEvent) => {
          // 外部视频拖入应用Video组件范围,松手后触发通过onDrop注册的回调。
          // 在DragEvent中会包含拖入的视频源信息,取出后赋值给状态变量videoSrc即可改变Video的视频源。
          let record = e.getData().getRecords()[0];
          if (record.getType() == uniformTypeDescriptor.UniformDataType.VIDEO) {
            let videoInfo = record as unifiedDataChannel.Video;
            this.videoSrc = videoInfo.videoUri;
          }
        })
    }
  }
}