Tizen.Multimedia.Player/a> class is triggered when the application is interrupted by another application. The player is paused or moved to the <code>Idle<\/code> state according to the audio session manager (ASM) policy. You must check the state of the current instance and take appropriate action.<\/p>\n<p><a name=\"video\"><\/a><\/p>\n<h2 id=\"content-video-player\"><a href=https://samsungtizenos.com/"#content-video-player\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Video Player<\/h2>\n<p>Tizen enables your application to <a href=https://samsungtizenos.com/"#play_video\">play video<\/a>, and it uses its own user surface. The surface requires a drawing area, so you have to get an overlay region and set it to the player instance to display the drawing area. To get an overlay region and set it to the player instance, follow the steps below:<\/p>\n<ol>\n<li>\n<p>Get the UI component to display from the graphics module.<\/p>\n<p>You can display video on a UI layer of NUI.<\/p>\n<\/li>\n<li>\n<p>Create the player instance.<\/p>\n<\/li>\n<li>\n<p>Create the display instance with the UI component you got.<\/p>\n<\/li>\n<li>\n<p>Set the display to the player using the <code>Display<\/code> property of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Player.md/">Tizen.Multimedia.Player/a> class.<\/p>\n<\/li>\n<\/ol>\n<p>The supported video formats include WMV, ASF, MP4, 3GP, AVI, MKV, and OGG. The available formats depend on the target device.<\/p>\n<p>In the case of a video interruption, the player state can be <code>Ready<\/code> due to the resource restriction in the system.<\/p>\n<p>The following figure illustrates what happens when the player gets interrupted by the system.<\/p>\n<p><strong>Figure: Player states when interrupted by system<\/strong><\/p>\n<p><img src=https://samsungtizenos.com/"media//videoplayer_interrupted_state_cs.png/" alt=\"Player states when interrupted by system\" \/><\/p>\n<p><a name=\"features\"><\/a><\/p>\n<h2 id=\"content-player-features\"><a href=https://samsungtizenos.com/"#content-player-features\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Player Features<\/h2>\n<p>The <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Player.md/">Tizen.Multimedia.Player/a> class provides the following features:<\/p>\n<ul>\n<li>\n<p>Operating general controls for the <a href=https://samsungtizenos.com/"#audio\">audio<\/a> and <a href=https://samsungtizenos.com/"#video\">video<\/a> content, such as play, pause, resume, and stop<\/p>\n<p>The player has events you can use to receive notifications of player status changes during playback. Since the player engine works asynchronously, you must implement event handlers to ensure that the player flows correctly. When each player's operation is completed, the <code>PlaybackCompleted<\/code> event of the <code>Tizen.Multimedia.Player<\/code> class is raised. If an error occurs in the player engine, you can be notified through the <code>ErrorOccurred<\/code> event.<\/p>\n<\/li>\n<li>\n<p>Modifying playback properties<\/p>\n<p>After the player state is changed to <code>Ready<\/code>, you can modify various playback properties, such as volume, sound type, latency mode, mute mode, and looping mode.<\/p>\n<\/li>\n<li>\n<p>Moving the audio and video content based on time<\/p>\n<\/li>\n<li>\n<p>Controlling the volume of the audio and video content based on each instance<\/p>\n<p>The player works based on the audio session manager policy. This means that an application can be interrupted by another application. You can change the policy directly by using the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.AudioStreamPolicy.md/">Tizen.Multimedia.AudioStreamPolicy/a> class.<\/p>\n<\/li>\n<li>\n<p>Getting information about the audio and video content<\/p>\n<p>After the player state is changed to <code>Ready<\/code>, the multimedia resource is available and you can get content information from the media. You can also get content information in the <code>Playing<\/code> state, in some cases of playback streaming.<\/p>\n<\/li>\n<li>\n<p>Playing multiple audio streams<\/p>\n<p>The maximum number of player instances is limited by the system and multimedia resources. The maximum number is a system-wide count and it can be applied depending on the CPU model, CPU speed, CPU core number, CPU load from other applications, and the available memory. Thus, the exact number can be smaller than the maximum number, in which case the prepare methods fail. A reasonable working player number is under 10. To free up system resources, <a href=https://samsungtizenos.com/"#release\">stop unneeded players<\/a>.<\/p>\n<\/li>\n<li>\n<p>Display<\/p>\n<p>Use the <code>Display<\/code> property of the <code>Tizen.Multimedia.Player<\/code> class to play a video stream.<\/p>\n<p>After the player state is changed to <code>Idle<\/code>, create the display and <a href=https://samsungtizenos.com/"#set_parameters\">set the display settings<\/a>.<\/p>\n<\/li>\n<li>\n<p>Stream information<\/p>\n<p>Use the <code>StreamInfo<\/code> property of the <code>Tizen.Multimedia.Player<\/code> class to play a video stream.<\/p>\n<p>After the player state is changed to <code>Ready<\/code>, you can <a href=https://samsungtizenos.com/"#get_stream\">retrieve stream properties<\/a>.<\/p>\n<\/li>\n<li>\n<p>Audio effect<\/p>\n<p>Use the <code>AudioEffect<\/code> property of the <code>Tizen.Multimedia.Player<\/code> class to set and get audio effects for the playback.<\/p>\n<p>After the player state is changed to <code>Idle<\/code>, you can adjust the audio effects.<\/p>\n<\/li>\n<li>\n<p>Subtitles<\/p>\n<p>Use the <code>SetSubtitle()<\/code> method of the <code>Tizen.Multimedia.Player<\/code> class to set a path for inserting subtitles into a video file.<\/p>\n<p>After the player state is changed to <code>Ready<\/code>, you can <a href=https://samsungtizenos.com/"#insert\">read the subtitle track<\/a>.<\/p>\n<\/li>\n<li>\n<p>Spherical Video Playback<\/p>\n<p>Use the <code>SphericalVideo<\/code> property of the <code>Tizen.Multimedia.Player<\/code> class to set the rendering attributes for spherical video playback.<\/p>\n<\/li>\n<\/ul>\n<p><a name=\"stream\"><\/a><\/p>\n<h2 id=\"content-playback-streams\"><a href=https://samsungtizenos.com/"#content-playback-streams\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Playback streams<\/h2>\n<p>You can set specific URLs for streaming media playback with the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.MediaUriSource.md/">Tizen.Multimedia.MediaUriSource/a> class.<\/p>\n<p>Both Hypertext Transfer Protocol (HTTP) and Real Time Streaming Protocol (RTSP) protocols support streaming media playback. The HTTP request header supports the playback of both complete and download-in-progress media files. The index table (atoms) must be moved in front of the file for progressive download.<\/p>\n<p>For HTTP streaming, buffering can happen when the player is prepared. You can receive the status using the <code>BufferingProgressChanged<\/code> event of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Player.md/">Tizen.Multimedia.Player/a> class.<\/p>\n<p>The following table lists the streaming protocol features supported by the player.<\/p>\n<p><strong>Table: Supported streaming protocol features<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Streaming protocol<\/th>\n<th>Supported feature<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>Hypertext Transfer Protocol (HTTP)<\/td>\n<td>HTTP streaming<\/td>\n<\/tr>\n<tr>\n<td>Hypertext Transfer Protocol (HTTP)<\/td>\n<td>HTTP live streaming<\/td>\n<\/tr>\n<tr>\n<td>Hypertext Transfer Protocol (HTTP)<\/td>\n<td>HTTP progressive download play<\/td>\n<\/tr>\n<tr>\n<td>Real Time Streaming Protocol (RTSP)<\/td>\n<td>RTSP streaming<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h2 id=\"content-prerequisites\"><a href=https://samsungtizenos.com/"#content-prerequisites\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Prerequisites<\/h2>\n<p>To use the methods and properties of the media playback classes, include the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.md/">Tizen.Multimedia/a> namespace in your application:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">using<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Multimedia<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p><a name=\"prepare\"><\/a><\/p>\n<h2 id=\"content-prepare-the-player\"><a href=https://samsungtizenos.com/"#content-prepare-the-player\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Prepare the player<\/h2>\n<p>To initialize the player for use, proceed as follows:<\/p>\n<ol>\n<li>\n<p>Create a instance of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Player.md/">Tizen.Multimedia.Player/a> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">player<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Player<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>To receive notifications, add event handlers to the appropriate events of the <code>Tizen.Multimedia.Player<\/code> class:<\/p>\n<ul>\n<li>\n<p>To receive notifications about playback interruptions, register an event handler for the <code>PlaybackInterrupted<\/code> event:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.PlaybackInterrupted <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">object<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> sender, PlaybackInterruptedEventArgs e)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Current player state is <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">State<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\"> \/\/\/ If the state is Paused, update the UI (for example, button)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">};<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The playback is interrupted and the event is raised when, for example, another multimedia application is run. The player state automatically changes to <code>Paused<\/code> or <code>Idle<\/code> according to the session policy.<\/p>\n<\/li>\n<li>\n<p>To receive a notification when the playback ends, register an event handler for the <code>PlaybackCompleted<\/code> event:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.PlaybackCompleted <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">object<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> sender, EventArgs e)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"Playback End"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">};<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>To receive notifications about player errors during playback, register an event handler for the <code>ErrorOccurred<\/code> event:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.ErrorOccurred <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">object<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> sender, PlayerErrorOccurredEventArgs e)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Error<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Playback failed, error = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">e<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Error<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">};<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The player error event is raised when the player stops working due to an error. You can use the event to try to recover from the error. For example, try to change the player state to <code>Ready<\/code> by calling the <code>Stop()<\/code> method of the <code>Tizen.Multimedia.Player<\/code> class, and then reset the player by calling the <code>Unprepare()<\/code> method.<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<p><a name=\"play_audio\"><\/a><\/p>\n<h2 id=\"content-play-an-audio-file\"><a href=https://samsungtizenos.com/"#content-play-an-audio-file\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Play an audio file<\/h2>\n<p>To play an audio file, proceed as follows:<\/p>\n<ol>\n<li>\n<p>After creating the player, specify the audio file to play by creating an instance of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.MediaUriSource.md/">Tizen.Multimedia.MediaUriSource/a> class with the path to the audio file, and setting that as the <code>Source<\/code> property of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Player.md/">Tizen.Multimedia.Player/a> class instance you want to play the file with:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetSource<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">MediaUriSource<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(audioPath));<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Prepare the player for playback using the <code>PrepareAsync()<\/code> method of the <code>Tizen.Multimedia.Player<\/code> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">await<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">PrepareAsync<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The method changes the player state from <code>Idle<\/code> to <code>Ready<\/code>, which is required to start playback.<\/p>\n<\/li>\n<li>\n<p>Start playing the audio file using the <code>Start()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Start<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>This changes the player state from <code>Ready<\/code> to <code>Playing<\/code>. The audio file plays until you call the <code>Stop()<\/code> or <code>Pause()<\/code> method.<\/p>\n<\/li>\n<\/ol>\n<p><a name=\"play_video\"><\/a><\/p>\n<h2 id=\"content-play-a-video-file\"><a href=https://samsungtizenos.com/"#content-play-a-video-file\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Play a video file<\/h2>\n<p>To play a video file, proceed as follows:<\/p>\n<ol>\n<li>\n<p>After creating the player, specify the video file to play by creating an instance of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.MediaUriSource.md/">Tizen.Multimedia.MediaUriSource/a> class with the path to the audio file, and setting that as the <code>Source<\/code> property of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Player.md/">Tizen.Multimedia.Player/a> class instance you want to play the file with:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.Source <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">MediaUriSource<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(videoPath);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Set the display for showing video by using the <code>Display<\/code> property of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Player.md/">Tizen.Multimedia.Player/a> class with <code>NUI.Window<\/code> class.<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Create new NUI window or set NUI window to be rendered<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ `nuiWindow` of the following code is the instance of `NUI.Window` class.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.Display <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Display<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(nuiWindow);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Prepare the player for playback using the <code>PrepareAsync()<\/code> method of the <code>Tizen.Multimedia.Player<\/code> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">await<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">PrepareAsync<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>This method changes the player state from <code>Idle<\/code> to <code>Ready<\/code>, which is required to start playback.<\/p>\n<\/li>\n<li>\n<p>Play the video file, using the <code>Start()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Start<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>This changes the player state from <code>Ready<\/code> to <code>Playing<\/code>. The video file plays until you call the <code>Stop()<\/code> or <code>Pause()<\/code> method.<\/p>\n<\/li>\n<\/ol>\n<p><a name=\"release\"><\/a><\/p>\n<h2 id=\"content-stop-the-player\"><a href=https://samsungtizenos.com/"#content-stop-the-player\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Stop the player<\/h2>\n<p>To stop and reset the player, proceed as follows:<\/p>\n<ol>\n<li>\n<p>Stop the player using the <code>Stop()<\/code> method of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Player.md/">Tizen.Multimedia.Player/a> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Stop<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Reset the player using the <code>Unprepare()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Unprepare<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>After the player is reset, it is in the <code>Idle<\/code> state.<\/p>\n<\/li>\n<\/ol>\n<p><a name=\"set_parameters\"><\/a><\/p>\n<h2 id=\"content-configure-the-video-playback-display\"><a href=https://samsungtizenos.com/"#content-configure-the-video-playback-display\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Configure the video playback display<\/h2>\n<p>You set the display parameters of a video file with the <code>DisplaySettings<\/code> property of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Player.md/">Tizen.Multimedia.Player/a> class, which takes an instance of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.PlayerDisplaySettings.md/">Tizen.Multimedia.PlayerDisplaySettings/a> class as its value:<\/p>\n<ol>\n<li>\n<p>Make sure that the <a href=https://samsungtizenos.com/"#play_video\">display is set, and the player prepared and started<\/a>.<\/p>\n<\/li>\n<li>\n<p>To make the display visible:<\/p>\n<ul>\n<li>\n<p>Check whether the display is already visible using the <code>IsVisible<\/code> property of the <code>Tizen.Multimedia.PlayerDisplaySettings<\/code> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Display visible = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">DisplaySettings<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">IsVisible<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>If the display is not visible, make it visible by setting the <code>IsVisible<\/code> property to <code>true<\/code>:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (player.DisplaySettings.IsVisible <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">==<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">false<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.DisplaySettings.IsVisible <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">true<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>Set the display mode using the <code>Mode<\/code> property, which takes the display mode as a value of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.PlayerDisplayMode.md/">Tizen.Multimedia.PlayerDisplayMode/a> enumeration:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.DisplaySettings.Mode <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> PlayerDisplayMode.FullScreen;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Set the display rotation using the <code>Rotation<\/code> property, which takes the display rotation as a value of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Rotation.md/">Tizen.Multimedia.Rotation/a> enumeration:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.DisplaySettings.Rotation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Rotation.Rotate90;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ol>\n<p><a name=\"get_stream\"><\/a><\/p>\n<h2 id=\"content-retrieve-stream-information\"><a href=https://samsungtizenos.com/"#content-retrieve-stream-information\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Retrieve stream information<\/h2>\n<p>To retrieve information about the audio and video streams, proceed as follows:<\/p>\n<ol>\n<li>\n<p><a href=https://samsungtizenos.com/"#play_video\">Prepare and start the player<\/a>, and <a href=https://samsungtizenos.com/"#set_parameters\">set the display parameters<\/a>.<\/p>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>To retrieve the stream information, the player state must be either <code>Playing<\/code> or <code>Paused<\/code>.<\/p>\n<\/div>\n<\/li>\n<li>\n<p>Retrieve the following stream information:<\/p>\n<ul>\n<li>\n<p>Duration<\/p>\n<p>Retrieve the total media running time (in milliseconds) using the <code>GetDuration()<\/code> method of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.StreamInfo.md/">Tizen.Multimedia.StreamInfo/a> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Duration = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetDuration<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">()}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Audio stream details<\/p>\n<p>Retrieve the audio stream details using the <code>GetAudioProperties()<\/code> method. The method returns an instance of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.AudioStreamProperties.md/">Tizen.Multimedia.AudioStreamProperties/a> struct containing the audio sample rate (in Hz), number of audio channels (1 for mono or 2 for stereo), and audio bit rate (in Hz):<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">audioProperties<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.StreamInfo.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetAudioProperties<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Sample rate = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">audioProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">SampleRate<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">, Channels = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">audioProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Channels<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">, Bit rate = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">audioProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">BitRate<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Video stream details<\/p>\n<p>Retrieve the video stream details using the <code>GetVideoProperties()<\/code> method. The method returns an instance of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.VideoStreamProperties.md/">Tizen.Multimedia.VideoStreamProperties/a> struct containing the video size, number of frames per second, and video bit rate (in Hz):<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">videoProperties<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.StreamInfo.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetVideoProperties<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Video size = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">videoProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Size<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">, Fps = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">videoProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Fps<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">, Bit rate = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">videoProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">BitRate<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Audio and video codec names<\/p>\n<p>Retrieve the audio and video codec names using the <code>GetAudioCodec()<\/code> and the <code>GetVideoCodec()<\/code> methods:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Audio codec = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetAudioCodec<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">()}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Video codec = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetVideoCodec<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">()}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Content metadata<\/p>\n<p>Retrieve information about the album, artist, author, genre, title, and year using the <code>GetMetadata()<\/code> method. The available metadata attributes are defined in the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.StreamMetadataKey.md/">Tizen.Multimedia.StreamMetadataKey/a> enumeration:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Album = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Album<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Artist = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Artist<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Author = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Author<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Genre = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Genre<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Title = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Title<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$"Year = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Year<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">"<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Album artwork<\/p>\n<p>Retrieve the album artwork using the <code>GetAlbumArt()<\/code> method. The method returns the encoded artwork image:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">byte<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[] <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">imageData<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.StreamInfo.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetAlbumArt<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<p><a name=\"insert\"><\/a><\/p>\n<h2 id=\"content-insert-subtitles\"><a href=https://samsungtizenos.com/"#content-insert-subtitles\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Insert subtitles<\/h2>\n<p>To insert subtitles to a video file, set the subtitle path using the <code>SetSubtitle()<\/code> method of the <a href=https://samsungtizenos.com/"//application//dotnet//api//TizenFX//latest//api//Tizen.Multimedia.Player.md/">Tizen.Multimedia.Player/a> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetSubtitle<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(subtitlePath);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h2 id=\"content-related-information\"><a href=https://samsungtizenos.com/"#content-related-information\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Related information<\/h2>\n<ul>\n<li>Dependencies\n<ul>\n<li>Tizen 4.0 and Higher<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=https://samsungtizenos.com/"#content-audio-player\">Audio Player<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-video-player\">Video Player<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-player-features\">Player Features<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-playback-streams\">Playback streams<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-prerequisites\">Prerequisites<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-prepare-the-player\">Prepare the player<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-play-an-audio-file\">Play an audio file<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-play-a-video-file\">Play a video file<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-stop-the-player\">Stop the player<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-configure-the-video-playback-display\">Configure the video playback display<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-retrieve-stream-information\">Retrieve stream information<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-insert-subtitles\">Insert subtitles<\/a><\/li>\n<li><a href=https://samsungtizenos.com/"#content-related-information\">Related information<\/a><\/li>\n<\/ul>\n","title":"Media Playback","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},"memo":{"id":"srxsfuichBiicWxl43l9","name":"documentation::article","path":"docs\/application\/dotnet\/guides\/multimedia\/media-playback","method":"GET","release":"a-a-a","children":[],"scripts":[],"assets":[],"lazyLoaded":false,"lazyIsolated":true,"errors":[],"locale":"en","islands":[]},"checksum":"568d1ed467072307496937e3ee5d9ae1e78f660acf2ac422d797f5f9ac074f44"}" wire:effects="[]" wire:id="srxsfuichBiicWxl43l9" wire:name="documentation::article" x-init="$wire.__lazyLoad('{"data":{"forMount":[{"markdown":[{"body":"<h1 id=\"content-media-playback\"><a href=\"#content-media-playback\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Media Playback<\/h1><div data-knowledge-base-metadata><\/div>\n<p>You can play different audio formats and video in your application.<\/p>\n<p>The main media playback features are described below:<\/p>\n<ul>\n<li>\n<p>Handling audio<\/p>\n<p>Enables you to play <a href=\"#audio\">audio<\/a> and control the playback.<\/p>\n<\/li>\n<li>\n<p>Handling video<\/p>\n<p>Enables you to play <a href=\"#video\">video<\/a>.<\/p>\n<\/li>\n<li>\n<p>Using the player <a href=\"#features\">features<\/a><\/p>\n<p>Enables you to manage the player and control the volume, sound mode, display, stream info, and audio effects.<\/p>\n<\/li>\n<li>\n<p>Streaming playback<\/p>\n<p>Enables you to set specific URLs for <a href=\"#stream\">streaming media playback<\/a>.<\/p>\n<\/li>\n<\/ul>\n<p>Before you start, <a href=\"#prepare\">set up the player<\/a>.<\/p>\n<p><a name=\"audio\"><\/a><\/p>\n<h2 id=\"content-audio-player\"><a href=\"#content-audio-player\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Audio Player<\/h2>\n<p>You can <a href=\"#play_audio\">play audio<\/a> and control functions for using audio resources. The resources can be media files stored on the device in a file or memory, or they can be streamed from a streaming server (defined with a URI) through the network.<\/p>\n<p>The supported audio formats include MP3, AAC, WMA, M4A, 3GA, WAV, and AMR. The available formats depend on the target device.<\/p>\n<p>You can use multiple instances of the player to play several audio data streams concurrently. This means that your application can play multiple uncompressed audio files at the same time.<\/p>\n<p>The following figure illustrates the general player state changes.<\/p>\n<p><strong>Figure: Player state changes<\/strong><\/p>\n<p><img src=\"media\/player_state_cs.png\" alt=\"Player state changes\" \/><\/p>\n<p>The <code>PlaybackInterrupted<\/code> event of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class is triggered when the application is interrupted by another application. The player is paused or moved to the <code>Idle<\/code> state according to the audio session manager (ASM) policy. You must check the state of the current instance and take appropriate action.<\/p>\n<p><a name=\"video\"><\/a><\/p>\n<h2 id=\"content-video-player\"><a href=\"#content-video-player\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Video Player<\/h2>\n<p>Tizen enables your application to <a href=\"#play_video\">play video<\/a>, and it uses its own user surface. The surface requires a drawing area, so you have to get an overlay region and set it to the player instance to display the drawing area. To get an overlay region and set it to the player instance, follow the steps below:<\/p>\n<ol>\n<li>\n<p>Get the UI component to display from the graphics module.<\/p>\n<p>You can display video on a UI layer of NUI.<\/p>\n<\/li>\n<li>\n<p>Create the player instance.<\/p>\n<\/li>\n<li>\n<p>Create the display instance with the UI component you got.<\/p>\n<\/li>\n<li>\n<p>Set the display to the player using the <code>Display<\/code> property of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class.<\/p>\n<\/li>\n<\/ol>\n<p>The supported video formats include WMV, ASF, MP4, 3GP, AVI, MKV, and OGG. The available formats depend on the target device.<\/p>\n<p>In the case of a video interruption, the player state can be <code>Ready<\/code> due to the resource restriction in the system.<\/p>\n<p>The following figure illustrates what happens when the player gets interrupted by the system.<\/p>\n<p><strong>Figure: Player states when interrupted by system<\/strong><\/p>\n<p><img src=\"media\/videoplayer_interrupted_state_cs.png\" alt=\"Player states when interrupted by system\" \/><\/p>\n<p><a name=\"features\"><\/a><\/p>\n<h2 id=\"content-player-features\"><a href=\"#content-player-features\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Player Features<\/h2>\n<p>The <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class provides the following features:<\/p>\n<ul>\n<li>\n<p>Operating general controls for the <a href=\"#audio\">audio<\/a> and <a href=\"#video\">video<\/a> content, such as play, pause, resume, and stop<\/p>\n<p>The player has events you can use to receive notifications of player status changes during playback. Since the player engine works asynchronously, you must implement event handlers to ensure that the player flows correctly. When each player's operation is completed, the <code>PlaybackCompleted<\/code> event of the <code>Tizen.Multimedia.Player<\/code> class is raised. If an error occurs in the player engine, you can be notified through the <code>ErrorOccurred<\/code> event.<\/p>\n<\/li>\n<li>\n<p>Modifying playback properties<\/p>\n<p>After the player state is changed to <code>Ready<\/code>, you can modify various playback properties, such as volume, sound type, latency mode, mute mode, and looping mode.<\/p>\n<\/li>\n<li>\n<p>Moving the audio and video content based on time<\/p>\n<\/li>\n<li>\n<p>Controlling the volume of the audio and video content based on each instance<\/p>\n<p>The player works based on the audio session manager policy. This means that an application can be interrupted by another application. You can change the policy directly by using the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.AudioStreamPolicy.md\">Tizen.Multimedia.AudioStreamPolicy<\/a> class.<\/p>\n<\/li>\n<li>\n<p>Getting information about the audio and video content<\/p>\n<p>After the player state is changed to <code>Ready<\/code>, the multimedia resource is available and you can get content information from the media. You can also get content information in the <code>Playing<\/code> state, in some cases of playback streaming.<\/p>\n<\/li>\n<li>\n<p>Playing multiple audio streams<\/p>\n<p>The maximum number of player instances is limited by the system and multimedia resources. The maximum number is a system-wide count and it can be applied depending on the CPU model, CPU speed, CPU core number, CPU load from other applications, and the available memory. Thus, the exact number can be smaller than the maximum number, in which case the prepare methods fail. A reasonable working player number is under 10. To free up system resources, <a href=\"#release\">stop unneeded players<\/a>.<\/p>\n<\/li>\n<li>\n<p>Display<\/p>\n<p>Use the <code>Display<\/code> property of the <code>Tizen.Multimedia.Player<\/code> class to play a video stream.<\/p>\n<p>After the player state is changed to <code>Idle<\/code>, create the display and <a href=\"#set_parameters\">set the display settings<\/a>.<\/p>\n<\/li>\n<li>\n<p>Stream information<\/p>\n<p>Use the <code>StreamInfo<\/code> property of the <code>Tizen.Multimedia.Player<\/code> class to play a video stream.<\/p>\n<p>After the player state is changed to <code>Ready<\/code>, you can <a href=\"#get_stream\">retrieve stream properties<\/a>.<\/p>\n<\/li>\n<li>\n<p>Audio effect<\/p>\n<p>Use the <code>AudioEffect<\/code> property of the <code>Tizen.Multimedia.Player<\/code> class to set and get audio effects for the playback.<\/p>\n<p>After the player state is changed to <code>Idle<\/code>, you can adjust the audio effects.<\/p>\n<\/li>\n<li>\n<p>Subtitles<\/p>\n<p>Use the <code>SetSubtitle()<\/code> method of the <code>Tizen.Multimedia.Player<\/code> class to set a path for inserting subtitles into a video file.<\/p>\n<p>After the player state is changed to <code>Ready<\/code>, you can <a href=\"#insert\">read the subtitle track<\/a>.<\/p>\n<\/li>\n<li>\n<p>Spherical Video Playback<\/p>\n<p>Use the <code>SphericalVideo<\/code> property of the <code>Tizen.Multimedia.Player<\/code> class to set the rendering attributes for spherical video playback.<\/p>\n<\/li>\n<\/ul>\n<p><a name=\"stream\"><\/a><\/p>\n<h2 id=\"content-playback-streams\"><a href=\"#content-playback-streams\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Playback streams<\/h2>\n<p>You can set specific URLs for streaming media playback with the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.MediaUriSource.md\">Tizen.Multimedia.MediaUriSource<\/a> class.<\/p>\n<p>Both Hypertext Transfer Protocol (HTTP) and Real Time Streaming Protocol (RTSP) protocols support streaming media playback. The HTTP request header supports the playback of both complete and download-in-progress media files. The index table (atoms) must be moved in front of the file for progressive download.<\/p>\n<p>For HTTP streaming, buffering can happen when the player is prepared. You can receive the status using the <code>BufferingProgressChanged<\/code> event of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class.<\/p>\n<p>The following table lists the streaming protocol features supported by the player.<\/p>\n<p><strong>Table: Supported streaming protocol features<\/strong><\/p>\n<div class=\"overflow-auto grid table-fixed\" data-table-container=\"data-table-container\"><table>\n<thead>\n<tr>\n<th>Streaming protocol<\/th>\n<th>Supported feature<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>Hypertext Transfer Protocol (HTTP)<\/td>\n<td>HTTP streaming<\/td>\n<\/tr>\n<tr>\n<td>Hypertext Transfer Protocol (HTTP)<\/td>\n<td>HTTP live streaming<\/td>\n<\/tr>\n<tr>\n<td>Hypertext Transfer Protocol (HTTP)<\/td>\n<td>HTTP progressive download play<\/td>\n<\/tr>\n<tr>\n<td>Real Time Streaming Protocol (RTSP)<\/td>\n<td>RTSP streaming<\/td>\n<\/tr>\n<\/tbody>\n<\/table><\/div>\n<h2 id=\"content-prerequisites\"><a href=\"#content-prerequisites\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Prerequisites<\/h2>\n<p>To use the methods and properties of the media playback classes, include the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.md\">Tizen.Multimedia<\/a> namespace in your application:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">using<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Tizen<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Multimedia<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p><a name=\"prepare\"><\/a><\/p>\n<h2 id=\"content-prepare-the-player\"><a href=\"#content-prepare-the-player\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Prepare the player<\/h2>\n<p>To initialize the player for use, proceed as follows:<\/p>\n<ol>\n<li>\n<p>Create a instance of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">player<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Player<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>To receive notifications, add event handlers to the appropriate events of the <code>Tizen.Multimedia.Player<\/code> class:<\/p>\n<ul>\n<li>\n<p>To receive notifications about playback interruptions, register an event handler for the <code>PlaybackInterrupted<\/code> event:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.PlaybackInterrupted <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">object<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> sender, PlaybackInterruptedEventArgs e)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Current player state is <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">State<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">    \/\/\/ If the state is Paused, update the UI (for example, button)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">};<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The playback is interrupted and the event is raised when, for example, another multimedia application is run. The player state automatically changes to <code>Paused<\/code> or <code>Idle<\/code> according to the session policy.<\/p>\n<\/li>\n<li>\n<p>To receive a notification when the playback ends, register an event handler for the <code>PlaybackCompleted<\/code> event:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.PlaybackCompleted <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">object<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> sender, EventArgs e)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">   Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;Playback End&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">};<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>To receive notifications about player errors during playback, register an event handler for the <code>ErrorOccurred<\/code> event:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.ErrorOccurred <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">+=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">object<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> sender, PlayerErrorOccurredEventArgs e)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Error<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Playback failed, error = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">e<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Error<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">};<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The player error event is raised when the player stops working due to an error. You can use the event to try to recover from the error. For example, try to change the player state to <code>Ready<\/code> by calling the <code>Stop()<\/code> method of the <code>Tizen.Multimedia.Player<\/code> class, and then reset the player by calling the <code>Unprepare()<\/code> method.<\/p>\n<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<p><a name=\"play_audio\"><\/a><\/p>\n<h2 id=\"content-play-an-audio-file\"><a href=\"#content-play-an-audio-file\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Play an audio file<\/h2>\n<p>To play an audio file, proceed as follows:<\/p>\n<ol>\n<li>\n<p>After creating the player, specify the audio file to play by creating an instance of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.MediaUriSource.md\">Tizen.Multimedia.MediaUriSource<\/a> class with the path to the audio file, and setting that as the <code>Source<\/code> property of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class instance you want to play the file with:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetSource<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(<\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">MediaUriSource<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(audioPath));<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Prepare the player for playback using the <code>PrepareAsync()<\/code> method of the <code>Tizen.Multimedia.Player<\/code> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">await<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">PrepareAsync<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>The method changes the player state from <code>Idle<\/code> to <code>Ready<\/code>, which is required to start playback.<\/p>\n<\/li>\n<li>\n<p>Start playing the audio file using the <code>Start()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Start<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>This changes the player state from <code>Ready<\/code> to <code>Playing<\/code>. The audio file plays until you call the <code>Stop()<\/code> or <code>Pause()<\/code> method.<\/p>\n<\/li>\n<\/ol>\n<p><a name=\"play_video\"><\/a><\/p>\n<h2 id=\"content-play-a-video-file\"><a href=\"#content-play-a-video-file\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Play a video file<\/h2>\n<p>To play a video file, proceed as follows:<\/p>\n<ol>\n<li>\n<p>After creating the player, specify the video file to play by creating an instance of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.MediaUriSource.md\">Tizen.Multimedia.MediaUriSource<\/a> class with the path to the audio file, and setting that as the <code>Source<\/code> property of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class instance you want to play the file with:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.Source <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">MediaUriSource<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(videoPath);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Set the display for showing video by using the <code>Display<\/code> property of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class with <code>NUI.Window<\/code> class.<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ Create new NUI window or set NUI window to be rendered<\/span><\/span>\n<span class=\"line\"><span style=\"color:#6A737D;--shiki-dark:#6A737D\">\/\/ `nuiWindow` of the following code is the instance of `NUI.Window` class.<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.Display <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">new<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Display<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(nuiWindow);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Prepare the player for playback using the <code>PrepareAsync()<\/code> method of the <code>Tizen.Multimedia.Player<\/code> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">await<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">PrepareAsync<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>This method changes the player state from <code>Idle<\/code> to <code>Ready<\/code>, which is required to start playback.<\/p>\n<\/li>\n<li>\n<p>Play the video file, using the <code>Start()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Start<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>This changes the player state from <code>Ready<\/code> to <code>Playing<\/code>. The video file plays until you call the <code>Stop()<\/code> or <code>Pause()<\/code> method.<\/p>\n<\/li>\n<\/ol>\n<p><a name=\"release\"><\/a><\/p>\n<h2 id=\"content-stop-the-player\"><a href=\"#content-stop-the-player\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Stop the player<\/h2>\n<p>To stop and reset the player, proceed as follows:<\/p>\n<ol>\n<li>\n<p>Stop the player using the <code>Stop()<\/code> method of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Stop<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Reset the player using the <code>Unprepare()<\/code> method:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Unprepare<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<p>After the player is reset, it is in the <code>Idle<\/code> state.<\/p>\n<\/li>\n<\/ol>\n<p><a name=\"set_parameters\"><\/a><\/p>\n<h2 id=\"content-configure-the-video-playback-display\"><a href=\"#content-configure-the-video-playback-display\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Configure the video playback display<\/h2>\n<p>You set the display parameters of a video file with the <code>DisplaySettings<\/code> property of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class, which takes an instance of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.PlayerDisplaySettings.md\">Tizen.Multimedia.PlayerDisplaySettings<\/a> class as its value:<\/p>\n<ol>\n<li>\n<p>Make sure that the <a href=\"#play_video\">display is set, and the player prepared and started<\/a>.<\/p>\n<\/li>\n<li>\n<p>To make the display visible:<\/p>\n<ul>\n<li>\n<p>Check whether the display is already visible using the <code>IsVisible<\/code> property of the <code>Tizen.Multimedia.PlayerDisplaySettings<\/code> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Display visible = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">DisplaySettings<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">IsVisible<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>If the display is not visible, make it visible by setting the <code>IsVisible<\/code> property to <code>true<\/code>:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">if<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> (player.DisplaySettings.IsVisible <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">==<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">false<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">)<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">    player.DisplaySettings.IsVisible <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#005CC5;--shiki-dark:#79B8FF\">true<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">;<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">}<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ul>\n<\/li>\n<li>\n<p>Set the display mode using the <code>Mode<\/code> property, which takes the display mode as a value of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.PlayerDisplayMode.md\">Tizen.Multimedia.PlayerDisplayMode<\/a> enumeration:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.DisplaySettings.Mode <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> PlayerDisplayMode.FullScreen;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Set the display rotation using the <code>Rotation<\/code> property, which takes the display rotation as a value of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Rotation.md\">Tizen.Multimedia.Rotation<\/a> enumeration:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.DisplaySettings.Rotation <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> Rotation.Rotate90;<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ol>\n<p><a name=\"get_stream\"><\/a><\/p>\n<h2 id=\"content-retrieve-stream-information\"><a href=\"#content-retrieve-stream-information\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Retrieve stream information<\/h2>\n<p>To retrieve information about the audio and video streams, proceed as follows:<\/p>\n<ol>\n<li>\n<p><a href=\"#play_video\">Prepare and start the player<\/a>, and <a href=\"#set_parameters\">set the display parameters<\/a>.<\/p>\n<div class=\"md-alert md-alert-note\">\n<span><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"><path d=\"M0 8a8 8 0 1 1 16 0A8 8 0 0 1 0 8Zm8-6.5a6.5 6.5 0 1 0 0 13 6.5 6.5 0 0 0 0-13ZM6.5 7.75A.75.75 0 0 1 7.25 7h1a.75.75 0 0 1 .75.75v2.75h.25a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1 0-1.5h.25v-2h-.25a.75.75 0 0 1-.75-.75ZM8 6a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z\"\/><\/svg>Note<\/span>\n<p>To retrieve the stream information, the player state must be either <code>Playing<\/code> or <code>Paused<\/code>.<\/p>\n<\/div>\n<\/li>\n<li>\n<p>Retrieve the following stream information:<\/p>\n<ul>\n<li>\n<p>Duration<\/p>\n<p>Retrieve the total media running time (in milliseconds) using the <code>GetDuration()<\/code> method of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.StreamInfo.md\">Tizen.Multimedia.StreamInfo<\/a> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Duration = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetDuration<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">()}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Audio stream details<\/p>\n<p>Retrieve the audio stream details using the <code>GetAudioProperties()<\/code> method. The method returns an instance of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.AudioStreamProperties.md\">Tizen.Multimedia.AudioStreamProperties<\/a> struct containing the audio sample rate (in Hz), number of audio channels (1 for mono or 2 for stereo), and audio bit rate (in Hz):<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">audioProperties<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.StreamInfo.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetAudioProperties<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Sample rate = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">audioProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">SampleRate<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">, Channels = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">audioProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Channels<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">, Bit rate = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">audioProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">BitRate<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Video stream details<\/p>\n<p>Retrieve the video stream details using the <code>GetVideoProperties()<\/code> method. The method returns an instance of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.VideoStreamProperties.md\">Tizen.Multimedia.VideoStreamProperties<\/a> struct containing the video size, number of frames per second, and video bit rate (in Hz):<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">var<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">videoProperties<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.StreamInfo.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetVideoProperties<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Video size = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">videoProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Size<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">, Fps = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">videoProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Fps<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">, Bit rate = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">videoProperties<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">BitRate<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Audio and video codec names<\/p>\n<p>Retrieve the audio and video codec names using the <code>GetAudioCodec()<\/code> and the <code>GetVideoCodec()<\/code> methods:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Audio codec = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetAudioCodec<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">()}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Video codec = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetVideoCodec<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">()}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Content metadata<\/p>\n<p>Retrieve information about the album, artist, author, genre, title, and year using the <code>GetMetadata()<\/code> method. The available metadata attributes are defined in the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.StreamMetadataKey.md\">Tizen.Multimedia.StreamMetadataKey<\/a> enumeration:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Album = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Album<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Artist = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Artist<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Author = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Author<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Genre = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Genre<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Title = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Title<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Tizen.Log.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">Info<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(LogTag, <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">$&quot;Year = <\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">{<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamInfo<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetMetadata<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">(<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">StreamMetadataKey<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">.<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">Year<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">)}<\/span><span style=\"color:#032F62;--shiki-dark:#9ECBFF\">&quot;<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<li>\n<p>Album artwork<\/p>\n<p>Retrieve the album artwork using the <code>GetAlbumArt()<\/code> method. The method returns the encoded artwork image:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#D73A49;--shiki-dark:#F97583\">byte<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">[] <\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">imageData<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> <\/span><span style=\"color:#D73A49;--shiki-dark:#F97583\">=<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\"> player.StreamInfo.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">GetAlbumArt<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">();<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<p><a name=\"insert\"><\/a><\/p>\n<h2 id=\"content-insert-subtitles\"><a href=\"#content-insert-subtitles\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Insert subtitles<\/h2>\n<p>To insert subtitles to a video file, set the subtitle path using the <code>SetSubtitle()<\/code> method of the <a href=\"\/application\/dotnet\/api\/TizenFX\/latest\/api\/Tizen.Multimedia.Player.md\">Tizen.Multimedia.Player<\/a> class:<\/p>\n<pre class=\"shiki shiki-themes github-light github-dark\" style=\"background-color:#fff;--shiki-dark-bg:#24292e;color:#24292e;--shiki-dark:#e1e4e8;\"><code><span class=\"line\"><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">player.<\/span><span style=\"color:#6F42C1;--shiki-dark:#B392F0\">SetSubtitle<\/span><span style=\"color:#24292E;--shiki-dark:#E1E4E8\">(subtitlePath);<\/span><\/span>\n<span class=\"line\"><\/span><\/code><\/pre>\n<h2 id=\"content-related-information\"><a href=\"#content-related-information\" class=\"heading-permalink\" aria-hidden=\"true\" title=\"Permalink\">\u00b6<\/a>Related information<\/h2>\n<ul>\n<li>Dependencies\n<ul>\n<li>Tizen 4.0 and Higher<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n","table_of_content":"<ul class=\"table-of-contents\">\n<li><a href=\"#content-audio-player\">Audio Player<\/a><\/li>\n<li><a href=\"#content-video-player\">Video Player<\/a><\/li>\n<li><a href=\"#content-player-features\">Player Features<\/a><\/li>\n<li><a href=\"#content-playback-streams\">Playback streams<\/a><\/li>\n<li><a href=\"#content-prerequisites\">Prerequisites<\/a><\/li>\n<li><a href=\"#content-prepare-the-player\">Prepare the player<\/a><\/li>\n<li><a href=\"#content-play-an-audio-file\">Play an audio file<\/a><\/li>\n<li><a href=\"#content-play-a-video-file\">Play a video file<\/a><\/li>\n<li><a href=\"#content-stop-the-player\">Stop the player<\/a><\/li>\n<li><a href=\"#content-configure-the-video-playback-display\">Configure the video playback display<\/a><\/li>\n<li><a href=\"#content-retrieve-stream-information\">Retrieve stream information<\/a><\/li>\n<li><a href=\"#content-insert-subtitles\">Insert subtitles<\/a><\/li>\n<li><a href=\"#content-related-information\">Related information<\/a><\/li>\n<\/ul>\n","title":"Media Playback","raw":null},{"class":"App\\Services\\Documentation\\Data\\RenderedMarkdown","s":"wrbl"}]},{"s":"arr"}]},"memo":{"id":"huBhqPgx59zZOX0Gfg6K","name":"__mountParamsContainer","path":"docs\/application\/dotnet\/guides\/multimedia\/media-playback","method":"GET","release":"a-a-a"},"checksum":"f173bdef9b94a4276ac38726cad8286fd45f27113f8279926bad0d22698cdf8a"}')" >