]> git.saurik.com Git - wxWidgets.git/blame_incremental - include/wx/mediactrl.h
Fix missing documentation for several GDI functions.
[wxWidgets.git] / include / wx / mediactrl.h
... / ...
CommitLineData
1///////////////////////////////////////////////////////////////////////////////
2// Name: wx/mediactrl.h
3// Purpose: wxMediaCtrl class
4// Author: Ryan Norton <wxprojects@comcast.net>
5// Modified by:
6// Created: 11/07/04
7// RCS-ID: $Id$
8// Copyright: (c) Ryan Norton
9// Licence: wxWindows licence
10///////////////////////////////////////////////////////////////////////////////
11
12// ============================================================================
13// Definitions
14// ============================================================================
15
16// ----------------------------------------------------------------------------
17// Header guard
18// ----------------------------------------------------------------------------
19#ifndef _WX_MEDIACTRL_H_
20#define _WX_MEDIACTRL_H_
21
22// ----------------------------------------------------------------------------
23// Pre-compiled header stuff
24// ----------------------------------------------------------------------------
25
26#include "wx/defs.h"
27
28// ----------------------------------------------------------------------------
29// Compilation guard
30// ----------------------------------------------------------------------------
31
32#if wxUSE_MEDIACTRL
33
34// ----------------------------------------------------------------------------
35// Includes
36// ----------------------------------------------------------------------------
37
38#include "wx/control.h"
39#include "wx/uri.h"
40
41// ============================================================================
42// Declarations
43// ============================================================================
44
45// ----------------------------------------------------------------------------
46//
47// Enumerations
48//
49// ----------------------------------------------------------------------------
50
51enum wxMediaState
52{
53 wxMEDIASTATE_STOPPED,
54 wxMEDIASTATE_PAUSED,
55 wxMEDIASTATE_PLAYING
56};
57
58enum wxMediaCtrlPlayerControls
59{
60 wxMEDIACTRLPLAYERCONTROLS_NONE = 0,
61 //Step controls like fastforward, step one frame etc.
62 wxMEDIACTRLPLAYERCONTROLS_STEP = 1 << 0,
63 //Volume controls like the speaker icon, volume slider, etc.
64 wxMEDIACTRLPLAYERCONTROLS_VOLUME = 1 << 1,
65 wxMEDIACTRLPLAYERCONTROLS_DEFAULT =
66 wxMEDIACTRLPLAYERCONTROLS_STEP |
67 wxMEDIACTRLPLAYERCONTROLS_VOLUME
68};
69
70#define wxMEDIABACKEND_DIRECTSHOW wxT("wxAMMediaBackend")
71#define wxMEDIABACKEND_MCI wxT("wxMCIMediaBackend")
72#define wxMEDIABACKEND_QUICKTIME wxT("wxQTMediaBackend")
73#define wxMEDIABACKEND_GSTREAMER wxT("wxGStreamerMediaBackend")
74#define wxMEDIABACKEND_REALPLAYER wxT("wxRealPlayerMediaBackend")
75#define wxMEDIABACKEND_WMP10 wxT("wxWMP10MediaBackend")
76
77// ----------------------------------------------------------------------------
78//
79// wxMediaEvent
80//
81// ----------------------------------------------------------------------------
82
83class WXDLLIMPEXP_MEDIA wxMediaEvent : public wxNotifyEvent
84{
85public:
86 // ------------------------------------------------------------------------
87 // wxMediaEvent Constructor
88 //
89 // Normal constructor, much the same as wxNotifyEvent
90 // ------------------------------------------------------------------------
91 wxMediaEvent(wxEventType commandType = wxEVT_NULL, int winid = 0)
92 : wxNotifyEvent(commandType, winid)
93 { }
94
95 // ------------------------------------------------------------------------
96 // wxMediaEvent Copy Constructor
97 //
98 // Normal copy constructor, much the same as wxNotifyEvent
99 // ------------------------------------------------------------------------
100 wxMediaEvent(const wxMediaEvent &clone)
101 : wxNotifyEvent(clone)
102 { }
103
104 // ------------------------------------------------------------------------
105 // wxMediaEvent::Clone
106 //
107 // Allocates a copy of this object.
108 // Required for wxEvtHandler::AddPendingEvent
109 // ------------------------------------------------------------------------
110 virtual wxEvent *Clone() const
111 { return new wxMediaEvent(*this); }
112
113
114 // Put this class on wxWidget's RTTI table
115 DECLARE_DYNAMIC_CLASS(wxMediaEvent)
116};
117
118// ----------------------------------------------------------------------------
119//
120// wxMediaCtrl
121//
122// ----------------------------------------------------------------------------
123
124class WXDLLIMPEXP_MEDIA wxMediaCtrl : public wxControl
125{
126public:
127 wxMediaCtrl() : m_imp(NULL), m_bLoaded(false)
128 { }
129
130 wxMediaCtrl(wxWindow* parent, wxWindowID winid,
131 const wxString& fileName = wxEmptyString,
132 const wxPoint& pos = wxDefaultPosition,
133 const wxSize& size = wxDefaultSize,
134 long style = 0,
135 const wxString& szBackend = wxEmptyString,
136 const wxValidator& validator = wxDefaultValidator,
137 const wxString& name = wxT("mediaCtrl"))
138 : m_imp(NULL), m_bLoaded(false)
139 { Create(parent, winid, fileName, pos, size, style,
140 szBackend, validator, name); }
141
142 wxMediaCtrl(wxWindow* parent, wxWindowID winid,
143 const wxURI& location,
144 const wxPoint& pos = wxDefaultPosition,
145 const wxSize& size = wxDefaultSize,
146 long style = 0,
147 const wxString& szBackend = wxEmptyString,
148 const wxValidator& validator = wxDefaultValidator,
149 const wxString& name = wxT("mediaCtrl"))
150 : m_imp(NULL), m_bLoaded(false)
151 { Create(parent, winid, location, pos, size, style,
152 szBackend, validator, name); }
153
154 virtual ~wxMediaCtrl();
155
156 bool Create(wxWindow* parent, wxWindowID winid,
157 const wxString& fileName = wxEmptyString,
158 const wxPoint& pos = wxDefaultPosition,
159 const wxSize& size = wxDefaultSize,
160 long style = 0,
161 const wxString& szBackend = wxEmptyString,
162 const wxValidator& validator = wxDefaultValidator,
163 const wxString& name = wxT("mediaCtrl"));
164
165 bool Create(wxWindow* parent, wxWindowID winid,
166 const wxURI& location,
167 const wxPoint& pos = wxDefaultPosition,
168 const wxSize& size = wxDefaultSize,
169 long style = 0,
170 const wxString& szBackend = wxEmptyString,
171 const wxValidator& validator = wxDefaultValidator,
172 const wxString& name = wxT("mediaCtrl"));
173
174 bool DoCreate(const wxClassInfo* instance,
175 wxWindow* parent, wxWindowID winid,
176 const wxPoint& pos = wxDefaultPosition,
177 const wxSize& size = wxDefaultSize,
178 long style = 0,
179 const wxValidator& validator = wxDefaultValidator,
180 const wxString& name = wxT("mediaCtrl"));
181
182 bool Play();
183 bool Pause();
184 bool Stop();
185
186 bool Load(const wxString& fileName);
187
188 wxMediaState GetState();
189
190 wxFileOffset Seek(wxFileOffset where, wxSeekMode mode = wxFromStart);
191 wxFileOffset Tell(); //FIXME: This should be const
192 wxFileOffset Length(); //FIXME: This should be const
193
194 double GetPlaybackRate(); //All but MCI & GStreamer
195 bool SetPlaybackRate(double dRate); //All but MCI & GStreamer
196
197 bool Load(const wxURI& location);
198 bool Load(const wxURI& location, const wxURI& proxy);
199
200 wxFileOffset GetDownloadProgress(); // DirectShow only
201 wxFileOffset GetDownloadTotal(); // DirectShow only
202
203 double GetVolume();
204 bool SetVolume(double dVolume);
205
206 bool ShowPlayerControls(
207 wxMediaCtrlPlayerControls flags = wxMEDIACTRLPLAYERCONTROLS_DEFAULT);
208
209 //helpers for the wxPython people
210 bool LoadURI(const wxString& fileName)
211 { return Load(wxURI(fileName)); }
212 bool LoadURIWithProxy(const wxString& fileName, const wxString& proxy)
213 { return Load(wxURI(fileName), wxURI(proxy)); }
214
215protected:
216 static const wxClassInfo* NextBackend(wxClassInfo::const_iterator* it);
217
218 void OnMediaFinished(wxMediaEvent& evt);
219 virtual void DoMoveWindow(int x, int y, int w, int h);
220 wxSize DoGetBestSize() const;
221
222 //FIXME: This is nasty... find a better way to work around
223 //inheritance issues
224#if defined(__WXOSX_CARBON__)
225 virtual void MacVisibilityChanged();
226#endif
227#if defined(__WXOSX_CARBON__) || defined(__WXCOCOA__)
228 friend class wxQTMediaBackend;
229#endif
230 class wxMediaBackend* m_imp;
231 bool m_bLoaded;
232
233 DECLARE_DYNAMIC_CLASS(wxMediaCtrl)
234};
235
236// ----------------------------------------------------------------------------
237//
238// wxMediaBackend
239//
240// Derive from this and use standard wxWidgets RTTI
241// (DECLARE_DYNAMIC_CLASS and IMPLEMENT_CLASS) to make a backend
242// for wxMediaCtrl. Backends are searched alphabetically -
243// the one with the earliest letter is tried first.
244//
245// Note that this is currently not API or ABI compatible -
246// so statically link or make the client compile on-site.
247//
248// ----------------------------------------------------------------------------
249
250class WXDLLIMPEXP_MEDIA wxMediaBackend : public wxObject
251{
252public:
253 wxMediaBackend()
254 { }
255
256 virtual ~wxMediaBackend();
257
258 virtual bool CreateControl(wxControl* WXUNUSED(ctrl),
259 wxWindow* WXUNUSED(parent),
260 wxWindowID WXUNUSED(winid),
261 const wxPoint& WXUNUSED(pos),
262 const wxSize& WXUNUSED(size),
263 long WXUNUSED(style),
264 const wxValidator& WXUNUSED(validator),
265 const wxString& WXUNUSED(name))
266 { return false; }
267
268 virtual bool Play()
269 { return false; }
270 virtual bool Pause()
271 { return false; }
272 virtual bool Stop()
273 { return false; }
274
275 virtual bool Load(const wxString& WXUNUSED(fileName))
276 { return false; }
277 virtual bool Load(const wxURI& WXUNUSED(location))
278 { return false; }
279
280 virtual bool SetPosition(wxLongLong WXUNUSED(where))
281 { return 0; }
282 virtual wxLongLong GetPosition()
283 { return 0; }
284 virtual wxLongLong GetDuration()
285 { return 0; }
286
287 virtual void Move(int WXUNUSED(x), int WXUNUSED(y),
288 int WXUNUSED(w), int WXUNUSED(h))
289 { }
290 virtual wxSize GetVideoSize() const
291 { return wxSize(0,0); }
292
293 virtual double GetPlaybackRate()
294 { return 0.0; }
295 virtual bool SetPlaybackRate(double WXUNUSED(dRate))
296 { return false; }
297
298 virtual wxMediaState GetState()
299 { return wxMEDIASTATE_STOPPED; }
300
301 virtual double GetVolume()
302 { return 0.0; }
303 virtual bool SetVolume(double WXUNUSED(dVolume))
304 { return false; }
305
306 virtual bool Load(const wxURI& WXUNUSED(location),
307 const wxURI& WXUNUSED(proxy))
308 { return false; }
309
310 virtual bool ShowPlayerControls(
311 wxMediaCtrlPlayerControls WXUNUSED(flags))
312 { return false; }
313 virtual bool IsInterfaceShown()
314 { return false; }
315
316 virtual wxLongLong GetDownloadProgress()
317 { return 0; }
318 virtual wxLongLong GetDownloadTotal()
319 { return 0; }
320
321 virtual void MacVisibilityChanged()
322 { }
323 virtual void RESERVED9() {}
324
325 DECLARE_DYNAMIC_CLASS(wxMediaBackend)
326};
327
328
329//Our events
330wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_MEDIA, wxEVT_MEDIA_FINISHED, wxMediaEvent );
331wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_MEDIA, wxEVT_MEDIA_STOP, wxMediaEvent );
332
333//Function type(s) our events need
334typedef void (wxEvtHandler::*wxMediaEventFunction)(wxMediaEvent&);
335
336#define wxMediaEventHandler(func) \
337 wxEVENT_HANDLER_CAST(wxMediaEventFunction, func)
338
339//Macro for usage with message maps
340#define EVT_MEDIA_FINISHED(winid, fn) wxDECLARE_EVENT_TABLE_ENTRY( wxEVT_MEDIA_FINISHED, winid, wxID_ANY, wxMediaEventHandler(fn), NULL ),
341#define EVT_MEDIA_STOP(winid, fn) wxDECLARE_EVENT_TABLE_ENTRY( wxEVT_MEDIA_STOP, winid, wxID_ANY, wxMediaEventHandler(fn), NULL ),
342
343wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_MEDIA, wxEVT_MEDIA_LOADED, wxMediaEvent );
344#define EVT_MEDIA_LOADED(winid, fn) wxDECLARE_EVENT_TABLE_ENTRY( wxEVT_MEDIA_LOADED, winid, wxID_ANY, wxMediaEventHandler(fn), NULL ),
345
346wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_MEDIA, wxEVT_MEDIA_STATECHANGED, wxMediaEvent );
347wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_MEDIA, wxEVT_MEDIA_PLAY, wxMediaEvent );
348wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_MEDIA, wxEVT_MEDIA_PAUSE, wxMediaEvent );
349#define EVT_MEDIA_STATECHANGED(winid, fn) wxDECLARE_EVENT_TABLE_ENTRY( wxEVT_MEDIA_STATECHANGED, winid, wxID_ANY, wxMediaEventHandler(fn), NULL ),
350#define EVT_MEDIA_PLAY(winid, fn) wxDECLARE_EVENT_TABLE_ENTRY( wxEVT_MEDIA_PLAY, winid, wxID_ANY, wxMediaEventHandler(fn), NULL ),
351#define EVT_MEDIA_PAUSE(winid, fn) wxDECLARE_EVENT_TABLE_ENTRY( wxEVT_MEDIA_PAUSE, winid, wxID_ANY, wxMediaEventHandler(fn), NULL ),
352
353// ----------------------------------------------------------------------------
354// common backend base class used by many other backends
355// ----------------------------------------------------------------------------
356
357class WXDLLIMPEXP_MEDIA wxMediaBackendCommonBase : public wxMediaBackend
358{
359public:
360 // add a pending wxMediaEvent of the given type
361 void QueueEvent(wxEventType evtType);
362
363 // notify that the movie playback is finished
364 void QueueFinishEvent()
365 {
366 QueueEvent(wxEVT_MEDIA_STATECHANGED);
367 QueueEvent(wxEVT_MEDIA_FINISHED);
368 }
369
370 // send the stop event and return true if it hasn't been vetoed
371 bool SendStopEvent();
372
373 // Queue pause event
374 void QueuePlayEvent();
375
376 // Queue pause event
377 void QueuePauseEvent();
378
379 // Queue stop event (no veto)
380 void QueueStopEvent();
381
382protected:
383 // call this when the movie size has changed but not because it has just
384 // been loaded (in this case, call NotifyMovieLoaded() below)
385 void NotifyMovieSizeChanged();
386
387 // call this when the movie is fully loaded
388 void NotifyMovieLoaded();
389
390
391 wxMediaCtrl *m_ctrl; // parent control
392};
393
394// ----------------------------------------------------------------------------
395// End compilation guard
396// ----------------------------------------------------------------------------
397#endif // wxUSE_MEDIACTRL
398
399// ----------------------------------------------------------------------------
400// End header guard and header itself
401// ----------------------------------------------------------------------------
402#endif // _WX_MEDIACTRL_H_
403
404