test raw bitmap access

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@19712 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2003-03-22 19:10:09 +00:00
parent f28e099ec3
commit b3f04dc2b2

View File

@@ -30,6 +30,7 @@
#include "smile.xpm"
#endif
#define wxHAVE_RAW_BITMAP
// derived classes
@@ -114,6 +115,9 @@ public:
void OnAbout( wxCommandEvent &event );
void OnNewFrame( wxCommandEvent &event );
#ifdef wxHAVE_RAW_BITMAP
void OnTestRawBitmap( wxCommandEvent &event );
#endif // wxHAVE_RAW_BITMAP
void OnQuit( wxCommandEvent &event );
MyCanvas *m_canvas;
@@ -224,6 +228,77 @@ private:
DECLARE_EVENT_TABLE()
};
#ifdef wxHAVE_RAW_BITMAP
#include "wx/rawbmp.h"
class MyRawBitmapFrame : public wxFrame
{
public:
enum
{
BORDER = 15,
SIZE = 150,
REAL_SIZE = SIZE - 2*BORDER
};
MyRawBitmapFrame(wxFrame *parent)
: wxFrame(parent, -1, _T("Raw bitmaps (how exciting)")),
m_bitmap(SIZE, SIZE, 32)
{
SetClientSize(SIZE, SIZE);
wxRawBitmapData data(m_bitmap);
if ( !data )
{
wxLogError(_T("Failed to gain raw access to bitmap data"));
return;
}
wxRawBitmapIterator p(data);
p.Offset(BORDER, BORDER);
for ( int y = 0; y < REAL_SIZE; ++y )
{
wxRawBitmapIterator rowStart = p;
int r = y < REAL_SIZE/3 ? 255 : 0,
g = (REAL_SIZE/3 <= y) && (y < 2*(REAL_SIZE/3)) ? 255 : 0,
b = 2*(REAL_SIZE/3) <= y ? 255 : 0;
for ( int x = 0; x < REAL_SIZE; ++x )
{
p.Red() = r;
p.Green() = g;
p.Blue() = b;
p.Alpha() = x;
++p; // same as p.OffsetX(1)
}
p = rowStart;
p.OffsetY(1);
}
}
void OnPaint(wxPaintEvent& WXUNUSED(event))
{
wxPaintDC dc( this );
dc.DrawText(_T("This is alpha and raw bitmap test"), 0, BORDER);
dc.DrawText(_T("This is alpha and raw bitmap test"), 0, SIZE/2 - BORDER);
dc.DrawText(_T("This is alpha and raw bitmap test"), 0, SIZE - 2*BORDER);
dc.DrawBitmap( m_bitmap, 0, 0, TRUE /* use mask */ );
}
private:
wxBitmap m_bitmap;
DECLARE_EVENT_TABLE()
};
#endif // wxHAVE_RAW_BITMAP
// MyApp
class MyApp: public wxApp
@@ -246,6 +321,14 @@ BEGIN_EVENT_TABLE(MyImageFrame, wxFrame)
EVT_LEFT_DCLICK(MyImageFrame::OnSave)
END_EVENT_TABLE()
#ifdef wxHAVE_RAW_BITMAP
BEGIN_EVENT_TABLE(MyRawBitmapFrame, wxFrame)
EVT_PAINT(MyRawBitmapFrame::OnPaint)
END_EVENT_TABLE()
#endif // wxHAVE_RAW_BITMAP
BEGIN_EVENT_TABLE(MyCanvas, wxScrolledWindow)
EVT_PAINT(MyCanvas::OnPaint)
END_EVENT_TABLE()
@@ -703,9 +786,13 @@ void MyCanvas::CreateAntiAliasedBitmap()
// MyFrame
const int ID_QUIT = 108;
const int ID_ABOUT = 109;
const int ID_NEW = 110;
enum
{
ID_QUIT = 108,
ID_ABOUT,
ID_NEW,
ID_SHOWRAW
};
IMPLEMENT_DYNAMIC_CLASS( MyFrame, wxFrame )
@@ -713,6 +800,9 @@ BEGIN_EVENT_TABLE(MyFrame,wxFrame)
EVT_MENU (ID_ABOUT, MyFrame::OnAbout)
EVT_MENU (ID_QUIT, MyFrame::OnQuit)
EVT_MENU (ID_NEW, MyFrame::OnNewFrame)
#ifdef wxHAVE_RAW_BITMAP
EVT_MENU (ID_SHOWRAW, MyFrame::OnTestRawBitmap)
#endif
END_EVENT_TABLE()
MyFrame::MyFrame()
@@ -720,11 +810,14 @@ MyFrame::MyFrame()
wxPoint(20,20), wxSize(470,360) )
{
wxMenu *file_menu = new wxMenu();
file_menu->Append( ID_NEW, _T("&Show image..."));
file_menu->Append( ID_NEW, _T("&Show image...\tCtrl-O"));
#ifdef wxHAVE_RAW_BITMAP
file_menu->Append( ID_SHOWRAW, _T("Test &raw bitmap...\tCtrl-R"));
#endif
file_menu->AppendSeparator();
file_menu->Append( ID_ABOUT, _T("&About..."));
file_menu->AppendSeparator();
file_menu->Append( ID_QUIT, _T("E&xit"));
file_menu->Append( ID_QUIT, _T("E&xit\tCtrl-Q"));
wxMenuBar *menu_bar = new wxMenuBar();
menu_bar->Append(file_menu, _T("&File"));
@@ -770,6 +863,15 @@ void MyFrame::OnNewFrame( wxCommandEvent &WXUNUSED(event) )
(new MyImageFrame(this, wxBitmap(image)))->Show();
}
#ifdef wxHAVE_RAW_BITMAP
void MyFrame::OnTestRawBitmap( wxCommandEvent &event )
{
(new MyRawBitmapFrame(this))->Show();
}
#endif // wxHAVE_RAW_BITMAP
//-----------------------------------------------------------------------------
// MyApp
//-----------------------------------------------------------------------------