1. wxBitmap copy ctor and operator=() taking wxIcon added

2. wxBitmapButton focus rect looks a bit better and it respects the icon
   mask
3. wxWizard::GetPageSize() added


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@4550 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
1999-11-14 02:22:27 +00:00
parent 954269e6dd
commit 4fe5383d6c
8 changed files with 218 additions and 141 deletions

View File

@@ -27,6 +27,7 @@ public:
// implement base class pure virtuals // implement base class pure virtuals
virtual bool RunWizard(wxWizardPage *firstPage); virtual bool RunWizard(wxWizardPage *firstPage);
virtual wxWizardPage *GetCurrentPage() const; virtual wxWizardPage *GetCurrentPage() const;
virtual wxSize GetPageSize() const;
// implementation only from now on // implementation only from now on
// ------------------------------- // -------------------------------

View File

@@ -56,8 +56,9 @@ public:
bool Create(const wxBitmap& bitmap); bool Create(const wxBitmap& bitmap);
// Implementation // Implementation
inline WXHBITMAP GetMaskBitmap(void) const { return m_maskBitmap; } WXHBITMAP GetMaskBitmap() const { return m_maskBitmap; }
inline void SetMaskBitmap(WXHBITMAP bmp) { m_maskBitmap = bmp; } void SetMaskBitmap(WXHBITMAP bmp) { m_maskBitmap = bmp; }
protected: protected:
WXHBITMAP m_maskBitmap; WXHBITMAP m_maskBitmap;
}; };
@@ -94,19 +95,19 @@ class WXDLLEXPORT wxBitmapHandler: public wxObject
{ {
DECLARE_DYNAMIC_CLASS(wxBitmapHandler) DECLARE_DYNAMIC_CLASS(wxBitmapHandler)
public: public:
wxBitmapHandler(void) { m_name = ""; m_extension = ""; m_type = 0; }; wxBitmapHandler() { m_name = ""; m_extension = ""; m_type = 0; };
virtual bool Create(wxBitmap *bitmap, void *data, long flags, int width, int height, int depth = 1); virtual bool Create(wxBitmap *bitmap, void *data, long flags, int width, int height, int depth = 1);
virtual bool LoadFile(wxBitmap *bitmap, const wxString& name, long flags, virtual bool LoadFile(wxBitmap *bitmap, const wxString& name, long flags,
int desiredWidth, int desiredHeight); int desiredWidth, int desiredHeight);
virtual bool SaveFile(wxBitmap *bitmap, const wxString& name, int type, const wxPalette *palette = NULL); virtual bool SaveFile(wxBitmap *bitmap, const wxString& name, int type, const wxPalette *palette = NULL);
inline void SetName(const wxString& name) { m_name = name; } void SetName(const wxString& name) { m_name = name; }
inline void SetExtension(const wxString& ext) { m_extension = ext; } void SetExtension(const wxString& ext) { m_extension = ext; }
inline void SetType(long type) { m_type = type; } void SetType(long type) { m_type = type; }
inline wxString GetName(void) const { return m_name; } wxString GetName() const { return m_name; }
inline wxString GetExtension(void) const { return m_extension; } wxString GetExtension() const { return m_extension; }
inline long GetType(void) const { return m_type; } long GetType() const { return m_type; }
protected: protected:
wxString m_name; wxString m_name;
wxString m_extension; wxString m_extension;
@@ -116,15 +117,14 @@ protected:
class WXDLLEXPORT wxBitmap: public wxGDIObject class WXDLLEXPORT wxBitmap: public wxGDIObject
{ {
DECLARE_DYNAMIC_CLASS(wxBitmap)
friend class WXDLLEXPORT wxBitmapHandler; friend class WXDLLEXPORT wxBitmapHandler;
public: public:
wxBitmap(); // Platform-specific // default ctor creates an invalid bitmap, you must Create() it later
wxBitmap() { Init(); }
// Copy constructors // Copy constructors
wxBitmap(const wxBitmap& bitmap); wxBitmap(const wxBitmap& bitmap) { Init(); Ref(bitmap); }
// Initialize with raw data // Initialize with raw data
wxBitmap(const char bits[], int width, int height, int depth = 1); wxBitmap(const char bits[], int width, int height, int depth = 1);
@@ -143,42 +143,57 @@ public:
// we must have this, otherwise icons are silently copied into bitmaps using // we must have this, otherwise icons are silently copied into bitmaps using
// the copy ctor but the resulting bitmap is invalid! // the copy ctor but the resulting bitmap is invalid!
wxBitmap(const wxIcon& icon); wxBitmap(const wxIcon& icon) { Init(); CopyFromIcon(icon); }
~wxBitmap(); wxBitmap& operator=(const wxBitmap& bitmap)
{
if ( m_refData != bitmap.m_refData )
Ref(bitmap);
return *this;
}
wxBitmap& operator=(const wxIcon& icon)
{
(void)CopyFromIcon(icon);
return *this;
}
virtual ~wxBitmap();
// copies the contents and mask of the given (colour) icon to the bitmap
bool CopyFromIcon(const wxIcon& icon);
virtual bool Create(int width, int height, int depth = -1); virtual bool Create(int width, int height, int depth = -1);
virtual bool Create(void *data, long type, int width, int height, int depth = 1); virtual bool Create(void *data, long type, int width, int height, int depth = 1);
virtual bool LoadFile(const wxString& name, long type = wxBITMAP_TYPE_BMP_RESOURCE); virtual bool LoadFile(const wxString& name, long type = wxBITMAP_TYPE_BMP_RESOURCE);
virtual bool SaveFile(const wxString& name, int type, const wxPalette *cmap = NULL); virtual bool SaveFile(const wxString& name, int type, const wxPalette *cmap = NULL);
inline bool Ok(void) const { return (M_BITMAPDATA && M_BITMAPDATA->m_ok); } bool Ok() const { return (M_BITMAPDATA && M_BITMAPDATA->m_ok); }
inline int GetWidth(void) const { return (M_BITMAPDATA ? M_BITMAPDATA->m_width : 0); } int GetWidth() const { return (M_BITMAPDATA ? M_BITMAPDATA->m_width : 0); }
inline int GetHeight(void) const { return (M_BITMAPDATA ? M_BITMAPDATA->m_height : 0); } int GetHeight() const { return (M_BITMAPDATA ? M_BITMAPDATA->m_height : 0); }
inline int GetDepth(void) const { return (M_BITMAPDATA ? M_BITMAPDATA->m_depth : 0); } int GetDepth() const { return (M_BITMAPDATA ? M_BITMAPDATA->m_depth : 0); }
inline int GetQuality(void) const { return (M_BITMAPDATA ? M_BITMAPDATA->m_quality : 0); } int GetQuality() const { return (M_BITMAPDATA ? M_BITMAPDATA->m_quality : 0); }
void SetWidth(int w); void SetWidth(int w);
void SetHeight(int h); void SetHeight(int h);
void SetDepth(int d); void SetDepth(int d);
void SetQuality(int q); void SetQuality(int q);
void SetOk(bool isOk); void SetOk(bool isOk);
#if WXWIN_COMPATIBILITY #if WXWIN_COMPATIBILITY
inline wxPalette *GetColourMap(void) const { return GetPalette(); } wxPalette *GetColourMap() const { return GetPalette(); }
void SetColourMap(wxPalette *cmap) { SetPalette(*cmap); }; void SetColourMap(wxPalette *cmap) { SetPalette(*cmap); };
#endif #endif
inline wxPalette* GetPalette(void) const { return (M_BITMAPDATA ? (& M_BITMAPDATA->m_bitmapPalette) : (wxPalette*) NULL); } wxPalette* GetPalette() const { return (M_BITMAPDATA ? (& M_BITMAPDATA->m_bitmapPalette) : (wxPalette*) NULL); }
void SetPalette(const wxPalette& palette); void SetPalette(const wxPalette& palette);
inline wxMask *GetMask(void) const { return (M_BITMAPDATA ? M_BITMAPDATA->m_bitmapMask : (wxMask*) NULL); } wxMask *GetMask() const { return (M_BITMAPDATA ? M_BITMAPDATA->m_bitmapMask : (wxMask*) NULL); }
void SetMask(wxMask *mask) ; void SetMask(wxMask *mask) ;
inline wxBitmap& operator = (const wxBitmap& bitmap) { if (*this == bitmap) return (*this); Ref(bitmap); return *this; } bool operator==(const wxBitmap& bitmap) { return m_refData == bitmap.m_refData; }
bool operator!=(const wxBitmap& bitmap) { return m_refData != bitmap.m_refData; }
inline bool operator == (const wxBitmap& bitmap) { return m_refData == bitmap.m_refData; }
inline bool operator != (const wxBitmap& bitmap) { return m_refData != bitmap.m_refData; }
// Format handling // Format handling
static inline wxList& GetHandlers(void) { return sm_handlers; } static wxList& GetHandlers() { return sm_handlers; }
static void AddHandler(wxBitmapHandler *handler); static void AddHandler(wxBitmapHandler *handler);
static void InsertHandler(wxBitmapHandler *handler); static void InsertHandler(wxBitmapHandler *handler);
static bool RemoveHandler(const wxString& name); static bool RemoveHandler(const wxString& name);
@@ -188,15 +203,16 @@ public:
static void InitStandardHandlers(); static void InitStandardHandlers();
static void CleanUpHandlers(); static void CleanUpHandlers();
protected: protected:
static wxList sm_handlers; static wxList sm_handlers;
// Implementation // Implementation
public: public:
void SetHBITMAP(WXHBITMAP bmp); void SetHBITMAP(WXHBITMAP bmp);
inline WXHBITMAP GetHBITMAP(void) const { return (M_BITMAPDATA ? M_BITMAPDATA->m_hBitmap : 0); } WXHBITMAP GetHBITMAP() const { return (M_BITMAPDATA ? M_BITMAPDATA->m_hBitmap : 0); }
inline void SetSelectedInto(wxDC *dc) { if (M_BITMAPDATA) M_BITMAPDATA->m_selectedInto = dc; } void SetSelectedInto(wxDC *dc) { if (M_BITMAPDATA) M_BITMAPDATA->m_selectedInto = dc; }
inline wxDC *GetSelectedInto(void) const { return (M_BITMAPDATA ? M_BITMAPDATA->m_selectedInto : (wxDC*) NULL); } wxDC *GetSelectedInto() const { return (M_BITMAPDATA ? M_BITMAPDATA->m_selectedInto : (wxDC*) NULL); }
bool FreeResource(bool force = FALSE); bool FreeResource(bool force = FALSE);
// Creates a bitmap that matches the device context's depth, from // Creates a bitmap that matches the device context's depth, from
@@ -212,6 +228,12 @@ public:
// Contributed by Frederic Villeneuve <frederic.villeneuve@natinst.com> // Contributed by Frederic Villeneuve <frederic.villeneuve@natinst.com>
wxBitmap GetBitmapForDC(wxDC& dc) const; wxBitmap GetBitmapForDC(wxDC& dc) const;
protected:
// common part of all ctors
void Init();
private:
DECLARE_DYNAMIC_CLASS(wxBitmap)
}; };
#endif #endif

View File

@@ -121,6 +121,10 @@ public:
// get the current page (NULL if RunWizard() isn't running) // get the current page (NULL if RunWizard() isn't running)
virtual wxWizardPage *GetCurrentPage() const = 0; virtual wxWizardPage *GetCurrentPage() const = 0;
// get the size available for the page: the wizards are not resizeable, so
// this size doesn't change
virtual wxSize GetPageSize() const = 0;
}; };
// include the real class declaration // include the real class declaration

