Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
8d19b5dc
D
Docs
项目概览
OpenHarmony
/
Docs
1 年多 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
8d19b5dc
编写于
8月 25, 2023
作者:
S
shuboxu
提交者:
Gitee
8月 25, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update zh-cn/application-dev/media/video-recording.md.
Signed-off-by:
N
shuboxu
<
xushubo1@huawei.com
>
上级
9aa61683
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
19 addition
and
18 deletion
+19
-18
zh-cn/application-dev/media/video-recording.md
zh-cn/application-dev/media/video-recording.md
+19
-18
未找到文件。
zh-cn/application-dev/media/video-recording.md
浏览文件 @
8d19b5dc
...
...
@@ -24,10 +24,10 @@ AVRecorder详细的API说明请参考[AVRecorder API参考](../reference/apis/js
```
ts
import
media
from
'
@ohos.multimedia.media
'
let
avRecorder
media
.
createAVRecorder
().
then
((
recorder
)
=>
{
let
avRecorder
:
media
.
AVRecorder
;
media
.
createAVRecorder
().
then
((
recorder
:
media
.
AVRecorder
)
=>
{
avRecorder
=
recorder
},
(
error
)
=>
{
},
(
error
:
Error
)
=>
{
console
.
error
(
'
createAVRecorder failed
'
)
})
```
...
...
@@ -40,11 +40,11 @@ AVRecorder详细的API说明请参考[AVRecorder API参考](../reference/apis/js
```
ts
// 状态上报回调函数
avRecorder
.
on
(
'
stateChange
'
,
(
state
,
r
eason
)
=>
{
avRecorder
.
on
(
'
stateChange
'
,
(
state
:
media
.
AVRecorderState
,
reason
:
media
.
StateChangeR
eason
)
=>
{
console
.
info
(
'
current state is:
'
+
state
);
})
// 错误上报回调函数
avRecorder
.
on
(
'
error
'
,
(
err
)
=>
{
avRecorder
.
on
(
'
error
'
,
(
err
:
BusinessError
)
=>
{
console
.
error
(
'
error happened, error message is
'
+
err
);
})
```
...
...
@@ -62,7 +62,7 @@ AVRecorder详细的API说明请参考[AVRecorder API参考](../reference/apis/js
> - 录制输出的url地址(即示例里avConfig中的url),形式为fd://xx (fd number)。需要调用基础文件操作接口([ohos.file.fs](../reference/apis/js-apis-file-fs.md))实现应用文件访问能力,获取方式参考[应用文件访问与管理](../file-management/app-file-access.md)。
```
ts
let
avProfile
=
{
let
avProfile
:
media
.
AVRecorderProfile
=
{
fileFormat
:
media
.
ContainerFormatType
.
CFT_MPEG_4
,
// 视频文件封装格式,只支持MP4
videoBitrate
:
200000
,
// 视频比特率
videoCodec
:
media
.
CodecMimeType
.
VIDEO_AVC
,
// 视频文件编码格式,支持mpeg4和avc两种格式
...
...
@@ -70,15 +70,15 @@ AVRecorder详细的API说明请参考[AVRecorder API参考](../reference/apis/js
videoFrameHeight
:
480
,
// 视频分辨率的高
videoFrameRate
:
30
// 视频帧率
}
let
avConfig
=
{
let
avConfig
:
media
.
AVRecorderConfig
=
{
videoSourceType
:
media
.
VideoSourceType
.
VIDEO_SOURCE_TYPE_SURFACE_YUV
,
// 视频源类型,支持YUV和ES两种格式
profile
:
this
.
avProfile
,
profile
:
avProfile
,
url
:
'
fd://35
'
,
// 参考应用文件访问与管理开发示例新建并读写一个文件
rotation
:
0
,
// 视频旋转角度,默认为0不旋转,支持的值为0、90、180、270
}
avRecorder
.
prepare
(
avConfig
).
then
(()
=>
{
console
.
info
(
'
avRecorder prepare success
'
)
},
(
error
)
=>
{
},
(
error
:
Error
)
=>
{
console
.
error
(
'
avRecorder prepare failed
'
)
})
```
...
...
@@ -89,9 +89,9 @@ AVRecorder详细的API说明请参考[AVRecorder API参考](../reference/apis/js
输入源模块通过SurfaceID可以获取到Surface,通过Surface可以将视频数据流传递给AVRecorder,由AVRecorder再进行视频数据的处理。
```
ts
avRecorder
.
getInputSurface
().
then
((
surfaceId
)
=>
{
avRecorder
.
getInputSurface
().
then
((
surfaceId
:
string
)
=>
{
console
.
info
(
'
avRecorder getInputSurface success
'
)
},
(
error
)
=>
{
},
(
error
:
Error
)
=>
{
console
.
error
(
'
avRecorder getInputSurface failed
'
)
})
```
...
...
@@ -118,11 +118,12 @@ AVRecorder详细的API说明请参考[AVRecorder API参考](../reference/apis/js
```
ts
import
media
from
'
@ohos.multimedia.media
'
import
{
BusinessError
}
from
'
@ohos.base
'
;
const
TAG
=
'
VideoRecorderDemo:
'
export
class
VideoRecorderDemo
{
private
avRecorder
;
private
videoOutSurfaceId
;
private
avProfile
=
{
private
avRecorder
:
media
.
AVRecorder
;
private
videoOutSurfaceId
:
string
;
private
avProfile
:
media
.
AVRecorderProfile
=
{
fileFormat
:
media
.
ContainerFormatType
.
CFT_MPEG_4
,
// 视频文件封装格式,只支持MP4
videoBitrate
:
100000
,
// 视频比特率
videoCodec
:
media
.
CodecMimeType
.
VIDEO_AVC
,
// 视频文件编码格式,支持mpeg4和avc两种格式
...
...
@@ -130,7 +131,7 @@ export class VideoRecorderDemo {
videoFrameHeight
:
480
,
// 视频分辨率的高
videoFrameRate
:
30
// 视频帧率
}
private
avConfig
=
{
private
avConfig
:
media
.
AVRecorderConfig
=
{
videoSourceType
:
media
.
VideoSourceType
.
VIDEO_SOURCE_TYPE_SURFACE_YUV
,
// 视频源类型,支持YUV和ES两种格式
profile
:
this
.
avProfile
,
url
:
'
fd://35
'
,
// 参考应用文件访问与管理开发示例新建并读写一个文件
...
...
@@ -140,11 +141,11 @@ export class VideoRecorderDemo {
// 注册avRecorder回调函数
setAvRecorderCallback
()
{
// 状态机变化回调函数
this
.
avRecorder
.
on
(
'
stateChange
'
,
(
state
,
r
eason
)
=>
{
this
.
avRecorder
.
on
(
'
stateChange
'
,
(
state
:
media
.
AVRecorderState
,
reason
:
media
.
StateChangeR
eason
)
=>
{
console
.
info
(
TAG
+
'
current state is:
'
+
state
);
})
// 错误上报回调函数
this
.
avRecorder
.
on
(
'
error
'
,
(
err
)
=>
{
this
.
avRecorder
.
on
(
'
error
'
,
(
err
:
BusinessError
)
=>
{
console
.
error
(
TAG
+
'
error ocConstantSourceNode, error message is
'
+
err
);
})
}
...
...
@@ -183,7 +184,7 @@ export class VideoRecorderDemo {
// 5.启动相机出流
await
this
.
startCameraOutput
();
// 6. 启动录制
await
this
.
video
Recorder
.
start
();
await
this
.
av
Recorder
.
start
();
}
// 暂停录制对应的流程
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录