1. more test code for drawing with ROPs/masks/bg brushes in drawing
2. wxListCtrl colour setting tests added git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@5895 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -570,11 +570,26 @@ void MyCanvas::DrawDefault(wxDC& dc)
|
|||||||
dc.FloodFill(0, 0, wxColour(255, 0, 0));
|
dc.FloodFill(0, 0, wxColour(255, 0, 0));
|
||||||
#endif //
|
#endif //
|
||||||
|
|
||||||
dc.DrawIcon( wxICON(mondrian), 410, 40 );
|
dc.DrawIcon( wxICON(mondrian), 40, 40 );
|
||||||
|
|
||||||
|
// this is the test for "blitting bitmap into DC damages selected brush"
|
||||||
|
// bug
|
||||||
|
dc.SetPen(*wxTRANSPARENT_PEN);
|
||||||
|
dc.SetBrush( *wxGREEN_BRUSH );
|
||||||
|
dc.DrawRectangle(100, 10, 40, 40);
|
||||||
|
dc.DrawBitmap(wxTheApp->GetStdIcon(wxICON_INFORMATION), 102, 12, TRUE);
|
||||||
|
dc.DrawRectangle(150, 10, 40, 40);
|
||||||
|
dc.DrawIcon(wxTheApp->GetStdIcon(wxICON_INFORMATION), 152, 12);
|
||||||
|
dc.DrawRectangle(200, 10, 40, 40);
|
||||||
|
|
||||||
|
// test for "transparent" bitmap drawing (it intersects with the last
|
||||||
|
// rectangle above)
|
||||||
|
//dc.SetBrush( *wxTRANSPARENT_BRUSH );
|
||||||
|
#include "../image/smile.xpm"
|
||||||
|
wxBitmap bmp(smile_xpm);
|
||||||
|
dc.DrawBitmap(bmp, 210, 30, TRUE);
|
||||||
|
|
||||||
dc.SetBrush( *wxBLACK_BRUSH );
|
dc.SetBrush( *wxBLACK_BRUSH );
|
||||||
dc.SetPen(*wxTRANSPARENT_PEN);
|
|
||||||
dc.DrawRectangle( 0, 160, 1000, 300 );
|
dc.DrawRectangle( 0, 160, 1000, 300 );
|
||||||
|
|
||||||
// draw lines
|
// draw lines
|
||||||
@@ -772,6 +787,7 @@ void MyCanvas::DrawWithLogicalOps(wxDC& dc)
|
|||||||
|
|
||||||
// reuse the text colour here
|
// reuse the text colour here
|
||||||
dc.SetPen(wxPen(m_owner->m_colourForeground, 1, wxSOLID));
|
dc.SetPen(wxPen(m_owner->m_colourForeground, 1, wxSOLID));
|
||||||
|
dc.SetBrush(*wxTRANSPARENT_BRUSH);
|
||||||
|
|
||||||
for ( size_t n = 0; n < WXSIZEOF(rasterOperations); n++ )
|
for ( size_t n = 0; n < WXSIZEOF(rasterOperations); n++ )
|
||||||
{
|
{
|
||||||
@@ -780,7 +796,7 @@ void MyCanvas::DrawWithLogicalOps(wxDC& dc)
|
|||||||
|
|
||||||
dc.DrawText(rasterOperations[n].name, x, y - 20);
|
dc.DrawText(rasterOperations[n].name, x, y - 20);
|
||||||
dc.SetLogicalFunction(rasterOperations[n].rop);
|
dc.SetLogicalFunction(rasterOperations[n].rop);
|
||||||
//dc.DrawRectangle(x, y, w, h);
|
dc.DrawRectangle(x, y, w, h);
|
||||||
dc.DrawLine(x, y, x + w, y + h);
|
dc.DrawLine(x, y, x + w, y + h);
|
||||||
dc.DrawLine(x + w, y, x, y + h);
|
dc.DrawLine(x + w, y, x, y + h);
|
||||||
}
|
}
|
||||||
|
@@ -31,6 +31,8 @@
|
|||||||
|
|
||||||
#include "wx/listctrl.h"
|
#include "wx/listctrl.h"
|
||||||
#include "wx/timer.h" // for wxStopWatch
|
#include "wx/timer.h" // for wxStopWatch
|
||||||
|
#include "wx/colordlg.h" // for wxGetColourFromUser
|
||||||
|
|
||||||
#include "listtest.h"
|
#include "listtest.h"
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
||||||
@@ -48,6 +50,8 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
|||||||
EVT_MENU(LIST_SELECT_ALL, MyFrame::OnSelectAll)
|
EVT_MENU(LIST_SELECT_ALL, MyFrame::OnSelectAll)
|
||||||
EVT_MENU(LIST_DELETE_ALL, MyFrame::OnDeleteAll)
|
EVT_MENU(LIST_DELETE_ALL, MyFrame::OnDeleteAll)
|
||||||
EVT_MENU(LIST_SORT, MyFrame::OnSort)
|
EVT_MENU(LIST_SORT, MyFrame::OnSort)
|
||||||
|
EVT_MENU(LIST_SET_FG_COL, MyFrame::OnSetFgColour)
|
||||||
|
EVT_MENU(LIST_SET_BG_COL, MyFrame::OnSetBgColour)
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE(MyListCtrl, wxListCtrl)
|
BEGIN_EVENT_TABLE(MyListCtrl, wxListCtrl)
|
||||||
@@ -75,16 +79,11 @@ int wxCALLBACK MyCompareFunction(long item1, long item2, long sortData)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// `Main program' equivalent, creating windows and returning main app frame
|
// `Main program' equivalent, creating windows and returning main app frame
|
||||||
bool MyApp::OnInit(void)
|
bool MyApp::OnInit()
|
||||||
{
|
{
|
||||||
// Create the main frame window
|
// Create the main frame window
|
||||||
MyFrame *frame = new MyFrame((wxFrame *) NULL, "wxListCtrl Test", 50, 50, 450, 340);
|
MyFrame *frame = new MyFrame((wxFrame *) NULL, "wxListCtrl Test", 50, 50, 450, 340);
|
||||||
|
|
||||||
// This reduces flicker effects - even better would be to define OnEraseBackground
|
|
||||||
// to do nothing. When the list control's scrollbars are show or hidden, the
|
|
||||||
// frame is sent a background erase event.
|
|
||||||
frame->SetBackgroundColour( *wxWHITE );
|
|
||||||
|
|
||||||
// Give it an icon
|
// Give it an icon
|
||||||
frame->SetIcon( wxICON(mondrian) );
|
frame->SetIcon( wxICON(mondrian) );
|
||||||
|
|
||||||
@@ -132,29 +131,42 @@ bool MyApp::OnInit(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Make a menubar
|
// Make a menubar
|
||||||
wxMenu *file_menu = new wxMenu;
|
wxMenu *menuFile = new wxMenu;
|
||||||
|
menuFile->Append(LIST_ABOUT, "&About");
|
||||||
|
menuFile->AppendSeparator();
|
||||||
|
#if 0 // what is this for? (VZ)
|
||||||
|
menuFile->Append(BUSY_ON, "&Busy cursor on");
|
||||||
|
menuFile->Append(BUSY_OFF, "&Busy cursor off");
|
||||||
|
menuFile->AppendSeparator();
|
||||||
|
#endif
|
||||||
|
menuFile->Append(LIST_QUIT, "E&xit\tAlt-X");
|
||||||
|
|
||||||
file_menu->Append(LIST_LIST_VIEW, "&List view\tF1");
|
wxMenu *menuView = new wxMenu;
|
||||||
file_menu->Append(LIST_REPORT_VIEW, "&Report view\tF2");
|
menuView->Append(LIST_LIST_VIEW, "&List view\tF1");
|
||||||
file_menu->Append(LIST_ICON_VIEW, "&Icon view\tF3");
|
menuView->Append(LIST_REPORT_VIEW, "&Report view\tF2");
|
||||||
file_menu->Append(LIST_ICON_TEXT_VIEW, "Icon view with &text\tF4");
|
menuView->Append(LIST_ICON_VIEW, "&Icon view\tF3");
|
||||||
file_menu->Append(LIST_SMALL_ICON_VIEW, "&Small icon view\tF5");
|
menuView->Append(LIST_ICON_TEXT_VIEW, "Icon view with &text\tF4");
|
||||||
file_menu->Append(LIST_SMALL_ICON_TEXT_VIEW, "Small icon &view with text\tF6");
|
menuView->Append(LIST_SMALL_ICON_VIEW, "&Small icon view\tF5");
|
||||||
file_menu->Append(LIST_DESELECT_ALL, "&Deselect All");
|
menuView->Append(LIST_SMALL_ICON_TEXT_VIEW, "Small icon &view with text\tF6");
|
||||||
file_menu->Append(LIST_SELECT_ALL, "S&elect All");
|
|
||||||
file_menu->AppendSeparator();
|
wxMenu *menuList = new wxMenu;
|
||||||
file_menu->Append(LIST_SORT, "&Sort\tCtrl-S");
|
menuList->Append(LIST_DESELECT_ALL, "&Deselect All\tCtrl-D");
|
||||||
file_menu->AppendSeparator();
|
menuList->Append(LIST_SELECT_ALL, "S&elect All\tCtrl-A");
|
||||||
file_menu->Append(LIST_DELETE_ALL, "Delete &all items");
|
menuList->AppendSeparator();
|
||||||
file_menu->AppendSeparator();
|
menuList->Append(LIST_SORT, "&Sort\tCtrl-S");
|
||||||
file_menu->Append(BUSY_ON, "&Busy cursor on");
|
menuList->AppendSeparator();
|
||||||
file_menu->Append(BUSY_OFF, "&Busy cursor off");
|
menuList->Append(LIST_DELETE_ALL, "Delete &all items");
|
||||||
file_menu->AppendSeparator();
|
|
||||||
file_menu->Append(LIST_ABOUT, "&About");
|
wxMenu *menuCol = new wxMenu;
|
||||||
file_menu->Append(LIST_QUIT, "E&xit\tAlt-X");
|
menuCol->Append(LIST_SET_FG_COL, "&Foreground colour...");
|
||||||
wxMenuBar *menu_bar = new wxMenuBar;
|
menuCol->Append(LIST_SET_BG_COL, "&Background colour...");
|
||||||
menu_bar->Append(file_menu, "&File");
|
|
||||||
frame->SetMenuBar(menu_bar);
|
wxMenuBar *menubar = new wxMenuBar;
|
||||||
|
menubar->Append(menuFile, "&File");
|
||||||
|
menubar->Append(menuView, "&View");
|
||||||
|
menubar->Append(menuList, "&List");
|
||||||
|
menubar->Append(menuCol, "&Colour");
|
||||||
|
frame->SetMenuBar(menubar);
|
||||||
|
|
||||||
// Make a panel with a message
|
// Make a panel with a message
|
||||||
frame->m_listCtrl = new MyListCtrl(frame, LIST_CTRL, wxPoint(0, 0), wxSize(400, 200),
|
frame->m_listCtrl = new MyListCtrl(frame, LIST_CTRL, wxPoint(0, 0), wxSize(400, 200),
|
||||||
@@ -177,15 +189,14 @@ bool MyApp::OnInit(void)
|
|||||||
frame->m_logWindow->SetConstraints(c);
|
frame->m_logWindow->SetConstraints(c);
|
||||||
frame->SetAutoLayout(TRUE);
|
frame->SetAutoLayout(TRUE);
|
||||||
|
|
||||||
|
wxString buf;
|
||||||
for ( int i=0; i < 30; i++)
|
for ( int i=0; i < 30; i++)
|
||||||
{
|
{
|
||||||
wxChar buf[20];
|
buf.Printf(_T("Item %d"), i);
|
||||||
wxSprintf(buf, _T("Item %d"), i);
|
frame->m_listCtrl->InsertItem(i, buf);
|
||||||
frame->m_listCtrl->InsertItem(i, buf);
|
}
|
||||||
}
|
|
||||||
|
|
||||||
frame->CreateStatusBar(3);
|
frame->CreateStatusBar(3);
|
||||||
frame->SetStatusText("", 0);
|
|
||||||
|
|
||||||
// Show the frame
|
// Show the frame
|
||||||
frame->Show(TRUE);
|
frame->Show(TRUE);
|
||||||
@@ -196,14 +207,14 @@ bool MyApp::OnInit(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// My frame constructor
|
// My frame constructor
|
||||||
MyFrame::MyFrame(wxFrame *frame, char *title, int x, int y, int w, int h):
|
MyFrame::MyFrame(wxFrame *frame, char *title, int x, int y, int w, int h)
|
||||||
wxFrame(frame, -1, title, wxPoint(x, y), wxSize(w, h))
|
: wxFrame(frame, -1, title, wxPoint(x, y), wxSize(w, h))
|
||||||
{
|
{
|
||||||
m_listCtrl = (MyListCtrl *) NULL;
|
m_listCtrl = (MyListCtrl *) NULL;
|
||||||
m_logWindow = (wxTextCtrl *) NULL;
|
m_logWindow = (wxTextCtrl *) NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
MyFrame::~MyFrame(void)
|
MyFrame::~MyFrame()
|
||||||
{
|
{
|
||||||
delete wxGetApp().m_imageListNormal;
|
delete wxGetApp().m_imageListNormal;
|
||||||
delete wxGetApp().m_imageListSmall;
|
delete wxGetApp().m_imageListSmall;
|
||||||
@@ -396,6 +407,18 @@ void MyFrame::OnSort(wxCommandEvent& WXUNUSED(event))
|
|||||||
sw.Time()));
|
sw.Time()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MyFrame::OnSetFgColour(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
m_listCtrl->SetForegroundColour(wxGetColourFromUser(this));
|
||||||
|
m_listCtrl->Refresh();
|
||||||
|
}
|
||||||
|
|
||||||
|
void MyFrame::OnSetBgColour(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
m_listCtrl->SetBackgroundColour(wxGetColourFromUser(this));
|
||||||
|
m_listCtrl->Refresh();
|
||||||
|
}
|
||||||
|
|
||||||
void MyFrame::OnDeleteAll(wxCommandEvent& WXUNUSED(event))
|
void MyFrame::OnDeleteAll(wxCommandEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
wxStopWatch sw;
|
wxStopWatch sw;
|
||||||
|
@@ -70,6 +70,8 @@ public:
|
|||||||
void OnSelectAll(wxCommandEvent& event);
|
void OnSelectAll(wxCommandEvent& event);
|
||||||
void OnDeleteAll(wxCommandEvent& event);
|
void OnDeleteAll(wxCommandEvent& event);
|
||||||
void OnSort(wxCommandEvent& event);
|
void OnSort(wxCommandEvent& event);
|
||||||
|
void OnSetFgColour(wxCommandEvent& event);
|
||||||
|
void OnSetBgColour(wxCommandEvent& event);
|
||||||
|
|
||||||
void BusyOn(wxCommandEvent& event);
|
void BusyOn(wxCommandEvent& event);
|
||||||
void BusyOff(wxCommandEvent& event);
|
void BusyOff(wxCommandEvent& event);
|
||||||
@@ -95,6 +97,8 @@ enum
|
|||||||
BUSY_OFF = 11,
|
BUSY_OFF = 11,
|
||||||
LIST_DELETE_ALL = 12,
|
LIST_DELETE_ALL = 12,
|
||||||
LIST_SORT,
|
LIST_SORT,
|
||||||
|
LIST_SET_FG_COL,
|
||||||
|
LIST_SET_BG_COL,
|
||||||
|
|
||||||
LIST_CTRL = 1000
|
LIST_CTRL = 1000
|
||||||
};
|
};
|
||||||
|
Reference in New Issue
Block a user