]> git.saurik.com Git - wxWidgets.git/blobdiff - samples/ownerdrw/ownerdrw.cpp
Corrected wrong use of delete in region code.
[wxWidgets.git] / samples / ownerdrw / ownerdrw.cpp
index 741ddec001375e4759ec9d8f4d48f423058855e4..f27293e7eaf303c2360ed7959f02b371649761ca 100644 (file)
 #include "wx/wxprec.h"
 
 #ifdef __BORLANDC__
-  #pragma hdrstop
+    #pragma hdrstop
 #endif
 
 #ifndef WX_PRECOMP
-  #include "wx/wx.h"
+    #include "wx/wx.h"
 #endif
 
 #include  "wx/ownerdrw.h"
 class OwnerDrawnApp: public wxApp
 {
 public:
-  bool OnInit();
+    bool OnInit();
 };
 
 // Define a new frame type
 class OwnerDrawnFrame : public wxFrame
 {
 public:
-  // ctor & dtor
-  OwnerDrawnFrame(wxFrame *frame, char *title, int x, int y, int w, int h);
-  ~OwnerDrawnFrame();
+    // ctor & dtor
+    OwnerDrawnFrame(wxFrame *frame, char *title, int x, int y, int w, int h);
+    ~OwnerDrawnFrame();
 
-  // notifications
-  void OnQuit             (wxCommandEvent& event);
-  void OnAbout            (wxCommandEvent& event);
-  void OnListboxSelect    (wxCommandEvent& event);
-  void OnCheckboxToggle   (wxCommandEvent& event);
-  void OnListboxDblClick  (wxCommandEvent& event);
-  bool OnClose            ()                        { return TRUE; }
+    // notifications
+    void OnQuit             (wxCommandEvent& event);
+    void OnAbout            (wxCommandEvent& event);
+    void OnListboxSelect    (wxCommandEvent& event);
+    void OnCheckboxToggle   (wxCommandEvent& event);
+    void OnListboxDblClick  (wxCommandEvent& event);
+    bool OnClose            ()                        { return TRUE; }
 
-  DECLARE_EVENT_TABLE()
+    DECLARE_EVENT_TABLE()
 
 private:
-  void InitMenu();
+    void InitMenu();
 
-  wxCheckListBox *m_pListBox;
+    wxCheckListBox *m_pListBox;
 };
 
 enum 
