/usr/include/fox-1.6/FXTabBar.h is in libfox-1.6-dev 1.6.50-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | /********************************************************************************
* *
* T a b B a r W i d g e t *
* *
*********************************************************************************
* Copyright (C) 1997,2006 by Jeroen van der Zijp. All Rights Reserved. *
*********************************************************************************
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Lesser General Public *
* License as published by the Free Software Foundation; either *
* version 2.1 of the License, or (at your option) any later version. *
* *
* This library is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
* Lesser General Public License for more details. *
* *
* You should have received a copy of the GNU Lesser General Public *
* License along with this library; if not, write to the Free Software *
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. *
*********************************************************************************
* $Id: FXTabBar.h,v 1.15 2006/01/22 17:58:10 fox Exp $ *
********************************************************************************/
#ifndef FXTABBAR_H
#define FXTABBAR_H
#ifndef FXPACKER_H
#include "FXPacker.h"
#endif
namespace FX {
/// Tab Book options
enum {
TABBOOK_TOPTABS = 0, /// Tabs on top (default)
TABBOOK_BOTTOMTABS = 0x00020000, /// Tabs on bottom
TABBOOK_SIDEWAYS = 0x00040000, /// Tabs on left
TABBOOK_LEFTTABS = TABBOOK_SIDEWAYS|TABBOOK_TOPTABS, /// Tabs on left
TABBOOK_RIGHTTABS = TABBOOK_SIDEWAYS|TABBOOK_BOTTOMTABS, /// Tabs on right
TABBOOK_NORMAL = TABBOOK_TOPTABS /// Normal tabs
};
/**
* The tab bar layout manager arranges tab items side by side,
* and raises the active tab item above the neighboring tab items.
* In a the horizontal arrangement, the tab bar can have the tab
* items on the top or on the bottom. In the vertical arrangement,
* the tabs can be on the left or on the right.
* When one of the tab items is pressed, the tab bar's setCurrent()
* is called with notify=TRUE. Thus causes the tab bar to send a
* SEL_COMMAND message to its target.
*/
class FXAPI FXTabBar : public FXPacker {
FXDECLARE(FXTabBar)
protected:
FXint current; // Current tab index
FXint shift; // Shift amount
protected:
FXTabBar(){}
private:
FXTabBar(const FXTabBar&);
FXTabBar& operator=(const FXTabBar&);
public:
long onPaint(FXObject*,FXSelector,void*);
long onFocusNext(FXObject*,FXSelector,void*);
long onFocusPrev(FXObject*,FXSelector,void*);
long onFocusUp(FXObject*,FXSelector,void*);
long onFocusDown(FXObject*,FXSelector,void*);
long onFocusLeft(FXObject*,FXSelector,void*);
long onFocusRight(FXObject*,FXSelector,void*);
long onCmdOpenItem(FXObject*,FXSelector,void*);
long onCmdSetValue(FXObject*,FXSelector,void*);
long onCmdSetIntValue(FXObject*,FXSelector,void*);
long onCmdGetIntValue(FXObject*,FXSelector,void*);
long onCmdOpen(FXObject*,FXSelector,void*);
long onUpdOpen(FXObject*,FXSelector,void*);
public:
enum {
ID_OPEN_ITEM=FXPacker::ID_LAST, /// Sent from one of the FXTabItems
ID_OPEN_FIRST, /// Switch to panel ID_OPEN_FIRST+i
ID_OPEN_SECOND,
ID_OPEN_THIRD,
ID_OPEN_FOURTH,
ID_OPEN_FIFTH,
ID_OPEN_SIXTH,
ID_OPEN_SEVENTH,
ID_OPEN_EIGHTH,
ID_OPEN_NINETH,
ID_OPEN_TENTH,
ID_OPEN_LAST=ID_OPEN_FIRST+100,
ID_LAST
};
public:
/// Construct a tab bar
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);
/// Return default width
virtual FXint getDefaultWidth();
/// Return default height
virtual FXint getDefaultHeight();
/// Perform layout
virtual void layout();
/**
* Change currently active tab item; this raises the active tab item
* slightly above the neighboring tab items. If notify=TRUE then the
* tab bar will also send a SEL_COMMAND message to its target.
*/
virtual void setCurrent(FXint panel,FXbool notify=FALSE);
/// Return the currently active tab item
FXint getCurrent() const { return current; }
/// Return tab bar style
FXuint getTabStyle() const;
/// Change tab tab style
void setTabStyle(FXuint style);
/// Save to stream
virtual void save(FXStream& store) const;
/// Load from stream
virtual void load(FXStream& store);
};
}
#endif
|