author | llornkcor <llornkcor> | 2003-02-23 03:35:32 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2003-02-23 03:35:32 (UTC) |
commit | 98ed23c5281a57d08c6c18b464fc50b4638385f8 (patch) (side-by-side diff) | |
tree | 79e3ad38c6e96ce3d0bbabb00e601a45f41d7210 /library | |
parent | 47fc358e914aecd13c4cb3d9cb4b3f2ca1a93b6c (diff) | |
download | opie-98ed23c5281a57d08c6c18b464fc50b4638385f8.zip opie-98ed23c5281a57d08c6c18b464fc50b4638385f8.tar.gz opie-98ed23c5281a57d08c6c18b464fc50b4638385f8.tar.bz2 |
added a couple public methods- remove(int) count() text(int) and setUseLabel. see header for notes
-rw-r--r-- | library/menubutton.cpp | 71 | ||||
-rw-r--r-- | library/menubutton.h | 6 |
2 files changed, 60 insertions, 17 deletions
diff --git a/library/menubutton.cpp b/library/menubutton.cpp index 007761f..4357460 100644 --- a/library/menubutton.cpp +++ b/library/menubutton.cpp @@ -67,6 +67,7 @@ MenuButton::MenuButton( const QStringList& items, QWidget* parent, const char* name) : QPushButton(parent,name) { + useLabel = true; init(); insertItems(items); } @@ -98,8 +99,8 @@ void MenuButton::init() */ void MenuButton::clear() { - delete pop; - init(); + delete pop; + init(); } /*! @@ -111,10 +112,10 @@ void MenuButton::insertItems( const QStringList& items ) { QStringList::ConstIterator it=items.begin(); for (; it!=items.end(); ++it) { - if ( (*it) == "--" ) - insertSeparator(); - else - insertItem(*it); + if ( (*it) == "--" ) + insertSeparator(); + else + insertItem(*it); } } @@ -127,7 +128,7 @@ void MenuButton::insertItems( const QStringList& items ) void MenuButton::insertItem( const QIconSet& icon, const QString& text ) { pop->insertItem(icon, text, nitems++); - if ( nitems==1 ) select(0); +// if ( nitems==1 ) select(0); } /*! @@ -139,7 +140,7 @@ void MenuButton::insertItem( const QIconSet& icon, const QString& text ) void MenuButton::insertItem( const QString& text ) { pop->insertItem(text, nitems++); - if ( nitems==1 ) select(0); +// if ( nitems==1 ) select(0); } /*! @@ -158,10 +159,10 @@ void MenuButton::insertSeparator() void MenuButton::select(const QString& s) { for (int i=0; i<nitems; i++) { - if ( pop->text(i) == s ) { - select(i); - break; - } + if ( pop->text(i) == s ) { + select(i); + break; + } } } @@ -174,7 +175,7 @@ void MenuButton::select(int s) cur = s; updateLabel(); if ( pop->iconSet(cur) ) - setIconSet(*pop->iconSet(cur)); + setIconSet(*pop->iconSet(cur)); emit selected(cur); emit selected(currentText()); } @@ -208,9 +209,45 @@ void MenuButton::setLabel(const QString& label) void MenuButton::updateLabel() { - QString t = pop->text(cur); - if ( !lab.isEmpty() ) - t = lab.arg(t); - setText(t); + if(useLabel) + { + QString t = pop->text(cur); + if ( !lab.isEmpty() ) + t = lab.arg(t); + setText(t); + } } + +/*! + remove item at id + */ +void MenuButton::remove(int id) +{ + pop->removeItem(id); + nitems--; +} + +/*! + return count of items in menu + */ +int MenuButton::count() +{ + return nitems; +} + +/*! + returns text of item id + */ +QString MenuButton::text(int id) +{ + return pop->text(id); +} + +/*! + sets true or false the use of label + */ +void MenuButton::setUseLabel(bool b) +{ + useLabel = b; +} diff --git a/library/menubutton.h b/library/menubutton.h index 6582b1e..ee5dcf1 100644 --- a/library/menubutton.h +++ b/library/menubutton.h @@ -31,6 +31,7 @@ public: void clear(); + int currentItem() const; QString currentText() const; @@ -40,6 +41,10 @@ public: void insertSeparator(); void setLabel(const QString& label); + int count(); + void remove(int id); + QString text(int id); + void setUseLabel(bool b); signals: void selected(int); @@ -50,6 +55,7 @@ public slots: void select(const QString&); private: + bool useLabel; void init(); QStringList txts; QPopupMenu* pop; |