summaryrefslogtreecommitdiff
path: root/lib/python2.7/site-packages/wx-3.0-msw/wx/combo.py
blob: 9298999ac3999ed9cf34aece586e5c610ad4f5e0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
# This file was created automatically by SWIG 1.3.29.
# Don't modify this file, modify the SWIG interface instead.

"""
ComboCtrl class that can have any type of popup widget, and also an
owner-drawn combobox control.
"""

import _combo
import new
new_instancemethod = new.instancemethod
def _swig_setattr_nondynamic(self,class_type,name,value,static=1):
    if (name == "thisown"): return self.this.own(value)
    if (name == "this"):
        if type(value).__name__ == 'PySwigObject':
            self.__dict__[name] = value
            return
    method = class_type.__swig_setmethods__.get(name,None)
    if method: return method(self,value)
    if (not static) or hasattr(self,name):
        self.__dict__[name] = value
    else:
        raise AttributeError("You cannot add attributes to %s" % self)

def _swig_setattr(self,class_type,name,value):
    return _swig_setattr_nondynamic(self,class_type,name,value,0)

def _swig_getattr(self,class_type,name):
    if (name == "thisown"): return self.this.own()
    method = class_type.__swig_getmethods__.get(name,None)
    if method: return method(self)
    raise AttributeError,name

def _swig_repr(self):
    try: strthis = "proxy of " + self.this.__repr__()
    except: strthis = ""
    return "<%s.%s; %s >" % (self.__class__.__module__, self.__class__.__name__, strthis,)

import types
try:
    _object = types.ObjectType
    _newclass = 1
except AttributeError:
    class _object : pass
    _newclass = 0
del types


def _swig_setattr_nondynamic_method(set):
    def set_attr(self,name,value):
        if (name == "thisown"): return self.this.own(value)
        if hasattr(self,name) or (name == "this"):
            set(self,name,value)
        else:
            raise AttributeError("You cannot add attributes to %s" % self)
    return set_attr


import _windows
import _core
import _controls
wx = _core 
__docfilter__ = wx.__DocFilter(globals()) 
#---------------------------------------------------------------------------

CC_SPECIAL_DCLICK = _combo.CC_SPECIAL_DCLICK
CC_STD_BUTTON = _combo.CC_STD_BUTTON
CC_BUTTON_OUTSIDE_BORDER = _combo.CC_BUTTON_OUTSIDE_BORDER
CC_POPUP_ON_MOUSE_UP = _combo.CC_POPUP_ON_MOUSE_UP
CC_NO_TEXT_AUTO_SELECT = _combo.CC_NO_TEXT_AUTO_SELECT
CC_BUTTON_STAYS_DOWN = _combo.CC_BUTTON_STAYS_DOWN
CC_FULL_BUTTON = _combo.CC_FULL_BUTTON
CC_BUTTON_COVERS_BORDER = _combo.CC_BUTTON_COVERS_BORDER
CC_MF_ON_BUTTON = _combo.CC_MF_ON_BUTTON
CC_MF_ON_CLICK_AREA = _combo.CC_MF_ON_CLICK_AREA
class ComboCtrlFeatures(object):
    """
    Namespace for `wx.combo.ComboCtrl` feature flags.  See
    `wx.combo.ComboCtrl.GetFeatures`.
    """
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
    def __init__(self): raise AttributeError, "No constructor defined"
    __repr__ = _swig_repr
    MovableButton = _combo.ComboCtrlFeatures_MovableButton
    BitmapButton = _combo.ComboCtrlFeatures_BitmapButton
    ButtonSpacing = _combo.ComboCtrlFeatures_ButtonSpacing
    TextIndent = _combo.ComboCtrlFeatures_TextIndent
    PaintControl = _combo.ComboCtrlFeatures_PaintControl
    PaintWritable = _combo.ComboCtrlFeatures_PaintWritable
    Borderless = _combo.ComboCtrlFeatures_Borderless
    All = _combo.ComboCtrlFeatures_All
