author | zecke <zecke> | 2003-09-07 12:47:42 (UTC) |
---|---|---|
committer | zecke <zecke> | 2003-09-07 12:47:42 (UTC) |
commit | dbea3ba9d8315f94d102af7e4a7244b1fb507f85 (patch) (side-by-side diff) | |
tree | 2c1fe2aa303b6a900f2fffe7a18f91a949fc2d99 | |
parent | e06de75edc6c01d97248050030f197bd8f21fb10 (diff) | |
download | opie-dbea3ba9d8315f94d102af7e4a7244b1fb507f85.zip opie-dbea3ba9d8315f94d102af7e4a7244b1fb507f85.tar.gz opie-dbea3ba9d8315f94d102af7e4a7244b1fb507f85.tar.bz2 |
Add thoughts and interface about dynamic ToolBar/MenuBar generation
and a modal helper template class
-rw-r--r-- | libopie/big-screen/obarcollection.h | 107 | ||||
-rw-r--r-- | libopie/big-screen/omodalhelper.h | 72 |
2 files changed, 179 insertions, 0 deletions
diff --git a/libopie/big-screen/obarcollection.h b/libopie/big-screen/obarcollection.h new file mode 100644 index 0000000..5822360 --- a/dev/null +++ b/libopie/big-screen/obarcollection.h @@ -0,0 +1,107 @@ +/* + =. This file is part of the OPIE Project + .=l. Copyright (c) 2003 hOlgAr <zecke@handhelds.org> + .>+-= + _;:, .> :=|. This library is free software; you can +.> <`_, > . <= redistribute it and/or modify it under +:`=1 )Y*s>-.-- : the terms of the GNU Library General Public +.="- .-=="i, .._ License as published by the Free Software + - . .-<_> .<> Foundation; either version 2 of the License, + ._= =} : or (at your option) any later version. + .%`+i> _;_. + .i_,=:_. -<s. 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 +..}^=.= = ; Library General Public License for more +++= -. .` .: details. + : = ...= . :.=- + -. .:....=;==+<; You should have received a copy of the GNU + -_. . . )=. = Library General Public License along with + -- :-=` this library; see the file COPYING.LIB. + If not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. + +*/ + +#ifndef HAZE_OBAR_EXTENSION +#define HAZE_OBAR_EXTENSION + +#include <qstring.h> +#include <qwidget.h> + +class QAction; +class QPopupMenu; + +/* + * ### TODO + * -Consider Life Updates + * -Make ValueBased like Opie-featurelist + */ + +/** + * The different screen sizes have different look and feel. On bigger + * screens only a QToolBar feels strange. One is at least known to have + * a Help-Menu, a File Menu with Quit/Exit but instead of providing two + * different ways / two action sets we will group actions to gether and give + * them attributes when and where we might want them to be visible. + * We can also group actions. For example you could Group All Actions + * into the File Group. This means with many actions you would only have more toolbar + * actions but many sub menus in File. On bigger screen this would automatically + * expand to a full blown MenuBar and ToolButtons. + * + * @short Grouping of actions for dynamic Bar Generation + * @version 0.01 + * @author hOlgAr + */ +class OBarGroup { +public: + enum Preference { Allways, Never, IfPlace }; + OBarGroup( const QString& name, enum Preference groupPreference ); + ~OBarGroup(); + + void add( QAction* action, enum Preference menuPreference, + enum Preference toolpreference ); + void add( const QString&, QPopupMenu* ); + + void add( OBarGroup* ); + + void remove( QAction* action ); + void remove( QMap* ); + +protected: + OBarGroup* parent()const; + +private: +}; + + +/** + * Add your groups in order to the bar manager + * and either call createGUI() on it, or tell it + * it the mainwindow and it is listening to the show event + * and then creates the toolbar + */ +class OBarManager : public QObject{ +public: + OBarManager( QWindow* parent ); + ~OBarManager(); + + void add( OBarGroup*, int pos = -1 ); + void remove( OBarGroup* ); + + bool eventFilter( QObject* , QEvent* ); + +public slots: + void createGUI(); +}; + +/* + * ### TODO GUI merging + */ + +#endif + + diff --git a/libopie/big-screen/omodalhelper.h b/libopie/big-screen/omodalhelper.h new file mode 100644 index 0000000..643458f --- a/dev/null +++ b/libopie/big-screen/omodalhelper.h @@ -0,0 +1,72 @@ +/* + =. This file is part of the OPIE Project + .=l. Copyright (c) 2003 hOlgAr <zecke@handhelds.org> + .>+-= + _;:, .> :=|. This library is free software; you can +.> <`_, > . <= redistribute it and/or modify it under +:`=1 )Y*s>-.-- : the terms of the GNU Library General Public +.="- .-=="i, .._ License as published by the Free Software + - . .-<_> .<> Foundation; either version 2 of the License, + ._= =} : or (at your option) any later version. + .%`+i> _;_. + .i_,=:_. -<s. 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 +..}^=.= = ; Library General Public License for more +++= -. .` .: details. + : = ...= . :.=- + -. .:....=;==+<; You should have received a copy of the GNU + -_. . . )=. = Library General Public License along with + -- :-=` this library; see the file COPYING.LIB. + If not, write to the Free Software Foundation, + Inc., 59 Temple Place - Suite 330, + Boston, MA 02111-1307, USA. + +*/ + +#ifndef HAZE_OMODAL_HELPER_H +#define HAZE_OMODAL_HELPER_H + +#include <qwidget.h> + +class OModalHelperSignal : public QObject { + Q_OBJECT +public: + OModalHelperSignal(); + +signals: + done( int status, int transaction ); + accpeted( int transaction ); + rejected( int transaction ); +}; + +/** + * Modality sucks! ;) But it is easy to work with + * do exec() on a dialog and you know everything is funky. + * You only need to have one Dialog loaded and so on. + * This class helps you to work like with modality and help + * you to keep things in sync + * It's a template class but it sends signals once one Item is ready + * the signals contains the status and id of the item and then you + * can fetch it. + * Also if you edit an record external you can tell this class and it'll + * call the merge() function of your widget to maybe merge in these changes. + * It also supports multiple modes. Either it can create new dialogs + * for each item or it can queue them depending on your usage. But it is + * so smart that if only one item is shown that the queue bar is not shown + * See the example for simple usage. + * + * @short helps to live without modaility + * @author hOlgAr + * @version 0.01 + */ +template<class Dialog, class Record> +class OModalHelper{ +public: + OModalHelper(QObject* parnet ); + +}; + +#endif |