]> git.saurik.com Git - wxWidgets.git/blobdiff - contrib/include/wx/foldbar/captionbar.h
Added accidentally omitted license to match source files
[wxWidgets.git] / contrib / include / wx / foldbar / captionbar.h
index bf5461854457f8fd71369335292c21cbd0ffc600..46ed80819fd1a263396746335a78ce25a36e6abd 100644 (file)
+/////////////////////////////////////////////////////////////////////////////
+// Name:        captionbar.h
+// Purpose:     wxFoldPanel
+// Author:      Jorgen Bodde
+// Modified by:
+// Created:     22/06/2004
+// RCS-ID:      $Id$
+// Copyright:   (c) Jorgen Bodde
+// Licence:     wxWindows licence
+/////////////////////////////////////////////////////////////////////////////
+
 #ifndef __FOLDPANELBAR_H__
 #define __FOLDPANELBAR_H__
 
+#ifdef WXMAKINGDLL_FOLDBAR
+    #define WXDLLIMPEXP_FOLDBAR WXEXPORT
+#elif defined(WXUSINGDLL)
+    #define WXDLLIMPEXP_FOLDBAR WXIMPORT
+#else // not making nor using DLL
+    #define WXDLLIMPEXP_FOLDBAR
+#endif
+
+
 #define wxFPB_EXTRA_X 10
 #define wxFPB_EXTRA_Y 4