_combo.ComboCtrlFeatures_swigregister(ComboCtrlFeatures)

class ComboCtrl(_core.Control,_core.TextEntry):
    """
    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.

    """
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
    __repr__ = _swig_repr
    def __init__(self, *args, **kwargs): 
        """
        __init__(self, Window parent, int id=ID_ANY, String value=wxEmptyString, 
            Point pos=DefaultPosition, Size size=DefaultSize, 
            long style=0, Validator validator=DefaultValidator, 
            String name=ComboBoxNameStr) -> ComboCtrl
        """
        _combo.ComboCtrl_swiginit(self,_combo.new_ComboCtrl(*args, **kwargs))
        self._setOORInfo(self);ComboCtrl._setCallbackInfo(self, self, ComboCtrl)

    def _setCallbackInfo(*args, **kwargs):
        """_setCallbackInfo(self, PyObject self, PyObject _class)"""
        return _combo.ComboCtrl__setCallbackInfo(*args, **kwargs)

    def Popup(*args, **kwargs):
        """Popup(self)"""
        return _combo.ComboCtrl_Popup(*args, **kwargs)

    def Dismiss(*args, **kwargs):
        """Dismiss(self)"""
        return _combo.ComboCtrl_Dismiss(*args, **kwargs)

    def ShowPopup(*args, **kwargs):
        """
        ShowPopup(self)

        Show the popup window.
        """
        return _combo.ComboCtrl_ShowPopup(*args, **kwargs)

    def HidePopup(*args, **kwargs):
        """
        HidePopup(self)

        Dismisses the popup window.
        """
        return _combo.ComboCtrl_HidePopup(*args, **kwargs)

    def OnButtonClick(*args, **kwargs):
        """
        OnButtonClick(self)

        Implement in a derived class to define what happens on dropdown button
        click.  Default action is to show the popup. 
        """
        return _combo.ComboCtrl_OnButtonClick(*args, **kwargs)

    def IsPopupShown(*args, **kwargs):
        """
        IsPopupShown(self) -> bool

        Returns true if the popup is currently shown.
        """
        return _combo.ComboCtrl_IsPopupShown(*args, **kwargs)

    def SetPopupControl(*args, **kwargs):
        """
        SetPopupControl(self, ComboPopup 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.
        """
        return _combo.ComboCtrl_SetPopupControl(*args, **kwargs)

    def GetPopupControl(*args, **kwargs):
        """
        GetPopupControl(self) -> ComboPopup

        Returns the current popup interface that has been set with
        `SetPopupControl`.
        """
        return _combo.ComboCtrl_GetPopupControl(*args, **kwargs)

    def GetPopupWindow(*args, **kwargs):
        """
        GetPopupWindow(self) -> Window

        Returns the popup window containing the popup control.
        """
        return _combo.ComboCtrl_GetPopupWindow(*args, **kwargs)

    def GetTextCtrl(*args, **kwargs):
        """
        GetTextCtrl(self) -> TextCtrl

        Get the text control which is part of the combo control.
        """
        return _combo.ComboCtrl_GetTextCtrl(*args, **kwargs)

    def GetButton(*args, **kwargs):
        """
        GetButton(self) -> Window

        Get the dropdown button which is part of the combobox.  Note: it's not
        necessarily a wx.Button or wx.BitmapButton.
        """
        return _combo.ComboCtrl_GetButton(*args, **kwargs)

    def SetMargins(*args):
        """
        SetMargins(self, Point pt) -> bool
        SetMargins(self, int left, int top=-1) -> bool
        """
        return _combo.ComboCtrl_SetMargins(*args)

    def GetMargins(*args, **kwargs):
        """GetMargins(self) -> Point"""
        return _combo.ComboCtrl_GetMargins(*args, **kwargs)

    def SetTextCtrlStyle(*args, **kwargs):
        """
        SetTextCtrlStyle(self, int style)

        Set a custom window style for the embedded wxTextCtrl. Usually you
        will need to use this during two-step creation, just before Create().
        For example::

            class MyComboCtrl(wx.combo.ComboCtrl):
                def __init__(self, *args, **kwargs):
                    pre = wx.combo.PreComboCtrl()
                    # Let's make the text right-aligned
                    pre.SetTextCtrlStyle(wx.TE_RIGHT)
                    pre.Create(*args, **kwargs);
                    self.PostCreate(pre)

        """
        return _combo.ComboCtrl_SetTextCtrlStyle(*args, **kwargs)

    def GetValue(*args, **kwargs):
        """
        GetValue(self) -> String

        Returns text representation of the current value. For writable combo
        control it always returns the value in the text field.
        """
        return _combo.ComboCtrl_GetValue(*args, **kwargs)

    GetMark = wx.TextEntry.GetSelection
    SetMark = wx.TextEntry.SetSelection

    def SetText(*args, **kwargs):
        """
        SetText(self, String 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.
        """
        return _combo.ComboCtrl_SetText(*args, **kwargs)

    def SetValueWithEvent(*args, **kwargs):
        """
        SetValueWithEvent(self, String value, bool withEvent=True)

        Same as `SetValue`, but also sends a EVT_TEXT event if withEvent is true.
        """
        return _combo.ComboCtrl_SetValueWithEvent(*args, **kwargs)

    def SetValueByUser(*args, **kwargs):
        """SetValueByUser(self, String value)"""
        return _combo.ComboCtrl_SetValueByUser(*args, **kwargs)

    def SetPopupMinWidth(*args, **kwargs):
        """
        SetPopupMinWidth(self, 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.
        """
        return _combo.ComboCtrl_SetPopupMinWidth(*args, **kwargs)

    def SetPopupMaxHeight(*args, **kwargs):
        """
        SetPopupMaxHeight(self, 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.
        """
        return _combo.ComboCtrl_SetPopupMaxHeight(*args, **kwargs)

    def SetPopupExtents(*args, **kwargs):
        """
        SetPopupExtents(self, 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.
        """
        return _combo.ComboCtrl_SetPopupExtents(*args, **kwargs)

    def SetCustomPaintWidth(*args, **kwargs):
        """
        SetCustomPaintWidth(self, 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.
        """
        return _combo.ComboCtrl_SetCustomPaintWidth(*args, **kwargs)

    def GetCustomPaintWidth(*args, **kwargs):
        """GetCustomPaintWidth(self) -> int"""
        return _combo.ComboCtrl_GetCustomPaintWidth(*args, **kwargs)

    def SetPopupAnchor(*args, **kwargs):
        """
        SetPopupAnchor(self, 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).
        """
        return _combo.ComboCtrl_SetPopupAnchor(*args, **kwargs)

    def SetButtonPosition(*args, **kwargs):
        """
        SetButtonPosition(self, int width=-1, int height=-1, int side=RIGHT, int spacingX=0)

        Set the position of the dropdown button.
        """
        return _combo.ComboCtrl_SetButtonPosition(*args, **kwargs)

    def GetButtonSize(*args, **kwargs):
        """
        GetButtonSize(self) -> Size

        Returns current size of the dropdown button.
        """
        return _combo.ComboCtrl_GetButtonSize(*args, **kwargs)

    def SetButtonBitmaps(*args, **kwargs):
        """
        SetButtonBitmaps(self, Bitmap bmpNormal, bool pushButtonBg=False, Bitmap bmpPressed=wxNullBitmap, 
            Bitmap bmpHover=wxNullBitmap, 
            Bitmap 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 button image.
            :param bmpHover:  Button image to use when the mouse hovers over it.
            :param bmpDisabled: Disabled button image.

        """
        return _combo.ComboCtrl_SetButtonBitmaps(*args, **kwargs)

    def SetTextIndent(*args, **kwargs):
        """
        SetTextIndent(self, 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.
        """
        return _combo.ComboCtrl_SetTextIndent(*args, **kwargs)

    def GetTextIndent(*args, **kwargs):
        """
        GetTextIndent(self) -> int

        Returns actual indentation in pixels.
        """
        return _combo.ComboCtrl_GetTextIndent(*args, **kwargs)

    def GetTextRect(*args, **kwargs):
        """
        GetTextRect(self) -> Rect

        Returns area covered by the text field (includes everything except
        borders and the dropdown button).
        """
        return _combo.ComboCtrl_GetTextRect(*args, **kwargs)

    def UseAltPopupWindow(*args, **kwargs):
        """
        UseAltPopupWindow(self, 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.
        """
        return _combo.ComboCtrl_UseAltPopupWindow(*args, **kwargs)

    def EnablePopupAnimation(*args, **kwargs):
        """
        EnablePopupAnimation(self, bool enable=True)

        Enables or disables popup animation, if any, depending on the value of
        the argument.
        """
        return _combo.ComboCtrl_EnablePopupAnimation(*args, **kwargs)

    def IsKeyPopupToggle(*args, **kwargs):
        """
        IsKeyPopupToggle(self, KeyEvent event) -> bool

        Returns true if given key combination should toggle the popup.
        """
        return _combo.ComboCtrl_IsKeyPopupToggle(*args, **kwargs)

    def PrepareBackground(*args, **kwargs):
        """
        PrepareBackground(self, DC dc, Rect rect, int flags)

        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
            ======================   ============================================

        """
        return _combo.ComboCtrl_PrepareBackground(*args, **kwargs)

    def ShouldDrawFocus(*args, **kwargs):
        """
        ShouldDrawFocus(self) -> bool

        Returns true if focus indicator should be drawn in the control.
        """
        return _combo.ComboCtrl_ShouldDrawFocus(*args, **kwargs)

    def GetBitmapNormal(*args, **kwargs):
        """GetBitmapNormal(self) -> Bitmap"""
        return _combo.ComboCtrl_GetBitmapNormal(*args, **kwargs)

    def GetBitmapPressed(*args, **kwargs):
        """GetBitmapPressed(self) -> Bitmap"""
        return _combo.ComboCtrl_GetBitmapPressed(*args, **kwargs)

    def GetBitmapHover(*args, **kwargs):
        """GetBitmapHover(self) -> Bitmap"""
        return _combo.ComboCtrl_GetBitmapHover(*args, **kwargs)

    def GetBitmapDisabled(*args, **kwargs):
        """GetBitmapDisabled(self) -> Bitmap"""
        return _combo.ComboCtrl_GetBitmapDisabled(*args, **kwargs)

    def GetInternalFlags(*args, **kwargs):
        """GetInternalFlags(self) -> unsigned int"""
        return _combo.ComboCtrl_GetInternalFlags(*args, **kwargs)

    def IsCreated(*args, **kwargs):
        """
        IsCreated(self) -> bool

        Return true if Create has finished
        """
        return _combo.ComboCtrl_IsCreated(*args, **kwargs)

    def GetBackgroundColour(*args, **kwargs):
        """
        GetBackgroundColour(self) -> Colour

        Returns the background colour of the window.
        """
        return _combo.ComboCtrl_GetBackgroundColour(*args, **kwargs)

    def OnPopupDismiss(*args, **kwargs):
        """
        OnPopupDismiss(self, bool generateEvent)

        Common code to be called on popup hide/dismiss
        """
        return _combo.ComboCtrl_OnPopupDismiss(*args, **kwargs)

    Hidden = _combo.ComboCtrl_Hidden
    Animating = _combo.ComboCtrl_Animating
    Visible = _combo.ComboCtrl_Visible
    def IsPopupWindowState(*args, **kwargs):
        """IsPopupWindowState(self, int state) -> bool"""
        return _combo.ComboCtrl_IsPopupWindowState(*args, **kwargs)

    def GetPopupWindowState(*args, **kwargs):
        """GetPopupWindowState(self) -> int"""
        return _combo.ComboCtrl_GetPopupWindowState(*args, **kwargs)

    def SetCtrlMainWnd(*args, **kwargs):
        """SetCtrlMainWnd(self, Window wnd)"""
        return _combo.ComboCtrl_SetCtrlMainWnd(*args, **kwargs)

    def DestroyPopup(*args, **kwargs):
        """DestroyPopup(self)"""
        return _combo.ComboCtrl_DestroyPopup(*args, **kwargs)

    def GetFeatures(*args, **kwargs):
        """
        GetFeatures() -> int

        Returns a bit-list of flags indicating which features of the ComboCtrl
        functionality are implemented by this implemetation.  See
        `wx.combo.ComboCtrlFeatures`.
        """
        return _combo.ComboCtrl_GetFeatures(*args, **kwargs)

    GetFeatures = staticmethod(GetFeatures)
    ShowBelow = _combo.ComboCtrl_ShowBelow
    ShowAbove = _combo.ComboCtrl_ShowAbove
    CanDeferShow = _combo.ComboCtrl_CanDeferShow
    def DoShowPopup(*args, **kwargs):
        """
        DoShowPopup(self, Rect 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
            ============  =====================================================

        """
        return _combo.ComboCtrl_DoShowPopup(*args, **kwargs)

    def AnimateShow(*args, **kwargs):
        """
        AnimateShow(self, Rect rect, int flags) -> bool

        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`.

        """
        return _combo.ComboCtrl_AnimateShow(*args, **kwargs)

    PopupControl = property(GetPopupControl,SetPopupControl) 
    PopupWindow = property(GetPopupWindow) 
    TextCtrl = property(GetTextCtrl) 
    Button = property(GetButton) 
    CustomPaintWidth = property(GetCustomPaintWidth,SetCustomPaintWidth) 
    ButtonSize = property(GetButtonSize) 
    TextIndent = property(GetTextIndent,SetTextIndent) 
    TextRect = property(GetTextRect) 
    BitmapNormal = property(GetBitmapNormal) 
    BitmapPressed = property(GetBitmapPressed) 
    BitmapHover = property(GetBitmapHover) 
    BitmapDisabled = property(GetBitmapDisabled) 
    PopupWindowState = property(GetPopupWindowState) 
