1# AVPlayer and AVRecorder 2 3The media module provides the [AVPlayer](#avplayer) and [AVRecorder](#avrecorder) class to implement audio and video playback and recording. 4 5## AVPlayer 6 7The AVPlayer transcodes audio and video media assets (such as MP4, MP3, MKV, and MPEG-TS) into renderable images and hearable audio analog signals, and plays the audio and video through output devices. 8 9The AVPlayer provides the integrated playback capability. This means that your application only needs to provide streaming media sources to implement media playback. It does not need to parse or decode data. 10 11 12### Audio Playback 13 14The figure below shows the interaction when the **AVPlayer** class is used to develop a music application. 15 16**Figure 1** Interaction with external modules for audio playback 17 18![Audio playback interaction diagram](figures/audio-playback-interaction-diagram.png) 19 20When a music application calls the **AVPlayer** APIs at the JS interface layer to implement audio playback, the player framework at the framework layer parses the media asset into audio data streams (in PCM format). The audio data streams are then decoded by software and output to the audio framework. The audio framework outputs the audio data streams to the audio HDI for rendering. A complete audio playback process requires the cooperation of the application, player framework, audio framework, and audio HDI. 21 22In Figure 1, the numbers indicate the process where data is transferred to external modules. 23 241. The music application transfers the media asset to the **AVPlayer** instance. 25 262. The player framework outputs the audio PCM data streams to the audio framework, which then outputs the data streams to the audio HDI. 27 28### Video Playback 29 30The figure below shows the interaction when the **AVPlayer** class is used to develop a video application. 31 32**Figure 2** Interaction with external modules for video playback 33 34![Video playback interaction diagram](figures/video-playback-interaction-diagram.png) 35 36When the video application calls the **AVPlayer** APIs at the JS interface layer to implement audio and video playback, the player framework at the framework layer parses the media asset into separate audio data streams and video data streams. The audio data streams are then decoded by software and output to the audio framework. The audio framework outputs the audio data streams to the audio HDI at the hardware interface layer to implement audio playback. The video data streams are then decoded by hardware (recommended) or software and output to the graphic framework. The graphic framework outputs the video data streams to the display HDI at the hardware interface layer to implement graphics rendering. 37 38A complete video playback process requires the cooperation of the application, XComponent, player framework, graphic framework, audio framework, display HDI, and audio HDI. 39 40In Figure 2, the numbers indicate the process where data is transferred to external modules. 41 421. The application obtains a window surface ID from the XComponent. For details about how to obtain the window surface ID, see [XComponent](../reference/arkui-ts/ts-basic-components-xcomponent.md). 43 442. The application transfers the media asset and surface ID to the **AVPlayer** instance. 45 463. The player framework outputs the video elementary streams (ESs) to the decoding HDI to obtain video frames (NV12/NV21/RGBA). 47 484. The player framework outputs the audio PCM data streams to the audio framework, which then outputs the data streams to the audio HDI. 49 505. The player framework outputs the video frames (NV12/NV21/RGBA) to the graphic framework, which then outputs the video frames to the display HDI. 51 52### Supported Formats and Protocols 53 54Audio and video containers and codecs are domains specific to content creators. You are advised to use the mainstream playback formats, rather than custom ones to avoid playback failures, frame freezing, and artifacts. The system will not be affected by incompatibility issues. If such an issue occurs, you can exit playback. 55 56The table below lists the supported protocols. 57 58| Scenario| Description| 59| -------- | -------- | 60| Local VOD| The file descriptor is supported, but the file path is not.| 61| Network VoD| HTTP, HTTPS, and HLS are supported.| 62 63The table below lists the supported audio playback formats. 64 65| Audio Container Format| Description| 66| -------- | -------- | 67| M4A| Audio format: AAC| 68| AAC| Audio format: AAC| 69| MP3| Audio format: MP3| 70| OGG| Audio format: VORBIS | 71| WAV| Audio format: PCM | 72 73> **NOTE** 74> 75> The supported video formats are further classified into mandatory and optional ones. All vendors must support mandatory ones and can determine whether to implement optional ones based on their service requirements. You are advised to perform compatibility processing to ensure that all the application functions are compatible on different platforms. 76 77| Video Format| Mandatory or Not| 78| -------- | -------- | 79| H.264 | Yes| 80| MPEG-2 | No| 81| MPEG-4 | No| 82| H.263 | No| 83| VP8 | No| 84 85The table below lists the supported playback formats and mainstream resolutions. 86 87| Video Container Format| Description| Resolution| 88| -------- | -------- | -------- | 89| MP4| Video formats: H.264, MPEG-2, MPEG-4, and H.263<br>Audio formats: AAC and MP3| Mainstream resolutions, such as 4K, 1080p, 720p, 480p, and 270p| 90| MKV| Video formats: H.264, MPEG-2, MPEG-4, and H.263<br>Audio formats: AAC and MP3| Mainstream resolutions, such as 4K, 1080p, 720p, 480p, and 270p| 91| TS| Video formats: H.264, MPEG-2, and MPEG-4<br>Audio formats: AAC and MP3| Mainstream resolutions, such as 4K, 1080p, 720p, 480p, and 270p| 92| WebM| Video format: VP8<br>Audio format: VORBIS| Mainstream resolutions, such as 4K, 1080p, 720p, 480p, and 270p| 93 94## AVRecorder 95 96The AVRecorder captures audio signals, receives video signals, encodes the audio and video signals, and saves them to files. With the AVRecorder, you can easily implement audio and video recording, including starting, pausing, resuming, and stopping recording, and releasing resources. You can also specify parameters such as the encoding format, encapsulation format, and file path for recording. 97 98**Figure 3** Interaction with external modules for video recording 99 100![Video recording interaction diagram](figures/video-recording-interaction-diagram.png) 101 102- Audio recording: When an application calls the **AVRecorder** APIs at the JS interface layer to implement audio recording, the player framework at the framework layer invokes the audio framework to capture audio data through the audio HDI. The audio data is then encoded by software and saved into a file. 103 104- Video recording: When an application calls the **AVRecorder** APIs at the JS interface layer to implement video recording, the camera framework is first invoked to capture image data. Through the video encoding HDI, the camera framework sends the data to the player framework at the framework layer. The player framework encodes the image data through the video HDI and saves the encoded image data into a file. 105 106With the AVRecorder, you can implement pure audio recording, pure video recording, and audio and video recording. 107 108In Figure 3, the numbers indicate the process where data is transferred to external modules. 109 1101. The application obtains a surface ID from the player framework through the **AVRecorder** instance. 111 1122. The application sets the surface ID for the camera framework, which obtains the surface corresponding to the surface ID. The camera framework captures image data through the video HDI and sends the data to the player framework at the framework layer. 113 1143. The camera framework transfers the video data to the player framework through the surface. 115 1164. The player framework encodes video data through the video HDI. 117 1185. The player framework sets the audio parameters for the audio framework and obtains the audio data from the audio framework. 119 120### Supported Formats 121 122The table below lists the supported audio sources. 123 124| Type| Description| 125| -------- | -------- | 126| mic | The system microphone is used as the audio source input.| 127 128The table below lists the supported video sources. 129 130| Type| Description | 131| -------- | -------- | 132| surface_yuv | The input surface carries raw data.| 133| surface_es | The input surface carries ES data.| 134 135The table below lists the supported audio and video encoding formats. 136 137| Encoding Format| Description | 138| -------- | -------- | 139| audio/mp4a-latm | Audio encoding format MP4A-LATM.| 140| video/mp4v-es | Video encoding format MPEG-4.| 141| video/avc | Video encoding format AVC.| 142 143The table below lists the supported output file formats. 144 145| Format| Description | 146| -------- | -------- | 147| MP4| Video container format MP4.| 148| M4A| Audio container format M4A.| 149