1 /** Copyright (c) 2017 Samsung Electronics Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
7 * http://www.apache.org/licenses/LICENSE-2.0
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
17 namespace Tizen.NUI.BaseComponents
21 using System.Runtime.InteropServices;
24 /// VideoView is a control for video playback and display.
26 public class VideoView : View
28 private global::System.Runtime.InteropServices.HandleRef swigCPtr;
30 internal VideoView(global::System.IntPtr cPtr, bool cMemoryOwn) : base(NDalicPINVOKE.VideoView_SWIGUpcast(cPtr), cMemoryOwn)
32 swigCPtr = new global::System.Runtime.InteropServices.HandleRef(this, cPtr);
35 internal static global::System.Runtime.InteropServices.HandleRef getCPtr(VideoView obj)
37 return (obj == null) ? new global::System.Runtime.InteropServices.HandleRef(null, global::System.IntPtr.Zero) : obj.swigCPtr;
40 protected override void Dispose(DisposeTypes type)
47 if(type == DisposeTypes.Explicit)
50 //Release your own managed resources here.
51 //You should release all of your own disposable objects here.
54 //Release your own unmanaged resources here.
55 //You should not access any managed member here except static instance.
56 //because the execution order of Finalizes is non-deterministic.
58 if (_videoViewFinishedCallbackDelegate != null)
60 FinishedSignal().Disconnect(_videoViewFinishedCallbackDelegate);
63 if (swigCPtr.Handle != global::System.IntPtr.Zero)
68 NDalicPINVOKE.delete_VideoView(swigCPtr);
70 swigCPtr = new global::System.Runtime.InteropServices.HandleRef(null, global::System.IntPtr.Zero);
77 /// Event arguments that passed via the finished signal.
79 public class FinishedEventArgs : EventArgs
81 private VideoView _videoView;
84 /// The view for video playback and display.
86 /// <since_tizen> 3 </since_tizen>
87 public VideoView VideoView
101 [UnmanagedFunctionPointer(CallingConvention.StdCall)]
102 private delegate void FinishedCallbackDelegate(IntPtr data);
103 private EventHandler<FinishedEventArgs> _videoViewFinishedEventHandler;
104 private FinishedCallbackDelegate _videoViewFinishedCallbackDelegate;
108 /// Event for the finished signal which can be used to subscribe or unsubscribe the event handler
109 /// (in the type of FinishedEventHandler-DaliEventHandler<object,FinishedEventArgs>) provided by the user.<br>
110 /// The finished signal is emitted when a video playback has finished.<br>
112 /// <since_tizen> 3 </since_tizen>
113 public event EventHandler<FinishedEventArgs> Finished
117 if (_videoViewFinishedEventHandler == null)
119 _videoViewFinishedCallbackDelegate = (OnFinished);
120 FinishedSignal().Connect(_videoViewFinishedCallbackDelegate);
122 _videoViewFinishedEventHandler += value;
126 _videoViewFinishedEventHandler -= value;
127 if (_videoViewFinishedEventHandler == null && FinishedSignal().Empty() == false)
129 FinishedSignal().Disconnect(_videoViewFinishedCallbackDelegate);
134 // Callback for VideoView Finished signal
135 private void OnFinished(IntPtr data)
137 FinishedEventArgs e = new FinishedEventArgs();
139 // Populate all members of "e" (FinishedEventArgs) with real data
140 e.VideoView = Registry.GetManagedBaseHandleFromNativePtr(data) as VideoView;
142 if (_videoViewFinishedEventHandler != null)
144 //here we send all data to user event handlers
145 _videoViewFinishedEventHandler(this, e);
149 internal new class Property
151 internal static readonly int VIDEO = NDalicPINVOKE.VideoView_Property_VIDEO_get();
152 internal static readonly int LOOPING = NDalicPINVOKE.VideoView_Property_LOOPING_get();
153 internal static readonly int MUTED = NDalicPINVOKE.VideoView_Property_MUTED_get();
154 internal static readonly int VOLUME = NDalicPINVOKE.VideoView_Property_VOLUME_get();
158 /// Creates an initialized VideoView.
160 /// <since_tizen> 3 </since_tizen>
161 public VideoView() : this(NDalicPINVOKE.VideoView_New__SWIG_0(), true)
163 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
168 /// Creates an initialized VideoView.<br>
169 /// If the string is empty, VideoView will not display anything.<br>
171 /// <param name="url">The URL of the video resource to display.</param>
172 /// <since_tizen> 3 </since_tizen>
173 public VideoView(string url) : this(NDalicPINVOKE.VideoView_New__SWIG_1(url), true)
175 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
178 internal VideoView(VideoView videoView) : this(NDalicPINVOKE.new_VideoView__SWIG_1(VideoView.getCPtr(videoView)), true)
180 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
183 [Obsolete("Please do not use! this will be deprecated")]
184 public new static VideoView DownCast(BaseHandle handle)
186 VideoView ret = Registry.GetManagedBaseHandleFromNativePtr(handle) as VideoView;
187 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
192 /// Starts the video playback.
194 /// <since_tizen> 3 </since_tizen>
197 NDalicPINVOKE.VideoView_Play(swigCPtr);
198 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
202 /// Pauses the video playback.
204 /// <since_tizen> 3 </since_tizen>
207 NDalicPINVOKE.VideoView_Pause(swigCPtr);
208 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
212 /// Stops the video playback.
214 /// <since_tizen> 3 </since_tizen>
217 NDalicPINVOKE.VideoView_Stop(swigCPtr);
218 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
222 /// Seeks forward by the specified number of milliseconds.
224 /// <param name="millisecond">The position for forward playback.</param>
225 /// <since_tizen> 3 </since_tizen>
226 public void Forward(int millisecond)
228 NDalicPINVOKE.VideoView_Forward(swigCPtr, millisecond);
229 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
233 /// Seeks backward by the specified number of milliseconds.
235 /// <param name="millisecond">The position for backward playback.</param>
236 /// <since_tizen> 3 </since_tizen>
237 public void Backward(int millisecond)
239 NDalicPINVOKE.VideoView_Backward(swigCPtr, millisecond);
240 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
243 internal VideoViewSignal FinishedSignal()
245 VideoViewSignal ret = new VideoViewSignal(NDalicPINVOKE.VideoView_FinishedSignal(swigCPtr), false);
246 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
251 /// Video file URL as string type or PropertyMap.
253 /// <since_tizen> 3 </since_tizen>
254 public PropertyMap Video
258 PropertyMap temp = new PropertyMap();
259 GetProperty(VideoView.Property.VIDEO).Get(temp);
264 SetProperty(VideoView.Property.VIDEO, new Tizen.NUI.PropertyValue(value));
269 /// The looping status, true or false.
271 /// <since_tizen> 3 </since_tizen>
277 GetProperty(VideoView.Property.LOOPING).Get(out temp);
282 SetProperty(VideoView.Property.LOOPING, new Tizen.NUI.PropertyValue(value));
287 /// The mute status, true or false.
289 /// <since_tizen> 3 </since_tizen>
295 GetProperty(VideoView.Property.MUTED).Get(out temp);
300 SetProperty(VideoView.Property.MUTED, new Tizen.NUI.PropertyValue(value));
305 /// The left and the right volume scalar as float type, PropertyMap with two values ( "left" and "right" ).
307 /// <since_tizen> 3 </since_tizen>
308 public PropertyMap Volume
312 PropertyMap temp = new PropertyMap();
313 GetProperty(VideoView.Property.VOLUME).Get(temp);
318 SetProperty(VideoView.Property.VOLUME, new PropertyValue(value));