harmony 鸿蒙Video

  • 2025-06-12
  • 浏览 (3)

Video

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

说明:

该组件从API version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
Video组件只提供简单的视频播放功能,无法支撑复杂的视频播控场景。复杂开发场景推荐使用AVPlayer播控APIXComponent组件开发。

权限列表

使用网络视频时,需要申请权限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&nbsp;|&nbsp;string&nbsp;|&nbsp;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&nbsp;|PixelMap&nbsp;|&nbsp;Resource 视频未播放时的预览图片路径,默认不显示图片。
string格式可用于加载本地图片和网络图片,
- 支持网络图片地址。
- 支持相对路径引用本地图片,例如:previewUri: “common/test.jpg”。当使用相对路径引用本地图片时,不支持跨包/跨模块调用。
- 支持file://路径前缀的字符串,即应用沙箱URI:file://<bundleName>/<sandboxPath>。用于读取应用沙箱路径内的资源。需要保证目录包路径下的文件有可读权限。
Resource格式可以跨包/跨模块访问资源文件。
- 支持rawfile文件下的资源,即通过\$rawfile引用图片。
- 支持通过\$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

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

objectFit

objectFit(value: ImageFit)

设置视频填充模式。

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

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

参数:

参数名 类型 必填 说明
value ImageFit 视频填充模式。
默认值:Cover。
约束:不支持ImageFit类型中的枚举值MATRIX,若设置,则作用效果与Cover一致。
异常值:若设置异常值undefined、null,或不在ImageFit枚举范围内的值,作用效果均与Cover一致。

loop

loop(value: boolean)

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

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

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

参数:

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

enableAnalyzer12+

enableAnalyzer(enable: boolean)

设置组件支持AI分析,当前支持主体识别、文字识别和对象查找等功能,支持attributeModifier动态设置属性方法。 使能后,视频播放暂停时自动进入分析状态,开始分析当前画面帧,视频继续播放后自动退出分析状态。 不能和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分析识别类型,包括主体识别、文字识别和对象查找等功能,支持attributeModifier动态设置属性方法。

原子化服务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:&nbsp;VoidCallback)

播放时触发该事件,支持attributeModifier动态设置属性方法。

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

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

参数:

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

onPause

onPause(event:&nbsp;VoidCallback)

暂停时触发该事件,支持attributeModifier动态设置属性方法。

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

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

参数:

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

onFinish

onFinish(event:&nbsp;VoidCallback)

播放结束时触发该事件,支持attributeModifier动态设置属性方法。

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

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

参数:

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

onError

onError(event: VoidCallback|ErrorCallback)

播放失败时触发该事件,支持attributeModifier动态设置属性方法。

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

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

参数:

参数名 类型 必填 说明
event VoidCallback |ErrorCallback20+ 视频播放失败时的回调函数,ErrorCallback入参用于接收异常信息。
Video组件报错信息请参考以下错误信息的详细介绍,其余错误码请请参考媒体错误码

以下是错误信息的详细介绍。

|错误码|错误信息|错误描述| |–|–|–| |103601|Failed to create the media player.|播放器创建失败。| |103602|Not a valid source.|视频资源设置无效。|

onStop12+

onStop(event: Callback&lt;void&gt;)

播放停止时触发该事件(当stop()方法被调用后触发),支持attributeModifier动态设置属性方法。

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

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

onPrepared

onPrepared(callback: Callback<PreparedInfo>)

视频准备完成时触发该事件,支持attributeModifier动态设置属性方法。

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

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

参数:

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

onSeeking

onSeeking(callback: Callback<PlaybackInfo>)

操作进度条过程时上报时间信息,支持attributeModifier动态设置属性方法。

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

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

参数:

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

onSeeked

onSeeked(callback: Callback<PlaybackInfo>)

操作进度条完成后,上报播放时间信息,支持attributeModifier动态设置属性方法。

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

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

参数:

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

onUpdate

onUpdate(callback: Callback<PlaybackInfo>)

播放进度变化时触发该事件,支持attributeModifier动态设置属性方法。

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

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

参数:

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

onFullscreenChange

onFullscreenChange(callback: Callback<FullscreenInfo>)

在全屏播放与非全屏播放状态之间切换时触发该事件,支持attributeModifier动态设置属性方法。

原子化服务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

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 //设置图像AI分析选项
      })
        .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;
          }
        })
    }
  }
}

示例4(视频填充模式)

使用objectFit属性设置视频填充模式。

// xxx.ets
@Entry
@Component
struct video {
  @State videoSrc: Resource = $rawfile('rabbit.mp4')
  @State previewUri: Resource = $r('app.media.tree')
  @State curRate: PlaybackSpeed = PlaybackSpeed.Speed_Forward_1_00_X
  @State isAutoPlay: boolean = true
  @State showControls: boolean = true
  controller: VideoController = new VideoController()

  build() {
    Column() {
      Text("ImageFit.Contain").fontSize(12)
      Video({
        src: this.videoSrc,
        previewUri: this.previewUri,
        currentProgressRate: this.curRate,
        controller: this.controller
      })
        .width(350)
        .height(230)
        .controls(this.showControls)
        .objectFit(ImageFit.Contain)//设置视频填充模式为ImageFit.Contain
        .margin(5)

      Text("ImageFit.Fill").fontSize(12)
      Video({
        src: this.videoSrc,
        previewUri: this.previewUri,
        currentProgressRate: this.curRate,
        controller: this.controller
      })
        .width(350)
        .height(230)
        .controls(this.showControls)
        .objectFit(ImageFit.Fill)//设置视频填充模式为ImageFit.Fill
        .margin(5)

      Text("ImageFit.START").fontSize(12)
      Video({
        src: this.videoSrc,
        previewUri: this.previewUri,
        currentProgressRate: this.curRate,
        controller: this.controller
      })
        .width(350)
        .height(230)
        .controls(this.showControls)
        .objectFit(ImageFit.START)//设置视频填充模式为ImageFit.START
        .margin(5)
    }.width('100%').alignItems(HorizontalAlign.Center)
  }
}

