author | mickeyl <mickeyl> | 2003-09-27 11:29:26 (UTC) |
---|---|---|
committer | mickeyl <mickeyl> | 2003-09-27 11:29:26 (UTC) |
commit | 651b6c612db4e809c506973996f2580c4158ac3a (patch) (side-by-side diff) | |
tree | 8c8edc86e4b206dd4542a6b556ad1a319d6698ab /inputmethods/dasher/QtDasherPlugin.cc | |
parent | d1a11b45e805fe7771ea05944757d767c3c4c8ea (diff) | |
download | opie-651b6c612db4e809c506973996f2580c4158ac3a.zip opie-651b6c612db4e809c506973996f2580c4158ac3a.tar.gz opie-651b6c612db4e809c506973996f2580c4158ac3a.tar.bz2 |
merge dasher which has been introduced in BRANCH first (wtf?) into HEAD
Diffstat (limited to 'inputmethods/dasher/QtDasherPlugin.cc') (more/less context) (ignore whitespace changes)
-rw-r--r-- | inputmethods/dasher/QtDasherPlugin.cc | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/inputmethods/dasher/QtDasherPlugin.cc b/inputmethods/dasher/QtDasherPlugin.cc new file mode 100644 index 0000000..fe1712e --- a/dev/null +++ b/inputmethods/dasher/QtDasherPlugin.cc @@ -0,0 +1,79 @@ +#include "QtDasherPlugin.h" + +#include <qpe/global.h> + +#include <qpainter.h> +#include <qlist.h> +#include <qbitmap.h> +#include <qlayout.h> +#include <qvbox.h> +#include <qdialog.h> +#include <qscrollview.h> +#include <qpopupmenu.h> +#include <qhbuttongroup.h> +#include <qpushbutton.h> +#include <qmessagebox.h> +#include <qwindowsystem_qws.h> + +QtDasherPlugin::QtDasherPlugin(QWidget* parent, const char* name, WFlags f) : QFrame(parent,name,f) +{ + (new QHBoxLayout(this))->setAutoAdd(TRUE); + interface = new CDasherInterface; + interface->SetSystemLocation("/opt/QtPalmtop/share/dasher"); + interface->Unpause(0); + interface->Start(); + d = new QtDasherScreen(240,100,interface,this,this); + interface->ChangeMaxBitRate(2.5); + d->show(); + utf8_codec = new QUtf8Codec; +} + +QSize QtDasherPlugin::sizeHint() const +{ + return QSize(240,100); +} + +QtDasherPlugin::~QtDasherPlugin() +{ + delete d; +} + +void QtDasherPlugin::resetState() +{ + flushcount=0; + interface->Start(); + interface->Redraw(); +} + +void QtDasherPlugin::unflush() +{ + if (flushcount==0) + return; + for (flushcount; flushcount>0; flushcount--) { + deletetext(); + } +} + +void QtDasherPlugin::output(int Symbol) +{ + std::string label = interface->GetEditText(Symbol); + QString unicodestring = utf8_codec->toUnicode(label.c_str()); + for (int i=0; i<int(unicodestring.length()); i++) { + emit key( unicodestring[i].unicode(), 0, 0, true, false ); + emit key( unicodestring[i].unicode(), 0, 0, false, false ); + } +} + +void QtDasherPlugin::deletetext() +{ + emit key( 0, Qt::Key_Backspace, 0, true, false); + emit key( 0, Qt::Key_Backspace, 0, false, false); +} + +void QtDasherPlugin::flush(int Symbol) +{ + if (Symbol==0) + return; + output(Symbol); + flushcount++; +} |