author | zecke <zecke> | 2004-10-15 02:30:08 (UTC) |
---|---|---|
committer | zecke <zecke> | 2004-10-15 02:30:08 (UTC) |
commit | 5c3759f02725c17ba0efc386193a83da55a9a5da (patch) (side-by-side diff) | |
tree | b03e604b282de315096b74b6f404851c2bba3ad6 | |
parent | fefeafe35f8dac30f4baab9e3bff8e2ffbd1afd0 (diff) | |
download | opie-5c3759f02725c17ba0efc386193a83da55a9a5da.zip opie-5c3759f02725c17ba0efc386193a83da55a9a5da.tar.gz opie-5c3759f02725c17ba0efc386193a83da55a9a5da.tar.bz2 |
Apply patch from Qtopia1.7 to allow 'Umlaute' in the pickboard
and make 'strings' translatable.
This also fixes #501
-rw-r--r-- | inputmethods/pickboard/pickboard.cpp | 25 | ||||
-rw-r--r-- | inputmethods/pickboard/pickboardcfg.cpp | 69 | ||||
-rw-r--r-- | inputmethods/pickboard/pickboardcfg.h | 19 | ||||
-rw-r--r-- | inputmethods/pickboard/pickboardimpl.cpp | 6 | ||||
-rw-r--r-- | inputmethods/pickboard/pickboardpicks.cpp | 31 |
5 files changed, 91 insertions, 59 deletions
diff --git a/inputmethods/pickboard/pickboard.cpp b/inputmethods/pickboard/pickboard.cpp index 087144e..1611cb0 100644 --- a/inputmethods/pickboard/pickboard.cpp +++ b/inputmethods/pickboard/pickboard.cpp @@ -1,89 +1,110 @@ /********************************************************************** -** Copyright (C) 2000 Trolltech AS. All rights reserved. +** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. ** -** This file is part of Qtopia Environment. +** This file is part of the Qtopia Environment. ** ** This file may be distributed and/or modified under the terms of the ** GNU General Public License version 2 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. ** ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. ** ** See http://www.trolltech.com/gpl/ for GPL licensing information. ** ** Contact info@trolltech.com if any conditions of this licensing are ** not clear to you. ** **********************************************************************/ #include "pickboard.h" #include "pickboardpicks.h" #include "pickboardcfg.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> +#ifdef QWS #include <qwindowsystem_qws.h> +#endif + +/*! \class Pickboard + \brief The Pickboard class provides an input method + based on a virtual keyboard combined with word-completion. + + This version of Pickboard is Dual Licensed Software. However, for you to be + able to license the technology to others, you may require a T9(R) Text + Input license from Tegic Communications Corporation. More information can + be found at http://www.t9.com/. + + \legalese + This version of Pickboard is Dual Licensed Software. However, for you to be + able to license the technology to others, you may require a T9(R) Text + Input license from Tegic Communications Corporation. More information can + be found at http://www.t9.com/. +*/ /* XPM */ static const char * const menu_xpm[]={ "9 9 2 1", "a c #000000", ". c None", ".........", ".........", ".........", "....a....", "...aaa...", "..aaaaa..", ".aaaaaaa.", ".........", "........."}; class PickboardPrivate { public: PickboardPrivate(Pickboard* parent) { picks = new PickboardPicks(parent); picks->initialise(); menu = new QPushButton(parent); menu->setSizePolicy(QSizePolicy(QSizePolicy::Minimum,QSizePolicy::Expanding)); menu->setPixmap(QPixmap((const char **)menu_xpm)); QObject::connect(menu,SIGNAL(clicked()),picks,SLOT(doMenu())); QObject::connect(picks,SIGNAL(key(ushort,ushort,ushort,bool,bool)), parent,SIGNAL(key(ushort,ushort,ushort,bool,bool))); } PickboardPicks* picks; QPushButton* menu; }; Pickboard::Pickboard(QWidget* parent, const char* name, WFlags f) : QFrame(parent,name,f) { (new QHBoxLayout(this))->setAutoAdd(TRUE); d = new PickboardPrivate(this); +// under Win32 we may not have smallsmooth font +#ifndef Q_OS_WIN32 setFont( QFont( "smallsmooth", 9 ) ); +#endif } Pickboard::~Pickboard() { delete d; } void Pickboard::resetState() { d->picks->resetState(); } diff --git a/inputmethods/pickboard/pickboardcfg.cpp b/inputmethods/pickboard/pickboardcfg.cpp index d500266..70a89cd 100644 --- a/inputmethods/pickboard/pickboardcfg.cpp +++ b/inputmethods/pickboard/pickboardcfg.cpp @@ -1,731 +1,738 @@ /********************************************************************** -** Copyright (C) 2000 Trolltech AS. All rights reserved. +** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. ** -** This file is part of Qtopia Environment. +** This file is part of the Qtopia Environment. ** ** This file may be distributed and/or modified under the terms of the ** GNU General Public License version 2 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. ** ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. ** ** See http://www.trolltech.com/gpl/ for GPL licensing information. ** ** Contact info@trolltech.com if any conditions of this licensing are ** not clear to you. ** **********************************************************************/ #include "pickboardcfg.h" #include "pickboardpicks.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> +#ifdef QWS #include <qwindowsystem_qws.h> +#endif static const char * pickboard_help = - "<h1>The Pickboard</h1>" + QT_TRANSLATE_NOOP("PickboardConfig", "<h1>The Pickboard</h1>" "<i>The smallest and fastest way to type.</i>" "<p>" "Enter a word by tapping letter-groups and picking the word." "<br>Enter spaces with \"Space\", or other keys through \"KEY\"." "<br>Use \"Shift\" to capitalize words that are not normally capitalized." "<br>Press \"Shift\" twice for an all-capitals word." - "<br>Add custom words by picking them, then selecting \"Add...\" from the menu on the right." + "<br>Add custom words by picking them, then selecting \"Add...\" from the menu on the right." ) ; const int intermatchmargin=5; PickboardConfig::~PickboardConfig() { } void PickboardConfig::updateRows(int from, int to) { if ( from != to ) { // (all) parent->update(); } else { QFontMetrics fm = parent->fontMetrics(); parent->update(QRect(0,1+fm.descent() + from * fm.lineSpacing(), parent->width(), fm.lineSpacing())); } } void PickboardConfig::updateItem(int r, int) { updateRows(r,r); } void PickboardConfig::changeMode(int m) { parent->setMode(m); } void PickboardConfig::generateText(const QString& s) { #if defined(Q_WS_QWS) || defined(_WS_QWS_) for (int i=0; i<(int)s.length(); i++) { - parent->emitKey(s[i].unicode(), 0, 0, true, false); - parent->emitKey(s[i].unicode(), 0, 0, false, false); + uint code = 0; + if ( s[i].unicode() >= 'a' && s[i].unicode() <= 'z' ) { + code = s[i].unicode() - 'a' + Key_A; + } + parent->emitKey(s[i].unicode(), code, 0, true, false); + parent->emitKey(s[i].unicode(), code, 0, false, false); } -#endif +#endif } void PickboardConfig::generateKey( int k ) { #if defined(Q_WS_QWS) || defined(_WS_QWS_) parent->emitKey(0, k, 0, true, false); parent->emitKey(0, k, 0, false, false); #endif } void PickboardConfig::pickPoint(const QPoint& p, bool press) { if ( press ) { int ls=parent->height()/nrows; int y=0; pressx = -1; for (int r=0; r<nrows; r++) { if ( p.y() >= y && p.y() < y+ls ) { pressrow = r; pressx = p.x(); pickInRow( pressrow, pressx, TRUE ); return; } y += ls; } } else if ( pressx >= 0 ) { pickInRow( pressrow, pressx, FALSE ); pressx = -1; } } void PickboardConfig::fillMenu(QPopupMenu& menu) { - menu.insertItem("Reset",100); + menu.insertItem(tr("Reset"),100); menu.insertSeparator(); - menu.insertItem("Help",1); + menu.insertItem(tr("Help"),1); } void PickboardConfig::doMenu(int i) { switch (i) { case 100: if ( parent->currentMode() ) { changeMode(0); updateRows(0,1); } break; case 1: { - QMessageBox help("Pickboard Help", pickboard_help, + QMessageBox help(tr("Pickboard Help"), tr(pickboard_help), QMessageBox::NoIcon, 1, 0, 0); help.showMaximized(); help.exec(); } } } void StringConfig::draw(QPainter* p) { QFontMetrics fm = p->fontMetrics(); for (int r=0; r<nrows; r++) { p->translate(0,fm.lineSpacing()); p->setPen(rowColor(r)); int tw=0; QString s; int i=0; for (; !(s=text(r,i)).isNull(); ++i) { int w = fm.width(s); tw += w; } bool spread = spreadRow(r);// && parent->width() > tw; int xw = spread ? (parent->width()-tw)/(i-1) : 3; int x = spread ? (parent->width()-tw-xw*(i-1))/2 : 2; i=0; for (; !(s=text(r,i)).isNull(); ++i) { int w = fm.width(s)+xw; if ( highlight(r,i) ) { - p->fillRect(x-xw/2,1+fm.descent()-fm.lineSpacing(),w,fm.lineSpacing(),::Qt::black); - p->setPen(::Qt::white); + p->fillRect(x-xw/2,1+fm.descent()-fm.lineSpacing(),w,fm.lineSpacing(),Qt::black); + p->setPen(Qt::white); }else{ - p->setPen(::Qt::black); + p->setPen(Qt::black); } p->drawText(x,-fm.descent()-1,s); x += w; } } } void StringConfig::pickInRow(int r, int xpos, bool press) { QFontMetrics fm = parent->fontMetrics(); int tw=0; QString s; int i=0; for (; !(s=text(r,i)).isNull(); ++i) { int w = fm.width(s); tw += w; } bool spread = spreadRow(r) && parent->width() > tw; int xw = spread ? (parent->width()-tw)/(i-1) : 3; int x = spread ? (parent->width()-tw-xw*(i-1))/2 : 2; i=0; for (; !(s=text(r,i)).isNull(); ++i) { int x2 = x + fm.width(s)+xw; if ( xpos >= x && xpos < x2 ) { pick(press, r, i); return; } x = x2; } } void StringConfig::updateItem(int r, int item) { QFontMetrics fm = parent->fontMetrics(); int y = r * fm.lineSpacing(); int tw=0; QString s; int i=0; for (; !(s=text(r,i)).isNull(); ++i) { int w = fm.width(s); tw += w; } bool spread = spreadRow(r) && parent->width() > tw; int xw = spread ? (parent->width()-tw)/(i-1) : 3; int x = spread ? (parent->width()-tw-xw*(i-1))/2 : 2; i=0; for (; !(s=text(r,i)).isNull(); ++i) { int w = fm.width(s)+xw; if ( i == item ) { parent->update(QRect(x-xw/2,y+1+fm.descent(),w,fm.lineSpacing())); return; } x += w; } } bool StringConfig::highlight(int,int) const { return FALSE; } LetterButton::LetterButton(const QChar& letter, QWidget* parent) : QPushButton(letter,parent) { setToggleButton(TRUE); setAutoDefault(FALSE); connect(this,SIGNAL(clicked()),this,SLOT(toggleCase())); skip=TRUE; } void LetterButton::toggleCase() { if ( skip ) { // Don't toggle case the first time skip=FALSE; return; } QChar ch = text()[0]; QChar nch = ch.lower(); if ( ch == nch ) nch = ch.upper(); setText(nch); } LetterChoice::LetterChoice(QWidget* parent, const QString& set) : QButtonGroup(parent) { QHBoxLayout *l = new QHBoxLayout(this); setFrameStyle(0); setExclusive(TRUE); for (int i=0; i<(int)set.length(); i++) { LetterButton* b = new LetterButton(set[i],this); l->addWidget(b,1,AlignCenter); connect(b,SIGNAL(clicked()),this,SLOT(change())); } } void LetterChoice::change() { LetterButton* b = (LetterButton*)sender(); ch = b->text()[0]; emit changed(); } PickboardAdd::PickboardAdd(QWidget* owner, const QStringList& setlist) : QDialog( owner, 0, TRUE ) { QVBoxLayout* l = new QVBoxLayout(this); l->setAutoAdd(TRUE); QScrollView *sv = new QScrollView(this); sv->setResizePolicy(QScrollView::AutoOneFit); setMaximumHeight(200); // ### QDialog shouldn't allow us to be bigger than the screen QVBox *letters = new QVBox(sv); letters->setSpacing(0); lc = new LetterChoice*[setlist.count()]; nlc = (int)setlist.count(); for (int i=0; i<nlc; i++) { lc[i] = new LetterChoice(letters,setlist[i]); connect(lc[i],SIGNAL(changed()),this,SLOT(checkAllDone())); } sv->addChild(letters); QHBox* hb = new QHBox(this); hb->setSpacing(0); - yes = new QPushButton("OK",hb); + yes = new QPushButton(tr("OK"),hb); yes->setEnabled(FALSE); - QPushButton *no = new QPushButton("Cancel",hb); + QPushButton *no = new QPushButton(tr("Cancel"),hb); connect(yes, SIGNAL(clicked()), this, SLOT(accept())); connect(no, SIGNAL(clicked()), this, SLOT(reject())); } PickboardAdd::~PickboardAdd() { delete [] lc; } QString PickboardAdd::word() const { QString str; for (int i=0; i<nlc; i++) { str += lc[i]->choice(); } return str; } bool PickboardAdd::exec() { QPoint pos = parentWidget()->mapToGlobal(QPoint(0,0)); pos.ry() -= height(); if ( QDialog::exec() ) { Global::addWords(QStringList(word())); return TRUE; } else { return FALSE; } } void PickboardAdd::checkAllDone() { if ( !yes->isEnabled() ) { for (int i=0; i<nlc; i++) { if ( lc[i]->choice().isNull() ) return; } yes->setEnabled(TRUE); } } void DictFilterConfig::doMenu(int i) { switch (i) { case 300: if ( input.count() == 0 ) { - QMessageBox::information(0, "Adding Words", - "To add words, pick the letters,\nthen " + QMessageBox::information(0, tr("Adding Words"), + tr("To add words, pick the letters,\nthen " "open the Add dialog. In that\ndialog, tap " "the correct letters\nfrom the list " - "(tap twice for\ncapitals)."); + "(tap twice for\ncapitals).")); } else { PickboardAdd add(parent,capitalize(input)); if ( add.exec() ) generateText(add.word()); input.clear(); matches.clear(); updateRows(0,0); } break; case 100: if ( !input.isEmpty() ) { input.clear(); matches.clear(); StringConfig::doMenu(i); updateRows(0,1); break; } // else fall through default: StringConfig::doMenu(i); } shift = 0; lit0 = -1; } QString DictFilterConfig::text(int r, int i) { - QStringList l = r ? sets : input.isEmpty() ? othermodes : matches; + QStringList l = r ? sets_a : input.isEmpty() ? othermodes : matches; return i < (int)l.count() ? (input.isEmpty() ? l[i] : capitalize(l[i])) : QString::null; } bool DictFilterConfig::spreadRow(int r) { return r ? TRUE : input.isEmpty() ? TRUE : FALSE; } QStringList DictFilterConfig::capitalize(const QStringList& l) { switch ( shift ) { case 1: { QStringList r; QStringList::ConstIterator it = l.begin(); r.append((*it).upper()); for (++it; it != l.end(); ++it) r.append(*it); return r; } case 2: { QStringList r; for (QStringList::ConstIterator it = l.begin(); it != l.end(); ++it) r.append((*it).upper()); return r; } } return l; } QString DictFilterConfig::capitalize(const QString& s) { switch ( shift ) { case 1: { QString u = s; u[0] = u[0].upper(); return u; break; } case 2: return s.upper(); break; } return s; } void DictFilterConfig::pick(bool press, int row, int item) { if ( row == 0 ) { if ( press ) { if ( input.isEmpty() ) { lit0 = item; - if ( othermodes[item] == "Space" ) { + if ( othermodes[item] == PickboardPicks::tr("Space") ) { updateItem(row,item); generateText(" "); - } else if ( othermodes[item] == "Back" ) { + } else if ( othermodes[item] == PickboardPicks::tr("Back") ) { updateItem(row,item); generateKey(::Qt::Key_Backspace); - } else if ( othermodes[item] == "Enter" ) { - updateItem(row,item); + } else if ( othermodes[item] == PickboardPicks::tr("Enter") ) { + updateItem(row,item); generateKey(::Qt::Key_Return); - } else if ( othermodes[item] == "Shift" ) { + } else if ( othermodes[item] == PickboardPicks::tr("Shift") ) { updateItem(row,item); shift = (shift+1)%3; } } } else { if ( !input.isEmpty() ) { input.clear(); if ( item>=0 ) { generateText(capitalize(matches[item])); } shift = 0; matches.clear(); updateRows(0,0); } else if ( item < 3 ) { lit0 = -1; changeMode(item+1); // I'm mode 0! #### updateRows(0,1); } if ( lit0 >= 0 ) { - if ( !shift || othermodes[lit0] != "Shift" ) { - updateItem(0,lit0); + if ( !shift || othermodes[lit0] != PickboardPicks::tr("Shift") ) { + updateItem(0,lit0); lit0 = -1; } } } } else { lit0 = -1; if ( press && item >= 0 ) { lit1 = item; add(sets[item]); - updateItem(1,item); + updateItem(1,item); updateRows(0,0); } else { - updateItem(1,lit1); + updateItem(1,lit1); lit1 = -1; } } } bool DictFilterConfig::scanMatch(const QString& set, const QChar& l) const { return set == "?" || set == "*" || set.contains(l); } //static int visit=0; //static int lvisit=0; void DictFilterConfig::scan(const QDawg::Node* n, int ipos, const QString& str, int length, bool extend) { if ( n ) { do { //visit++; bool pastend = ipos >= (int)input.count(); if ( pastend && extend || !pastend && scanMatch(input[ipos],n->letter().lower()) ) { if ( length>1 ) { if ( !pastend && input[ipos] == "*" ) { scan(n->jump(),ipos+1,str+n->letter(),length-1,FALSE); scan(n->jump(),ipos,str+n->letter(),length,FALSE); } else { scan(n->jump(),ipos+1,str+n->letter(),length-1,extend); } } else { if ( n->isWord() ) { matches.append(str+n->letter()); } } } n = n->next(); } while (n); } } void DictFilterConfig::scanLengths(const QDawg::Node* n, int ipos, int& length_bitarray) { if ( n ) { do { //lvisit++; bool pastend = ipos >= (int)input.count(); if ( pastend || scanMatch(input[ipos],n->letter().lower()) ) { scanLengths(n->jump(),ipos+1,length_bitarray); if ( n->isWord() ) length_bitarray |= (1<<(ipos+1)); } n = n->next(); } while (n); } } void DictFilterConfig::add(const QString& set) { QFontMetrics fm = parent->fontMetrics(); input.append(set.lower()); matches.clear(); //visit=0; //lvisit=0; int length_bitarray = 0; if ( input.count() > 4 ) { scanLengths(Global::addedDawg().root(),0,length_bitarray); scanLengths(Global::fixedDawg().root(),0,length_bitarray); } else { length_bitarray = 0xffffffff; } for (int len=input.count(); len<22 /* 32 */; ++len) { if ( length_bitarray & (1<<len) ) { scan(Global::addedDawg().root(),0,"",len,TRUE); scan(Global::fixedDawg().root(),0,"",len,TRUE); int x = 2; for (QStringList::Iterator it=matches.begin(); it!=matches.end(); ++it) { x += fm.width(*it)+intermatchmargin; if ( x >= parent->width() ) { //qDebug("%d+%d visits",lvisit,visit); return; // RETURN - No point finding more } } } if ( len == 1 && input.count() == 1 ) { // Allow all single-characters to show as "matches" for ( int i=0; i<(int)set.length(); i++ ) { QChar ch = set[i].lower(); matches.append(ch); } } } //qDebug("%d+%d visits",lvisit,visit); } bool DictFilterConfig::highlight(int r,int c) const { return r == 0 ? c == lit0 : c == lit1; } -void DictFilterConfig::addSet(const QString& s) +void DictFilterConfig::addSet(const QString& appearance, const QString& set) { - sets.append(s); + sets_a.append( appearance ); + sets.append( set ); } void DictFilterConfig::addMode(const QString& s) { othermodes.append(s); } void DictFilterConfig::fillMenu(QPopupMenu& menu) { - menu.insertItem("Add...",300); + menu.insertItem(tr("Add..."),300); StringConfig::fillMenu(menu); } QValueList<QPixmap> KeycodeConfig::row(int i) { return i ? keypm2 : keypm1; } void KeycodeConfig::pickInRow(int r, int xpos, bool press) { QValueList<QPixmap> pl = row(r); QValueList<QPixmap>::Iterator it; int item=0; int x=xmarg; for (it=pl.begin(); it!=pl.end(); ++it) { int x2 = x + (*it).width(); if ( (*it).height() > 1 ) x2 += xw; if ( xpos >= x && xpos < x2 ) { pick(press, r, item); return; } x = x2; item++; } } void KeycodeConfig::pick(bool press, int row, int item) { if ( !press ) { if ( item >= 0 ) { int k = row == 0 ? keys1[item] : keys2[item]; if ( k ) generateKey(k); } changeMode(0); updateRows(0,1); } } void KeycodeConfig::draw(QPainter* p) { int y=3; QValueList<QPixmap>::Iterator it; for (int r=0; r<nrows; r++) { QValueList<QPixmap> pl = row(r); int x = xmarg; for (it=pl.begin(); it!=pl.end(); ++it) { if ( (*it).height() == 1 ) { // just a gap x += (*it).width(); } else { p->drawPixmap(x,y,*it); x += (*it).width()+xw; } } y += parent->height()/nrows; } } void KeycodeConfig::addKey(int r, const QPixmap& pm, int code) { if ( r == 0 ) { keypm1.append(pm); keys1.append(code); } else { keypm2.append(pm); keys2.append(code); } } void KeycodeConfig::addGap(int r, int w) { QBitmap pm(w,1); // ick. addKey(r,pm,0); } QString CharConfig::text(int r, int i) { QStringList l = r ? chars2 : chars1; return i < (int)l.count() ? l[i] : QString::null; } bool CharConfig::spreadRow(int) { return TRUE; } void CharConfig::pick(bool press, int row, int item) { if ( !press ) { if ( item >= 0 ) { generateText(row == 0 ? chars1[item] : chars2[item]); } changeMode(0); updateRows(0,1); } } void CharConfig::addChar(int r, const QString& s) { if ( r ) chars2.append(s); else chars1.append(s); } QString CharStringConfig::text(int r, int i) { QStringList l = r ? chars : QStringList(input); return i < (int)l.count() ? l[i] : QString::null; } bool CharStringConfig::spreadRow(int i) { return i ? TRUE : FALSE; } void CharStringConfig::pick(bool press, int row, int item) { if ( row == 0 ) { if ( !press ) { if ( item>=0 ) { generateText(input); } input = ""; changeMode(0); updateRows(0,1); } } else { if ( press && item >= 0 ) { input.append(chars[item]); updateRows(0,0); } } } void CharStringConfig::addChar(const QString& s) { chars.append(s); } void CharStringConfig::doMenu(int i) { if ( i == 100 ) { input = ""; updateRows(0,0); } StringConfig::doMenu(i); } diff --git a/inputmethods/pickboard/pickboardcfg.h b/inputmethods/pickboard/pickboardcfg.h index b1913df..92c6420 100644 --- a/inputmethods/pickboard/pickboardcfg.h +++ b/inputmethods/pickboard/pickboardcfg.h @@ -1,213 +1,218 @@ /********************************************************************** -** Copyright (C) 2000 Trolltech AS. All rights reserved. +** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. ** -** This file is part of Qtopia Environment. +** This file is part of the Qtopia Environment. ** ** This file may be distributed and/or modified under the terms of the ** GNU General Public License version 2 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. ** ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. ** ** See http://www.trolltech.com/gpl/ for GPL licensing information. ** ** Contact info@trolltech.com if any conditions of this licensing are ** not clear to you. ** **********************************************************************/ #ifndef PICKBOARDCFG_H #define PICKBOARDCFG_H #include <qpe/qdawg.h> #include <qpushbutton.h> #include <qhbuttongroup.h> #include <qdialog.h> #include <qlist.h> // Internal stuff... class PickboardPicks; class LetterButton : public QPushButton { Q_OBJECT public: LetterButton(const QChar& letter, QWidget* parent); private slots: void toggleCase(); private: bool skip; }; class LetterChoice : public QButtonGroup { Q_OBJECT public: LetterChoice(QWidget* parent, const QString& set); QChar choice() { return ch; } signals: void changed(); private slots: void change(); private: QChar ch; }; class PickboardAdd : public QDialog { Q_OBJECT public: PickboardAdd(QWidget* owner, const QStringList& setlist); ~PickboardAdd(); QString word() const; bool exec(); private slots: void checkAllDone(); private: QPushButton *yes; LetterChoice **lc; int nlc; }; -class PickboardConfig : QObject { +class PickboardConfig : public QObject { + Q_OBJECT public: PickboardConfig(PickboardPicks* p) : parent(p), nrows(2), pressx(-1) { } virtual ~PickboardConfig(); virtual void pickPoint(const QPoint& p, bool press); virtual void draw(QPainter*)=0; virtual void fillMenu(QPopupMenu&); virtual void doMenu(int); protected: void updateRows(int from, int to); virtual void updateItem(int r, int i); virtual void pickInRow(int r, int xpos, bool press)=0; void changeMode(int m); virtual void generateText(const QString& s); void generateKey( int k ); virtual void pick(bool press, int row, int item)=0; protected: PickboardPicks* parent; int nrows; private: int pressrow, pressx; }; class StringConfig : public PickboardConfig { + Q_OBJECT public: StringConfig(PickboardPicks* p) : PickboardConfig(p) { } void draw(QPainter* p); protected: virtual QString text(int r, int i)=0; virtual bool spreadRow(int i)=0; - virtual QColor rowColor(int) { return ::Qt::black; } + virtual QColor rowColor(int) { return Qt::black; } virtual void pickInRow(int r, int xpos, bool press); virtual void updateItem(int r, int i); virtual bool highlight(int,int) const; }; class CharStringConfig : public StringConfig { + Q_OBJECT QString input; QStringList chars; public: CharStringConfig(PickboardPicks* p) : StringConfig(p) { } void addChar(const QString& s); virtual void doMenu(int); protected: QString text(int r, int i); bool spreadRow(int i); void pick(bool press, int row, int item); }; class DictFilterConfig : public StringConfig { + Q_OBJECT QStringList matches; + QStringList sets_a; QStringList sets; QStringList othermodes; int lit0; int lit1; int shift; QString capitalize(const QString& s); QStringList capitalize(const QStringList& s); public: QStringList input; DictFilterConfig(PickboardPicks* p) : StringConfig(p) { shift = 0; lit0 = -1; lit1 = -1; } - void addSet(const QString& s); + void addSet(const QString& apperance, const QString& set); void addMode(const QString& s); void fillMenu(QPopupMenu& menu); void doMenu(int i); void add(const QString& set); protected: QString text(int r, int i); bool spreadRow(int i); void pick(bool press, int row, int item); bool scanMatch(const QString& set, const QChar& l) const; void scan(const QDawg::Node* n, int ipos, const QString& str, int length, bool extend); void scanLengths(const QDawg::Node* n, int ipos, int& bitarray); bool highlight(int r,int c) const; }; class CharConfig : public StringConfig { + Q_OBJECT QStringList chars1; QStringList chars2; public: CharConfig(PickboardPicks* p) : StringConfig(p) { } void addChar(int r, const QString& s); protected: QString text(int r, int i); bool spreadRow(int); void pick(bool press, int row, int item); }; class KeycodeConfig : public PickboardConfig { QValueList<int> keys1; QValueList<int> keys2; QValueList<QPixmap> keypm1; QValueList<QPixmap> keypm2; - static const int xw = 8; - static const int xmarg = 8; + enum { xw = 8, xmarg = 8 }; public: KeycodeConfig(PickboardPicks* p) : PickboardConfig(p) { } void addKey(int r, const QPixmap& pm, int code); void addGap(int r, int w); void draw(QPainter* p); protected: void pickInRow(int r, int xpos, bool press); QValueList<QPixmap> row(int i); void pick(bool press, int row, int item); }; #endif diff --git a/inputmethods/pickboard/pickboardimpl.cpp b/inputmethods/pickboard/pickboardimpl.cpp index 9a21229..f839452 100644 --- a/inputmethods/pickboard/pickboardimpl.cpp +++ b/inputmethods/pickboard/pickboardimpl.cpp @@ -1,103 +1,103 @@ /********************************************************************** -** Copyright (C) 2000 Trolltech AS. All rights reserved. +** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. ** -** This file is part of Qtopia Environment. +** This file is part of the Qtopia Environment. ** ** This file may be distributed and/or modified under the terms of the ** GNU General Public License version 2 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. ** ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. ** ** See http://www.trolltech.com/gpl/ for GPL licensing information. ** ** Contact info@trolltech.com if any conditions of this licensing are ** not clear to you. ** **********************************************************************/ #include <qapplication.h> #include <qobject.h> #include <qpixmap.h> #include "pickboard.h" #include "pickboardimpl.h" /* XPM */ static const char * pb_xpm[]={ "28 7 2 1", "# c #303030", -" c None", +" c None", // No tr " ########################## ", " # # # # # # # ", " # # # # # # # ", " ########################## ", " # # # # # # ", " # # # # # # ", " ########################## "}; PickboardImpl::PickboardImpl() : pickboard(0), icn(0) { } PickboardImpl::~PickboardImpl() { delete pickboard; delete icn; } QWidget *PickboardImpl::inputMethod( QWidget *parent, Qt::WFlags f ) { if ( !pickboard ) pickboard = new Pickboard( parent, "pickboard", f ); return pickboard; } void PickboardImpl::resetState() { if ( pickboard ) pickboard->resetState(); } QPixmap *PickboardImpl::icon() { if ( !icn ) icn = new QPixmap( (const char **)pb_xpm ); return icn; } QString PickboardImpl::name() { return qApp->translate( "InputMethods", "Pickboard" ); } void PickboardImpl::onKeyPress( QObject *receiver, const char *slot ) { if ( pickboard ) QObject::connect( pickboard, SIGNAL(key(ushort,ushort,ushort,bool,bool)), receiver, slot ); } #ifndef QT_NO_COMPONENT QRESULT PickboardImpl::queryInterface( const QUuid &uuid, QUnknownInterface **iface ) { *iface = 0; if ( uuid == IID_QUnknown ) *iface = this; else if ( uuid == IID_InputMethod ) *iface = this; else return QS_FALSE; if ( *iface ) (*iface)->addRef(); return QS_OK; } Q_EXPORT_INTERFACE() { Q_CREATE_INSTANCE( PickboardImpl ) } #endif diff --git a/inputmethods/pickboard/pickboardpicks.cpp b/inputmethods/pickboard/pickboardpicks.cpp index a80bbf8..b9d9928 100644 --- a/inputmethods/pickboard/pickboardpicks.cpp +++ b/inputmethods/pickboard/pickboardpicks.cpp @@ -1,418 +1,417 @@ /********************************************************************** -** Copyright (C) 2000 Trolltech AS. All rights reserved. +** Copyright (C) 2000-2002 Trolltech AS. All rights reserved. ** -** This file is part of Qtopia Environment. +** This file is part of the Qtopia Environment. ** ** This file may be distributed and/or modified under the terms of the ** GNU General Public License version 2 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. ** ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. ** ** See http://www.trolltech.com/gpl/ for GPL licensing information. ** ** Contact info@trolltech.com if any conditions of this licensing are ** not clear to you. ** **********************************************************************/ #include "pickboardpicks.h" #include "pickboardcfg.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> +#ifdef QWS #include <qwindowsystem_qws.h> +#endif void PickboardPicks::doMenu() { QWidget* cause = (QWidget*)sender(); // evil QPopupMenu popup(this); config()->fillMenu(popup); QPoint pos = cause->mapToGlobal(cause->rect().topRight()); QSize sz = popup.sizeHint(); pos.ry() -= sz.height(); pos.rx() -= sz.width(); popup.move(pos); config()->doMenu(popup.exec()); } static const char *BS_xpm[] = { "5 7 2 1", "a c #000000", ". c None", "...aa", "..aaa", ".aaaa", "aaaaa", ".aaaa", "..aaa", "...aa", }; static const char *Del_xpm[] = { "14 7 2 1", "a c #000000", ". c None", "aaa..aaaa.a...", "a..a.a....a...", "a..a.a....a...", "a..a.aaa..a...", "a..a.a....a...", "a..a.a....a...", "aaa..aaaa.aaaa" }; static const char *Home_xpm[] = { "20 7 2 1", "a c #000000", ". c None", "a..a..aa..a...a.aaaa", "a..a.a..a.aa.aa.a...", "a..a.a..a.a.a.a.a...", "aaaa.a..a.a.a.a.aaa.", "a..a.a..a.a...a.a...", "a..a.a..a.a...a.a...", "a..a..aa..a...a.aaaa" }; static const char *PgUp_xpm[] = { "20 7 2 1", "a c #000000", ". c None", "aaa.......a..a......", "a..a......a..a......", "a..a.aa...a..a.aaa..", "aaa.a.....a..a.a..a.", "a...a.aa..a..a.aaa..", "a...a..a..a..a.a....", "a....aaa...aa..a...." }; static const char *PgDn_xpm[] = { "20 7 2 1", "a c #000000", ". c None", "aaa.......aaa.......", "a..a......a..a......", "a..a.aa...a..a.a..a.", "aaa.a.....a..a.aa.a.", "a...a.aa..a..a.a.aa.", "a...a..a..a..a.a..a.", "a....aaa..aaa..a..a." }; static const char *End_xpm[] = { "14 7 2 1", "a c #000000", ". c None", "aaaa.a..a.aaa.", "a....aa.a.a..a", "a....a.aa.a..a", "aaa..a..a.a..a", "a....a..a.a..a", "a....a..a.a..a", "aaaa.a..a.aaa." }; static const char *Enter_xpm[] = { "14 7 2 1", "a c #000000", ". c None", ".............a", ".............a", "..a..........a", ".aa.........a.", "aaaaaaaaaaaa..", ".aa...........", "..a..........." }; static const char *Esc_xpm[] = { "14 7 2 1", "a c #000000", ". c None", "aaaa..aa...aa.", "a....a..a.a..a", "a....a....a...", "aaa...aa..a...", "a.......a.a...", "a....a..a.a..a", "aaaa..aa...aa." }; static const char *Ins_xpm[] = { "13 7 2 1", "a c #000000", ". c None", "aaa.a..a..aa.", ".a..aa.a.a..a", ".a..a.aa.a...", ".a..a..a..aa.", ".a..a..a....a", ".a..a..a.a..a", "aaa.a..a..aa." }; static const char *Up_xpm[] = { "7 7 2 1", "a c #000000", ". c None", "...a...", "..aaa..", ".a.a.a.", "a..a..a", "...a...", "...a...", "...a..." }; static const char *Left_xpm[] = { "7 7 2 1", "a c #000000", ". c None", "...a...", "..a....", ".a.....", "aaaaaaa", ".a.....", "..a....", "...a..." }; static const char *Down_xpm[] = { "7 7 2 1", "a c #000000", ". c None", "...a...", "...a...", "...a...", "a..a..a", ".a.a.a.", "..aaa..", "...a..." }; static const char *Right_xpm[] = { "7 7 2 1", "a c #000000", ". c None", "...a...", "....a..", ".....a.", "aaaaaaa", ".....a.", "....a..", "...a..." }; static const char *BackTab_xpm[] = { "8 7 2 1", "a c #000000", ". c None", "a.......", "a..a....", "a.aa....", "aaaaaaaa", "a.aa....", "a..a....", "a......." }; static const char *Tab_xpm[] = { "8 7 2 1", "a c #000000", ". c None", ".......a", "....a..a", "....aa.a", "aaaaaaaa", "....aa.a", "....a..a", ".......a" }; static const char *Space_xpm[] = { "9 9 2 1", "a c #000000", ". c None", "aaaaaaaaa", "a.......a", "a.......a", "a.......a", "a.......a", "a.......a", "a.......a", "a.......a", "aaaaaaaaa" }; PickboardPicks::PickboardPicks(QWidget* parent, const char* name, WFlags f ) : QFrame(parent,name,f) { + configs.setAutoDelete( TRUE ); } void PickboardPicks::initialise(void) { setSizePolicy(QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Fixed)); mode = 0; DictFilterConfig* dc = new DictFilterConfig(this); - dc->addSet("ABC"); - dc->addSet("DEF"); - dc->addSet("GHI"); - dc->addSet("JKL"); - dc->addSet("MNO"); - dc->addSet("PQR"); - dc->addSet("STU"); - dc->addSet("VWX"); - dc->addSet("YZ-'"); + QStringList sets_a = QStringList::split(' ',tr("ABC DEF GHI JKL MNO PQR STU VWX YZ-'")); + QStringList sets = QStringList::split(' ', + tr("ABC%/1iso8859-15 DEF%/1iso8859-15 GHI%/1iso8859-15 JKL MNO%/1iso8859-15 PQR%/1iso8859-15 STU%/1iso8859-15 VWX YZ-'%/1iso8859-15")); + for (QStringList::ConstIterator it = sets.begin(), it_a = sets_a.begin(); it!=sets.end(); ++it,++it_a) + dc->addSet(*it_a,*it); dc->addMode("123"); dc->addMode("@*!?"); - dc->addMode("KEY"); - dc->addMode("Space"); - dc->addMode("Back"); - dc->addMode("Enter"); - dc->addMode("Shift"); + dc->addMode(tr("KEY")); + dc->addMode(tr("Space")); + dc->addMode(tr("Back")); + dc->addMode(tr("Enter")); + dc->addMode(tr("Shift")); configs.append(dc); CharStringConfig* number = new CharStringConfig(this); number->addChar("0"); number->addChar("1"); number->addChar("2"); number->addChar("3"); number->addChar("4"); number->addChar("5"); number->addChar("6"); number->addChar("7"); number->addChar("8"); number->addChar("9"); number->addChar("."); // #### or "," in some locales configs.append(number); CharConfig* punc = new CharConfig(this); punc->addChar(0,"\""); punc->addChar(0,"`"); punc->addChar(0,"'"); punc->addChar(0,"\253"); punc->addChar(0,"\273"); punc->addChar(0,"\277"); punc->addChar(1,"("); punc->addChar(1,")"); punc->addChar(1,"["); punc->addChar(1,"]"); punc->addChar(1,"{"); punc->addChar(1,"}"); punc->addChar(0,"+"); punc->addChar(0,"-"); punc->addChar(0,"*"); punc->addChar(0,"/"); punc->addChar(0,"="); punc->addChar(0,"_"); punc->addChar(0,"$"); punc->addChar(0,"&"); punc->addChar(1,"|"); punc->addChar(1,"@"); punc->addChar(1,"\\"); punc->addChar(1,"#"); punc->addChar(1,"^"); punc->addChar(1,"~"); punc->addChar(1,"<"); punc->addChar(1,">"); punc->addChar(0,"."); punc->addChar(0,"?"); punc->addChar(0,"!"); punc->addChar(0,","); punc->addChar(0,";"); punc->addChar(1,":"); punc->addChar(1,"\267"); punc->addChar(1,"\277"); punc->addChar(1,"\241"); punc->addChar(1,"\367"); punc->addChar(0,"$"); punc->addChar(0,"\242"); punc->addChar(0,"\245"); punc->addChar(1,"\243"); punc->addChar(1,"\244"); punc->addChar(1,"\260"); configs.append(punc); KeycodeConfig* keys = new KeycodeConfig(this); keys->addKey(0,QPixmap(Esc_xpm),Key_Escape); keys->addKey(0,QPixmap(BS_xpm),Key_Backspace); keys->addGap(0,10); keys->addKey(0,QPixmap(Ins_xpm),Key_Insert); keys->addKey(0,QPixmap(Home_xpm),Key_Home); keys->addKey(0,QPixmap(PgUp_xpm),Key_PageUp); keys->addGap(0,25); keys->addKey(0,QPixmap(Up_xpm),Key_Up); keys->addGap(0,15); keys->addKey(1,QPixmap(BackTab_xpm),Key_Tab); keys->addGap(1,3); keys->addKey(1,QPixmap(Tab_xpm),Key_Tab); keys->addGap(1,10); keys->addKey(1,QPixmap(Del_xpm),Key_Delete); keys->addGap(1,2); keys->addKey(1,QPixmap(End_xpm),Key_End); keys->addGap(1,3); keys->addKey(1,QPixmap(PgDn_xpm),Key_PageDown); keys->addGap(1,10); keys->addKey(1,QPixmap(Left_xpm),Key_Left); keys->addKey(1,QPixmap(Down_xpm),Key_Down); keys->addKey(1,QPixmap(Right_xpm),Key_Right); keys->addGap(1,13); keys->addKey(1,QPixmap(Space_xpm),Key_Space); keys->addGap(0,10); keys->addKey(0,QPixmap(Enter_xpm),Key_Return); configs.append(keys); } PickboardPicks::~PickboardPicks() { } QSize PickboardPicks::sizeHint() const { return QSize(240,fontMetrics().lineSpacing()*2+3); } void PickboardPicks::drawContents(QPainter* p) { config()->draw(p); } void PickboardPicks::mousePressEvent(QMouseEvent* e) { config()->pickPoint(e->pos(),TRUE); } void PickboardPicks::mouseDoubleClickEvent(QMouseEvent* e) { config()->pickPoint(e->pos(),TRUE); } void PickboardPicks::mouseReleaseEvent(QMouseEvent* e) { config()->pickPoint(e->pos(),FALSE); } void PickboardPicks::setMode(int m) { mode = m; } void PickboardPicks::resetState() { config()->doMenu(100); } |