X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/84bc0d49e411fd74ddac8b13318fc2edfba9258a..9e477492e29e03c02827b1e42a16cb09a13f5149:/wxPython/src/combo.i diff --git a/wxPython/src/combo.i b/wxPython/src/combo.i index 2cfd494ed5..d14a2487ce 100644 --- a/wxPython/src/combo.i +++ b/wxPython/src/combo.i @@ -61,7 +61,9 @@ enum }; -// Namespace for wxComboCtrl feature flags +DocStr( wxComboCtrlFeatures, + "Namespace for `wx.combo.ComboCtrl` feature flags. See +`wx.combo.ComboCtrl.GetFeatures`.", ""); struct wxComboCtrlFeatures { enum @@ -122,6 +124,29 @@ public: wxComboCtrl::DoSetPopupControl(popup); } + virtual bool IsKeyPopupToggle( const wxKeyEvent& event ) const + { + bool found; + bool rval = false; + wxPyBlock_t blocked = wxPyBeginBlockThreads(); + if ((found = wxPyCBH_findCallback(m_myInst, "OnComboKeyEvent"))) { + PyObject* oevt = wxPyConstructObject((void*)&event, wxT("wxKeyEvent"), 0); + rval = wxPyCBH_callCallback(m_myInst, Py_BuildValue("(O)", oevt)); + Py_DECREF(oevt); + } + wxPyEndBlockThreads(blocked); + if (! found) + rval = wxComboCtrl::IsKeyPopupToggle(event); + return rval; + } + + + virtual wxWindow *GetMainWindowOfCompositeControl() + { + return wxComboCtrl::GetMainWindowOfCompositeControl(); + } + + enum { ShowBelow = 0x0000, // Showing popup below the control @@ -130,6 +155,8 @@ public: }; + DEC_PYCALLBACK_VOID_(ShowPopup); + DEC_PYCALLBACK_VOID_(HidePopup); DEC_PYCALLBACK_VOID_(OnButtonClick); DEC_PYCALLBACK__RECTINT(DoShowPopup); DEC_PYCALLBACK_BOOL_RECTINT(AnimateShow); @@ -139,6 +166,8 @@ public: IMPLEMENT_ABSTRACT_CLASS(wxPyComboCtrl, wxComboCtrl); +IMP_PYCALLBACK_VOID_(wxPyComboCtrl, wxComboCtrl, ShowPopup); +IMP_PYCALLBACK_VOID_(wxPyComboCtrl, wxComboCtrl, HidePopup); IMP_PYCALLBACK_VOID_(wxPyComboCtrl, wxComboCtrl, OnButtonClick); IMP_PYCALLBACK__RECTINT(wxPyComboCtrl, wxComboCtrl, DoShowPopup); IMP_PYCALLBACK_BOOL_RECTINT(wxPyComboCtrl, wxComboCtrl, AnimateShow); @@ -148,6 +177,40 @@ IMP_PYCALLBACK_BOOL_RECTINT(wxPyComboCtrl, wxComboCtrl, AnimateShow); // Now declare wxPyComboCtrl for Python + +DocStr(wxPyComboCtrl, +"A combo control is a generic combobox that allows for a totally custom +popup. In addition it has other customization features. For instance, +position and size of the dropdown button can be changed. + +To specify what to use for the popup control you need to derive a +class from `wx.combo.ComboPopup` and pass it to the ComboCtrl with +`SetPopupControl`. It doesn't derive from any widget class so it can +be used either as a mixin class combined with some standard or custom +widget, or you can use the derived ComboPopup to create and hold an +independent reference to the widget to be used for the popup. +", " + +Window Styles +------------- + ==================== ============================================ + wx.CB_READONLY Text will not be editable. + wx.CB_SORT Sorts the entries in the list alphabetically. + wx.TE_PROCESS_ENTER The control will generate the event + EVT_TEXT_ENTER (otherwise pressing Enter key + is either processed internally by the control + or used for navigation between dialog controls). + wx.CC_SPECIAL_DCLICK Double-clicking triggers a call to popup's + OnComboDoubleClick. Actual behaviour is defined + by a derived class. For instance, + OwnerDrawnComboBox will cycle an item. This + style only applies if wx.CB_READONLY is used + as well. + wx.CC_STD_BUTTON Drop button will behave more like a standard + push button. + ==================== ============================================ +"); + MustHaveApp(wxPyComboCtrl); %rename(ComboCtrl) wxPyComboCtrl; @@ -157,59 +220,103 @@ public: %pythonAppend wxPyComboCtrl "self._setOORInfo(self);" setCallbackInfo(ComboCtrl) %pythonAppend wxPyComboCtrl() ""; - wxPyComboCtrl(wxWindow *parent, - wxWindowID id = wxID_ANY, - const wxString& value = wxEmptyString, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - long style = 0, - const wxValidator& validator = wxDefaultValidator, - const wxString& name = wxPyComboBoxNameStr); + DocCtorStr( + wxPyComboCtrl(wxWindow *parent, + wxWindowID id = wxID_ANY, + const wxString& value = wxEmptyString, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxPyComboBoxNameStr), + "", ""); + + DocCtorStrName( + wxPyComboCtrl(), + "", "", + PreComboCtrl); - %RenameCtor(PreComboCtrl, wxPyComboCtrl()); void _setCallbackInfo(PyObject* self, PyObject* _class); - // show/hide popup window - virtual void ShowPopup(); - virtual void HidePopup(); + DocDeclStr( + virtual void , ShowPopup(), + "Show the popup window.", ""); + + DocDeclStr( + virtual void , HidePopup(), + "Dismisses the popup window.", ""); + // Override for totally custom combo action - virtual void OnButtonClick(); + DocDeclStr( + virtual void , OnButtonClick(), + "Implement in a derived class to define what happens on dropdown button +click. Default action is to show the popup. ", ""); + // return true if the popup is currently shown - bool IsPopupShown() const; + DocDeclStr( + bool , IsPopupShown() const, + "Returns true if the popup is currently shown.", ""); - // set interface class instance derived from wxComboPopup - // NULL popup can be used to indicate default in a derived class %disownarg(wxPyComboPopup* popup); - void SetPopupControl( wxPyComboPopup* popup ); + DocDeclStr( + void , SetPopupControl( wxPyComboPopup* popup ), + "Set popup interface class derived from `wx.combo.ComboPopup`. This +method should be called as soon as possible after the control has been +created, unless `OnButtonClick` has been overridden.", ""); %cleardisown(wxPyComboPopup* popup); - // get interface class instance derived from wxComboPopup - wxPyComboPopup* GetPopupControl(); + DocDeclStr( + wxPyComboPopup* , GetPopupControl(), + "Returns the current popup interface that has been set with +`SetPopupControl`.", ""); + + + DocDeclStr( + wxWindow *, GetPopupWindow() const, + "Returns the popup window containing the popup control.", ""); - // get the popup window containing the popup control - wxWindow *GetPopupWindow() const; - // Get the text control which is part of the combobox. - wxTextCtrl *GetTextCtrl() const; + DocDeclStr( + wxTextCtrl *, GetTextCtrl() const, + "Get the text control which is part of the combo control.", ""); - // get the dropdown button which is part of the combobox - // note: its not necessarily a wxButton or wxBitmapButton - wxWindow *GetButton() const; - // forward these methods to all subcontrols - virtual bool Enable(bool enable = true); - virtual bool Show(bool show = true); - virtual bool SetFont(const wxFont& font); + DocDeclStr( + wxWindow *, GetButton() const, + "Get the dropdown button which is part of the combobox. Note: it's not +necessarily a wx.Button or wx.BitmapButton.", ""); + +// NOTE: These are virtuals defined in a base class, so there +// shouldn't be any reason to provide SWIG wrappers for them... +// // forward these methods to all subcontrols +// virtual bool Enable(bool enable = true); +// virtual bool Show(bool show = true); +// virtual bool SetFont(const wxFont& font); +// virtual void SetValidator(const wxValidator &validator); +// virtual wxValidator *GetValidator(); + + // wxTextCtrl methods - for readonly combo they should return // without errors. - virtual wxString GetValue() const; - virtual void SetValue(const wxString& value); + + DocDeclStr( + virtual wxString , GetValue() const, + "Returns text representation of the current value. For writable combo +control it always returns the value in the text field.", ""); + + DocDeclStr( + virtual void , SetValue(const wxString& value), + "Sets the text for the combo control text field. For a combo control +with wx.CB_READONLY style the string must be accepted by the popup (for +instance, exist in the dropdown list), otherwise the call to +SetValue is ignored.", ""); + virtual void Copy(); virtual void Cut(); virtual void Paste(); @@ -223,146 +330,172 @@ public: %Rename(SetMark, void , SetSelection(long from, long to)); - // This method sets the text without affecting list selection - // (ie. wxComboPopup::SetStringValue doesn't get called). - void SetText(const wxString& value); - // This method sets value and also optionally sends EVT_TEXT - // (needed by combo popups) - void SetValueWithEvent(const wxString& value, bool withEvent = true); + DocDeclStr( + void , SetText(const wxString& value), + "Sets the text for the text field without affecting the popup. Thus, +unlike `SetValue`, it works equally well with combo control using +wx.CB_READONLY style.", ""); + + + DocDeclStr( + void , SetValueWithEvent(const wxString& value, bool withEvent = true), + "Same as `SetValue`, but also sends a EVT_TEXT event if withEvent is true.", ""); + // // Popup customization methods // - // Sets minimum width of the popup. If wider than combo control, it will - // extend to the left. - // Remarks: - // * Value -1 indicates the default. - // * Custom popup may choose to ignore this (wxOwnerDrawnComboBox does not). - void SetPopupMinWidth( int width ); - - // Sets preferred maximum height of the popup. - // Remarks: - // * Value -1 indicates the default. - // * Custom popup may choose to ignore this (wxOwnerDrawnComboBox does not). - void SetPopupMaxHeight( int height ); - - // Extends popup size horizontally, relative to the edges of the combo control. - // Remarks: - // * Popup minimum width may override extLeft (ie. it has higher precedence). - // * Values 0 indicate default. - // * Custom popup may not take this fully into account (wxOwnerDrawnComboBox takes). - void SetPopupExtents( int extLeft, int extRight ); - - // Set width, in pixels, of custom paint area in writable combo. - // In read-only, used to indicate area that is not covered by the - // focus rectangle (which may or may not be drawn, depending on the - // popup type). - void SetCustomPaintWidth( int width ); + DocDeclStr( + void , SetPopupMinWidth( int width ), + "Sets minimum width of the popup. If wider than combo control, it will +extend to the left. A value of -1 indicates to use the default. The +popup implementation may choose to ignore this.", ""); + + + DocDeclStr( + void , SetPopupMaxHeight( int height ), + "Sets preferred maximum height of the popup. A value of -1 indicates to +use the default. The popup implementation may choose to ignore this.", ""); + + + DocDeclStr( + void , SetPopupExtents( int extLeft, int extRight ), + "Extends popup size horizontally, relative to the edges of the combo +control. Values are given in pixels, and the defaults are zero. It +is up to the popup to fully take these values into account.", ""); + + + DocDeclStr( + void , SetCustomPaintWidth( int width ), + "Set width, in pixels, of custom painted area in control without +wx.CB_READONLY style. In read-only OwnerDrawnComboBox, this is used +to indicate the area that is not covered by the focus rectangle.", ""); + int GetCustomPaintWidth() const; - // Set side of the control to which the popup will align itself. - // Valid values are wxLEFT, wxRIGHT and 0. The default value 0 means - // that the side of the button will be used. - void SetPopupAnchor( int anchorSide ); - - // Set position of dropdown button. - // width: button width. <= 0 for default. - // height: button height. <= 0 for default. - // side: wxLEFT or wxRIGHT, indicates on which side the button will be placed. - // spacingX: empty space on sides of the button. Default is 0. - // Remarks: - // There is no spacingY - the button will be centered vertically. - void SetButtonPosition( int width = -1, - int height = -1, - int side = wxRIGHT, - int spacingX = 0 ); - - // Returns current size of the dropdown button. - wxSize GetButtonSize(); - // - // Sets dropbutton to be drawn with custom bitmaps. - // - // bmpNormal: drawn when cursor is not on button - // pushButtonBg: Draw push button background below the image. - // NOTE! This is usually only properly supported on platforms with appropriate - // method in wxRendererNative. - // bmpPressed: drawn when button is depressed - // bmpHover: drawn when cursor hovers on button. This is ignored on platforms - // that do not generally display hover differently. - // bmpDisabled: drawn when combobox is disabled. - void SetButtonBitmaps( const wxBitmap& bmpNormal, - bool pushButtonBg = false, - const wxBitmap& bmpPressed = wxNullBitmap, - const wxBitmap& bmpHover = wxNullBitmap, - const wxBitmap& bmpDisabled = wxNullBitmap ); + DocDeclStr( + void , SetPopupAnchor( int anchorSide ), + "Set side of the control to which the popup will align itself. Valid +values are wx.LEFT, wx.RIGHT and 0. The default value 0 means that the +most appropriate side is used (which, currently, is always wx.LEFT).", ""); + + + DocDeclStr( + void , SetButtonPosition( int width = -1, + int height = -1, + int side = wxRIGHT, + int spacingX = 0 ), + "Set the position of the dropdown button.", ""); + + + DocDeclStr( + wxSize , GetButtonSize(), + "Returns current size of the dropdown button.", ""); + + + DocDeclStr( + void , SetButtonBitmaps( const wxBitmap& bmpNormal, + bool pushButtonBg = false, + const wxBitmap& bmpPressed = wxNullBitmap, + const wxBitmap& bmpHover = wxNullBitmap, + const wxBitmap& bmpDisabled = wxNullBitmap ), + "Sets custom dropdown button graphics. + + :param bmpNormal: Default button image + :param pushButtonBg: If ``True``, blank push button background is painted below the image. + :param bmpPressed: Depressed butotn image. + :param bmpHover: Button imate to use when the mouse hovers over it. + :param bmpDisabled: Disabled button image. +", ""); - // - // This will set the space in pixels between left edge of the control and the - // text, regardless whether control is read-only (ie. no wxTextCtrl) or not. - // Platform-specific default can be set with value-1. - // Remarks - // * This method may do nothing on some native implementations. - void SetTextIndent( int indent ); - // Returns actual indentation in pixels. - wxCoord GetTextIndent() const; + DocDeclStr( + void , SetTextIndent( int indent ), + "This will set the space in pixels between left edge of the control and +the text, regardless whether control is read-only or not. A value of -1 can +be given to indicate platform default.", ""); - // Returns area covered by the text field. - const wxRect& GetTextRect() const; - // Call with enable as true to use a type of popup window that guarantees ability - // to focus the popup control, and normal function of common native controls. - // This alternative popup window is usually a wxDialog, and as such it's parent - // frame will appear as if the focus has been lost from it. - void UseAltPopupWindow( bool enable = true ); + DocDeclStr( + wxCoord , GetTextIndent() const, + "Returns actual indentation in pixels.", ""); + + + DocDeclStr( + const wxRect& , GetTextRect() const, + "Returns area covered by the text field (includes everything except +borders and the dropdown button).", ""); + + + DocDeclStr( + void , UseAltPopupWindow( bool enable = true ), + "Enable or disable usage of an alternative popup window, which +guarantees ability to focus the popup control, and allows common +native controls to function normally. This alternative popup window is +usually a wxDialog, and as such, when it is shown, its parent +top-level window will appear as if the focus has been lost from it.", ""); + + + DocDeclStr( + void , EnablePopupAnimation( bool enable = true ), + "Enables or disables popup animation, if any, depending on the value of +the argument.", ""); - // Call with false to disable popup animation, if any. - void EnablePopupAnimation( bool enable = true ); // // Utilies needed by the popups or native implementations // - // Returns true if given key combination should toggle the popup. - // NB: This is a separate from other keyboard handling because: - // 1) Replaceability. - // 2) Centralized code (otherwise it'd be split up between - // wxComboCtrl key handler and wxVListBoxComboPopup's - // key handler). - virtual bool IsKeyPopupToggle(const wxKeyEvent& event) const; - - // Prepare background of combo control or an item in a dropdown list - // in a way typical on platform. This includes painting the focus/disabled - // background and setting the clipping region. - // Unless you plan to paint your own focus indicator, you should always call this - // in your wxComboPopup::PaintComboControl implementation. - // In addition, it sets pen and text colour to what looks good and proper - // against the background. - // flags: wxRendererNative flags: wxCONTROL_ISSUBMENU: is drawing a list item instead of combo control - // wxCONTROL_SELECTED: list item is selected - // wxCONTROL_DISABLED: control/item is disabled - virtual void PrepareBackground( wxDC& dc, const wxRect& rect, int flags ) const; - - // Returns true if focus indicator should be drawn in the control. - bool ShouldDrawFocus() const; - - // These methods return references to appropriate dropbutton bitmaps + DocDeclStr( + virtual bool , IsKeyPopupToggle(const wxKeyEvent& event) const, + "Returns true if given key combination should toggle the popup.", ""); + + + DocDeclStr( + virtual void , PrepareBackground( wxDC& dc, const wxRect& rect, int flags ) const, + "Prepare background of combo control or an item in a dropdown list in a +way typical on platform. This includes painting the focus/disabled +background and setting the clipping region. Unless you plan to paint +your own focus indicator, you should always call this in your +wxComboPopup::PaintComboControl implementation. In addition, it sets +pen and text colour to what looks good and proper against the +background. + +flags are the same as wx.RendererNative flags: + + ====================== ============================================ + wx.CONTROL_ISSUBMENU drawing a list item instead of combo control + wx.CONTROL_SELECTED list item is selected + wx.CONTROL_DISABLED control/item is disabled + ====================== ============================================ +", ""); + + + + DocDeclStr( + bool , ShouldDrawFocus() const, + "Returns true if focus indicator should be drawn in the control.", ""); + + const wxBitmap& GetBitmapNormal() const; const wxBitmap& GetBitmapPressed() const; const wxBitmap& GetBitmapHover() const; const wxBitmap& GetBitmapDisabled() const; - // Return internal flags wxUint32 GetInternalFlags() const; - // Return true if Create has finished - bool IsCreated() const; + DocDeclStr( + bool , IsCreated() const, + "Return true if Create has finished", ""); + + + DocDeclStr( + void , OnPopupDismiss(), + "Common code to be called on popup hide/dismiss", ""); - // common code to be called on popup hide/dismiss - void OnPopupDismiss(); // PopupShown states enum @@ -379,8 +512,14 @@ public: // Set value returned by GetMainWindowOfCompositeControl void SetCtrlMainWnd( wxWindow* wnd ); + virtual wxWindow *GetMainWindowOfCompositeControl(); + + DocDeclStr( + static int , GetFeatures(), + "Returns a bit-list of flags indicating which features of the ComboCtrl +functionality are implemented by this implemetation. See +`wx.combo.ComboCtrlFeatures`.", ""); - static int GetFeatures(); // Flags for DoShowPopup and AnimateShow @@ -392,13 +531,43 @@ public: }; // Shows and positions the popup. - virtual void DoShowPopup( const wxRect& rect, int flags ); - - // Implement in derived class to create a drop-down animation. - // Return true if finished immediately. Otherwise popup is only - // shown when the derived class call DoShowPopup. - // Flags are same as for DoShowPopup. - virtual bool AnimateShow( const wxRect& rect, int flags ); + DocDeclStr( + virtual void , DoShowPopup( const wxRect& rect, int flags ), + "Shows and positions the popup. + +Flags: + ============ ===================================================== + ShowBelow Showing popup below the control + ShowAbove Showing popup above the control + CanDeferShow Can only return true from AnimateShow if this is set + ============ ===================================================== +", ""); + + + + DocDeclStr( + virtual bool , AnimateShow( const wxRect& rect, int flags ), + "Implement in derived class to create a drop-down animation. Return +``True`` if finished immediately. Otherwise the popup is only shown when the +derived class calls `DoShowPopup`. Flags are same as for `DoShowPopup`. +", ""); + + + %property(PopupControl, GetPopupControl, SetPopupControl); + %property(PopupWindow, GetPopupWindow); + %property(TextCtrl, GetTextCtrl); + %property(Button, GetButton); + %property(Value, GetValue, SetValue); + %property(InsertionPoint, GetInsertionPoint); + %property(CustomPaintWidth, GetCustomPaintWidth, SetCustomPaintWidth); + %property(ButtonSize, GetButtonSize); + %property(TextIndent, GetTextIndent, SetTextIndent); + %property(TextRect, GetTextRect); + %property(BitmapNormal, GetBitmapNormal); + %property(BitmapPressed, GetBitmapPressed); + %property(BitmapHover, GetBitmapHover); + %property(BitmapDisabled, GetBitmapDisabled); + %property(PopupWindowState, GetPopupWindowState); }; @@ -521,7 +690,19 @@ IMP_PYCALLBACK_BOOL_(wxPyComboPopup, wxComboPopup, LazyCreate); -// Now declare wxPyComboCtrl for Python +// Now declare wxPyComboPopup for Python +DocStr(wxPyComboPopup, +"In order to use a custom popup with `wx.combo.ComboCtrl` an interface +class derived from wx.combo.ComboPopup is used to manage the interface +between the popup control and the popup. You can either derive a new +class from both the widget class and this ComboPopup class, or the +derived class can have a reference to the widget used for the popup. +In either case you simply need to return the widget from the +`GetControl` method to allow the ComboCtrl to interact with it. + +Nearly all of the methods of this class are overridable in Python.", ""); + + MustHaveApp(wxPyComboPopup); %rename(ComboPopup) wxPyComboPopup; @@ -530,78 +711,135 @@ class wxPyComboPopup public: %pythonAppend wxPyComboPopup setCallbackInfo(ComboPopup); - wxPyComboPopup(); - ~wxPyComboPopup(); + DocCtorStr( + wxPyComboPopup(), + "Constructor", ""); + + DocCtorStr( + ~wxPyComboPopup(), + "Destructor", ""); + void _setCallbackInfo(PyObject* self, PyObject* _class); - // This is called immediately after construction finishes. m_combo member - // variable has been initialized before the call. - // NOTE: It is not in constructor so the derived class doesn't need to redefine - // a default constructor of its own. - virtual void Init(); + DocDeclStr( + virtual void , Init(), + "This method is called after the popup is contructed and has been +assigned to the ComboCtrl. Derived classes can override this to do +extra inialization or whatever.", ""); + // Create the popup child control. // Return true for success. - virtual bool Create(wxWindow* parent); + DocDeclStr( + virtual bool , Create(wxWindow* parent), + "The derived class must implement this method to create the popup +control. It should be a child of the ``parent`` passed in, but other +than that there is much flexibility in what the widget can be, its +style, etc. Return ``True`` for success, ``False`` otherwise. (NOTE: +this return value is not currently checked...)", ""); + + + DocDeclStr( + virtual wxWindow *, GetControl(), + "The derived class must implement this method and it should return a +reference to the widget created in the `Create` method. If the +derived class inherits from both the widget class and ComboPopup then +the return value is probably just ``self``.", ""); + + + DocDeclStr( + virtual void , OnPopup(), + "The derived class may implement this to do special processing when +popup is shown.", ""); + + + DocDeclStr( + virtual void , OnDismiss(), + "The derived class may implement this to do special processing when +popup is hidden.", ""); + + + DocDeclStr( + virtual void , SetStringValue( const wxString& value ), + "Called just prior to displaying the popup. The derived class can +implement this to \"select\" the item in the popup that coresponds to +the passed in string value, if appropriate. The default +implementation does nothing.", ""); + + + DocDeclStr( + virtual wxString , GetStringValue() const, + "Gets the string representation of the currently selected value to be +used to display in the combo widget.", ""); + + + DocDeclStr( + virtual void , PaintComboControl( wxDC& dc, const wxRect& rect ), + "This is called to custom paint in the combo control itself (ie. not +the popup). Default implementation draws the current value as string.", ""); - // We must have an associated control which is subclassed by the combobox. - virtual wxWindow *GetControl(); - // Called immediately after the popup is shown - virtual void OnPopup(); + DocDeclStr( + virtual void , OnComboKeyEvent( wxKeyEvent& event ), + "Receives key events from the parent ComboCtrl. Events not handled +should be skipped, as usual.", ""); - // Called when popup is dismissed - virtual void OnDismiss(); - // Called just prior to displaying popup. - // Default implementation does nothing. - virtual void SetStringValue( const wxString& value ); + DocDeclStr( + virtual void , OnComboDoubleClick(), + "Implement this method in the derived class if you need to support +special actions when the user double-clicks on the parent ComboCtrl.", ""); - // Gets displayed string representation of the value. - virtual wxString GetStringValue() const; - // This is called to custom paint in the combo control itself (ie. not the popup). - // Default implementation draws value as string. - virtual void PaintComboControl( wxDC& dc, const wxRect& rect ); + DocDeclStr( + virtual wxSize , GetAdjustedSize( int minWidth, int prefHeight, int maxHeight ), + "The derived class may implement this method to return adjusted size +for the popup control, according to the variables given. It is called +on every popup, just prior to `OnPopup`. - // Receives key events from the parent wxComboCtrl. - // Events not handled should be skipped, as usual. - virtual void OnComboKeyEvent( wxKeyEvent& event ); + :param minWidth: Preferred minimum width. + :param prefHeight: Preferred height. May be -1 to indicate no preference. + :maxWidth: Max height for window, as limited by screen size, and + should only be rounded down, if necessary. +", ""); - // Implement if you need to support special action when user - // double-clicks on the parent wxComboCtrl. - virtual void OnComboDoubleClick(); - // Return final size of popup. Called on every popup, just prior to OnPopup. - // minWidth = preferred minimum width for window - // prefHeight = preferred height. Only applies if > 0, - // maxHeight = max height for window, as limited by screen size - // and should only be rounded down, if necessary. - virtual wxSize GetAdjustedSize( int minWidth, int prefHeight, int maxHeight ); + DocDeclStr( + virtual bool , LazyCreate(), + "The derived class may implement this to return ``True`` if it wants to +delay the call to `Create` until the popup is shown for the first +time. It is more efficient, but on the other hand it is often more +convenient to have the control created immediately. The default +implementation returns ``False``.", ""); - // Return true if you want delay call to Create until the popup is shown - // for the first time. It is more efficient, but note that it is often - // more convenient to have the control created immediately. - // Default returns false. - virtual bool LazyCreate(); // // Utilies // - // Hides the popup - void Dismiss(); - // Returns true if Create has been called. - bool IsCreated() const; + DocDeclStr( + void , Dismiss(), + "Hides the popup", ""); - // Default PaintComboControl behaviour - static void DefaultPaintComboControl( wxComboCtrlBase* combo, - wxDC& dc, - const wxRect& rect ); - wxPyComboCtrl* GetCombo(); + DocDeclStr( + bool , IsCreated() const, + "Returns true if `Create` has been called.", ""); + + + DocDeclStr( + static void , DefaultPaintComboControl( wxComboCtrlBase* combo, + wxDC& dc, + const wxRect& rect ), + "Default PaintComboControl behaviour", ""); + + + DocDeclStr( + wxPyComboCtrl* , GetCombo(), + "Returns a reference to the `wx.combo.ComboCtrl` this ComboPopup object +is associated with.", ""); }; @@ -657,7 +895,18 @@ IMP_PYCALLBACK__DCRECTINTINT_const(wxPyOwnerDrawnComboBox, wxOwnerDrawnComboBox, -// Now declare wxPyComboCtrl for Python +// Now declare wxPyOwnerDrawnComboBox for Python + +DocStr(wxPyOwnerDrawnComboBox, +"wx.combo.OwnerDrawnComboBox is a combobox with owner-drawn list +items. In essence, it is a `wx.combo.ComboCtrl` with a `wx.VListBox` +popup and a `wx.ControlWithItems` API. + +Implementing item drawing and measuring is similar to wx.VListBox. +The application needs to subclass wx.combo.OwnerDrawnComboBox and +implement the `OnDrawItem`, `OnMeasureItem` and `OnMeasureItemWidth` +methods.", ""); + MustHaveApp(wxPyOwnerDrawnComboBox); %rename(OwnerDrawnComboBox) wxPyOwnerDrawnComboBox; @@ -668,39 +917,216 @@ public: %pythonAppend wxPyOwnerDrawnComboBox "self._setOORInfo(self);" setCallbackInfo(OwnerDrawnComboBox) %pythonAppend wxPyOwnerDrawnComboBox() ""; - wxPyOwnerDrawnComboBox(wxWindow *parent, - wxWindowID id = -1, - const wxString& value = wxPyEmptyString, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - const wxArrayString& choices = wxPyEmptyStringArray, - long style = 0, - const wxValidator& validator = wxDefaultValidator, - const wxString& name = wxPyComboBoxNameStr); + DocCtorStr( + wxPyOwnerDrawnComboBox(wxWindow *parent, + wxWindowID id = -1, + const wxString& value = wxPyEmptyString, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + const wxArrayString& choices = wxPyEmptyStringArray, + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxPyComboBoxNameStr), + "Standard constructor.", ""); + + DocCtorStrName(wxPyOwnerDrawnComboBox(), + "2-phase create constructor.", "", + PreOwnerDrawnComboBox); - %RenameCtor(PreOwnerDrawnComboBox, wxPyOwnerDrawnComboBox()); + void _setCallbackInfo(PyObject* self, PyObject* _class); + + DocDeclStr( + bool , Create(wxWindow *parent, + wxWindowID id = -1, + const wxString& value = wxPyEmptyString, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + const wxArrayString& choices = wxPyEmptyStringArray, + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxPyComboBoxNameStr), + "Create the UI object, and other initialization.", ""); + + + DocDeclStr( + virtual int , GetWidestItemWidth(), + "Return the widest item width (recalculating it if necessary.)", ""); + + + DocDeclStr( + virtual int , GetWidestItem(), + "Return the index of the widest item (recalculating it if necessary.)", ""); + - bool Create(wxWindow *parent, - wxWindowID id = -1, - const wxString& value = wxPyEmptyString, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - const wxArrayString& choices = wxPyEmptyStringArray, - long style = 0, - const wxValidator& validator = wxDefaultValidator, - const wxString& name = wxPyComboBoxNameStr); + void SetSelection(int n); + %Rename(SetMark, void , SetSelection(long from, long to)); - // Return the widest item width (recalculating it if necessary) - virtual int GetWidestItemWidth(); - // Return the index of the widest item (recalculating it if necessary) - virtual int GetWidestItem(); + // Callback for drawing. Font, background and text colour have been + // prepared according to selection, focus and such. + // item: item index to be drawn, may be wxNOT_FOUND when painting combo control itself + // and there is no valid selection + // flags: wxODCB_PAINTING_CONTROL is set if painting to combo control instead of list + DocDeclStr( + virtual void , OnDrawItem( wxDC& dc, const wxRect& rect, int item, int flags ) const, + "The derived class may implement this function to actually draw the +item with the given index on the provided DC. If this method is not +overridden, the item text is simply drawn as if the control was a +normal combobox. + + :param dc: The device context to use for drawing. + :param rect: The bounding rectangle for the item being drawn, the + DC's clipping region is set to this rectangle before + calling this method. + :param item: The index of the item to be drawn. + + :param flags: ``wx.combo.ODCB_PAINTING_CONTROL`` (The Combo control itself + is being painted, instead of a list item. The ``item`` + parameter may be ``wx.NOT_FOUND`` in this case. + ``wx.combo.ODCB_PAINTING_SELECTED`` (An item with + selection background is being painted. The DC's text colour + should already be correct. +", ""); + + + DocDeclStr( + virtual wxCoord , OnMeasureItem( size_t item ) const, + "The derived class may implement this method to return the height of +the specified item (in pixels). The default implementation returns +text height, as if this control was a normal combobox.", ""); + + + DocDeclStr( + virtual wxCoord , OnMeasureItemWidth( size_t item ) const, + "The derived class may implement this method to return the width of the +specified item (in pixels). If -1 is returned, then the item text +width is used. The default implementation returns -1.", ""); + + + DocDeclStr( + virtual void , OnDrawBackground( wxDC& dc, const wxRect& rect, int item, int flags ) const, + "This method is used to draw the items background and, maybe, a border +around it. + +The base class version implements a reasonable default behaviour which +consists in drawing the selected item with the standard background +colour and drawing a border around the item if it is either selected +or current. ``flags`` has the sam meaning as with `OnDrawItem`.", ""); + - void SetSelection(int n); - %Rename(SetMark, void , SetSelection(long from, long to)); }; +//--------------------------------------------------------------------------- + +%{ +#include +%} + +DocStr(wxBitmapComboBox, + "A combobox that displays a bitmap in front of the list items. It +currently only allows using bitmaps of one size, and resizes itself so +that a bitmap can be shown next to the text field.", +" + +Window Styles +------------- + =================== ============================================ + wx.CB_READONLY Creates a combobox without a text editor. On + some platforms the control may appear very + different when this style is used. + wx.CB_SORT Sorts the entries in the list alphabetically. + wx.TE_PROCESS_ENTER The control will generate the event + wx.EVT__TEXT_ENTER (otherwise pressing Enter + key is either processed internally by the + control or used for navigation between dialog + controls). + =================== ============================================ +"); + +MustHaveApp(wxBitmapComboBox); + +class wxBitmapComboBox : public wxPyOwnerDrawnComboBox +{ +public: + %pythonAppend wxBitmapComboBox "self._setOORInfo(self);"; + %pythonAppend wxBitmapComboBox() ""; + + DocCtorStr( + wxBitmapComboBox(wxWindow *parent, + wxWindowID id = -1, + const wxString& value = wxPyEmptyString, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + const wxArrayString& choices = wxPyEmptyStringArray, + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxBitmapComboBoxNameStr), + "Standard constructor", ""); + + DocCtorStrName(wxBitmapComboBox(), + "2-phase create constructor.", "", + PreBitmapComboBox); + + DocDeclStr( + bool , Create(wxWindow *parent, + wxWindowID id = -1, + const wxString& value = wxPyEmptyString, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + const wxArrayString& choices = wxPyEmptyStringArray, + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxBitmapComboBoxNameStr), + "Create the UI object, and other initialization.", ""); + + + + %extend { + DocStr(Append, + "Adds the item to the control, associating the given data with the item +if not None. The return value is the index of the newly added item.", ""); + int Append(const wxString& item, const wxBitmap& bitmap = wxNullBitmap, PyObject* clientData=NULL) { + if (clientData) { + wxPyClientData* data = new wxPyClientData(clientData); + return self->Append(item, bitmap, data); + } else + return self->Append(item, bitmap); + } + } + + + DocDeclStr( + virtual wxBitmap , GetItemBitmap(/*unsigned*/ int n) const, + "Returns the image of the item with the given index.", ""); + + + %extend { + DocStr(Insert, + "Insert an item into the control before the item at the ``pos`` index, +optionally associating some data object with the item.", ""); + int Insert(const wxString& item, const wxBitmap& bitmap, + /*unsigned*/ int pos, PyObject* clientData=NULL) { + if (clientData) { + wxPyClientData* data = new wxPyClientData(clientData); + return self->Insert(item, bitmap, pos, data); + } else + return self->Insert(item, bitmap, pos); + } + } + + + DocDeclStr( + virtual void , SetItemBitmap(/*unsigned*/ int n, const wxBitmap& bitmap), + "Sets the image for the given item.", ""); + + + DocDeclStr( + virtual wxSize , GetBitmapSize() const, + "Returns size of the image used in list.", ""); + + +}; //--------------------------------------------------------------------------- @@ -708,6 +1134,7 @@ public: // Map renamed classes back to their common name for OOR wxPyPtrTypeMap_Add("wxComboCtrl", "wxPyComboCtrl"); wxPyPtrTypeMap_Add("wxComboPopup", "wxPyComboPopup"); + wxPyPtrTypeMap_Add("wxOwnerDrawnComboBox", "wxPyOwnerDrawnComboBox"); %} //---------------------------------------------------------------------------