-{ 
-  Menu_Quit = 1, 
-  Menu_First = 100,
-  Menu_Test1, Menu_Test2, Menu_Test3, 
-  Menu_Bitmap, Menu_Bitmap2, 
-  Menu_Submenu, Menu_Sub1, Menu_Sub2, Menu_Sub3,
-  Control_First = 1000,
-  Control_Listbox, Control_Listbox2,
+{
+    Menu_Quit = 1, 
+    Menu_First = 100,
+    Menu_Test1, Menu_Test2, Menu_Test3, 
+    Menu_Bitmap, Menu_Bitmap2, 
+    Menu_Submenu, Menu_Sub1, Menu_Sub2, Menu_Sub3,
+    Control_First = 1000,
+    Control_Listbox, Control_Listbox2,
 };
 
 BEGIN_EVENT_TABLE(OwnerDrawnFrame, wxFrame)
-  EVT_MENU(Menu_Quit, OwnerDrawnFrame::OnQuit)
-  EVT_LISTBOX(Control_Listbox, OwnerDrawnFrame::OnListboxSelect)
-  EVT_CHECKLISTBOX(Control_Listbox, OwnerDrawnFrame::OnCheckboxToggle)
-  EVT_COMMAND(Control_Listbox, wxEVT_COMMAND_LISTBOX_DOUBLECLICKED, 
-              OwnerDrawnFrame::OnListboxDblClick)
+    EVT_MENU(Menu_Quit, OwnerDrawnFrame::OnQuit)
+    EVT_LISTBOX(Control_Listbox, OwnerDrawnFrame::OnListboxSelect)
+    EVT_CHECKLISTBOX(Control_Listbox, OwnerDrawnFrame::OnCheckboxToggle)
+    EVT_COMMAND(Control_Listbox, wxEVT_COMMAND_LISTBOX_DOUBLECLICKED, 
+                OwnerDrawnFrame::OnListboxDblClick)
 END_EVENT_TABLE()
 
 IMPLEMENT_APP(OwnerDrawnApp);
@@ -83,173 +83,194 @@ IMPLEMENT_APP(OwnerDrawnApp);
 // init our app: create windows
 bool OwnerDrawnApp::OnInit(void)
 {
-  OwnerDrawnFrame *pFrame = new OwnerDrawnFrame(NULL, "wxWindows Ownerdraw Sample",
-                                                50, 50, 450, 340);
-  SetTopWindow(pFrame);
+    OwnerDrawnFrame *pFrame
+        = new OwnerDrawnFrame(NULL, "wxWindows Ownerdraw Sample",
+                              50, 50, 450, 340);
+
+    SetTopWindow(pFrame);
 
-  return TRUE;
+    return TRUE;
 }
 
 // create the menu bar for the main frame
 void OwnerDrawnFrame::InitMenu()
 {
-  // Make a menubar
-  wxMenu *file_menu = new wxMenu,
-         *sub_menu  = new wxMenu;
-
-  // vars used for menu construction
-  wxMenuItem *pItem;
-  wxFont fontLarge(18, wxROMAN, wxNORMAL, wxBOLD, FALSE),
-         fontUlined(12, wxDEFAULT, wxNORMAL, wxNORMAL, TRUE),
-         fontItalic(12, wxMODERN, wxITALIC, wxBOLD, FALSE),
-         // should be at least of the size of bitmaps
-         fontBmp(14, wxDEFAULT, wxNORMAL, wxNORMAL, FALSE);
-
-  // sorry for my artistic skills...
-  wxBitmap bmpBell("bell"), bmpSound("sound"), bmpNoSound("nosound");
-
-  // construct submenu
-  pItem = new wxMenuItem(sub_menu, Menu_Sub1, "Submenu &first", "large", TRUE);
-  pItem->SetFont(fontLarge);
-  sub_menu->Append(pItem);
-  
-  pItem = new wxMenuItem(sub_menu, Menu_Sub2, "Submenu &second", "italic", TRUE);
-  pItem->SetFont(fontItalic);
-  sub_menu->Append(pItem);
-  
-  pItem = new wxMenuItem(sub_menu, Menu_Sub3, "Submenu &third", "underlined", TRUE);
-  pItem->SetFont(fontUlined);
-  sub_menu->Append(pItem);
-  
-  // construct menu
-  pItem = new wxMenuItem(file_menu, Menu_Test1, "&Uncheckable", "red item");
-  pItem->SetFont(*wxITALIC_FONT);
-  pItem->SetTextColour(wxColor(255, 0, 0));
-  pItem->SetMarginWidth(23);
-  file_menu->Append(pItem);
-
-  pItem = new wxMenuItem(file_menu, Menu_Test2, "&Checkable", "checkable item", TRUE);
-  pItem->SetFont(*wxSMALL_FONT);
-  file_menu->Append(pItem);
-  file_menu->Check(Menu_Test2, TRUE);
-
-  pItem = new wxMenuItem(file_menu, Menu_Test3, "&Disabled", "disabled item");
-  pItem->SetFont(*wxNORMAL_FONT);
-  file_menu->Append(pItem);
-  file_menu->Enable(Menu_Test3, FALSE);
-
-  file_menu->AppendSeparator();
-
-  pItem = new wxMenuItem(file_menu, Menu_Bitmap, "&Bell", "check/uncheck me!", TRUE);
-  pItem->SetFont(fontBmp);
-  pItem->SetBitmaps(bmpBell);
-  file_menu->Append(pItem);
-
-  pItem = new wxMenuItem(file_menu, Menu_Bitmap2, "So&und", "icon changes!", TRUE);
-  pItem->SetFont(fontBmp);
-  pItem->SetBitmaps(bmpSound, bmpNoSound);
-  file_menu->Append(pItem);
-
-  file_menu->AppendSeparator();
-
-  pItem = new wxMenuItem(file_menu, Menu_Submenu, "&Sub menu", "", TRUE, sub_menu);
-  pItem->SetFont(*wxSWISS_FONT);
-  file_menu->Append(pItem);
-
-  file_menu->AppendSeparator();
-  file_menu->Append(Menu_Quit, "&Quit", "Normal item");
-
-  wxMenuBar *menu_bar = new wxMenuBar;
-
-  menu_bar->Append(file_menu, "&File");
-  SetMenuBar(menu_bar);
+    // Make a menubar
+    wxMenu *file_menu = new wxMenu,
+           *sub_menu  = new wxMenu;
+
+    // vars used for menu construction
+    wxMenuItem *pItem;
+    wxFont fontLarge(18, wxROMAN, wxNORMAL, wxBOLD, FALSE),
+           fontUlined(12, wxDEFAULT, wxNORMAL, wxNORMAL, TRUE),
+           fontItalic(12, wxMODERN, wxITALIC, wxBOLD, FALSE),
+           // should be at least of the size of bitmaps
+           fontBmp(14, wxDEFAULT, wxNORMAL, wxNORMAL, FALSE);
+
+    // sorry for my artistic skills...
+    wxBitmap bmpBell("bell"), bmpSound("sound"), bmpNoSound("nosound");
+
+    // construct submenu
+    pItem = new wxMenuItem(sub_menu, Menu_Sub1, "Submenu &first", "large");
+
+    pItem->SetFont(fontLarge);
+    sub_menu->Append(pItem);
+
+    pItem = new wxMenuItem(sub_menu, Menu_Sub2, "Submenu &second", "italic",
+                           wxITEM_CHECK);
+    pItem->SetFont(fontItalic);
+    sub_menu->Append(pItem);
+
+    pItem = new wxMenuItem(sub_menu, Menu_Sub3, "Submenu &third", "underlined",
+                           wxITEM_CHECK);
+    pItem->SetFont(fontUlined);
+    sub_menu->Append(pItem);
+
+    // construct menu
+    pItem = new wxMenuItem(file_menu, Menu_Test1, "&Uncheckable", "red item");
+    pItem->SetFont(*wxITALIC_FONT);
+    pItem->SetTextColour(wxColor(255, 0, 0));
+    pItem->SetMarginWidth(23);
+    file_menu->Append(pItem);
+
+    pItem = new wxMenuItem(file_menu, Menu_Test2, "&Checkable",
+                           "checkable item", wxITEM_CHECK);
+    pItem->SetFont(*wxSMALL_FONT);
+    file_menu->Append(pItem);
+    file_menu->Check(Menu_Test2, TRUE);
+
+    pItem = new wxMenuItem(file_menu, Menu_Test3, "&Disabled", "disabled item");
+    pItem->SetFont(*wxNORMAL_FONT);
+    file_menu->Append(pItem);
+    file_menu->Enable(Menu_Test3, FALSE);
+
+    file_menu->AppendSeparator();
+
+    pItem = new wxMenuItem(file_menu, Menu_Bitmap, "&Bell",
+                           "check/uncheck me!", wxITEM_CHECK);
+    pItem->SetFont(fontBmp);
+    pItem->SetBitmaps(bmpBell);
+    file_menu->Append(pItem);
+
+    pItem = new wxMenuItem(file_menu, Menu_Bitmap2, "So&und",
+                           "icon changes!", wxITEM_CHECK);
+    pItem->SetFont(fontBmp);
+    pItem->SetBitmaps(bmpSound, bmpNoSound);
+    file_menu->Append(pItem);
+
+    file_menu->AppendSeparator();
+
+    pItem = new wxMenuItem(file_menu, Menu_Submenu, "&Sub menu", "",
+                           wxITEM_CHECK, sub_menu);
+    pItem->SetFont(*wxSWISS_FONT);
+    file_menu->Append(pItem);
+
+    file_menu->AppendSeparator();
+    file_menu->Append(Menu_Quit, "&Quit", "Normal item");
+
+    wxMenuBar *menu_bar = new wxMenuBar;
+
+    menu_bar->Append(file_menu, "&File");
+    SetMenuBar(menu_bar);
 }
 
 // main frame constructor
-OwnerDrawnFrame::OwnerDrawnFrame(wxFrame *frame, char *title, int x, int y, int w, int h)
+OwnerDrawnFrame::OwnerDrawnFrame(wxFrame *frame, char *title,
+                                 int x, int y, int w, int h)
          : wxFrame(frame, -1, title, wxPoint(x, y), wxSize(w, h))
 {
-  // set the icon
-  SetIcon(wxIcon("mondrian"));
+    // set the icon
+    SetIcon(wxIcon("mondrian"));
 
-  // create the menu
-  InitMenu();
+    // create the menu
+    InitMenu();
 
-  // make a panel with some controls
-  wxPanel *pPanel = new wxPanel(this, -1, wxPoint(0, 0), 
-                                wxSize(400, 200), wxTAB_TRAVERSAL);
+    // create the status line
+    const int widths[] = { -1, 60 };
+    CreateStatusBar(2);
+    SetStatusWidths(2, widths);
+    SetStatusText("no selection", 0);
 
-  // check list box
-  static const char* aszChoices[] = { "Hello", "world", "and", 
+    // make a panel with some controls
+    wxPanel *pPanel = new wxPanel(this, -1, wxPoint(0, 0), 
+                                  wxSize(400, 200), wxTAB_TRAVERSAL);
+
+    // check list box
+    static const char* aszChoices[] = { "Hello", "world", "and", 
                                       "goodbye", "cruel", "world",
                                       "-------", "owner-drawn", "listbox" };
 
-  wxString *astrChoices = new wxString[WXSIZEOF(aszChoices)];
-  unsigned int ui;
-  for ( ui = 0; ui < WXSIZEOF(aszChoices); ui++ )
-    astrChoices[ui] = aszChoices[ui];
-
-  m_pListBox = new wxCheckListBox
-                   (                                             
-                     pPanel,             // parent               
-                     Control_Listbox,    // control id           
-                     wxPoint(10, 10),    // listbox poistion     
-                     wxSize(200, 200),   // listbox size         
-                     WXSIZEOF(aszChoices), // number of strings    
-                     astrChoices         // array of strings
-                   );                                            
-                                                                            
-  delete [] astrChoices;
-
-  for ( ui = 0; ui < WXSIZEOF(aszChoices); ui += 2 ) {
-    m_pListBox->GetItem(ui)->SetBackgroundColour(wxColor(200, 200, 200));
-  }
-
-  m_pListBox->Check(2);
-
-  // normal (but owner-drawn) listbox
-  static const char* aszColors[] = { "Red", "Blue", "Pink",
-                                     "Green", "Yellow", 
-                                     "Black", "Violet"  };
-  struct { unsigned int r, g, b; } aColors[] = { {255,0,0}, {0,0,255}, {255,128,192},
-                                        {0,255,0}, {255,255,128}, 
-                                        {0,0,0}, {128,0,255} };
-  astrChoices = new wxString[WXSIZEOF(aszColors)];
-  for ( ui = 0; ui < WXSIZEOF(aszColors); ui++ )
-    astrChoices[ui] = aszColors[ui];
-
-  wxListBox *pListBox = new wxListBox
-                           (                                             
-                             pPanel,              // parent               
-                             Control_Listbox2,    // control id           
-                             wxPoint(220, 10),    // listbox poistion     
-                             wxDefaultSize,       // listbox size         
-                             WXSIZEOF(aszColors),   // number of strings    
-                             astrChoices,         // array of strings
-                             wxLB_OWNERDRAW,      // owner-drawn
-                             wxDefaultValidator,  // 
-                             wxListBoxNameStr
-                           );
-
-  for ( ui = 0; ui < WXSIZEOF(aszColors); ui++ ) {
-    pListBox->GetItem(ui)->SetTextColour(wxColor(aColors[ui].r,
-                                                aColors[ui].g, 
-                                                aColors[ui].b));
-    // yellow on white is horrible...
-    if ( ui == 4 )
-      pListBox->GetItem(ui)->SetBackgroundColour(wxColor(0, 0, 0));
-    
-  }
-
-  delete[] astrChoices;
-
-  // create the status line
-  const int widths[] = { -1, 60 };
-  CreateStatusBar(2);
-  SetStatusWidths(2, widths);
-  SetStatusText("no selection", 0);
-
-  Show(TRUE);
+    wxString *astrChoices = new wxString[WXSIZEOF(aszChoices)];
+    unsigned int ui;
+    for ( ui = 0; ui < WXSIZEOF(aszChoices); ui++ )
+        astrChoices[ui] = aszChoices[ui];
+
+    m_pListBox = new wxCheckListBox
+        (
+            pPanel,             // parent
+            Control_Listbox,    // control id
+            wxPoint(10, 10),    // listbox position
+            wxSize(200, 200),   // listbox size
+            WXSIZEOF(aszChoices), // number of strings
+            astrChoices         // array of strings
+        );
+
+    delete [] astrChoices;
+
+    for ( ui = 0; ui < WXSIZEOF(aszChoices); ui += 2 )
+    {
+        m_pListBox->GetItem(ui)->SetBackgroundColour(wxColor(200, 200, 200));
+    }
+
+    m_pListBox->Check(2);
+
+    // normal (but owner-drawn) listbox
+    static const char* aszColors[] = { "Red", "Blue", "Pink",
+                                       "Green", "Yellow", 
+                                       "Black", "Violet"  };
+    struct { unsigned int r, g, b; } aColors[] =
+        {
+            {255,0,0}, {0,0,255}, {255,128,192},
+            {0,255,0}, {255,255,128}, 
+            {0,0,0}, {128,0,255}
+        };
+
+    astrChoices = new wxString[WXSIZEOF(aszColors)];
+
+    for ( ui = 0; ui < WXSIZEOF(aszColors); ui++ )
+    {
+        astrChoices[ui] = aszColors[ui];
+    }
+
+    wxListBox *pListBox = new wxListBox
+        (
+            pPanel,              // parent
+            Control_Listbox2,    // control id
+            wxPoint(220, 10),    // listbox position
+            wxDefaultSize,       // listbox size
+            WXSIZEOF(aszColors),   // number of strings
+            astrChoices,         // array of strings
+            wxLB_OWNERDRAW,      // owner-drawn
+            wxDefaultValidator,  //
+            wxListBoxNameStr
+        );
+
+    for ( ui = 0; ui < WXSIZEOF(aszColors); ui++ )
+    {
+        pListBox->GetItem(ui)->SetTextColour(wxColor(aColors[ui].r,
+                                                     aColors[ui].g, 
+                                                     aColors[ui].b));
+        // yellow on white is horrible...
+        if ( ui == 4 )
+        {
+            pListBox->GetItem(ui)->SetBackgroundColour(wxColor(0, 0, 0));
+        }
+
+    }
+
+    delete[] astrChoices;
+
+    Show(TRUE);
 }
 
 OwnerDrawnFrame::~OwnerDrawnFrame()
@@ -258,39 +279,40 @@ OwnerDrawnFrame::~OwnerDrawnFrame()
 
 void OwnerDrawnFrame::OnQuit(wxCommandEvent& event)
 {
-  Close(TRUE);
+    Close(TRUE);
 }
 
 void OwnerDrawnFrame::OnAbout(wxCommandEvent& event)
 {
-  wxMessageDialog dialog(this,
-                         "Demo of owner-drawn controls\n",
-                         "About wxOwnerDrawn", wxYES_NO | wxCANCEL);
-  dialog.ShowModal();
+    wxMessageDialog dialog(this,
+                           "Demo of owner-drawn controls\n",
+                           "About wxOwnerDrawn", wxYES_NO | wxCANCEL);
+    dialog.ShowModal();
 }
 
 void OwnerDrawnFrame::OnListboxSelect(wxCommandEvent& event)
 {
-  wxString strSelection;
-  unsigned int nSel = event.GetSelection();
-  strSelection.sprintf("item %d selected (%schecked)", nSel,
-                       m_pListBox->IsChecked(nSel) ? "" : "not ");
-  SetStatusText(strSelection);
+    wxString strSelection;
+    unsigned int nSel = event.GetSelection();
+    strSelection.sprintf(wxT("item %d selected (%schecked)"), nSel,
+                         m_pListBox->IsChecked(nSel) ? wxT("") : wxT("not "));
+    SetStatusText(strSelection);
 }
 
 void OwnerDrawnFrame::OnListboxDblClick(wxCommandEvent& event)
 {
-  wxString strSelection;
-  strSelection.sprintf("item %d double clicked", m_pListBox->GetSelection());
-  wxMessageDialog dialog(this, strSelection);
-  dialog.ShowModal();
+    wxString strSelection;
+    strSelection.sprintf(wxT("item %d double clicked"),
+                         m_pListBox->GetSelection());
+    wxMessageDialog dialog(this, strSelection);
+    dialog.ShowModal();
 }
 
 void OwnerDrawnFrame::OnCheckboxToggle(wxCommandEvent& event)
 {
-  wxString strSelection;
-  unsigned int nItem = event.GetInt();
-  strSelection.sprintf("item %d was %schecked", nItem,
-                       m_pListBox->IsChecked(nItem) ? "" : "un");
-  SetStatusText(strSelection);
-}
\ No newline at end of file
+    wxString strSelection;
+    unsigned int nItem = event.GetInt();
+    strSelection.sprintf(wxT("item %d was %schecked"), nItem,
+                         m_pListBox->IsChecked(nItem) ? wxT("") : wxT("un"));
+    SetStatusText(strSelection);
+}