-#define wxFPB_BMP_RIGHTSPACE 2 // pixels of the bmp to be alligned from the right filled with space
+#define wxFPB_BMP_RIGHTSPACE 2    // pixels of the bmp to be alligned from the right filled with space
 
 enum
 {
-       /** Specifies the bars as gradient vertical filled caption bars going from top to bottom. The gradient 
-           starts with first colour, and ends with second colour */
-       wxCAPTIONBAR_GRADIENT_V = 1,
-       /** Specifies the gradient going from left to right. The gradient starts with first colour, and 
-           ends with second colour on the right */
-       wxCAPTIONBAR_GRADIENT_H,
-       /** Fills the captionbar with a single colour. The first colour is used for this fill */
-       wxCAPTIONBAR_SINGLE,
-       /** Draws a rectangle only using the second colour. The first colour is not used*/
-       wxCAPTIONBAR_RECTANGLE,
-       /** Fills the captionbar with a single colour (first colour) and draws a rectangle around it 
-           using the second colour. */
-       wxCAPTIONBAR_FILLED_RECTANGLE
+    /** Specifies the bars as gradient vertical filled caption bars going from top to bottom. The gradient 
+        starts with first colour, and ends with second colour */
+    wxCAPTIONBAR_GRADIENT_V = 1,
+    /** Specifies the gradient going from left to right. The gradient starts with first colour, and 
+        ends with second colour on the right */
+    wxCAPTIONBAR_GRADIENT_H,
+    /** Fills the captionbar with a single colour. The first colour is used for this fill */
+    wxCAPTIONBAR_SINGLE,
+    /** Draws a rectangle only using the second colour. The first colour is not used*/
+    wxCAPTIONBAR_RECTANGLE,
+    /** Fills the captionbar with a single colour (first colour) and draws a rectangle around it 
+        using the second colour. */
+    wxCAPTIONBAR_FILLED_RECTANGLE
 };
 
 /** \class wxCaptionBarStyle
-       This class encapsulates the styles you wish to set for the wxCaptionBar (this is the part of the wxFoldPanel 
+    This class encapsulates the styles you wish to set for the wxCaptionBar (this is the part of the wxFoldPanel 
     where the caption is displayed). It can either be applied at creation time be reapplied when styles need to 
-       be changed. 
-       
-       At construction time, all styles are set to their default transparency. This means none of the styles will be 
-       applied to the wxCaptionBar in question, meaning it will be created using the default internals. When setting i.e
-       the color, font or panel style, these styles become active to be used. 
+    be changed. 
+    
+    At construction time, all styles are set to their default transparency. This means none of the styles will be 
+    applied to the wxCaptionBar in question, meaning it will be created using the default internals. When setting i.e
+    the color, font or panel style, these styles become active to be used. 
 */
 class wxCaptionBarStyle
 {
 private:
-       // boolean flags for default transparency on styles
-       bool _firstColourUsed, 
-                _secondColourUsed,
-                _textColourUsed, 
-                _captionFontUsed, 
-                _captionStyleUsed;
+    // boolean flags for default transparency on styles
+    bool _firstColourUsed, 
+         _secondColourUsed,
+         _textColourUsed, 
+         _captionFontUsed, 
+         _captionStyleUsed;
 
-       wxFont _captionFont;
-       wxColour _firstColour, _secondColour, _textColour;
+    wxFont _captionFont;
+    wxColour _firstColour, _secondColour, _textColour;
 
-       int _captionStyle;
+    int _captionStyle;
 
 public:
-       /** Default constructor for this class */
-       wxCaptionBarStyle() {
-               ResetDefaults();
-       };
-
-       ~wxCaptionBarStyle() {
-
-       };
-
-       void ResetDefaults() {
-               _firstColourUsed = false;
-               _secondColourUsed = false;
-               _textColourUsed = false;
-               _captionFontUsed = false;
-               _captionStyleUsed = false;
-               _captionStyle = wxCAPTIONBAR_GRADIENT_V;
-       };
-               
-       /** Copy operator. Only the styles in use in the source object are being copied to the destination object. All other 
-           styles are not copied */
-       void operator=(const wxCaptionBarStyle &s) {
-               if(s._captionStyleUsed)
-               {
-                       _captionStyleUsed = true;
-                       _captionStyle = s._captionStyle;
-               }
-               if(s._captionFontUsed)
-               {
-                       _captionFontUsed = true;
-                       _captionFont = s._captionFont;
-               }
-               if(s._firstColourUsed)
-               {
-                       _firstColourUsed = true;
-                       _firstColour = s._firstColour;
-               }
-               if(s._secondColourUsed)
-               {
-                       _secondColourUsed = true;
-                       _secondColour = s._secondColour;
-               }
-               if(s._textColourUsed)
-               {
-                       _textColourUsed = true;
-                       _textColour = s._textColour;
-               }
-       };
-
-       // ------- CaptionBar Font -------
-
-       /** Set font for the caption bar. If this is not set, the font property is undefined
-           and will not be used. Use CaptionFontUsed() to check if this style is used */
-       void SetCaptionFont(const wxFont &font) {
-               _captionFont = font;
-               _captionFontUsed = true;
-       };
-
-       /** Checks if the caption bar font is set */
-       bool CaptionFontUsed() const {
-               return _captionFontUsed;
-       };
-
-       /** Returns the font for the caption bar. Please be warned this will result in an assertion failure when
-           this property is not previously set 
-               \sa SetCaptionFont(), CaptionFontUsed() */
-       wxFont GetCaptionFont() const {
-               wxASSERT(_captionFontUsed);
-               return _captionFont;
-       };
-
-       // ------- FirstColour -------
-
-       /** Set first colour for the caption bar. If this is not set, the colour property is 
-           undefined and will not be used. Use FirstColourUsed() to check if this 
-               style is used */
-       void SetFirstColour(const wxColour &col) {
-               _firstColour = col;
-               _firstColourUsed = true;
-       };
-
-       /** Checks if the first colour of the caption bar is set */
-       bool FirstColourUsed() const {
-               return _firstColourUsed;
-       };
-
-       /** Returns the first colour for the caption bar. Please be warned this will 
-           result in an assertion failure when this property is not previously set.
-               \sa SetCaptionFirstColour(), CaptionFirstColourUsed() */
-       wxColour GetFirstColour() const {
-               wxASSERT(_firstColourUsed);
-               return _firstColour;
-       };
-
-       // ------- SecondColour -------
-
-       /** Set second colour for the caption bar. If this is not set, the colour property is undefined and 
-           will not be used. Use SecondColourUsed() to check if this style is used */
-       void SetSecondColour(const wxColour &col) {
-               _secondColour = col;
-               _secondColourUsed = true;
-       };
-
-       /** Checks if the second colour of the caption bar is set */
-       bool SecondColourUsed() const {
-               return _secondColourUsed;
-       };
-
-       /** Returns the second colour for the caption bar. Please be warned this will result in 
-           an assertion failure when this property is not previously set.
-               \sa SetSecondColour(), SecondColourUsed() */
-       wxColour GetSecondColour() const {
-               wxASSERT(_secondColourUsed);
-               return _secondColour;
-       };
-
-       // ------- Caption Text Colour -------
-
-       /** Set caption colour for the caption bar. If this is not set, the colour property is 
-           undefined and will not be used. Use CaptionColourUsed() to check if this style is used */
-       void SetCaptionColour(const wxColour &col) {
-               _textColour = col;
-               _textColourUsed = true;
-       };
-
-       /** Checks if the caption colour of the caption bar is set */
-       bool CaptionColourUsed() const {
-               return _textColourUsed;
-       };
-
-       /** Returns the caption colour for the caption bar. Please be warned this will 
-           result in an assertion failure when this property is not previously set.
-               \sa SetCaptionColour(), CaptionColourUsed() */
-       wxColour GetCaptionColour() const {
-               wxASSERT(_textColourUsed);
-               return _textColour;
-       };
-
-       // ------- CaptionStyle  -------
-
-       /** Set caption style for the caption bar. If this is not set, the property is 
-           undefined and will not be used. Use CaptionStyleUsed() to check if this style is used. 
-               The following styles can be applied:
-               - wxCAPTIONBAR_GRADIENT_V: Draws a vertical gradient from top to bottom
-               - wxCAPTIONBAR_GRADIENT_H: Draws a horizontal gradient from left to right
-               - wxCAPTIONBAR_SINGLE: Draws a single filled rectangle to draw the caption
-               - wxCAPTIONBAR_RECTANGLE: Draws a single colour with a rectangle around the caption
-               - wxCAPTIONBAR_FILLED_RECTANGLE: Draws a filled rectangle and a border around it
-       */
-       void SetCaptionStyle(int style) {
-               _captionStyle = style;
-               _captionStyleUsed = true;
-       };
-
-       /** Checks if the caption style of the caption bar is set */
-       bool CaptionStyleUsed() const {
-               return _captionStyleUsed;
-       };
-
-       /** Returns the caption style for the caption bar. Please be warned this will 
-           result in an assertion failure when this property is not previously set.
-               \sa SetCaptionStyle(), CaptionStyleUsed() */
-       int GetCaptionStyle() const {
-               wxASSERT(_captionStyleUsed);
-               return _captionStyle;
-       };
+    /** Default constructor for this class */
+    wxCaptionBarStyle() {
+        ResetDefaults();
+    };
+
+    ~wxCaptionBarStyle() {
+
+    };
+
+    void ResetDefaults() {
+        _firstColourUsed = false;
+        _secondColourUsed = false;
+        _textColourUsed = false;
+        _captionFontUsed = false;
+        _captionStyleUsed = false;
+        _captionStyle = wxCAPTIONBAR_GRADIENT_V;
+    };
+        
+    /** Copy operator. Only the styles in use in the source object are being copied to the destination object. All other 
+        styles are not copied */
+    void operator=(const wxCaptionBarStyle &s) {
+        if(s._captionStyleUsed)
+        {
+            _captionStyleUsed = true;
+            _captionStyle = s._captionStyle;
+        }
+        if(s._captionFontUsed)
+        {
+            _captionFontUsed = true;
+            _captionFont = s._captionFont;
+        }
+        if(s._firstColourUsed)
+        {
+            _firstColourUsed = true;
+            _firstColour = s._firstColour;
+        }
+        if(s._secondColourUsed)
+        {
+            _secondColourUsed = true;
+            _secondColour = s._secondColour;
+        }
+        if(s._textColourUsed)
+        {
+            _textColourUsed = true;
+            _textColour = s._textColour;
+        }
+    };
+
+    // ------- CaptionBar Font -------
+
+    /** Set font for the caption bar. If this is not set, the font property is undefined
+        and will not be used. Use CaptionFontUsed() to check if this style is used */
+    void SetCaptionFont(const wxFont &font) {
+        _captionFont = font;
+        _captionFontUsed = true;
+    };
+
+    /** Checks if the caption bar font is set */
+    bool CaptionFontUsed() const {
+        return _captionFontUsed;
+    };
+
+    /** Returns the font for the caption bar. Please be warned this will result in an assertion failure when
+        this property is not previously set 
+        \sa SetCaptionFont(), CaptionFontUsed() */
+    wxFont GetCaptionFont() const {
+        wxASSERT(_captionFontUsed);
+        return _captionFont;
+    };
+
+    // ------- FirstColour -------
+
+    /** Set first colour for the caption bar. If this is not set, the colour property is 
+        undefined and will not be used. Use FirstColourUsed() to check if this 
+        style is used */
+    void SetFirstColour(const wxColour &col) {
+        _firstColour = col;
+        _firstColourUsed = true;
+    };
+
+    /** Checks if the first colour of the caption bar is set */
+    bool FirstColourUsed() const {
+        return _firstColourUsed;
+    };
+
+    /** Returns the first colour for the caption bar. Please be warned this will 
+        result in an assertion failure when this property is not previously set.
+        \sa SetCaptionFirstColour(), CaptionFirstColourUsed() */
+    wxColour GetFirstColour() const {
+        wxASSERT(_firstColourUsed);
+        return _firstColour;
+    };
+
+    // ------- SecondColour -------
+
+    /** Set second colour for the caption bar. If this is not set, the colour property is undefined and 
+        will not be used. Use SecondColourUsed() to check if this style is used */
+    void SetSecondColour(const wxColour &col) {
+        _secondColour = col;
+        _secondColourUsed = true;
+    };
+
+    /** Checks if the second colour of the caption bar is set */
+    bool SecondColourUsed() const {
+        return _secondColourUsed;
+    };
+
+    /** Returns the second colour for the caption bar. Please be warned this will result in 
+        an assertion failure when this property is not previously set.
+        \sa SetSecondColour(), SecondColourUsed() */
+    wxColour GetSecondColour() const {
+        wxASSERT(_secondColourUsed);
+        return _secondColour;
+    };
+
+    // ------- Caption Text Colour -------
+
+    /** Set caption colour for the caption bar. If this is not set, the colour property is 
+        undefined and will not be used. Use CaptionColourUsed() to check if this style is used */
+    void SetCaptionColour(const wxColour &col) {
+        _textColour = col;
+        _textColourUsed = true;
+    };
+
+    /** Checks if the caption colour of the caption bar is set */
+    bool CaptionColourUsed() const {
+        return _textColourUsed;
+    };
+
+    /** Returns the caption colour for the caption bar. Please be warned this will 
+        result in an assertion failure when this property is not previously set.
+        \sa SetCaptionColour(), CaptionColourUsed() */
+    wxColour GetCaptionColour() const {
+        wxASSERT(_textColourUsed);
+        return _textColour;
+    };
+
+    // ------- CaptionStyle  -------
+
+    /** Set caption style for the caption bar. If this is not set, the property is 
+        undefined and will not be used. Use CaptionStyleUsed() to check if this style is used. 
+        The following styles can be applied:
+        - wxCAPTIONBAR_GRADIENT_V: Draws a vertical gradient from top to bottom
+        - wxCAPTIONBAR_GRADIENT_H: Draws a horizontal gradient from left to right
+        - wxCAPTIONBAR_SINGLE: Draws a single filled rectangle to draw the caption
+        - wxCAPTIONBAR_RECTANGLE: Draws a single colour with a rectangle around the caption
+        - wxCAPTIONBAR_FILLED_RECTANGLE: Draws a filled rectangle and a border around it
+    */
+    void SetCaptionStyle(int style) {
+        _captionStyle = style;
+        _captionStyleUsed = true;
+    };
+
+    /** Checks if the caption style of the caption bar is set */
+    bool CaptionStyleUsed() const {
+        return _captionStyleUsed;
+    };
+
+    /** Returns the caption style for the caption bar. Please be warned this will 
+        result in an assertion failure when this property is not previously set.
+        \sa SetCaptionStyle(), CaptionStyleUsed() */
+    int GetCaptionStyle() const {
+        wxASSERT(_captionStyleUsed);
+        return _captionStyle;
+    };
 };
 
 #ifndef _NO_CAPTIONBAR_
 
 /** \class wxCaptionBar
-       This class is a graphical caption component that consists of a caption and a clickable arrow.
-       
-       The wxCaptionBar fires an event EVT_CAPTIONBAR which is a wxCaptionBarEvent. This event can be caught
-       and the parent window can act upon the collapsed or expanded state of the bar (which is actually just
-       the icon which changed). The parent panel can reduce size or expand again.
+    This class is a graphical caption component that consists of a caption and a clickable arrow.
+    
+    The wxCaptionBar fires an event EVT_CAPTIONBAR which is a wxCaptionBarEvent. This event can be caught
+    and the parent window can act upon the collapsed or expanded state of the bar (which is actually just
+    the icon which changed). The parent panel can reduce size or expand again.
 */
 
 #include <wx/imaglist.h>
