1//----------------------------------------------------------------------------- 2// Name: custclas.h 3// Purpose: XML resources sample: A custom class to insert into a XRC file 4// Author: Robert O'Connor (rob@medicalmnemonics.com), Vaclav Slavik 5// RCS-ID: $Id: custclas.h 35650 2005-09-23 12:56:45Z MR $ 6// Copyright: (c) Robert O'Connor and Vaclav Slavik 7// Licence: wxWindows licence 8//----------------------------------------------------------------------------- 9 10//---------------------------------------------------------------------------------------- 11// Begin single inclusion of this .h file condition 12//---------------------------------------------------------------------------------------- 13 14#ifndef _CUSTCLAS_H_ 15#define _CUSTCLAS_H_ 16 17//---------------------------------------------------------------------------------------- 18// Headers 19//---------------------------------------------------------------------------------------- 20 21#include "wx/listctrl.h" 22 23//---------------------------------------------------------------------------------------- 24// Class definition: MyResizableListCtrl 25//---------------------------------------------------------------------------------------- 26 27//! A custom listctrl that resizes itself and pops up a context-sensitive menu. 28class MyResizableListCtrl : public wxListCtrl 29{ 30 // Very helpful wxWidgets macro required for wxWidgets-RTTI tracing: By using this 31 // you will see "Leaked one object of type myResizeableListCtrl" in the debug log, 32 // along with which line you if was created, but you forget to free the memory. 33 // NOTE: Using this REQUIRES a default constructor: that means either: giving a 34 // default value for all parameters in your constructor, or else having a dummy 35 // MyResizableListCtrl(){} constructor in addition to your regular one. 36 DECLARE_DYNAMIC_CLASS( MyResizableListCtrl ) 37 38public: 39 40 // Constructor. 41 /* 42 These parameters are the same as a wxWidgets constructor. 43 \param parent The parent window. 44 \param id The id of the progress_listbox. Will usually be -1 unless multiple 45 of them on the same dialog. 46 \param pos The pixel position of the listctrl on its parent window 47 \param size The pixel size of the listctrl 48 \param style Style of the listbox. See wxWidgets wxListBox docs for details. 49 \param validator Window validator. See wxWidgets docs for details. 50 \param name Windows name (rarely used). 51 \param exclusion_column_caption The label of header of listctrl's exclusion 52 column. 53 */ 54 MyResizableListCtrl( wxWindow *parent = NULL, 55 wxWindowID id = wxID_ANY, 56 const wxPoint &pos = wxDefaultPosition, 57 const wxSize &size = wxDefaultSize, 58 long style = wxLC_REPORT, 59 const wxValidator& validator = wxDefaultValidator, 60 const wxString &name = wxT("myResizableListCtrl") 61 ); 62 63 // Destuctor. 64 ~MyResizableListCtrl(){}; 65 66protected: 67 68 // A custom function for a context sensitive menu. 69 void ContextSensitiveMenu( wxMouseEvent& event ); 70 71 // This is a wxWidgets function that we are going to override with our own behaviour. 72 void OnSize( wxSizeEvent &event ); 73 74 // A custom function. What is called in the constructor, and in an OnSize() 75 void SetColumnWidths(); 76 77private: 78 79 // wxWidgets macro, required to be able to use Event tables in the .cpp file. 80 DECLARE_EVENT_TABLE() 81 82}; 83 84//---------------------------------------------------------------------------------------- 85// End single inclusion of this .h file condition 86//---------------------------------------------------------------------------------------- 87 88#endif //_CUSTCLAS_H_ 89 90