View File

@@ -355,14 +355,16 @@ void wxObject::Ref(const wxObject& clone)
void wxObject::UnRef() void wxObject::UnRef()
{ {
if (m_refData) { if ( m_refData )
assert(m_refData->m_count > 0); {
--(m_refData->m_count); wxASSERT_MSG( m_refData->m_count > 0, _T("invalid ref data count") );
if (m_refData->m_count == 0)
if ( !--m_refData->m_count )
delete m_refData; delete m_refData;
}
m_refData = (wxObjectRefData *) NULL; m_refData = (wxObjectRefData *) NULL;
} }
}
/* /*
* wxObjectData * wxObjectData

View File

@@ -265,6 +265,11 @@ wxWizardPage *wxWizard::GetCurrentPage() const
return m_page; return m_page;
} }
wxSize wxWizard::GetPageSize() const
{
return wxSize(m_width, m_height);
}
void wxWizard::OnCancel(wxCommandEvent& WXUNUSED(event)) void wxWizard::OnCancel(wxCommandEvent& WXUNUSED(event))
{ {
// this function probably can never be called when we don't have an active // this function probably can never be called when we don't have an active

View File

@@ -93,59 +93,77 @@ wxBitmapRefData::~wxBitmapRefData()
wxList wxBitmap::sm_handlers; wxList wxBitmap::sm_handlers;
wxBitmap::wxBitmap() // this function should be called from all wxBitmap ctors
void wxBitmap::Init()
{ {
// m_refData = NULL; done in the base class ctor
if ( wxTheBitmapList ) if ( wxTheBitmapList )
wxTheBitmapList->AddBitmap(this); wxTheBitmapList->AddBitmap(this);
} }
wxBitmap::wxBitmap(const wxIcon& icon) bool wxBitmap::CopyFromIcon(const wxIcon& icon)
{ {
if ( wxTheBitmapList ) UnRef();
wxTheBitmapList->AddBitmap(this);
if ( !icon.Ok() ) if ( !icon.Ok() )
return; return FALSE;
int width = icon.GetWidth(), int width = icon.GetWidth(),
height = icon.GetHeight(); height = icon.GetHeight();
HDC hdc = ::CreateCompatibleDC(NULL); // screen DC HICON hicon = (HICON) icon.GetHICON();
HBITMAP hbitmap = ::CreateCompatibleBitmap(hdc, width, height);
// GetIconInfo() doesn't exist under Win16 and I don't know any other way
// to create a bitmap from icon there - but using this way we won't have
// the mask (FIXME)
#ifdef __WIN16__
// copy the icon to the bitmap
HDC hdcScreen = ::GetDC((HWND)NULL);
HDC hdc = ::CreateCompatibleDC(hdcScreen);
HBITMAP hbitmap = ::CreateCompatibleBitmap(hdcScreen, width, height);
HBITMAP hbmpOld = (HBITMAP)::SelectObject(hdc, hbitmap); HBITMAP hbmpOld = (HBITMAP)::SelectObject(hdc, hbitmap);
HICON hicon = (HICON) icon.GetHICON();
#if defined(__WIN32__) && !defined(__SC__) && !defined(__TWIN32__)
::DrawIconEx(hdc, 0, 0, hicon, width, height, 0, 0, DI_NORMAL);
#else
::DrawIcon(hdc, 0, 0, hicon); ::DrawIcon(hdc, 0, 0, hicon);
#endif
::SelectObject(hdc, hbmpOld); ::SelectObject(hdc, hbmpOld);
::DeleteDC(hdc); ::DeleteDC(hdc);
::ReleaseDC((HWND)NULL, hdcScreen);
#else // Win32
ICONINFO iconInfo;
if ( !GetIconInfo(hicon, &iconInfo) )
{
wxLogLastError("GetIconInfo");
return FALSE;
}
HBITMAP hbitmap = iconInfo.hbmColor;
wxBitmap bmpMask(width, height, 1);
bmpMask.SetHBITMAP((WXHBITMAP)iconInfo.hbmMask);
SetMask(new wxMask(bmpMask));
#endif // Win16/32
m_refData = new wxBitmapRefData; m_refData = new wxBitmapRefData;
M_BITMAPDATA->m_width = width; M_BITMAPDATA->m_width = width;
M_BITMAPDATA->m_height = height; M_BITMAPDATA->m_height = height;
M_BITMAPDATA->m_depth = wxDisplayDepth(); M_BITMAPDATA->m_depth = wxDisplayDepth();
M_BITMAPDATA->m_numColors = 0;
M_BITMAPDATA->m_hBitmap = (WXHBITMAP)hbitmap; M_BITMAPDATA->m_hBitmap = (WXHBITMAP)hbitmap;
M_BITMAPDATA->m_ok = TRUE; M_BITMAPDATA->m_ok = TRUE;
}
wxBitmap::wxBitmap(const wxBitmap& bitmap) return TRUE;
{
Ref(bitmap);
if ( wxTheBitmapList )
wxTheBitmapList->AddBitmap(this);
} }
wxBitmap::~wxBitmap() wxBitmap::~wxBitmap()
{ {
if (wxTheBitmapList) if (wxTheBitmapList)
wxTheBitmapList->DeleteObject(this); wxTheBitmapList->DeleteObject(this);
delete GetMask();
} }
bool wxBitmap::FreeResource(bool WXUNUSED(force)) bool wxBitmap::FreeResource(bool WXUNUSED(force))
@@ -175,6 +193,8 @@ bool wxBitmap::FreeResource(bool WXUNUSED(force))
wxBitmap::wxBitmap(const char bits[], int the_width, int the_height, int no_bits) wxBitmap::wxBitmap(const char bits[], int the_width, int the_height, int no_bits)
{ {
Init();
m_refData = new wxBitmapRefData; m_refData = new wxBitmapRefData;
M_BITMAPDATA->m_width = the_width ; M_BITMAPDATA->m_width = the_width ;
@@ -190,39 +210,35 @@ wxBitmap::wxBitmap(const char bits[], int the_width, int the_height, int no_bits
M_BITMAPDATA->m_ok = FALSE; M_BITMAPDATA->m_ok = FALSE;
M_BITMAPDATA->m_selectedInto = NULL; M_BITMAPDATA->m_selectedInto = NULL;
if ( wxTheBitmapList )
wxTheBitmapList->AddBitmap(this);
} }
// Create from XPM data // Create from XPM data
wxBitmap::wxBitmap(char **data, wxControl *WXUNUSED(anItem)) wxBitmap::wxBitmap(char **data, wxControl *WXUNUSED(anItem))
{ {
Init();
(void)Create((void *)data, wxBITMAP_TYPE_XPM_DATA, 0, 0, 0); (void)Create((void *)data, wxBITMAP_TYPE_XPM_DATA, 0, 0, 0);
} }
wxBitmap::wxBitmap(int w, int h, int d) wxBitmap::wxBitmap(int w, int h, int d)
{ {
(void)Create(w, h, d); Init();
if ( wxTheBitmapList ) (void)Create(w, h, d);
wxTheBitmapList->AddBitmap(this);
} }
wxBitmap::wxBitmap(void *data, long type, int width, int height, int depth) wxBitmap::wxBitmap(void *data, long type, int width, int height, int depth)
{ {
(void) Create(data, type, width, height, depth); Init();
if ( wxTheBitmapList ) (void) Create(data, type, width, height, depth);
wxTheBitmapList->AddBitmap(this);
} }
wxBitmap::wxBitmap(const wxString& filename, long type) wxBitmap::wxBitmap(const wxString& filename, long type)
{ {
LoadFile(filename, (int)type); Init();
if ( wxTheBitmapList ) LoadFile(filename, (int)type);
wxTheBitmapList->AddBitmap(this);
} }
bool wxBitmap::Create(int w, int h, int d) bool wxBitmap::Create(int w, int h, int d)

View File

@@ -155,7 +155,20 @@ bool wxBitmapButton::MSWOnDraw(WXDRAWITEMSTRUCT *item)
y1 ++; y1 ++;
} }
::BitBlt(hDC, x1, y1, bitmap->GetWidth(), bitmap->GetHeight(), memDC, 0, 0, SRCCOPY); wxMask *mask = bitmap->GetMask();
if ( mask )
{
::MaskBlt(hDC, x1, y1, bitmap->GetWidth(), bitmap->GetHeight(), // dst
memDC, 0, 0, // src
(HBITMAP)mask->GetMaskBitmap(), 0, 0, // mask
MAKEROP4(SRCPAINT, SRCCOPY));
}
else
{
::BitBlt(hDC, x1, y1, bitmap->GetWidth(), bitmap->GetHeight(), // dst
memDC, 0, 0, // src
SRCCOPY);
}
if ( (state & ODS_DISABLED) && (GetWindowStyleFlag() & wxBU_AUTODRAW) ) if ( (state & ODS_DISABLED) && (GetWindowStyleFlag() & wxBU_AUTODRAW) )
DrawButtonDisable( (WXHDC) hDC, lpDIS->rcItem.left, lpDIS->rcItem.top, lpDIS->rcItem.right, lpDIS->rcItem.bottom, TRUE ) ; DrawButtonDisable( (WXHDC) hDC, lpDIS->rcItem.left, lpDIS->rcItem.top, lpDIS->rcItem.right, lpDIS->rcItem.bottom, TRUE ) ;
@@ -232,7 +245,8 @@ void wxBitmapButton::DrawFace( WXHDC dc, int left, int top, int right, int botto
DeleteObject(brushFace); DeleteObject(brushFace);
} }
#define FOCUS_MARGIN 6 // VZ: should be at the very least less than wxDEFAULT_BUTTON_MARGIN
#define FOCUS_MARGIN 3
void wxBitmapButton::DrawButtonFocus( WXHDC dc, int left, int top, int right, int bottom, bool sel ) void wxBitmapButton::DrawButtonFocus( WXHDC dc, int left, int top, int right, int bottom, bool sel )
{ {

View File

@@ -99,15 +99,28 @@ wxSize wxStaticText::DoGetBestSize()
wxString text(wxGetWindowText(GetHWND())); wxString text(wxGetWindowText(GetHWND()));
int widthTextMax = 0, widthLine, int widthTextMax = 0, widthLine,
heightTextTotal = 0, heightLine; heightTextTotal = 0, heightLineDefault = 0, heightLine = 0;
wxString curLine; wxString curLine;
for ( const wxChar *pc = text; ; pc++ ) { for ( const wxChar *pc = text; ; pc++ ) {
if ( *pc == wxT('\n') || *pc == wxT('\0') ) { if ( *pc == wxT('\n') || *pc == wxT('\0') ) {
if ( !curLine ) {
// we can't use GetTextExtent - it will return 0 for both width
// and height and an empty line should count in height
// calculation
if ( !heightLineDefault )
heightLineDefault = heightLine;
if ( !heightLineDefault )
GetTextExtent(_T("W"), NULL, &heightLineDefault);
heightTextTotal += heightLineDefault;
}
else {
GetTextExtent(curLine, &widthLine, &heightLine); GetTextExtent(curLine, &widthLine, &heightLine);
if ( widthLine > widthTextMax ) if ( widthLine > widthTextMax )
widthTextMax = widthLine; widthTextMax = widthLine;
heightTextTotal += heightLine; heightTextTotal += heightLine;
}
if ( *pc == wxT('\n') ) { if ( *pc == wxT('\n') ) {
curLine.Empty(); curLine.Empty();