X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/bbcf2821a15b8dd75fcd4daa2ac91d600b23b2d1..cd15bcaf50ead53ccf9d50965312f0dc754affb4:/samples/erase/erase.cpp diff --git a/samples/erase/erase.cpp b/samples/erase/erase.cpp index bb452f239a..37fc81bb88 100644 --- a/samples/erase/erase.cpp +++ b/samples/erase/erase.cpp @@ -32,13 +32,14 @@ #include "wx/custombgwin.h" #include "wx/dcbuffer.h" +#include "wx/artprov.h" // ---------------------------------------------------------------------------- // resources // ---------------------------------------------------------------------------- // the application icon -#if !defined(__WXMSW__) && !defined(__WXPM__) +#ifndef wxHAS_IMAGES_IN_RESOURCES #include "../sample.xpm" #endif @@ -146,13 +147,28 @@ public: ControlWithTransparency(wxWindow *parent, const wxPoint& pos, const wxSize& size) - : wxWindow(parent, wxID_ANY, pos, size, wxBORDER_NONE) { + wxString reason; + if ( parent->IsTransparentBackgroundSupported(&reason) ) + { + SetBackgroundStyle (wxBG_STYLE_TRANSPARENT); + m_message = "This is custom control with transparency"; + } + else + { + m_message = "Transparency not supported, check tooltip."; + } + + Create (parent, wxID_ANY, pos, size, wxBORDER_NONE); Connect(wxEVT_PAINT, wxPaintEventHandler(ControlWithTransparency::OnPaint)); - } - virtual bool HasTransparentBackground() { return true; } + if ( !reason.empty() ) + { + // This can be only done now, after creating the window. + SetToolTip(reason); + } + } private: void OnPaint( wxPaintEvent& WXUNUSED(event) ) @@ -165,8 +181,17 @@ private: dc.SetTextForeground(*wxBLUE); dc.SetBackgroundMode(wxTRANSPARENT); - dc.DrawText("This is custom control with transparency", 0, 2); + dc.DrawText(m_message, 0, 2); + + // Draw some bitmap/icon to ensure transparent bitmaps are indeed + // transparent on transparent windows + wxBitmap bmp(wxArtProvider::GetBitmap(wxART_WARNING, wxART_MENU)); + wxIcon icon(wxArtProvider::GetIcon(wxART_GOTO_LAST, wxART_MENU)); + dc.DrawBitmap (bmp, GetSize().x - 1 - bmp.GetWidth(), 2); + dc.DrawIcon(icon, GetSize().x - 1 - bmp.GetWidth()-icon.GetWidth(), 2); } + + wxString m_message; }; // ---------------------------------------------------------------------------- @@ -249,7 +274,7 @@ MyFrame::MyFrame() wxMenu *helpMenu = new wxMenu; - helpMenu->Append(Erase_Menu_About, "&About...\tCtrl-A", "Show about dialog"); + helpMenu->Append(Erase_Menu_About, "&About\tCtrl-A", "Show about dialog"); wxMenuBar *menuBar = new wxMenuBar(); menuBar->Append(menuFile, "&File"); @@ -329,7 +354,7 @@ MyCanvas::MyCanvas(wxFrame *parent) "right one drawn directly", wxPoint(150, 20)); - new ControlWithTransparency(this, wxPoint(65, 125), wxSize(300, 22)); + new ControlWithTransparency(this, wxPoint(65, 125), wxSize(350, 22)); SetFocusIgnoringChildren(); SetBackgroundColour(*wxCYAN); @@ -337,10 +362,16 @@ MyCanvas::MyCanvas(wxFrame *parent) void MyCanvas::DoPaint(wxDC& dc) { + PrepareDC(dc); + if ( m_eraseBgInPaint ) { dc.SetBackground(*wxLIGHT_GREY); - dc.Clear(); + + // Erase the entire virtual area, not just the client area. + dc.SetPen(*wxTRANSPARENT_PEN); + dc.SetBrush(GetBackgroundColour()); + dc.DrawRectangle(GetVirtualSize()); dc.DrawText("Background erased in OnPaint", 65, 110); } @@ -362,15 +393,11 @@ void MyCanvas::OnPaint( wxPaintEvent &WXUNUSED(event) ) if ( m_useBuffer ) { wxAutoBufferedPaintDC dc(this); - PrepareDC(dc); - DoPaint(dc); } else { wxPaintDC dc(this); - PrepareDC(dc); - DoPaint(dc); } } @@ -394,12 +421,12 @@ void MyCanvas::OnEraseBackground( wxEraseEvent& event ) wxDC& dc = *event.GetDC(); dc.SetPen(*wxGREEN_PEN); - PrepareDC( dc ); - // clear any junk currently displayed dc.Clear(); - const wxSize size = GetClientSize(); + PrepareDC( dc ); + + const wxSize size = GetVirtualSize(); for ( int x = 0; x < size.x; x += 15 ) { dc.DrawLine(x, 0, x, size.y);