X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/12d1ab44bb48542e60dc4103537bd63ba7be8858..a6c129111b38341eb561b110fd1566b260740675:/contrib/src/animate/animate.cpp diff --git a/contrib/src/animate/animate.cpp b/contrib/src/animate/animate.cpp index a0bad64e6e..8b3ecd27e7 100644 --- a/contrib/src/animate/animate.cpp +++ b/contrib/src/animate/animate.cpp @@ -9,19 +9,19 @@ // Licence: wxWindows licence /////////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ - #pragma implementation "animate.h" -#endif - #include "wx/wxprec.h" #ifdef __BORLANDC__ #pragma hdrstop #endif //__BORLANDC__ +#include "wx/log.h" #include "wx/wfstream.h" #include "wx/image.h" #include "wx/gifdecod.h" +#include "wx/dcmemory.h" +#include "wx/dc.h" +#include "wx/dcclient.h" #include "wx/animate/animate.h" /* @@ -34,15 +34,15 @@ wxAnimationPlayer::wxAnimationPlayer(wxAnimationBase *animation, bool destroyAni { m_animation = animation; m_destroyAnimation = destroyAnimation; + m_customBackgroundColour = wxColour(0, 0, 0); m_currentFrame = 0; m_window = (wxWindow*) NULL; m_position = wxPoint(0, 0); - m_looped = TRUE; - m_isPlaying = FALSE; - m_useBackgroundColour = FALSE; - m_customBackgroundColour = wxColour(0, 0, 0); - m_useCustomBackgroundColour = FALSE; - m_useParentBackground = FALSE; + m_looped = true; + m_isPlaying = false; + m_useBackgroundColour = false; + m_useCustomBackgroundColour = false; + m_useParentBackground = false; m_timer.SetPlayer(this); } @@ -65,25 +65,27 @@ void wxAnimationPlayer::SetAnimation(wxAnimationBase* animation, bool destroyAni } // Play -bool wxAnimationPlayer::Play(wxWindow& window, const wxPoint& pos, bool looped) +bool wxAnimationPlayer::Play(wxWindow& window, const wxPoint& pos, bool WXUNUSED(looped)) { m_window = & window; if (!m_animation || !m_animation->IsValid()) - return FALSE; + return false; wxSize sz = GetLogicalScreenSize(); wxRect rect(pos, sz); SaveBackground(rect); - if (m_frames.Number() == 0) + if (m_frames.GetCount() == 0) { if (!Build()) { - wxLogWarning("wxAnimationPlayer::Play: could not build the image cache."); - return FALSE; + wxLogWarning(_T("wxAnimationPlayer::Play: could not build the image cache.")); + + return false; } } + m_currentFrame = 0; // Create the backing store @@ -91,7 +93,7 @@ bool wxAnimationPlayer::Play(wxWindow& window, const wxPoint& pos, bool looped) PlayFrame(); - return TRUE; + return true; } // Build animation (list of wxImages). If not called before Play @@ -99,44 +101,41 @@ bool wxAnimationPlayer::Play(wxWindow& window, const wxPoint& pos, bool looped) bool wxAnimationPlayer::Build() { ClearCache(); - if (m_animation) + if (!m_animation) + return false; + + int i, n; + + n = GetFrameCount(); + for (i = 0; i < n; i++) { - int n = GetFrameCount(); - int i; - for (i = 0; i < n; i++) - { - wxBitmap* bitmap = NULL; - wxImage* image = GetFrame(i); - if (image) - { - // If the frame has transparency, - // set the colour so converting to a bitmap - // will create a mask - wxColour transparentColour; - if (GetTransparentColour(transparentColour)) - image->SetMaskColour(transparentColour.Red(), transparentColour.Green(), transparentColour.Blue()); - - bitmap = new wxBitmap(* image); - delete image; - if (bitmap) - m_frames.Append(bitmap); - else - return FALSE; - } - else - return FALSE; - } - return TRUE; + wxImage* image = GetFrame(i); + if (image == NULL) + return false; + + // If the frame has transparency, + // set the colour so converting to a bitmap + // will create a mask + wxColour transparentColour; + if (GetTransparentColour(transparentColour)) + image->SetMaskColour(transparentColour.Red(), transparentColour.Green(), transparentColour.Blue()); + + wxBitmap* bitmap = new wxBitmap(*image); + delete image; + if (bitmap == NULL) + return false; + + m_frames.Append(bitmap); } - else - return FALSE; + + return true; } // Stop the animation void wxAnimationPlayer::Stop() { m_timer.Stop(); - m_isPlaying = FALSE; + m_isPlaying = false; } // Draw the current view of the animation into this DC. @@ -146,7 +145,6 @@ void wxAnimationPlayer::Draw(wxDC& dc) dc.DrawBitmap(m_backingStore, m_position.x, m_position.y); } - int wxAnimationPlayer::GetFrameCount() const { if (m_animation) @@ -200,7 +198,7 @@ bool wxAnimationPlayer::GetBackgroundColour(wxColour& col) const if (m_animation) return m_animation->GetBackgroundColour(col); else - return FALSE; + return false; } bool wxAnimationPlayer::GetTransparentColour(wxColour& col) const @@ -208,11 +206,11 @@ bool wxAnimationPlayer::GetTransparentColour(wxColour& col) const if (m_animation) return m_animation->GetTransparentColour(col); else - return FALSE; + return false; } // Play the frame -bool wxAnimationPlayer::PlayFrame(int frame, wxWindow& window, wxPoint& pos) +bool wxAnimationPlayer::PlayFrame(int frame, wxWindow& window, const wxPoint& WXUNUSED(pos)) { wxMemoryDC dc; dc.SelectObject(m_backingStore); @@ -225,9 +223,7 @@ bool wxAnimationPlayer::PlayFrame(int frame, wxWindow& window, wxPoint& pos) if (UsingCustomBackgroundColour()) col = GetCustomBackgroundColour(); else - { GetBackgroundColour(col); - } // Draw the background colour loaded from the animation // (or set by the user) @@ -239,16 +235,14 @@ bool wxAnimationPlayer::PlayFrame(int frame, wxWindow& window, wxPoint& pos) dc.DrawBitmap(m_savedBackground, 0, 0); } - // Draw all intermediate frames that haven't been removed from the - // animation + // Draw all intermediate frames that haven't been removed from the animation int i; - for (i = 0; i < (frame - 1); i++) + for (i = 0; i < frame; i++) { if ((GetDisposalMethod(i) == wxANIM_DONOTREMOVE) || (GetDisposalMethod(i) == wxANIM_UNSPECIFIED)) - { DrawFrame(i, dc, wxPoint(0, 0)); - } } + DrawFrame(frame, dc, wxPoint(0, 0)); dc.SelectObject(wxNullBitmap); @@ -257,17 +251,21 @@ bool wxAnimationPlayer::PlayFrame(int frame, wxWindow& window, wxPoint& pos) wxClientDC clientDC(& window); Draw(clientDC); - return TRUE; + return true; } bool wxAnimationPlayer::PlayFrame() { - m_isPlaying = TRUE; + m_isPlaying = true; PlayFrame(GetCurrentFrame(), * GetWindow(), GetPosition()); // Set the timer for the next frame - m_timer.Start(GetDelay(GetCurrentFrame())); + int delay = GetDelay(GetCurrentFrame()); + if (delay == 0) + delay = 1; // 0 is invalid timeout for wxTimer. + + m_timer.Start(delay); m_currentFrame ++; @@ -277,25 +275,26 @@ bool wxAnimationPlayer::PlayFrame() if (!m_looped) { m_timer.Stop(); - m_isPlaying = FALSE; + m_isPlaying = false; } else m_currentFrame = 0; } - return TRUE; + return true; } // Clear the wxImage cache void wxAnimationPlayer::ClearCache() { - wxNode* node = m_frames.First(); + wxList::compatibility_iterator node = m_frames.GetFirst(); while (node) { - wxNode* next = node->Next(); - wxBitmap* bitmap = (wxBitmap*) node->Data(); + wxList::compatibility_iterator next = node->GetNext(); + wxBitmap* bitmap = (wxBitmap*) node->GetData(); delete bitmap; - delete node; + m_frames.Erase(node); + node = next; } } @@ -303,18 +302,16 @@ void wxAnimationPlayer::ClearCache() // Draw the background colour void wxAnimationPlayer::DrawBackground(wxDC& dc, const wxPoint& pos, const wxColour& colour) { - wxASSERT_MSG( (m_animation != NULL), "Animation not present in wxAnimationPlayer"); - wxASSERT_MSG( (m_frames.Number() != 0), "Animation cache not present in wxAnimationPlayer"); + wxASSERT_MSG( (m_animation != NULL), _T("Animation not present in wxAnimationPlayer")); + wxASSERT_MSG( (m_frames.GetCount() > 0), _T("Animation cache not present in wxAnimationPlayer")); // Optimization: if the first frame fills the whole area, and is non-transparent, // don't bother drawing the background - wxBitmap* firstBitmap = (wxBitmap*) m_frames.First()->Data() ; + wxBitmap* firstBitmap = (wxBitmap*) m_frames.GetFirst()->GetData() ; wxSize screenSize = GetLogicalScreenSize(); if (!firstBitmap->GetMask() && (firstBitmap->GetWidth() == screenSize.x) && (firstBitmap->GetHeight() == screenSize.y)) - { return; - } wxBrush brush(colour, wxSOLID); wxPen pen(colour, 1, wxSOLID); @@ -329,7 +326,7 @@ void wxAnimationPlayer::DrawBackground(wxDC& dc, const wxPoint& pos, const wxCol // it if drawing transparently void wxAnimationPlayer::SaveBackground(const wxRect& rect) { - wxASSERT( GetWindow() ); + wxASSERT( (GetWindow() != NULL) ); if (!GetWindow()) return; @@ -358,21 +355,21 @@ void wxAnimationPlayer::SaveBackground(const wxRect& rect) memDC.Blit(0, 0, rect.width, rect.height, & dc, rect.x, rect.y); } + memDC.SelectObject(wxNullBitmap); } // Draw this frame void wxAnimationPlayer::DrawFrame(int frame, wxDC& dc, const wxPoint& pos) { - wxASSERT_MSG( (m_animation != NULL), "Animation not present in wxAnimationPlayer"); - wxASSERT_MSG( (m_frames.Number() != 0), "Animation cache not present in wxAnimationPlayer"); - wxASSERT_MSG( (m_frames.Nth(frame) != (wxNode*) NULL), "Image not present in wxAnimationPlayer::DrawFrame"); - - wxBitmap* bitmap = (wxBitmap*) m_frames.Nth(frame)->Data() ; + wxASSERT_MSG( (m_animation != NULL), _T("Animation not present in wxAnimationPlayer")); + wxASSERT_MSG( (m_frames.GetCount() != 0), _T("Animation cache not present in wxAnimationPlayer")); + wxASSERT_MSG( !!m_frames.Item(frame), _T("Image not present in wxAnimationPlayer::DrawFrame")); + wxBitmap* bitmap = (wxBitmap*) m_frames.Item(frame)->GetData() ; wxRect rect = GetFrameRect(frame); - dc.DrawBitmap(* bitmap, pos.x + rect.x, pos.y + rect.y, (bitmap->GetMask() != NULL)); + dc.DrawBitmap(*bitmap, pos.x + rect.x, pos.y + rect.y, (bitmap->GetMask() != NULL)); } void wxAnimationTimer::Notify() @@ -404,27 +401,28 @@ wxGIFAnimation::~wxGIFAnimation() int wxGIFAnimation::GetFrameCount() const { - wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), "m_decoder must be non-NULL"); + wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), _T("m_decoder must be non-NULL")); return m_decoder->GetNumberOfFrames(); } wxImage* wxGIFAnimation::GetFrame(int i) const { - wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), "m_decoder must be non-NULL"); + wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), _T("m_decoder must be non-NULL")); - m_decoder->GoFrame(i); + m_decoder->GoFrame(i + 1); wxImage* image = new wxImage; m_decoder->ConvertToImage(image); + return image; } wxAnimationDisposal wxGIFAnimation::GetDisposalMethod(int i) const { - wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), "m_decoder must be non-NULL"); + wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), _T("m_decoder must be non-NULL")); - m_decoder->GoFrame(i); + m_decoder->GoFrame(i + 1); int disposalMethod = m_decoder->GetDisposalMethod(); return (wxAnimationDisposal) disposalMethod; @@ -432,69 +430,63 @@ wxAnimationDisposal wxGIFAnimation::GetDisposalMethod(int i) const wxRect wxGIFAnimation::GetFrameRect(int i) const { - wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), "m_decoder must be non-NULL"); + wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), _T("m_decoder must be non-NULL")); - m_decoder->GoFrame(i); + m_decoder->GoFrame(i + 1); wxRect rect(m_decoder->GetLeft(), m_decoder->GetTop(), m_decoder->GetWidth(), m_decoder->GetHeight()); + return rect; } int wxGIFAnimation::GetDelay(int i) const { - wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), "m_decoder must be non-NULL"); + wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), _T("m_decoder must be non-NULL")); + + m_decoder->GoFrame(i + 1); - m_decoder->GoFrame(i); return m_decoder->GetDelay(); } wxSize wxGIFAnimation::GetLogicalScreenSize() const { - wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), "m_decoder must be non-NULL"); + wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), _T("m_decoder must be non-NULL")); return wxSize(m_decoder->GetLogicalScreenWidth(), m_decoder->GetLogicalScreenHeight()); } bool wxGIFAnimation::GetBackgroundColour(wxColour& col) const { - wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), "m_decoder must be non-NULL"); + wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), _T("m_decoder must be non-NULL")); int i = m_decoder->GetBackgroundColour(); if (i == -1) - return FALSE; - else - { - unsigned char* pal = m_decoder->GetPalette(); + return false; - if (pal) - { - col = wxColour(pal[3*i + 0], pal[3*i + 1], pal[3*i + 2]); - return TRUE; - } - else - return FALSE; - } + const unsigned char *pal = m_decoder->GetPalette(); + bool result = (pal != NULL); + + if (result) + col = wxColour(pal[3*i + 0], pal[3*i + 1], pal[3*i + 2]); + + return result; } bool wxGIFAnimation::GetTransparentColour(wxColour& col) const { - wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), "m_decoder must be non-NULL"); + wxASSERT_MSG( (m_decoder != (wxGIFDecoder*) NULL), _T("m_decoder must be non-NULL")); int i = m_decoder->GetTransparentColour(); if (i == -1) - return FALSE; - else - { - unsigned char* pal = m_decoder->GetPalette(); + return false; - if (pal) - { - col = wxColour(pal[3*i + 0], pal[3*i + 1], pal[3*i + 2]); - return TRUE; - } - else - return FALSE; - } + const unsigned char *pal = m_decoder->GetPalette(); + bool result = (pal != NULL); + + if (result) + col = wxColour(pal[3*i + 0], pal[3*i + 1], pal[3*i + 2]); + + return result; } bool wxGIFAnimation::IsValid() const @@ -504,34 +496,35 @@ bool wxGIFAnimation::IsValid() const bool wxGIFAnimation::LoadFile(const wxString& filename) { + if (!wxFileExists(filename)) + return false; + + bool result = true; + if (m_decoder) + { delete m_decoder; - m_decoder = NULL; + m_decoder = NULL; + } - if (wxFileExists(filename)) { wxFileInputStream stream(filename); - m_decoder = new wxGIFDecoder(& stream, TRUE); - if (m_decoder->ReadGIF() != wxGIF_OK) - { - delete m_decoder; - m_decoder = NULL; - return FALSE; - } + if (stream.GetLength() > 0) + m_decoder = new wxGIFDecoder(&stream, true); - if (!m_decoder->IsAnimation()) - { - delete m_decoder; - m_decoder = NULL; + result = ((m_decoder != NULL) && (m_decoder->ReadGIF() == wxGIF_OK)); + if (result) + result = m_decoder->IsAnimation(); + } - return FALSE; - } - else - return TRUE; + if (!result && (m_decoder != NULL)) + { + delete m_decoder; + m_decoder = NULL; } - else - return FALSE; + + return result; } /* @@ -555,28 +548,32 @@ bool wxAnimationCtrlBase::Create(wxWindow *parent, wxWindowID id, m_filename = filename; if (!wxControl::Create(parent, id, pos, size, style, wxDefaultValidator, name)) - return FALSE; + return false; SetBackgroundColour(parent->GetBackgroundColour()); m_animationPlayer.SetCustomBackgroundColour(GetBackgroundColour()); - // Want to give the impression of transparency by painting - // the parent background + // give the impression of transparency by painting + // with the parent background // if (parent) -// m_animationPlayer.UseParentBackground(TRUE); +// m_animationPlayer.UseParentBackground(true); + m_animationPlayer.SetWindow(this); m_animationPlayer.SetPosition(wxPoint(0, 0)); - m_animationPlayer.SetDestroyAnimation(FALSE); + m_animationPlayer.SetDestroyAnimation(false); - return TRUE; + LoadFile(filename); + + return true; } wxAnimationCtrlBase::~wxAnimationCtrlBase() { if (m_animationPlayer.IsPlaying()) m_animationPlayer.Stop(); - m_animationPlayer.SetAnimation(NULL, FALSE); + m_animationPlayer.SetAnimation(NULL, false); + delete m_animation; } @@ -588,10 +585,11 @@ bool wxAnimationCtrlBase::LoadFile(const wxString& filename) wxString filename1(filename); if (filename1.IsEmpty()) + { filename1 = m_filename; - - if (filename1.IsEmpty()) - return FALSE; + if (filename1.IsEmpty()) + return false; + } if (m_animation) { @@ -601,20 +599,22 @@ bool wxAnimationCtrlBase::LoadFile(const wxString& filename) m_animation = DoCreateAnimation(filename1); if (!m_animation) - return FALSE; + return false; if (!m_animation->LoadFile(filename) || !m_animation->IsValid()) { delete m_animation; m_animation = NULL; - return FALSE; + + return false; } - m_animationPlayer.SetAnimation(m_animation, FALSE); + + m_animationPlayer.SetAnimation(m_animation, false); if (GetWindowStyle() & wxAN_FIT_ANIMATION) FitToAnimation(); - return TRUE; + return true; } bool wxAnimationCtrlBase::Play(bool looped) @@ -625,13 +625,9 @@ bool wxAnimationCtrlBase::Play(bool looped) wxSize wxAnimationCtrlBase::DoGetBestSize() const { if (m_animationPlayer.HasAnimation() && (GetWindowStyle() & wxAN_FIT_ANIMATION)) - { return m_animationPlayer.GetLogicalScreenSize(); - } else - { return GetSize(); - } } void wxAnimationCtrlBase::FitToAnimation() @@ -643,14 +639,12 @@ void wxAnimationCtrlBase::FitToAnimation() SetClientSize(sz); } -void wxAnimationCtrlBase::OnPaint(wxPaintEvent& event) +void wxAnimationCtrlBase::OnPaint(wxPaintEvent& WXUNUSED(event)) { wxPaintDC dc(this); if (GetPlayer().IsPlaying()) - { GetPlayer().Draw(dc); - } } /* @@ -664,3 +658,4 @@ wxAnimationBase* wxGIFAnimationCtrl::DoCreateAnimation(const wxString& WXUNUSED( { return new wxGIFAnimation; } +