Video
用于播放視頻文件并控制其播放狀態(tài)的組件。
說明:
該組件從API Version 7開始支持。后續(xù)版本如有新增內(nèi)容,則采用上角標(biāo)單獨標(biāo)記該內(nèi)容的起始版本。
權(quán)限列表
使用網(wǎng)絡(luò)視頻時,需要申請權(quán)限ohos.permission.INTERNET。具體申請方式請參考[權(quán)限申請聲明]。
子組件
不支持子組件。
接口
Video(value: {src?: string | Resource, currentProgressRate?: number | string | PlaybackSpeed, previewUri?: string | PixelMap | Resource, controller?: VideoController})
參數(shù)名 | 參數(shù)類型 | 必填 | 參數(shù)描述 |
---|---|---|---|
src | string | [Resource] | 否 |
currentProgressRate | number | string | PlaybackSpeed8+ |
previewUri | string | PixelMap | [Resource] |
controller | [VideoController] | 否 | 設(shè)置視頻控制器,可以控制視頻的播放狀態(tài)。 |
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倍速播放。 |
屬性
除支持[通用屬性]外,還支持以下屬性:
名稱 | 參數(shù)類型 | 描述 |
---|---|---|
muted | boolean | 是否靜音。 默認(rèn)值:false |
autoPlay | boolean | 是否自動播放。 默認(rèn)值:false |
controls | boolean | 控制視頻播放的控制欄是否顯示。 默認(rèn)值:true |
objectFit | [ImageFit] | 設(shè)置視頻顯示模式。 默認(rèn)值:Cover |
loop | boolean | 是否單個視頻循環(huán)播放。 默認(rèn)值:false |
事件
除支持[通用事件]外,還支持以下事件:
名稱 | 功能描述 |
---|---|
onStart(event:() => void) | 播放時觸發(fā)該事件。 |
onPause(event:() => void) | 暫停時觸發(fā)該事件。 |
onFinish(event:() => void) | 播放結(jié)束時觸發(fā)該事件。 |
onError(event:() => void) | 播放失敗時觸發(fā)該事件。 |
onPrepared(callback:(event?: { duration: number }) => void) | 視頻準(zhǔn)備完成時觸發(fā)該事件。 duration:當(dāng)前視頻的時長,單位為秒(s)。 |
onSeeking(callback:(event?: { time: number }) => void) | 操作進(jìn)度條過程時上報時間信息。 time:當(dāng)前視頻播放的進(jìn)度,單位為s。 |
onSeeked(callback:(event?: { time: number }) => void) | 操作進(jìn)度條完成后,上報播放時間信息。 time:當(dāng)前視頻播放的進(jìn)度,單位為s。 |
onUpdate(callback:(event?: { time: number }) => void) | 播放進(jìn)度變化時觸發(fā)該事件。 time:當(dāng)前視頻播放的進(jìn)度,單位為s。 |
onFullscreenChange(callback:(event?: { fullscreen: boolean }) => void) | 在全屏播放與非全屏播放狀態(tài)之間切換時觸發(fā)該事件。 fullscreen:返回值為true表示進(jìn)入全屏播放狀態(tài),為false則表示非全屏播放。 |
VideoController
一個VideoController對象可以控制一個或多個video,可用視頻播放實例請參考[@ohos.multimedia.media])。
導(dǎo)入對象
let controller: VideoController = new VideoController()
start
start(): void
開始播放。
pause
pause(): void
暫停播放,顯示當(dāng)前幀,再次播放時從當(dāng)前位置繼續(xù)播放。
stop
stop(): void
停止播放,顯示當(dāng)前幀,再次播放時從頭開始播放。
setCurrentTime
setCurrentTime(value: number)
指定視頻播放的進(jìn)度位置。
參數(shù):
參數(shù)名 | 參數(shù)類型 | 必填 | 參數(shù)描述 |
---|---|---|---|
value | number | 是 | 視頻播放進(jìn)度位置,單位為s。 |
requestFullscreen
requestFullscreen(value: boolean)
請求全屏播放。
參數(shù):
參數(shù)名 | 參數(shù)類型 | 必填 | 參數(shù)描述 |
---|---|---|---|
value | boolean | 是 | 是否全屏(填充滿應(yīng)用窗口)播放。 |
exitFullscreen
exitFullscreen()
退出全屏播放。
setCurrentTime8+
setCurrentTime(value: number, seekMode: SeekMode)
指定視頻播放的進(jìn)度位置,并指定跳轉(zhuǎn)模式。
參數(shù):
參數(shù)名 | 參數(shù)類型 | 必填 | 參數(shù)描述 |
---|---|---|---|
value | number | 是 | 視頻播放進(jìn)度位置,單位為s。 |
seekMode | SeekMode | 是 | 跳轉(zhuǎn)模式。 |
SeekMode8+枚舉說明
名稱 開發(fā)前請熟悉鴻蒙開發(fā)指導(dǎo)文檔:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md ] | 描述 |
---|---|
PreviousKeyframe | 跳轉(zhuǎn)到前一個最近的關(guān)鍵幀。 |
NextKeyframe | 跳轉(zhuǎn)到后一個最近的關(guān)鍵幀。 |
ClosestKeyframe | 跳轉(zhuǎn)到最近的關(guān)鍵幀。 |
Accurate | 精準(zhǔn)跳轉(zhuǎn),不論是否為關(guān)鍵幀。 |
示例
// 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
controller: VideoController = new VideoController()
build() {
Column() {
Video({
src: this.videoSrc,
previewUri: this.previewUri,
currentProgressRate: this.curRate,
controller: this.controller
})
.width('100%')
.height(600)
.autoPlay(this.isAutoPlay)
.controls(this.showControls)
.onStart(() = > {
console.info('onStart')
})
.onPause(() = > {
console.info('onPause')
})
.onFinish(() = > {
console.info('onFinish')
})
.onError(() = > {
console.info('onError')
})
.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)
}
})
Row() {
Button('src').onClick(() = > {
this.videoSrc = $rawfile('video2.mp4') // 切換視頻源
}).margin(5)
Button('previewUri').onClick(() = > {
this.previewUri = $r('app.media.poster2') // 切換視頻預(yù)覽海報
}).margin(5)
Button('controls').onClick(() = > {
this.showControls = !this.showControls // 切換是否顯示視頻控制欄
}).margin(5)
}
Row() {
Button('start').onClick(() = > {
this.controller.start() // 開始播放
}).margin(5)
Button('pause').onClick(() = > {
this.controller.pause() // 暫停播放
}).margin(5)
Button('stop').onClick(() = > {
this.controller.stop() // 結(jié)束播放
}).margin(5)
Button('setTime').onClick(() = > {
this.controller.setCurrentTime(10, SeekMode.Accurate) // 精準(zhǔn)跳轉(zhuǎn)到視頻的10s位置
}).margin(5)
}
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;
}
審核編輯 黃宇
-
組件
+關(guān)注
關(guān)注
1文章
512瀏覽量
17813 -
鴻蒙
+關(guān)注
關(guān)注
57文章
2342瀏覽量
42818
發(fā)布評論請先 登錄
相關(guān)推薦
評論