author | mickeyl <mickeyl> | 2005-01-29 14:18:51 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2005-01-29 14:18:51 (UTC) |
commit | 555b999359a5aad999eaaf48632ce85f25125b85 (patch) (side-by-side diff) | |
tree | 7414362241e49e06f49486e93a8f504113961b1c /examples/opiecore/onotifydemo | |
parent | 7b06e36fe27adc6a4fde2004eac13aaf8c0f0f02 (diff) | |
download | opie-555b999359a5aad999eaaf48632ce85f25125b85.zip opie-555b999359a5aad999eaaf48632ce85f25125b85.tar.gz opie-555b999359a5aad999eaaf48632ce85f25125b85.tar.bz2 |
examples appear here
Diffstat (limited to 'examples/opiecore/onotifydemo') (more/less context) (ignore whitespace changes)
-rw-r--r-- | examples/opiecore/onotifydemo/.cvsignore | 6 | ||||
-rw-r--r-- | examples/opiecore/onotifydemo/onotifydemo.cpp | 144 | ||||
-rw-r--r-- | examples/opiecore/onotifydemo/onotifydemo.pro | 18 |
3 files changed, 168 insertions, 0 deletions
diff --git a/examples/opiecore/onotifydemo/.cvsignore b/examples/opiecore/onotifydemo/.cvsignore new file mode 100644 index 0000000..8f7300c --- a/dev/null +++ b/examples/opiecore/onotifydemo/.cvsignore @@ -0,0 +1,6 @@ +Makefile* +moc* +*moc +*.o +~* + diff --git a/examples/opiecore/onotifydemo/onotifydemo.cpp b/examples/opiecore/onotifydemo/onotifydemo.cpp new file mode 100644 index 0000000..b9ff9db --- a/dev/null +++ b/examples/opiecore/onotifydemo/onotifydemo.cpp @@ -0,0 +1,144 @@ +/* OPIE */ +#include <opie2/odebug.h> +#include <opie2/oapplication.h> +#include <opie2/ofiledialog.h> +#include <opie2/olistview.h> +#include <opie2/ofilenotify.h> +using namespace Opie::Core; +using namespace Opie::Ui; + +/* QT */ +#include <qcheckbox.h> +#include <qvbox.h> +#include <qhbox.h> +#include <qhbuttongroup.h> +#include <qvbuttongroup.h> +#include <qmessagebox.h> +#include <qpushbutton.h> + +class DemoApp : public OApplication +{ + Q_OBJECT +public: + DemoApp( int argc, char** argv ) : OApplication( argc, argv, "libopie2 notify demo" ) + { + + QVBox* vbox = new QVBox(); + setMainWidget( vbox ); + + l = new OListView( vbox ); + l->addColumn( "Notification Path" ); + l->addColumn( "Trigger Type" ); + l->addColumn( "Trigger Mask" ); + l->setColumnAlignment( 1, AlignCenter ); + l->setColumnAlignment( 2, AlignCenter ); + + QHBox* hbox = new QHBox( vbox ); + + g2 = new QVButtonGroup( "Specify Trigger Type", hbox ); + //QCheckBox* c1 = new QCheckBox( "Multi", g2 ); + QCheckBox* c2 = new QCheckBox( "Access", g2 ); + QCheckBox* c3 = new QCheckBox( "Modify", g2 ); + QCheckBox* c4 = new QCheckBox( "Create", g2 ); + QCheckBox* c5 = new QCheckBox( "Delete", g2 ); + QCheckBox* c6 = new QCheckBox( "Rename", g2 ); + QCheckBox* c7 = new QCheckBox( "Attrib", g2 ); + g2->insert( c2, Access ); + g2->insert( c3, Modify ); + g2->insert( c4, Create ); + g2->insert( c5, Delete ); + g2->insert( c6, Rename ); + g2->insert( c7, Attrib ); + connect( g2, SIGNAL( pressed(int) ), this, SLOT( modifierClicked(int) ) ); + + g1 = new QVButtonGroup( "Add/Remove", hbox ); + QPushButton* plus1 = new QPushButton( "Add\n&Single", g1 ); + QPushButton* plus2 = new QPushButton( "Add\n&Multi", g1 ); + QPushButton* minus = new QPushButton( "&Remove\nIt!", g1 ); + g1->insert( plus1, 0 ); + g1->insert( plus2, 1 ); + g1->insert( minus, 2 ); + connect( plus1, SIGNAL( clicked() ), this, SLOT( addSingle() ) ); + connect( plus2, SIGNAL( clicked() ), this, SLOT( addMulti() ) ); + connect( minus, SIGNAL( clicked() ), this, SLOT( delTrigger() ) ); + + g1->show(); + g2->show(); + l->show(); + hbox->show(); + vbox->show(); + showMainWidget( vbox ); + } + +public: + void addTrigger( bool multi = false ) + { + if ( !m ) + { + QMessageBox::warning( 0, "Add Trigger", "<p>Can't add trigger without at least one selected trigger type</p>", "&Sorry", 0 ); + return; + } + + QString filename = OFileDialog::getOpenFileName( OFileSelector::ExtendedAll ); + if ( !filename.isEmpty() ) + { + odebug << "Filename = " << filename << oendl; + + int fntype = m; + if ( multi ) fntype |=(int) Multi; + + QString modifier = QString().sprintf( " = 0x%08x", fntype ); + new OListViewItem( l, filename, multi ? "MULTI" : "SINGLE", modifier ); + if ( !multi ) + OFileNotification::singleShot( filename, this, SLOT( trigger() ), (OFileNotificationType) fntype ); + else + OFileNotification::singleShot( filename, this, SLOT( trigger() ), (OFileNotificationType) fntype ); + } + else + { + odebug << "cancelled." << oendl; + } + } + +public slots: + void modifierClicked( int modifier ) { m = static_cast<OFileNotificationType>( (int)m ^ int(modifier) ); }; + void addSingle() { addTrigger(); }; + void addMulti() { addTrigger( true ); }; + + void delTrigger() + { + QListViewItem* item = l->selectedItem(); + if ( !item ) + { + QMessageBox::warning( 0, "Del Trigger", "<p>No trigger selected!</p>", "&Sorry", 0 ); + return; + } + else + { + QString filename( item->text( 0 ) ); + odebug << "Filename = " << filename << oendl; + } + } + + void trigger() + { + owarn << "FIRE!" << oendl; + } + +private: + OListView* l; + QButtonGroup* g1; + QButtonGroup* g2; + OFileNotificationType m; +}; + +int main( int argc, char** argv ) +{ + DemoApp* app = new DemoApp( argc, argv ); + app->exec(); + + return 0; + +} + +#include "moc/onotifydemo.moc" diff --git a/examples/opiecore/onotifydemo/onotifydemo.pro b/examples/opiecore/onotifydemo/onotifydemo.pro new file mode 100644 index 0000000..d2c9138 --- a/dev/null +++ b/examples/opiecore/onotifydemo/onotifydemo.pro @@ -0,0 +1,18 @@ +TEMPLATE = app +CONFIG = qt warn_on +HEADERS = +SOURCES = onotifydemo.cpp +INCLUDEPATH += $(OPIEDIR)/include +DEPENDPATH += $(OPIEDIR)/include +LIBS += -lopiecore2 -lopieui2 +TARGET = onotifydemo + +!contains( platform, x11 ) { + include( $(OPIEDIR)/include.pro ) +} + +contains( platform, x11 ) { + LIBS += -L$(OPIEDIR)/lib -Wl,-rpath,$(OPIEDIR)/lib +} + +MOC_DIR = moc |