@@ -229,137 +249,137 @@ public:
 /** Defines an empty captionbar style */
 #define wxEmptyCaptionBarStyle wxCaptionBarStyle()
 
-class wxCaptionBar: public wxWindow
+class WXDLLIMPEXP_FOLDBAR wxCaptionBar: public wxWindow
 {
 private:
-       wxString _caption;
-       wxImageList *_foldIcons;
-       wxSize _oldSize;
-       //wxFont _captionFont;
-       int _rightIndent;
-       int _iconWidth, _iconHeight;
-       //int _captionStyle;
+    wxString _caption;
+    wxImageList *_foldIcons;
+    wxSize _oldSize;
+    //wxFont _captionFont;
+    int _rightIndent;
+    int _iconWidth, _iconHeight;
+    //int _captionStyle;
 
-       //wxColour _firstColour, _secondColour, _textColour;
+    //wxColour _firstColour, _secondColour, _textColour;
 
-       /** True when the caption is in collapsed state (means at the bottom of the wxFoldPanel */
-       bool _collapsed;
+    /** True when the caption is in collapsed state (means at the bottom of the wxFoldPanel */
+    bool _collapsed;
 
-       wxCaptionBarStyle _style;
+    wxCaptionBarStyle _style;
 
-       /** Fills the background of the caption with either a gradient, or a solid color */
-       void FillCaptionBackground(wxPaintDC &dc);
+    /** Fills the background of the caption with either a gradient, or a solid color */
+    void FillCaptionBackground(wxPaintDC &dc);
 
-       /* Draw methods */
-       void DrawHorizontalGradient(wxDC &dc, const wxRect &rect );
-       void DrawVerticalGradient(wxDC &dc, const wxRect &rect );
-       void DrawSingleColour(wxDC &dc, const wxRect &rect );
-       void DrawSingleRectangle(wxDC &dc, const wxRect &rect );
+    /* Draw methods */
+    void DrawHorizontalGradient(wxDC &dc, const wxRect &rect );
+    void DrawVerticalGradient(wxDC &dc, const wxRect &rect );
+    void DrawSingleColour(wxDC &dc, const wxRect &rect );
+    void DrawSingleRectangle(wxDC &dc, const wxRect &rect );
 
-       void RedrawIconBitmap();
+    void RedrawIconBitmap();
 
-       void ApplyCaptionStyle(const wxCaptionBarStyle &cbstyle, bool applyDefault);
+    void ApplyCaptionStyle(const wxCaptionBarStyle &cbstyle, bool applyDefault);
 
 public:
     /** Constructor of wxCaptionBar. To create a wxCaptionBar with the arrow images, simply pass an image list
-           which contains at least two bitmaps. The bitmaps contain the expanded and collapsed icons needed to 
-               represent it's state. If you don't want images, simply pass a null pointer and the bitmap is disabled. */
-       wxCaptionBar(wxWindow* parent, const wxString &caption, wxImageList *images, 
-                        wxWindowID id = -1, const wxCaptionBarStyle &cbstyle = wxEmptyCaptionBarStyle,
-                                const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = wxNO_BORDER);
-
-       ~wxCaptionBar();
-
-       /** Set wxCaptionBar styles with wxCapionBarSyle class. All styles that are actually set, are applied. If you 
-           set applyDefault to true, all other (not defined) styles will be set to default. If it is false,
-               the styles which are not set in the wxCaptionBarStyle will be ignored */
-       void SetCaptionStyle(bool applyDefault, wxCaptionBarStyle style = wxEmptyCaptionBarStyle) {
-               ApplyCaptionStyle(style, applyDefault);
-               Refresh();
-       };
-       
-       /** Returns the current style of the captionbar in a wxCaptionBarStyle class. This can be used to change and set back the 
-           changes. */
-       wxCaptionBarStyle GetCaptionStyle() {
-               return _style;
-       };
+        which contains at least two bitmaps. The bitmaps contain the expanded and collapsed icons needed to 
+        represent it's state. If you don't want images, simply pass a null pointer and the bitmap is disabled. */
+    wxCaptionBar(wxWindow* parent, const wxString &caption, wxImageList *images, 
+                 wxWindowID id = wxID_ANY, const wxCaptionBarStyle &cbstyle = wxEmptyCaptionBarStyle,
+                 const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, long style = wxNO_BORDER);
+
+    ~wxCaptionBar();
+
+    /** Set wxCaptionBar styles with wxCapionBarSyle class. All styles that are actually set, are applied. If you 
+        set applyDefault to true, all other (not defined) styles will be set to default. If it is false,
+        the styles which are not set in the wxCaptionBarStyle will be ignored */
+    void SetCaptionStyle(bool applyDefault, wxCaptionBarStyle style = wxEmptyCaptionBarStyle) {
+        ApplyCaptionStyle(style, applyDefault);
+        Refresh();
+    };
+    
+    /** Returns the current style of the captionbar in a wxCaptionBarStyle class. This can be used to change and set back the 
+        changes. */
+    wxCaptionBarStyle GetCaptionStyle() {
+        return _style;
+    };
 
 #if 0
-       /** Sets a pointer to an image list resource (a non owned pointer) to the collapsed and expand icon bitmap.
-           The reason why it will be assigned a pointer is that it is very likely that multiple caption bars will 
-               be used and if they all have their own bitmap resources it will eat up more memory then needed. It will
-               also ease the use of shared icon change, when there is any need to.
-               
-               If no wxImageList is assigned, there will be no fold icons and only the doubleclick on the panel 
-               will work to collapse / expand. 
-               
-               The image list must contain 2 bitmaps. Index 0 will be the expanded state, and index 1 will be the 
-               collapsed state of the bitmap. The size of the bitmap is taken in account when the minimal height and
-               widht is calculated.
-
-               The bitmaps must be the second thing to be done before using it (SetRightIndent should be the first thing),
-               make sure if the icons are larger than the font, that the parent of this window gets a Fit call to resize
-               all the windows accordingly */
-
-       void SetFoldIcons(wxImageList *images) {
-               _foldIcons = images;
-               _iconWidth = _iconHeight = 0;
-               if(_foldIcons)
-                       _foldIcons->GetSize(0, _iconWidth, _iconHeight);
-
-               Refresh();
-       };
+    /** Sets a pointer to an image list resource (a non owned pointer) to the collapsed and expand icon bitmap.
+        The reason why it will be assigned a pointer is that it is very likely that multiple caption bars will 
+        be used and if they all have their own bitmap resources it will eat up more memory then needed. It will
+        also ease the use of shared icon change, when there is any need to.
+        
+        If no wxImageList is assigned, there will be no fold icons and only the doubleclick on the panel 
+        will work to collapse / expand. 
+        
+        The image list must contain 2 bitmaps. Index 0 will be the expanded state, and index 1 will be the 
+        collapsed state of the bitmap. The size of the bitmap is taken in account when the minimal height and
+        widht is calculated.
+
+        The bitmaps must be the second thing to be done before using it (SetRightIndent should be the first thing),
+        make sure if the icons are larger than the font, that the parent of this window gets a Fit call to resize
+        all the windows accordingly */
+
+    void SetFoldIcons(wxImageList *images) {
+        _foldIcons = images;
+        _iconWidth = _iconHeight = 0;
+        if(_foldIcons)
+            _foldIcons->GetSize(0, _iconWidth, _iconHeight);
+
+        Refresh();
+    };
 
 #endif
 
-       /** Returns wether the status of the bar is expanded or collapsed */
-       bool IsCollapsed() const {
-               return _collapsed;
-       };
+    /** Returns wether the status of the bar is expanded or collapsed */
+    bool IsCollapsed() const {
+        return _collapsed;
+    };
 
-       /** Sets the amount of pixels on the right from which the bitmap is trailing. If this is 0, it will be 
-           drawn all the way to the right, default is equal to wxFPB_BMP_RIGHTSPACE. Assign this before 
-               assigning an image list to prevent a redraw */
+    /** Sets the amount of pixels on the right from which the bitmap is trailing. If this is 0, it will be 
+        drawn all the way to the right, default is equal to wxFPB_BMP_RIGHTSPACE. Assign this before 
+        assigning an image list to prevent a redraw */
 
-       void SetRightIndent(int pixels) {
-               wxCHECK2(pixels >= 0, return);
-               _rightIndent = pixels;
-               // issue a refresh (if we have a bmp)
-               if(_foldIcons)
-                       Refresh();
-       };
+    void SetRightIndent(int pixels) {
+        wxCHECK2(pixels >= 0, return);
+        _rightIndent = pixels;
+        // issue a refresh (if we have a bmp)
+        if(_foldIcons)
+            Refresh();
+    };
 
 
-       /** Return the best size for this panel, based upon the font assigned to this window, and the 
-           caption string */
-       wxSize DoGetBestSize() const;
+    /** Return the best size for this panel, based upon the font assigned to this window, and the 
+        caption string */
+    wxSize DoGetBestSize() const;
 
-       /** This sets the internal state / representation to collapsed. This does not trigger a wxCaptionBarEvent
-           to be sent to the parent */
-       void Collapse() {
-               _collapsed = true;
-               RedrawIconBitmap();
-       };
+    /** This sets the internal state / representation to collapsed. This does not trigger a wxCaptionBarEvent
+        to be sent to the parent */
+    void Collapse() {
+        _collapsed = true;
+        RedrawIconBitmap();
+    };
 
-       /** This sets the internal state / representation to expanded. This does not trigger a wxCaptionBarEvent
-           to be sent to the parent */
-       void Expand() {
-               _collapsed = false;
-               RedrawIconBitmap();
-       };
+    /** This sets the internal state / representation to expanded. This does not trigger a wxCaptionBarEvent
+        to be sent to the parent */
+    void Expand() {
+        _collapsed = false;
+        RedrawIconBitmap();
+    };
 
-       void SetBoldFont() {
-               GetFont().SetWeight(wxBOLD);
-       };
+    void SetBoldFont() {
+        GetFont().SetWeight(wxBOLD);
+    };
 
-       void SetNormalFont() {
-               GetFont().SetWeight(wxNORMAL);
-       };
+    void SetNormalFont() {
+        GetFont().SetWeight(wxNORMAL);
+    };
 
 
 private:
     /** The paint event for flat or gradient fill */
-       void OnPaint(wxPaintEvent& event);
+    void OnPaint(wxPaintEvent& event);
         
     /** For clicking the icon, the mouse event must be intercepted */
     void OnMouseEvent(wxMouseEvent& event);
@@ -367,7 +387,7 @@ private:
     /** Maybe when focus (don't know how yet) a cursor left or backspace will collapse or expand */
     void OnChar(wxKeyEvent& event);
 
-       void OnSize(wxSizeEvent &event);
+    void OnSize(wxSizeEvent &event);
 
 
 protected:
@@ -378,74 +398,73 @@ protected:
 /***********************************************************************************************************/
 
 /** \class wxCaptionBarEvent
-       This event will be sent when a EVT_CAPTIONBAR is mapped in the parent. It is to notify the parent 
-       that the bar is now in collapsed or expanded state. The parent should re-arrange the associated
-       windows accordingly */
+    This event will be sent when a EVT_CAPTIONBAR is mapped in the parent. It is to notify the parent 
+    that the bar is now in collapsed or expanded state. The parent should re-arrange the associated
+    windows accordingly */
 
-class WXDLLEXPORT wxCaptionBarEvent : public wxCommandEvent
+class WXDLLIMPEXP_FOLDBAR wxCaptionBarEvent : public wxCommandEvent
 {
 
 private:
-       bool _collapsed;
-       wxCaptionBar *_bar;
-       void *_tag;
+    bool _collapsed;
+    wxCaptionBar *_bar;
+    void *_tag;
 
 public:
     wxCaptionBarEvent(wxEventType commandType = wxEVT_NULL, int id = 0)
         : wxCommandEvent(commandType, id)
-               , _collapsed(false)
-               , _bar(0) 
-               , _tag(0)
-       { }
+        , _collapsed(false)
+        , _bar(0) 
+        , _tag(0)
+    { }
+    
+    /** Constructor for clone copy */
+    wxCaptionBarEvent(const wxCaptionBarEvent &event);
     
-       /** Constructor for clone copy */
-       wxCaptionBarEvent(const wxCaptionBarEvent &event);
-       
-       /** Clone function */
-       virtual wxEvent *Clone() const {
-               return new wxCaptionBarEvent(*this);
-       };
-
-       /** Returns wether the bar is expanded or collapsed. True means expanded */
-       bool GetFoldStatus() const { 
-               wxCHECK(_bar, false);
-               return !_bar->IsCollapsed();
-       };
-
-       /** Returns the bar associated with this event */
-       wxCaptionBar *GetBar() const {
-               return _bar;
-       };
-
-       void SetTag(void *tag) {
-               _tag = tag;
-       };
-
-       void *GetTag() const {
-               return _tag;
-       };
-
-       /** Sets the bar associated with this event, should not used
-           by any other then the originator of the event */
-       void SetBar(wxCaptionBar *bar) {
-               _bar = bar;
-       };
-
-       DECLARE_DYNAMIC_CLASS(wxCaptionBarEvent)
+    /** Clone function */
+    virtual wxEvent *Clone() const {
+        return new wxCaptionBarEvent(*this);
+    };
+
+    /** Returns wether the bar is expanded or collapsed. True means expanded */
+    bool GetFoldStatus() const { 
+        wxCHECK(_bar, false);
+        return !_bar->IsCollapsed();
+    };
+
+    /** Returns the bar associated with this event */
+    wxCaptionBar *GetBar() const {
+        return _bar;
+    };
+
+    void SetTag(void *tag) {
+        _tag = tag;
+    };
+
+    void *GetTag() const {
+        return _tag;
+    };
+
+    /** Sets the bar associated with this event, should not used
+        by any other then the originator of the event */
+    void SetBar(wxCaptionBar *bar) {
+        _bar = bar;
+    };
+
+    DECLARE_DYNAMIC_CLASS(wxCaptionBarEvent)
 
 };
 
 BEGIN_DECLARE_EVENT_TYPES()
-    DECLARE_EVENT_TYPE(wxEVT_CAPTIONBAR, 7777)
+    DECLARE_EXPORTED_EVENT_TYPE(WXDLLIMPEXP_FOLDBAR, wxEVT_CAPTIONBAR, 7777)
 END_DECLARE_EVENT_TYPES()
 
 typedef void (wxEvtHandler::*wxCaptionBarEventFunction)(wxCaptionBarEvent&);
 
 #define EVT_CAPTIONBAR(id, fn) \
     DECLARE_EVENT_TABLE_ENTRY( \
-        wxEVT_CAPTIONBAR, id, -1, \
-        (wxObjectEventFunction)(wxEventFunction)(wxCaptionBarEventFunction) \
-        & fn, \
+        wxEVT_CAPTIONBAR, id, wxID_ANY, \
+        (wxObjectEventFunction)(wxEventFunction) wxStaticCastEvent(wxCaptionBarEventFunction, & fn), \
         (wxObject *) NULL \
     ),