// Created: 17/09/98
// RCS-ID: $Id$
// Copyright: (c) Julian Smart
-// Licence: wxWindows licence
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifdef __GNUG__
#pragma implementation "statbmp.h"
#endif
+#include "wx/defs.h"
+
#include "wx/statbmp.h"
+#ifdef __VMS__
+#pragma message disable nosimpint
+#endif
#include <Xm/Xm.h>
#include <Xm/Label.h>
#include <Xm/LabelG.h>
#include <Xm/RowColumn.h>
+#ifdef __VMS__
+#pragma message enable nosimpint
+#endif
-#include <wx/motif/private.h>
+#include "wx/motif/private.h"
-#if !USE_SHARED_LIBRARY
IMPLEMENT_DYNAMIC_CLASS(wxStaticBitmap, wxControl)
-#endif
/*
* wxStaticBitmap
const wxString& name)
{
m_messageBitmap = bitmap;
+ m_messageBitmapOriginal = bitmap;
SetName(name);
m_backgroundColour = parent->GetBackgroundColour();
m_foregroundColour = parent->GetForegroundColour();
if (parent) parent->AddChild(this);
if ( id == -1 )
- m_windowId = (int)NewControlId();
+ m_windowId = (int)NewControlId();
else
- m_windowId = id;
+ m_windowId = id;
m_windowStyle = style;
XmNalignment, XmALIGNMENT_BEGINNING,
NULL);
- XtVaSetValues ((Widget) m_mainWidget,
- XmNlabelPixmap, (Pixmap) ((wxBitmap&)bitmap).GetLabelPixmap (m_mainWidget),
- XmNlabelType, XmPIXMAP,
- NULL);
+ ChangeBackgroundColour ();
- SetCanAddEventHandler(TRUE);
- AttachWidget (parent, m_mainWidget, (WXWidget) NULL, pos.x, pos.y, size.x, size.y);
+ DoSetBitmap();
- SetFont(* parent->GetFont());
+ m_font = parent->GetFont();
+ ChangeFont(FALSE);
- ChangeBackgroundColour ();
+ SetCanAddEventHandler(TRUE);
+
+ wxSize actualSize(size);
+ // work around the cases where the bitmap is a wxNull(Icon/Bitmap)
+ if (actualSize.x == -1)
+ actualSize.x = bitmap.GetWidth() ? bitmap.GetWidth() : 1;
+ if (actualSize.y == -1)
+ actualSize.y = bitmap.GetHeight() ? bitmap.GetHeight() : 1;
+ AttachWidget (parent, m_mainWidget, (WXWidget) NULL, pos.x, pos.y, actualSize.x, actualSize.y);
return TRUE;
}
SetBitmap(wxNullBitmap);
}
-void wxStaticBitmap::SetSize(int x, int y, int width, int height, int sizeFlags)
-{
- wxControl::SetSize(x, y, width, height, sizeFlags);
-}
-
-void wxStaticBitmap::SetBitmap(const wxBitmap& bitmap)
+void wxStaticBitmap::DoSetBitmap()
{
- m_messageBitmap = bitmap;
-
Widget widget = (Widget) m_mainWidget;
int x, y, w1, h1, w2, h2;
GetPosition(&x, &y);
- if (bitmap.Ok())
+ if (m_messageBitmapOriginal.Ok())
{
- w2 = bitmap.GetWidth();
- h2 = bitmap.GetHeight();
+ w2 = m_messageBitmapOriginal.GetWidth();
+ h2 = m_messageBitmapOriginal.GetHeight();
+
+ Pixmap pixmap;
+
+ // Must re-make the bitmap to have its transparent areas drawn
+ // in the current widget background colour.
+ if (m_messageBitmapOriginal.GetMask())
+ {
+ int backgroundPixel;
+ XtVaGetValues( widget, XmNbackground, &backgroundPixel,
+ NULL);
+
+ wxColour col;
+ col.SetPixel(backgroundPixel);
+
+ wxBitmap newBitmap = wxCreateMaskedBitmap(m_messageBitmapOriginal, col);
+ m_messageBitmap = newBitmap;
+
+ pixmap = (Pixmap) m_messageBitmap.GetPixmap();
+ }
+ else
+ {
+ m_bitmapCache.SetBitmap( m_messageBitmap );
+ pixmap = (Pixmap)m_bitmapCache.GetLabelPixmap(widget);
+ }
+
XtVaSetValues (widget,
- XmNlabelPixmap, ((wxBitmap&)bitmap).GetLabelPixmap (widget),
+ XmNlabelPixmap, pixmap,
XmNlabelType, XmPIXMAP,
- NULL);
+ NULL);
GetSize(&w1, &h1);
if (! (w1 == w2) && (h1 == h2))
// since it is no longer valid.
XtVaSetValues (widget,
XmNlabelType, XmSTRING,
- XmNlabelPixmap, NULL, // TODO: Does this work?
+ XmNlabelPixmap, XmUNSPECIFIED_PIXMAP,
NULL);
- }
+ }
}
-void wxStaticBitmap::ChangeFont()
+void wxStaticBitmap::SetBitmap(const wxBitmap& bitmap)
{
- // TODO
+ m_messageBitmap = bitmap;
+ m_messageBitmapOriginal = bitmap;
+
+ DoSetBitmap();
+}
+
+void wxStaticBitmap::ChangeFont(bool keepOriginalSize)
+{
+ wxWindow::ChangeFont(keepOriginalSize);
}
void wxStaticBitmap::ChangeBackgroundColour()
{
- // TODO
+ wxWindow::ChangeBackgroundColour();
+
+ // must recalculate the background colour
+ m_bitmapCache.SetColoursChanged();
+ DoSetBitmap();
}
void wxStaticBitmap::ChangeForegroundColour()
{
- // TODO
+ m_bitmapCache.SetColoursChanged();
+ wxWindow::ChangeForegroundColour();
}