]>
git.saurik.com Git - wxWidgets.git/blob - samples/xrc/custclas.h
1 //-----------------------------------------------------------------------------
3 // Purpose: XML resources sample: A custom class to insert into a XRC file
4 // Author: Robert O'Connor (rob@medicalmnemonics.com), Vaclav Slavik
6 // Copyright: (c) Robert O'Connor and Vaclav Slavik
7 // Licence: wxWindows licence
8 //-----------------------------------------------------------------------------
10 //----------------------------------------------------------------------------------------
11 // Begin single inclusion of this .h file condition
12 //----------------------------------------------------------------------------------------
17 //----------------------------------------------------------------------------------------
19 //----------------------------------------------------------------------------------------
22 #pragma interface "custclas.h"
25 //----------------------------------------------------------------------------------------
27 //----------------------------------------------------------------------------------------
29 #include "wx/listctrl.h"
31 //----------------------------------------------------------------------------------------
32 // Class definition: MyResizableListCtrl
33 //----------------------------------------------------------------------------------------
35 //! A custom listctrl that resizes itself and pops up a context-sensitive menu.
36 class MyResizableListCtrl
: public wxListCtrl
38 // Very helpful wxWindows macro required for wxWindows-RTTI tracing: By using this
39 // you will see "Leaked one object of type myResizeableListCtrl" in the debug log,
40 // along with which line you if was created, but you forget to free the memory.
41 // NOTE: Using this REQUIRES a default constructor: that means either: giving a
42 // default value for all parameters in your constructor, or else having a dummy
43 // MyResizableListCtrl(){} constructor in addition to your regular one.
44 DECLARE_DYNAMIC_CLASS( MyResizableListCtrl
)
50 These parameters are the same as a wxWindows constructor.
51 \param parent The parent window.
52 \param id The id of the progress_listbox. Will usually be -1 unless multiple
53 of them on the same dialog.
54 \param pos The pixel position of the listctrl on its parent window
55 \param size The pixel size of the listctrl
56 \param style Style of the listbox. See wxWindows wxListBox docs for details.
57 \param validator Window validator. See wxWindows docs for details.
58 \param name Windows name (rarely used).
59 \param exclusion_column_caption The label of header of listctrl's exclusion
62 MyResizableListCtrl( wxWindow
*parent
= NULL
,
64 const wxPoint
&pos
= wxDefaultPosition
,
65 const wxSize
&size
= wxDefaultSize
,
66 long style
= wxLC_REPORT
,
67 const wxValidator
& validator
= wxDefaultValidator
,
68 const wxString
&name
= wxT("myResizableListCtrl")
72 ~MyResizableListCtrl();
76 // A custom function for a context sensitive menu.
77 void ContextSensitiveMenu( wxMouseEvent
& event
);
79 // This is a wxWindows function that we are going to override with our own behaviour.
80 void OnSize( wxSizeEvent
&event
);
82 // A custom function. What is called in the constructor, and in an OnSize()
83 void SetColumnWidths();
87 // wxWindows macro, required to be able to use Event tables in the .cpp file.
92 //----------------------------------------------------------------------------------------
93 // End single inclusion of this .h file condition
94 //----------------------------------------------------------------------------------------