未验证 提交 f684c4ea 编写于 作者: S shuboxu 提交者: Gitee

update en/application-dev/media/video-recording.md.

Signed-off-by: Nshuboxu <xushubo1@huawei.com>
上级 b8092dcb
...@@ -123,11 +123,30 @@ Refer to the sample code below to complete the process of starting, pausing, res ...@@ -123,11 +123,30 @@ Refer to the sample code below to complete the process of starting, pausing, res
```ts ```ts
import media from '@ohos.multimedia.media' import media from '@ohos.multimedia.media'
import { BusinessError } from '@ohos.base';
const TAG = 'VideoRecorderDemo:' const TAG = 'VideoRecorderDemo:'
class AVProfile {
fileFormat: media.ContainerFormatType;
videoBitrate: number;
videoCodec: media.CodecMimeType;
videoFrameWidth: number;
videoFrameHeight: number;
videoFrameRate: number;
}
class AVConfig {
videoSourceType: media.VideoSourceType;
profile: AVProfile;
url: string;
rotation: number;
}
export class VideoRecorderDemo { export class VideoRecorderDemo {
private avRecorder; private avRecorder: media.AVRecorder;
private videoOutSurfaceId; private videoOutSurfaceId: string;
private avProfile = { private avProfile: AVProfile = {
fileFormat: media.ContainerFormatType.CFT_MPEG_4, // Video file encapsulation format. Only MP4 is supported. fileFormat: media.ContainerFormatType.CFT_MPEG_4, // Video file encapsulation format. Only MP4 is supported.
videoBitrate : 100000, // Video bit rate. videoBitrate : 100000, // Video bit rate.
videoCodec: media.CodecMimeType.VIDEO_AVC, // Video file encoding format. Both MPEG-4 and AVC are supported. videoCodec: media.CodecMimeType.VIDEO_AVC, // Video file encoding format. Both MPEG-4 and AVC are supported.
...@@ -135,7 +154,7 @@ export class VideoRecorderDemo { ...@@ -135,7 +154,7 @@ export class VideoRecorderDemo {
videoFrameHeight: 480, // Video frame height. videoFrameHeight: 480, // Video frame height.
videoFrameRate: 30 // Video frame rate. videoFrameRate: 30 // Video frame rate.
} }
private avConfig = { private avConfig: AVConfig = {
videoSourceType: media.VideoSourceType.VIDEO_SOURCE_TYPE_SURFACE_YUV, // Video source type. YUV and ES are supported. videoSourceType: media.VideoSourceType.VIDEO_SOURCE_TYPE_SURFACE_YUV, // Video source type. YUV and ES are supported.
profile : this.avProfile, profile : this.avProfile,
url: 'fd://35', // Create, read, and write a file by referring to the sample code in Application File Access and Management. url: 'fd://35', // Create, read, and write a file by referring to the sample code in Application File Access and Management.
...@@ -145,11 +164,11 @@ export class VideoRecorderDemo { ...@@ -145,11 +164,11 @@ export class VideoRecorderDemo {
// Set AVRecorder callback functions. // Set AVRecorder callback functions.
setAvRecorderCallback() { setAvRecorderCallback() {
// Callback function for state changes. // Callback function for state changes.
this.avRecorder.on('stateChange', (state, reason) => { this.avRecorder.on('stateChange', (state: media.AVRecorderState, reason: media.StateChangeReason) => {
console.info(TAG + 'current state is: ' + state); console.info(TAG + 'current state is: ' + state);
}) })
// Callback function for errors. // Callback function for errors.
this.avRecorder.on('error', (err) => { this.avRecorder.on('error', (err: BusinessError) => {
console.error(TAG + 'error ocConstantSourceNode, error message is ' + err); console.error(TAG + 'error ocConstantSourceNode, error message is ' + err);
}) })
} }
...@@ -188,7 +207,7 @@ export class VideoRecorderDemo { ...@@ -188,7 +207,7 @@ export class VideoRecorderDemo {
// 5. Start the camera stream output. // 5. Start the camera stream output.
await this.startCameraOutput(); await this.startCameraOutput();
// 6. Start recording. // 6. Start recording.
await this.videoRecorder.start(); await this.avRecorder.start();
} }
// Process of pausing recording. // Process of pausing recording.
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册