summaryrefslogtreecommitdiff
authordrw <drw>2002-08-11 22:12:54 (UTC)
committer drw <drw>2002-08-11 22:12:54 (UTC)
commit496ba37b34ef5847865e0e387443d7481b1487f0 (patch) (unidiff)
tree60ec019d7d4539818743b6babd71300e22b1cbeb
parente7af03e8257119824b53a63f581366b6e25f4ae5 (diff)
downloadopie-496ba37b34ef5847865e0e387443d7481b1487f0.zip
opie-496ba37b34ef5847865e0e387443d7481b1487f0.tar.gz
opie-496ba37b34ef5847865e0e387443d7481b1487f0.tar.bz2
OTabWidget updates
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/settings/sysinfo/otabwidget.cpp78
-rw-r--r--noncore/settings/sysinfo/otabwidget.h13
2 files changed, 61 insertions, 30 deletions
diff --git a/noncore/settings/sysinfo/otabwidget.cpp b/noncore/settings/sysinfo/otabwidget.cpp
index 5154196..9fe6c4b 100644
--- a/noncore/settings/sysinfo/otabwidget.cpp
+++ b/noncore/settings/sysinfo/otabwidget.cpp
@@ -24,5 +24,4 @@
24 24
25#include <qcombobox.h> 25#include <qcombobox.h>
26#include <qlist.h>
27#include <qtabbar.h> 26#include <qtabbar.h>
28#include <qwidgetstack.h> 27#include <qwidgetstack.h>
@@ -84,4 +83,6 @@ OTabWidget::OTabWidget( QWidget *parent, const char *name = 0x0,
84 tabBar->setShape( QTabBar::RoundedBelow ); 83 tabBar->setShape( QTabBar::RoundedBelow );
85 } 84 }
85
86 currentTab= 0x0;
86} 87}
87 88
@@ -109,8 +110,6 @@ void OTabWidget::addTab( QWidget *child, const QString &icon, const QString &lab
109 } 110 }
110 int tabid = tabBar->addTab( tab ); 111 int tabid = tabBar->addTab( tab );
111 tabBar->setCurrentTab( tab );
112 112
113 // Add to tabList 113 // Add to tabList
114
115 if ( tabBarStyle == IconTab || tabBarStyle == IconList ) 114 if ( tabBarStyle == IconTab || tabBarStyle == IconList )
116 { 115 {
@@ -121,5 +120,4 @@ void OTabWidget::addTab( QWidget *child, const QString &icon, const QString &lab
121 tabList->insertItem( label ); 120 tabList->insertItem( label );
122 } 121 }
123 tabList->setCurrentItem( tabList->count()-1 );
124 122
125 // Add child to widget list 123 // Add child to widget list
@@ -128,7 +126,35 @@ void OTabWidget::addTab( QWidget *child, const QString &icon, const QString &lab
128 126
129 // Save tab information 127 // Save tab information
130 tabs.append( TabInfo( tabid, child, icon, label ) ); 128 TabInfo *tabinfo = new TabInfo( tabid, child, icon, label );
129 tabs.append( tabinfo );
130 selectTab( tabinfo );
131
132// setUpLayout();
133}
131 134
132 setUpLayout( FALSE ); 135void OTabWidget::setCurrentTab( QWidget *childwidget )
136{
137 TabInfo *newtab = tabs.first();
138 while ( newtab && newtab->control() != childwidget )
139 {
140 newtab = tabs.next();
141 }
142 if ( newtab && newtab->control() == childwidget )
143 {
144 selectTab( newtab );
145 }
146}
147
148void OTabWidget::setCurrentTab( QString tabname )
149{
150 TabInfo *newtab = tabs.first();
151 while ( newtab && newtab->label() != tabname )
152 {
153 newtab = tabs.next();
154 }
155 if ( newtab && newtab->label() == tabname )
156 {
157 selectTab( newtab );
158 }
133} 159}
134 160
@@ -155,9 +181,10 @@ void OTabWidget::setTabPosition( TabPosition p )
155void OTabWidget::slotTabBarSelected( int id ) 181void OTabWidget::slotTabBarSelected( int id )
156{ 182{
157 183 TabInfo *newtab = tabs.first();
158 TabInfoList::Iterator newtab = tabs.begin(); 184 while ( newtab && newtab->id() != id )
159 while ( newtab != tabs.end() && (*newtab).id() != id ) 185 {
160 newtab++; 186 newtab = tabs.next();
161 if ( (*newtab).id() == id ) 187 }
188 if ( newtab && newtab->id() == id )
162 { 189 {
163 selectTab( newtab ); 190 selectTab( newtab );
@@ -167,6 +194,6 @@ void OTabWidget::slotTabBarSelected( int id )
167void OTabWidget::slotTabListSelected( int index ) 194void OTabWidget::slotTabListSelected( int index )
168{ 195{
169 TabInfoList::Iterator newtab = tabs.at( index ); 196 TabInfo *newtab = tabs.at( index );
170 if ( newtab != tabs.end() ) 197 if ( newtab )
171 { 198 {
172 selectTab( newtab ); 199 selectTab( newtab );
@@ -182,25 +209,26 @@ QPixmap OTabWidget::loadSmooth( const QString &name )
182} 209}
183 210
184void OTabWidget::selectTab( TabInfoList::Iterator tab ) 211void OTabWidget::selectTab( TabInfo *tab )
185{ 212{
186 if ( tabBarStyle == IconTab ) 213 if ( tabBarStyle == IconTab )
187 { 214 {
188 if ( currentTab != 0x0 ) 215 if ( currentTab )
189 { 216 {
190 tabBar->tab( (*currentTab).id() )->label = QString::null; 217 tabBar->tab( currentTab->id() )->setText( QString::null );
218 setUpLayout();
191 } 219 }
192 tabBar->tab( (*tab).id() )->label = (*tab).label(); 220 tabBar->tab( tab->id() )->setText( tab->label() );
193 currentTab = tab; 221 currentTab = tab;
194 } 222 }
195 tabBar->layoutTabs(); 223 tabBar->setCurrentTab( tab->id() );
224 setUpLayout();
196 tabBar->update(); 225 tabBar->update();
197 226
198 widgetStack->raiseWidget( (*tab).control() ); 227 widgetStack->raiseWidget( tab->control() );
199
200 setUpLayout( FALSE );
201} 228}
202 229
203void OTabWidget::setUpLayout( bool onlyCheck ) 230void OTabWidget::setUpLayout()
204{ 231{
232 tabBar->layoutTabs();
205 QSize t( tabBarStack->sizeHint() ); 233 QSize t( tabBarStack->sizeHint() );
206 if ( t.width() > width() ) 234 if ( t.width() > width() )
@@ -218,6 +246,6 @@ void OTabWidget::setUpLayout( bool onlyCheck )
218 } 246 }
219 247
220 if ( !onlyCheck ) 248// if ( !onlyCheck )
221 update(); 249// update();
222 if ( autoMask() ) 250 if ( autoMask() )
223 updateMask(); 251 updateMask();
@@ -233,4 +261,4 @@ QSize OTabWidget::sizeHint() const
233void OTabWidget::resizeEvent( QResizeEvent * ) 261void OTabWidget::resizeEvent( QResizeEvent * )
234{ 262{
235 setUpLayout( FALSE ); 263 setUpLayout();
236} 264}
diff --git a/noncore/settings/sysinfo/otabwidget.h b/noncore/settings/sysinfo/otabwidget.h
index 38f4d20..7450d51 100644
--- a/noncore/settings/sysinfo/otabwidget.h
+++ b/noncore/settings/sysinfo/otabwidget.h
@@ -22,4 +22,5 @@
22 22
23#include <qwidget.h> 23#include <qwidget.h>
24#include <qlist.h>
24 25
25class QComboBox; 26class QComboBox;
@@ -46,5 +47,5 @@ private:
46}; 47};
47 48
48typedef QValueList<TabInfo> TabInfoList; 49typedef QList<TabInfo> TabInfoList;
49 50
50class OTabWidget : public QWidget 51class OTabWidget : public QWidget
@@ -64,4 +65,6 @@ public:
64 65
65 void addTab( QWidget *, const QString &, const QString & ); 66 void addTab( QWidget *, const QString &, const QString & );
67 void setCurrentTab( QWidget * );
68 void setCurrentTab( QString );
66 QSize sizeHint() const; 69 QSize sizeHint() const;
67 70
@@ -71,6 +74,6 @@ protected:
71 74
72private: 75private:
73 TabInfoList tabs; 76 TabInfoList tabs;
74 TabInfoList::Iterator currentTab; 77 TabInfo *currentTab;
75 78
76 TabStyle tabBarStyle; 79 TabStyle tabBarStyle;
@@ -84,6 +87,6 @@ private:
84 87
85 QPixmap loadSmooth( const QString & ); 88 QPixmap loadSmooth( const QString & );
86 void selectTab( TabInfoList::Iterator ); 89 void selectTab( TabInfo * );
87 void setUpLayout( bool ); 90 void setUpLayout();
88 91
89private slots: 92private slots: