X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7115e540ece749b83928eded985ac79e8ccbe68a..01aefd229e82820455518e9feab1af5058433a1b:/src/mac/carbon/mediactrl.cpp diff --git a/src/mac/carbon/mediactrl.cpp b/src/mac/carbon/mediactrl.cpp index 716590fefd..7a1dd947f7 100644 --- a/src/mac/carbon/mediactrl.cpp +++ b/src/mac/carbon/mediactrl.cpp @@ -118,7 +118,11 @@ public: void FinishLoad(); wxSize m_bestSize; //Original movie size +#ifdef __WXMAC_OSX__ struct MovieType** m_movie; //QT Movie handle/instance +#else + Movie m_movie ; +#endif wxControl* m_ctrl; //Parent control bool m_bVideo; //Whether or not we have video class _wxQTTimer* m_timer; //Timer for streaming the movie @@ -220,7 +224,7 @@ wxQTMediaBackend::~wxQTMediaBackend() if(m_timer) Cleanup(); - //Note that ExitMovies() is not neccessary... + //Note that ExitMovies() is not necessary... ExitMovies(); } @@ -257,17 +261,21 @@ bool wxQTMediaBackend::CreateControl(wxControl* ctrl, wxWindow* parent, if ( ! #if wxUSE_CREATEMOVIECONTROL - ctrl->wxControl::Create(parent, id, pos, size, - m_ctrl->MacRemoveBordersFromStyle(style), - validator, name) -#else ctrl->wxWindow::Create(parent, id, pos, size, m_ctrl->MacRemoveBordersFromStyle(style), name) +#else + ctrl->wxControl::Create(parent, id, pos, size, + m_ctrl->MacRemoveBordersFromStyle(style), + validator, name) #endif ) return false; +#if wxUSE_VALIDATORS + ctrl->SetValidator(validator); +#endif + m_ctrl = ctrl; return true; } @@ -290,6 +298,12 @@ bool wxQTMediaBackend::Load(const wxString& fileName) short movieResFile; FSSpec sfFile; + //FIXME:wxMacFilename2FSSpec crashes on empty string - + //does it crash on other strings too and should this + //"fix" be put in the carbon wxSound? + if (fileName.empty()) + return false; + wxMacFilename2FSSpec( fileName , &sfFile ); if (OpenMovieFile (&sfFile, &movieResFile, fsRdPerm) != noErr) @@ -401,6 +415,8 @@ void wxQTMediaBackend::FinishLoad() //Native CreateMovieControl QT control (Thanks to Kevin Olliver's //wxQTMovie for some of this). // + #define GetControlPeer(whatever) ctrl->m_peer + wxMediaCtrl* ctrl = (wxMediaCtrl*) m_ctrl; Rect bounds = wxMacGetBoundsForControl(m_ctrl, m_ctrl->GetPosition(), m_ctrl->GetSize()); @@ -419,7 +435,7 @@ void wxQTMediaBackend::FinishLoad() //ManuallyIdled - app handles movie idling rather than internal timer event loop ::CreateMovieControl( (WindowRef) - m_ctrl->MacGetTopLevelWindowRef(), //parent + ctrl->MacGetTopLevelWindowRef(), //parent &bounds, //control bounds m_movie, //movie handle kMovieControlOptionHideController @@ -427,10 +443,9 @@ void wxQTMediaBackend::FinishLoad() | kMovieControlOptionSetKeysEnabled // | kMovieControlOptionManuallyIdled , //flags - GetControlPeer(m_ctrl)->GetControlRefAddr() ); + ctrl->m_peer->GetControlRefAddr() ); - ::EmbedControl(GetControlPeer(m_ctrl)->GetControlRef(), - (ControlRef) m_ctrl->GetParent()->GetHandle()); + ::EmbedControl(ctrl->m_peer->GetControlRef(), (ControlRef)ctrl->GetParent()->GetHandle()); #else // //"Emulation" @@ -452,7 +467,7 @@ void wxQTMediaBackend::FinishLoad() // //Here, if the parent of the control has a sizer - we //tell it to recalculate the size of this control since - //the user opened a seperate media file + //the user opened a separate media file // m_ctrl->InvalidateBestSize(); m_ctrl->GetParent()->Layout(); @@ -600,7 +615,7 @@ void wxQTMediaBackend::Cleanup() m_timer = NULL; #if wxUSE_CREATEMOVIECONTROL - DisposeControl(GetControlPeer(m_ctrl)->GetControlRef()); + DisposeControl(((wxMediaCtrl*)m_ctrl)->m_peer->GetControlRef()); #endif StopMovie(m_movie); @@ -620,8 +635,8 @@ wxSize wxQTMediaBackend::GetVideoSize() const //--------------------------------------------------------------------------- // wxQTMediaBackend::Move // -// If not using a native 10.2 QT control performs some emulated window -// movement stuff +// We need to do this even when using native qt control because +// CreateMovieControl is broken in this regard... //--------------------------------------------------------------------------- void wxQTMediaBackend::Move(int x, int y, int w, int h) { @@ -638,12 +653,21 @@ void wxQTMediaBackend::Move(int x, int y, int w, int h) ::SetMovieBox(m_movie, &theRect); wxASSERT(::GetMoviesError() == noErr); } +#else + if(m_timer && m_ctrl) + { + m_ctrl->GetParent()->MacWindowToRootWindow(&x, &y); + + ::MoveControl( (ControlRef) m_ctrl->GetHandle(), x, y ); + m_ctrl->GetParent()->Refresh(); + m_ctrl->GetParent()->Update(); + } #endif } //in source file that contains stuff you don't directly use -#include +#include "wx/html/forcelnk.h" FORCE_LINK_ME(basewxmediabackends); #endif //wxUSE_MEDIACTRL