VideoObjectFit

示例5(onError事件上报错误码)

以下示例以传入不存在的视频资源路径为例,展示了如何使Video组件能够通过onError事件获取错误码。

// xxx.ets
@Entry
@Component
struct VideoErrorComponent {
  @State videoSrc: string = "video.mp4" // 传入不存在的视频资源路径。
  @State curRate: PlaybackSpeed = PlaybackSpeed.Speed_Forward_1_00_X
  @State isAutoPlay: boolean = false
  @State showControls: boolean = true
  @State showFirstFrame: boolean = false
  controller: VideoController = new VideoController()
  @State errorMessage: string = ""

  build() {
    Column() {
      Video({
        src: this.videoSrc,
        currentProgressRate: this.curRate,
        controller: this.controller,
      })
        .width(200)
        .height(120)
        .margin(5)
        .autoPlay(this.isAutoPlay)
        .controls(this.showControls)
        .onError((err) => {
          // 通过onError事件获取错误码,code为错误码,message为错误信息。
          console.error(`code is ${err.code}, message is ${err.message}`);
          this.errorMessage = `code is ${err.code}, message is ${err.message}`;
        })
      // 传入不存在的视频资源路径,预期:"code is 103602, message is Not a valid source"。
      Text(this.errorMessage)
    }
    .width("100%")
    .height("100%")
    .backgroundColor('rgb(213,213,213)')
  }
}

示例6(使用attributeModifier动态设置Video组件的属性及方法)

以下示例展示了如何使用attributeModifier动态设置Video组件的enableAnalyzer、analyzerConfig属性和onStart、onPause、onFinish、onError、onStop、onPrepared、onSeeking、onSeeked、onUpdate、onFullscreenChange方法。

// xxx.ets
class MyVideoModifier implements AttributeModifier<VideoAttribute> {
  applyNormalAttribute(instance: VideoAttribute): void {
    // 设置开启组件AI分析功能,长按触发AI识别功能
    instance.enableAnalyzer(true)
    let config: ImageAnalyzerConfig = {
      types: [ImageAnalyzerType.SUBJECT, ImageAnalyzerType.TEXT]
    }
    instance.analyzerConfig(config)
    instance.onStart(() => {
      console.info('video: onStart')
    })
    instance.onPause(() => {
      console.info('video: onPause')
    })
    instance.onFinish(() => {
      console.info('video: onFinish')
    })
    instance.onError((err) => {
      console.error('video: onError is code = ' + err.code + ', message = ' + err.message)
    })
    instance.onStop(() => {
      console.info('video: onStop')
    })
    instance.onPrepared((e?: DurationObject) => {
      if (e != undefined) {
        console.info('video: onPrepared is ' + e.duration)
      }
    })
    instance.onSeeking((e?: TimeObject) => {
      if (e != undefined) {
        console.info('video: onSeeking is ' + e.time)
      }
    })
    instance.onSeeked((e?: TimeObject) => {
      if (e != undefined) {
        console.info('video: onSeeked is ' + e.time)
      }
    })
    instance.onUpdate((e?: TimeObject) => {
      if (e != undefined) {
        console.info('video: onUpdate is ' + e.time)
      }
    })
    instance.onFullscreenChange((e?: FullscreenObject) => {
      if (e != undefined) {
        console.info('video: onFullscreenChange is ' + e.fullscreen)
      }
    })
  }
}

@Entry
@Component
struct VideoModifierDemo {
  @State videoSrc: Resource = $rawfile('video.mp4');
  @State curRate: PlaybackSpeed = PlaybackSpeed.Speed_Forward_1_00_X;
  @State isAutoPlay: boolean = false;
  @State showControls: boolean = false;
  controller: VideoController = new VideoController();
  @State modifier: MyVideoModifier = new MyVideoModifier()

  build() {
    Column() {
      Video({
        src: this.videoSrc,
        currentProgressRate: this.curRate, //设置播放速度
        controller: this.controller
      })
        .width(300)
        .height(180)
        .autoPlay(this.isAutoPlay)
        .controls(this.showControls)
        .attributeModifier(this.modifier)
      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)
      }

      Row() {
        Button('Fullscreen').onClick(() => {
          this.controller.requestFullscreen(true) // 全屏
        }).margin(2)
        Button('showControls').onClick(() => {
          this.showControls = !this.showControls // 显示控制栏
        }).margin(2)
      }
    }
  }
}

interface DurationObject {
  duration: number;
}

interface TimeObject {
  time: number;
}

interface FullscreenObject {
  fullscreen: boolean;
}

你可能感兴趣的鸿蒙文章

harmony 鸿蒙图像AI分析错误码

harmony 鸿蒙ArcButton

harmony 鸿蒙ArcSlider

harmony 鸿蒙Chip

harmony 鸿蒙ChipGroup

harmony 鸿蒙ComposeListItem

harmony 鸿蒙ComposeTitleBar

harmony 鸿蒙advanced.Counter

harmony 鸿蒙弹出框 (Dialog)

harmony 鸿蒙DialogV2

0  赞