Main Page   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members

FXTabBar.h

Go to the documentation of this file.
00001 /********************************************************************************
00002 *                                                                               *
00003 *                           T a b  B a r   W i d g e t                          *
00004 *                                                                               *
00005 *********************************************************************************
00006 * Copyright (C) 1997,2006 by Jeroen van der Zijp.   All Rights Reserved.        *
00007 *********************************************************************************
00008 * This library is free software; you can redistribute it and/or                 *
00009 * modify it under the terms of the GNU Lesser General Public                    *
00010 * License as published by the Free Software Foundation; either                  *
00011 * version 2.1 of the License, or (at your option) any later version.            *
00012 *                                                                               *
00013 * This library is distributed in the hope that it will be useful,               *
00014 * but WITHOUT ANY WARRANTY; without even the implied warranty of                *
00015 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU             *
00016 * Lesser General Public License for more details.                               *
00017 *                                                                               *
00018 * You should have received a copy of the GNU Lesser General Public              *
00019 * License along with this library; if not, write to the Free Software           *
00020 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA.    *
00021 *********************************************************************************
00022 * $Id: FXTabBar.h,v 1.15 2006/01/22 17:58:10 fox Exp $                          *
00023 ********************************************************************************/
00024 #ifndef FXTABBAR_H
00025 #define FXTABBAR_H
00026 
00027 #ifndef FXPACKER_H
00028 #include "FXPacker.h"
00029 #endif
00030 
00031 namespace FX {
00032 
00033 
00034 /// Tab Book options
00035 enum {
00036   TABBOOK_TOPTABS    = 0,                                   /// Tabs on top (default)
00037   TABBOOK_BOTTOMTABS = 0x00020000,                          /// Tabs on bottom
00038   TABBOOK_SIDEWAYS   = 0x00040000,                          /// Tabs on left
00039   TABBOOK_LEFTTABS   = TABBOOK_SIDEWAYS|TABBOOK_TOPTABS,    /// Tabs on left
00040   TABBOOK_RIGHTTABS  = TABBOOK_SIDEWAYS|TABBOOK_BOTTOMTABS, /// Tabs on right
00041   TABBOOK_NORMAL     = TABBOOK_TOPTABS                      /// Normal tabs
00042   };
00043 
00044 
00045 
00046 /**
00047 * The tab bar layout manager arranges tab items side by side,
00048 * and raises the active tab item above the neighboring tab items.
00049 * In a the horizontal arrangement, the tab bar can have the tab
00050 * items on the top or on the bottom.  In the vertical arrangement,
00051 * the tabs can be on the left or on the right.
00052 * When one of the tab items is pressed, the tab bar's setCurrent()
00053 * is called with notify=TRUE.  Thus causes the tab bar to send a
00054 * SEL_COMMAND message to its target.
00055 */
00056 class FXAPI FXTabBar : public FXPacker {
00057   FXDECLARE(FXTabBar)
00058 protected:
00059   FXint current;        // Current tab index
00060   FXint shift;          // Shift amount
00061 protected:
00062   FXTabBar(){}
00063 private:
00064   FXTabBar(const FXTabBar&);
00065   FXTabBar& operator=(const FXTabBar&);
00066 public:
00067   long onPaint(FXObject*,FXSelector,void*);
00068   long onFocusNext(FXObject*,FXSelector,void*);
00069   long onFocusPrev(FXObject*,FXSelector,void*);
00070   long onFocusUp(FXObject*,FXSelector,void*);
00071   long onFocusDown(FXObject*,FXSelector,void*);
00072   long onFocusLeft(FXObject*,FXSelector,void*);
00073   long onFocusRight(FXObject*,FXSelector,void*);
00074   long onCmdOpenItem(FXObject*,FXSelector,void*);
00075   long onCmdSetValue(FXObject*,FXSelector,void*);
00076   long onCmdSetIntValue(FXObject*,FXSelector,void*);
00077   long onCmdGetIntValue(FXObject*,FXSelector,void*);
00078   long onCmdOpen(FXObject*,FXSelector,void*);
00079   long onUpdOpen(FXObject*,FXSelector,void*);
00080 public:
00081   enum {
00082     ID_OPEN_ITEM=FXPacker::ID_LAST,   /// Sent from one of the FXTabItems
00083     ID_OPEN_FIRST,                    /// Switch to panel ID_OPEN_FIRST+i
00084     ID_OPEN_SECOND,
00085     ID_OPEN_THIRD,
00086     ID_OPEN_FOURTH,
00087     ID_OPEN_FIFTH,
00088     ID_OPEN_SIXTH,
00089     ID_OPEN_SEVENTH,
00090     ID_OPEN_EIGHTH,
00091     ID_OPEN_NINETH,
00092     ID_OPEN_TENTH,
00093     ID_OPEN_LAST=ID_OPEN_FIRST+100,
00094     ID_LAST
00095     };
00096 public:
00097 
00098   /// Construct a tab bar
00099   FXTabBar(FXComposite* p,FXObject* tgt=NULL,FXSelector sel=0,FXuint opts=TABBOOK_NORMAL,FXint x=0,FXint y=0,FXint w=0,FXint h=0,FXint pl=DEFAULT_SPACING,FXint pr=DEFAULT_SPACING,FXint pt=DEFAULT_SPACING,FXint pb=DEFAULT_SPACING);
00100 
00101   /// Return default width
00102   virtual FXint getDefaultWidth();
00103 
00104   /// Return default height
00105   virtual FXint getDefaultHeight();
00106 
00107   /// Perform layout
00108   virtual void layout();
00109 
00110   /**
00111   * Change currently active tab item; this raises the active tab item
00112   * slightly above the neighboring tab items.  If notify=TRUE then the
00113   * tab bar will also send a SEL_COMMAND message to its target.
00114   */
00115   virtual void setCurrent(FXint panel,FXbool notify=FALSE);
00116 
00117   /// Return the currently active tab item
00118   FXint getCurrent() const { return current; }
00119 
00120   /// Return tab bar style
00121   FXuint getTabStyle() const;
00122 
00123   /// Change tab tab style
00124   void setTabStyle(FXuint style);
00125 
00126   /// Save to stream
00127   virtual void save(FXStream& store) const;
00128 
00129   /// Load from stream
00130   virtual void load(FXStream& store);
00131   };
00132 
00133 }
00134 
00135 #endif

Copyright © 1997-2005 Jeroen van der Zijp