_combo.ComboCtrl_swigregister(ComboCtrl)

def PreComboCtrl(*args, **kwargs):
    """PreComboCtrl() -> ComboCtrl"""
    val = _combo.new_PreComboCtrl(*args, **kwargs)
    return val

def ComboCtrl_GetFeatures(*args):
  """
    ComboCtrl_GetFeatures() -> int

    Returns a bit-list of flags indicating which features of the ComboCtrl
    functionality are implemented by this implemetation.  See
    `wx.combo.ComboCtrlFeatures`.
    """
  return _combo.ComboCtrl_GetFeatures(*args)

#---------------------------------------------------------------------------

class ComboPopup(object):
    """
    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.
    """
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
    __repr__ = _swig_repr
    def __init__(self, *args, **kwargs): 
        """
        __init__(self) -> ComboPopup

        Constructor
        """
        _combo.ComboPopup_swiginit(self,_combo.new_ComboPopup(*args, **kwargs))
        ComboPopup._setCallbackInfo(self, self, ComboPopup)

    __swig_destroy__ = _combo.delete_ComboPopup
    __del__ = lambda self : None;
    def _setCallbackInfo(*args, **kwargs):
        """_setCallbackInfo(self, PyObject self, PyObject _class)"""
        return _combo.ComboPopup__setCallbackInfo(*args, **kwargs)

    def Init(*args, **kwargs):
        """
        Init(self)

        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.
        """
        return _combo.ComboPopup_Init(*args, **kwargs)

    def Create(*args, **kwargs):
        """
        Create(self, Window parent) -> bool

        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...)
        """
        return _combo.ComboPopup_Create(*args, **kwargs)

    def DestroyPopup(*args, **kwargs):
        """DestroyPopup(self)"""
        return _combo.ComboPopup_DestroyPopup(*args, **kwargs)

    def GetControl(*args, **kwargs):
        """
        GetControl(self) -> Window

        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``.
        """
        return _combo.ComboPopup_GetControl(*args, **kwargs)

    def OnPopup(*args, **kwargs):
        """
        OnPopup(self)

        The derived class may implement this to do special processing when
        popup is shown.
        """
        return _combo.ComboPopup_OnPopup(*args, **kwargs)

    def OnDismiss(*args, **kwargs):
        """
        OnDismiss(self)

        The derived class may implement this to do special processing when
        popup is hidden.
        """
        return _combo.ComboPopup_OnDismiss(*args, **kwargs)

    def SetStringValue(*args, **kwargs):
        """
        SetStringValue(self, String 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.
        """
        return _combo.ComboPopup_SetStringValue(*args, **kwargs)

    def GetStringValue(*args, **kwargs):
        """
        GetStringValue(self) -> String

        Gets the string representation of the currently selected value to be
        used to display in the combo widget.
        """
        return _combo.ComboPopup_GetStringValue(*args, **kwargs)

    def PaintComboControl(*args, **kwargs):
        """
        PaintComboControl(self, DC dc, Rect rect)

        This is called to custom paint in the combo control itself (ie. not
        the popup).  Default implementation draws the current value as string.
        """
        return _combo.ComboPopup_PaintComboControl(*args, **kwargs)

    def FindItem(*args, **kwargs):
        """FindItem(self, String item) -> bool"""
        return _combo.ComboPopup_FindItem(*args, **kwargs)

    def OnComboKeyEvent(*args, **kwargs):
        """
        OnComboKeyEvent(self, KeyEvent event)

        Receives key events from the parent ComboCtrl.  Events not handled
        should be skipped, as usual.
        """
        return _combo.ComboPopup_OnComboKeyEvent(*args, **kwargs)

    def OnComboCharEvent(*args, **kwargs):
        """OnComboCharEvent(self, KeyEvent event)"""
        return _combo.ComboPopup_OnComboCharEvent(*args, **kwargs)

    def OnComboDoubleClick(*args, **kwargs):
        """
        OnComboDoubleClick(self)

        Implement this method in the derived class if you need to support
        special actions when the user double-clicks on the parent ComboCtrl.
        """
        return _combo.ComboPopup_OnComboDoubleClick(*args, **kwargs)

    def GetAdjustedSize(*args, **kwargs):
        """
        GetAdjustedSize(self, int minWidth, int prefHeight, int maxHeight) -> Size

        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`.

            :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.

        """
        return _combo.ComboPopup_GetAdjustedSize(*args, **kwargs)

    def LazyCreate(*args, **kwargs):
        """
        LazyCreate(self) -> bool

        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 _combo.ComboPopup_LazyCreate(*args, **kwargs)

    def Dismiss(*args, **kwargs):
        """
        Dismiss(self)

        Hides the popup
        """
        return _combo.ComboPopup_Dismiss(*args, **kwargs)

    def IsCreated(*args, **kwargs):
        """
        IsCreated(self) -> bool

        Returns true if `Create` has been called.
        """
        return _combo.ComboPopup_IsCreated(*args, **kwargs)

    def GetComboCtrl(*args, **kwargs):
        """
        GetComboCtrl(self) -> wxComboCtrl

        Returns the associated parent ComboCtrl.
        """
        return _combo.ComboPopup_GetComboCtrl(*args, **kwargs)

    def DefaultPaintComboControl(*args, **kwargs):
        """
        DefaultPaintComboControl(wxComboCtrlBase combo, DC dc, Rect rect)

        Default PaintComboControl behaviour
        """
        return _combo.ComboPopup_DefaultPaintComboControl(*args, **kwargs)

    DefaultPaintComboControl = staticmethod(DefaultPaintComboControl)
    def GetCombo(*args, **kwargs):
        """
        GetCombo(self) -> ComboCtrl

        Returns a reference to the `wx.combo.ComboCtrl` this ComboPopup object
        is associated with.
        """
        return _combo.ComboPopup_GetCombo(*args, **kwargs)

_combo.ComboPopup_swigregister(ComboPopup)

def ComboPopup_DefaultPaintComboControl(*args, **kwargs):
  """
    ComboPopup_DefaultPaintComboControl(wxComboCtrlBase combo, DC dc, Rect rect)

    Default PaintComboControl behaviour
    """
  return _combo.ComboPopup_DefaultPaintComboControl(*args, **kwargs)

#---------------------------------------------------------------------------

ODCB_DCLICK_CYCLES = _combo.ODCB_DCLICK_CYCLES
ODCB_STD_CONTROL_PAINT = _combo.ODCB_STD_CONTROL_PAINT
ODCB_PAINTING_CONTROL = _combo.ODCB_PAINTING_CONTROL
ODCB_PAINTING_SELECTED = _combo.ODCB_PAINTING_SELECTED
class OwnerDrawnComboBox(ComboCtrl,_core.ItemContainer):
    """
    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.
    """
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
    __repr__ = _swig_repr
    def __init__(self, *args, **kwargs): 
        """
        __init__(self, Window parent, int id=-1, String value=EmptyString, 
            Point pos=DefaultPosition, Size size=DefaultSize, 
            wxArrayString choices=wxPyEmptyStringArray, 
            long style=0, Validator validator=DefaultValidator, 
            String name=ComboBoxNameStr) -> OwnerDrawnComboBox

        Standard constructor.
        """
        _combo.OwnerDrawnComboBox_swiginit(self,_combo.new_OwnerDrawnComboBox(*args, **kwargs))
        self._setOORInfo(self);OwnerDrawnComboBox._setCallbackInfo(self, self, OwnerDrawnComboBox)

    def _setCallbackInfo(*args, **kwargs):
        """_setCallbackInfo(self, PyObject self, PyObject _class)"""
        return _combo.OwnerDrawnComboBox__setCallbackInfo(*args, **kwargs)

    def Create(*args, **kwargs):
        """
        Create(self, Window parent, int id=-1, String value=EmptyString, 
            Point pos=DefaultPosition, Size size=DefaultSize, 
            wxArrayString choices=wxPyEmptyStringArray, 
            long style=0, Validator validator=DefaultValidator, 
            String name=ComboBoxNameStr) -> bool

        Create the UI object, and other initialization.
        """
        return _combo.OwnerDrawnComboBox_Create(*args, **kwargs)

    def GetWidestItemWidth(*args, **kwargs):
        """
        GetWidestItemWidth(self) -> int

        Return the widest item width (recalculating it if necessary.)
        """
        return _combo.OwnerDrawnComboBox_GetWidestItemWidth(*args, **kwargs)

    def GetWidestItem(*args, **kwargs):
        """
        GetWidestItem(self) -> int

        Return the index of the widest item (recalculating it if necessary.)
        """
        return _combo.OwnerDrawnComboBox_GetWidestItem(*args, **kwargs)

    GetString = wx.ItemContainer.GetString 
    GetSelection = wx.ItemContainer.GetSelection
    SetSelection = wx.ItemContainer.SetSelection

    def OnDrawItem(*args, **kwargs):
        """
        OnDrawItem(self, DC dc, Rect rect, int item, int flags)

        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.

        """
        return _combo.OwnerDrawnComboBox_OnDrawItem(*args, **kwargs)

    def OnMeasureItem(*args, **kwargs):
        """
        OnMeasureItem(self, size_t item) -> int

        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.
        """
        return _combo.OwnerDrawnComboBox_OnMeasureItem(*args, **kwargs)

    def OnMeasureItemWidth(*args, **kwargs):
        """
        OnMeasureItemWidth(self, size_t item) -> int

        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.
        """
        return _combo.OwnerDrawnComboBox_OnMeasureItemWidth(*args, **kwargs)

    def OnDrawBackground(*args, **kwargs):
        """
        OnDrawBackground(self, DC dc, Rect rect, int item, int flags)

        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`.
        """
        return _combo.OwnerDrawnComboBox_OnDrawBackground(*args, **kwargs)

_combo.OwnerDrawnComboBox_swigregister(OwnerDrawnComboBox)

def PreOwnerDrawnComboBox(*args, **kwargs):
    """
    PreOwnerDrawnComboBox() -> OwnerDrawnComboBox

    2-phase create constructor.
    """
    val = _combo.new_PreOwnerDrawnComboBox(*args, **kwargs)
    return val

class BitmapComboBox(_controls.ComboBox):
    """
    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.
    """
    thisown = property(lambda x: x.this.own(), lambda x, v: x.this.own(v), doc='The membership flag')
    __repr__ = _swig_repr
    def __init__(self, *args, **kwargs): 
        """
        __init__(self, Window parent, int id=-1, String value=EmptyString, 
            Point pos=DefaultPosition, Size size=DefaultSize, 
            wxArrayString choices=wxPyEmptyStringArray, 
            long style=0, Validator validator=DefaultValidator, 
            String name=wxBitmapComboBoxNameStr) -> BitmapComboBox

        Standard constructor
        """
        _combo.BitmapComboBox_swiginit(self,_combo.new_BitmapComboBox(*args, **kwargs))
        self._setOORInfo(self);

    def Create(*args, **kwargs):
        """
        Create(Window parent, int id=-1, String value=EmptyString,
            Point pos=DefaultPosition, Size size=DefaultSize,
            List choices=EmptyList, long style=0, Validator validator=DefaultValidator,
            String name=ChoiceNameStr) -> bool

        Create the UI object, and other initialization.
        """
        return _combo.BitmapComboBox_Create(*args, **kwargs)

    def Append(*args, **kwargs):
        """
        Append(self, String item, Bitmap bitmap=wxNullBitmap, PyObject clientData=None) -> int

        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.
        """
        return _combo.BitmapComboBox_Append(*args, **kwargs)

    def GetItemBitmap(*args, **kwargs):
        """
        GetItemBitmap(self, int n) -> Bitmap

        Returns the image of the item with the given index.
        """
        return _combo.BitmapComboBox_GetItemBitmap(*args, **kwargs)

    def Insert(*args, **kwargs):
        """
        Insert(self, String item, Bitmap bitmap, int pos, PyObject clientData=None) -> int

        Insert an item into the control before the item at the ``pos`` index,
        optionally associating some data object with the item.
        """
        return _combo.BitmapComboBox_Insert(*args, **kwargs)

    def SetItemBitmap(*args, **kwargs):
        """
        SetItemBitmap(self, int n, Bitmap bitmap)

        Sets the image for the given item.
        """
        return _combo.BitmapComboBox_SetItemBitmap(*args, **kwargs)

    def GetBitmapSize(*args, **kwargs):
        """
        GetBitmapSize(self) -> Size

        Returns size of the image used in list.
        """
        return _combo.BitmapComboBox_GetBitmapSize(*args, **kwargs)

_combo.BitmapComboBox_swigregister(BitmapComboBox)

def PreBitmapComboBox(*args, **kwargs):
    """
    PreBitmapComboBox() -> BitmapComboBox

    2-phase create constructor.
    """
    val = _combo.new_PreBitmapComboBox(*args, **kwargs)
    return val