Release 4.0.0-preview1-00151
[platform/core/csapi/tizenfx.git] / src / Tizen.Multimedia.Remoting / MediaController / PlaybackStateUpdatedEventArgs.cs
1 /*
2  * Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  * Licensed under the Apache License, Version 2.0 (the License);
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an AS IS BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 using System;
18 using System.Diagnostics;
19 using Native = Interop.MediaControllerClient;
20
21 namespace Tizen.Multimedia.Remoting
22 {
23     /// <summary>
24     /// Provides data for the <see cref="MediaController.PlaybackStateUpdated"/> event.
25     /// </summary>
26     public class PlaybackStateUpdatedEventArgs : EventArgs
27     {
28         /// <summary>
29         /// Initializes a new instance of the <see cref="PlaybackStateUpdatedEventArgs"/> class.
30         /// </summary>
31         /// <param name="state">The playback state.</param>
32         /// <param name="position">The playback position in milliseconds.</param>
33         /// <exception cref="ArgumentException"><paramref name="state"/> is invalid.</exception>
34         /// <exception cref="ArgumentOutOfRangeException"><paramref name="position"/> is less than zero.</exception>
35         public PlaybackStateUpdatedEventArgs(MediaControlPlaybackState state, long position)
36         {
37             ValidationUtil.ValidateEnum(typeof(MediaControlPlaybackState), state, nameof(state));
38
39             if (position < 0)
40             {
41                 throw new ArgumentOutOfRangeException(nameof(position), position, "position can't be less than zero.");
42             }
43
44             State = state;
45             Position = position;
46         }
47
48         /// <summary>
49         /// Gets the playback state.
50         /// </summary>
51         public MediaControlPlaybackState State { get; }
52
53         /// <summary>
54         /// Gets the playback position in milliseconds.
55         /// </summary>
56         public long Position { get; }
57     }
58 }