+/////////////////////////////////////////////////////////////////////////////
+// Name: statpict.cpp
+// Purpose: wxStaticPicture
+// Author: Wade Brainerd (wadeb@wadeb.com)
+// Modified by:
+// Created: 2003-05-01
+// RCS-ID:
+// Copyright: (c) Wade Brainerd
+// Licence: wxWindows licence
+/////////////////////////////////////////////////////////////////////////////
+
+#ifdef __GNUG__
+ #pragma implementation "statpict.h"
+#endif
+
+#include "wx/defs.h"
+
+#include "statpict.h"
+#include "wx/dcclient.h"
+
+#if !USE_SHARED_LIBRARY
+IMPLEMENT_DYNAMIC_CLASS(wxStaticPicture, wxControl)
+#endif
+
+/*
+ * wxStaticPicture
+ */
+
+BEGIN_EVENT_TABLE(wxStaticPicture, wxControl)
+ EVT_PAINT(wxStaticPicture::OnPaint)
+END_EVENT_TABLE()
+
+bool wxStaticPicture::Create(wxWindow *parent, wxWindowID id,
+ const wxBitmap& bitmap,
+ const wxPoint& pos,
+ const wxSize& s,
+ long style,
+ const wxString& name)
+{
+ SetName(name);
+
+ wxSize size = s ;
+ if ( bitmap.Ok() )
+ {
+ if ( size.x == -1 )
+ size.x = bitmap.GetWidth() ;
+ if ( size.y == -1 )
+ size.y = bitmap.GetHeight() ;
+ }
+
+ m_backgroundColour = parent->GetBackgroundColour() ;
+ m_foregroundColour = parent->GetForegroundColour() ;
+
+ Bitmap = bitmap;
+ Align = 0;
+ Scale = 0;
+ ScaleX = ScaleY = 1;
+
+#ifndef __WXMSW__
+ LastScaleX = LastScaleY = -1;
+ if ( Bitmap.Ok() )
+ OriginalImage = Bitmap.ConvertToImage();
+#endif
+
+ if ( id == -1 )
+ m_windowId = (int)NewControlId();
+ else
+ m_windowId = id;
+
+ m_windowStyle = style;
+
+ bool ret = wxControl::Create( parent, id, pos, size, style, wxDefaultValidator, name );
+
+ SetBestSize( size ) ;
+
+ return ret;
+}
+
+void wxStaticPicture::SetBitmap( const wxBitmap& bmp )
+{
+ Bitmap = bmp;
+#ifndef __WXMSW__
+ if ( Bitmap.Ok() )
+ OriginalImage = Bitmap.ConvertToImage();
+ LastScaleX = LastScaleY = -1;
+#endif
+}
+
+void wxStaticPicture::OnPaint(wxPaintEvent& WXUNUSED(event))
+{
+ if ( !Bitmap.Ok() )
+ return;
+
+ wxPaintDC dc( this );
+ PrepareDC( dc );
+ dc.BeginDrawing();
+
+ wxSize sz = GetSize();
+ wxSize bmpsz( Bitmap.GetWidth(), Bitmap.GetHeight() );
+ float sx = 1.0f, sy = 1.0f;
+
+ if ( Scale & wxSCALE_UNIFORM )
+ {
+ float _sx = (float)sz.GetWidth() / (float)bmpsz.GetWidth();
+ float _sy = (float)sz.GetHeight() / (float)bmpsz.GetHeight();
+ sx = sy = _sx < _sy ? _sx : _sy;
+ }
+ else
+ if ( Scale & wxSCALE_CUSTOM )
+ {
+ sx = ScaleX;
+ sy = ScaleY;
+ }
+ else
+ {
+ if ( Scale & wxSCALE_HORIZONTAL )
+ sx = (float)sz.x/(float)bmpsz.x;
+ if ( Scale & wxSCALE_VERTICAL )
+ sy = (float)sz.y/(float)bmpsz.y;
+ }
+
+ bmpsz = wxSize( (int)(bmpsz.x*sx), (int)(bmpsz.y*sy) );
+
+ wxPoint pos( 0, 0 );
+
+ if ( Align & wxALIGN_CENTER_HORIZONTAL ) pos.x = (sz.x-bmpsz.x)/2;
+ else if ( Align & wxALIGN_RIGHT ) pos.x = sz.x-bmpsz.x;
+
+ if ( Align & wxALIGN_CENTER_VERTICAL ) pos.y = (sz.y-bmpsz.y)/2;
+ else if ( Align & wxALIGN_BOTTOM ) pos.y = sz.y-bmpsz.y;
+
+ if ( Scale )
+ {
+#ifdef __WXMSW__
+ double ux, uy;
+ dc.GetUserScale( &ux, &uy );
+ dc.SetUserScale( ux*sx, uy*sy );
+ dc.DrawBitmap( Bitmap, (int)((float)pos.x/sx), (int)((float)pos.y/sy) );
+ dc.SetUserScale( ux, uy );
+#else
+ if ( LastScaleX != sx || LastScaleY != sy )
+ {
+ LastScaleX = sx;
+ LastScaleY = sy;
+ ScaledBitmap = wxBitmap( OriginalImage.Scale( bmpsz.x, bmpsz.y ) );
+ }
+ dc.DrawBitmap( ScaledBitmap, pos.x, pos.y );
+#endif
+ }
+ else
+ dc.DrawBitmap( Bitmap, pos.x, pos.y );
+
+ dc.EndDrawing();
+}
+
+//WXDLLEXPORT_DATA(const wxChar *) wxStaticPictureNameStr = wxT("message");
+const wxChar * wxStaticPictureNameStr = wxT("message");