0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

OpenHarmony视频播放器

ArkUI详解 来源:鸿蒙实验室 作者:鸿蒙实验室 2022-08-16 15:06 次阅读

OpenHarmony视频播放器

作者“坚果,华为云享专家,InfoQ签约作者,润和软件KOL专家,电子发烧友鸿蒙MVP,51CTO博客专家博主,阿里云博客专家,开源项目gin-vue-admin成员之一

由于视频资源在项目中使用较为频繁,于是有了这个教程,本教程在最后也是实现了一个简单的播放器。

效果预览

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( 视频播放源的路径 )这个参数是必填的。

支持本地视频路径和网络路径。

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

支持dataability://的路径前缀,用于访问通过Data Ability提供的视频路径

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

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

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

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

PlaybackSpeed类型接口说明

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倍速播放。
名称 描述

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。

start() : void 开始播放。

pause() : void 暂停播放。

stop() : void 停止播放。

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

requestFullscreen() : boolean() 请求全屏播放,true是横屏,false竖屏。

exitFullscreen() : void 退出全屏。

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

setCurrentTime8+

setCurrentTime(value: number, seekMode: SeekMode)

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

参数

SeekMode8+类型接口说明

declare enum SeekMode {

PreviousKeyframe,

NextKeyframe,

ClosestKeyframe,

Accurate,

}

Video属性

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

详细介绍

.muted(boolean) 默认值false 是否静音。

.autoPlay(boolean) 默认值false 是否自动播放。

.controls(boolean) 默认值true 控制视频播放的控制栏是否显示。

.loop(boolean) 是否单个视频循环播放。

.objectFit(ImageFit) 默认值Cover 设置视频显示模式。ImageFit有如下枚举值可选

ImageFit枚举说明

名称 描述
Cover 保持宽高比进行缩小或者放大,使得图片两边都大于或等于显示边界。
Contain 保持宽高比进行缩小或者放大,使得图片完全显示在显示边界内。
Fill 不保持宽高比进行放大缩小,使得图片填充满显示边界。
None 保持原有尺寸显示。通常配合objectRepeat属性一起使用。
ScaleDown 保持宽高比显示,图片缩小或者保持不变。

事件

onStart() => void 播放时触发该事件。

onPause() => void 暂停时触发该事件。

onFinish() => void 播放结束时触发该事件。

onError() => void 播放失败时触发该事件。

onFullscreenChange(event?: { fullscreen: boolean }) => void) 视频进入和退出全屏时触发该事件。

onPrepared(event?: { duration: number }) => void 视频准备完成时触发该事件,通过duration可以获取视频时长,单位为秒(s)。

onSeeking(event?: { time: number }) => void 操作进度条过程时上报时间信息,单位为s。

onSeeked(event?: { time: number }) => void 操作进度条完成后,上报播放时间信息,单位为s。

onUpdate(event?: { time: number }) => void 播放进度变化时触发该事件,单位为s,更新时间间隔为250ms。

表格

名称 功能描述
onStart() => void 播放时触发该事件。
onPause() => void 暂停时触发该事件。
onFinish() => void 播放结束时触发该事件。
onError() => void 播放失败时触发该事件。
onPrepared(event?: { duration: number }) => void 视频准备完成时触发该事件,通过duration可以获取视频时长,单位为秒(s)。
onSeeking(event?: { time: number }) => void 操作进度条过程时上报时间信息,单位为s。
onSeeked(event?: { time: number }) => void 操作进度条完成后,上报播放时间信息,单位为s。
onUpdate(event?: { time: number }) => void 播放进度变化时触发该事件,单位为s,更新时间间隔为250ms。

完整示例

@

Entry

@

Component

struct

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%'

)

}

}

参考文档

video

flex

名称 描述
PreviousKeyframe 跳转到前一个最近的关键帧。
NextKeyframe 跳转到后一个最近的关键帧。
ClosestKeyframe 跳转到最近的关键帧。
Accurate 精准跳转,不论是否为关键帧。
参数名 参数类型 必填 默认值 参数描述
value number - 视频播放进度位置。
seekMode SeekMode - 跳转模式。
审核编辑:汤梓红
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Video
    +关注

    关注

    0

    文章

    192

    浏览量

    44857
  • 视频播放器
    +关注

    关注

    0

    文章

    33

    浏览量

    11781
  • OpenHarmony
    +关注

    关注

    23

    文章

    3275

    浏览量

    15159
收藏 人收藏

    评论

    相关推荐

    灵活电影播放器视频/音频播放软件

    (Flexible Movie Player)视频/音频播放软件包。该软件将从2008年7月开始在日本上市。灵活电影播放器是适用于SH-Mobile的软件,它整合了支持H.264/MPEG-4AVC*2(以下
    发表于 03-06 19:52

    labview做视频播放器

    labview做视频播放器
    发表于 08-25 15:13

    【教学基地】07漂亮的视频播放器

    ` 本帖最后由 a156789156782 于 2018-6-2 13:28 编辑 【教学视频03007】labview视频播放器通过本节视频
    发表于 05-24 22:15

    基于LabVIEW的视频播放器

    利用LabVIEW制作视频播放器的主要方法都在这里了,高级版可以添加追踪,还包含一个未完成的小论文,可以拿去当课程设计
    发表于 06-27 19:50

    视频播放器在linux环境的应用

    推荐一款linux环境下好用的视频播放器mplayer没有图形化界面smplayer是mplayer的有图形化界面的软件
    发表于 07-19 06:51

    DistributedVideoPlayer分布式视频播放器的设计资料

    1、DistributedVideoPlayer分布式视频播放器的设计资料(一)本示例是在官方Video Play Ability 模板基础上做了扩展开发,官方模板提供基本的视频播放
    发表于 03-22 11:55

    如何基于 OpenHarmony 制作一个简单视频播放器

    OpenHarmony视频播放器作者“坚果,华为云享专家,InfoQ签约作者,润和软件KOL专家,电子发烧友鸿蒙MVP,阿里云博客专家,开源项目gin-vue-admin成员之一由于视频
    发表于 08-16 18:02

    #DAYU200#OpenHarmony 视频播放器

    0.75,1.0,1.25,1.75,2.0。previewUri:string 预览图片的路径,可以作为视频播放时的封面。controller:VideoController 控制。一个
    发表于 09-15 17:25

    在DAYU200上实现OpenHarmony视频播放器

    内容简介本文介绍了如何使用ArkUI框架提供的video组件,实现一个具有简易播放器。通过VideoController控制来控制倍速、全屏、进度调节等功能。由于使用本地视频文件会影响App的包
    发表于 10-14 12:12

    网页视频播放器代码

    网页视频播放器代码
    发表于 01-10 11:23 102次下载
    网页<b class='flag-5'>视频</b><b class='flag-5'>播放器</b>代码

    flv视频播放器代码

    flv视频播放器代码 FlV视频播放器代码 代码如下这里只是介绍几个例子,现在把代码公布一下,大家可以参考着做,也可以把你喜欢的视频连接
    发表于 01-10 12:36 1926次阅读

    MP4播放器视频播放格式有哪些?

    MP4播放器视频播放格式有哪些?        
    发表于 12-21 15:51 2.4w次阅读

    关于VR电影视频播放器 盘点12款VR播放器

    VR电影和视频那个播放器好,哪些播放器更为实用,由于视频资源格式多样,在一个播放器播放不了的
    发表于 06-27 15:50 12.2w次阅读

    在DAYU200上实现OpenHarmony视频播放器

    何使用ArkUI框架提供的video组件,实现一个具有简易播放器。通过VideoController控制器来控制倍速、全屏、进度调节等功能。 由于使用本地视频文件会影响App的包大小,所以通常我们
    的头像 发表于 10-27 10:19 651次阅读

    HarmonyOS开发案例:【视频播放器

    使用ArkTS语言实现视频播放器,主要包括主界面和视频播放界面,
    的头像 发表于 04-23 17:25 116次阅读
    HarmonyOS开发案例:【<b class='flag-5'>视频</b><b class='flag-5'>播放器</b>】