summaryrefslogtreecommitdiff
authorbrad <brad>2004-07-03 07:07:40 (UTC)
committer brad <brad>2004-07-03 07:07:40 (UTC)
commit88c9b1b2bbc64bae352eb7ddb7eabf9fbaca416d (patch) (unidiff)
treeb2f5bf2b2bf4ab8638708c6e2228e6c3f9fe83e7
parent0b0cc8ff22fdae62b8f40dc2a77a4de9a6fd0cb6 (diff)
downloadopie-88c9b1b2bbc64bae352eb7ddb7eabf9fbaca416d.zip
opie-88c9b1b2bbc64bae352eb7ddb7eabf9fbaca416d.tar.gz
opie-88c9b1b2bbc64bae352eb7ddb7eabf9fbaca416d.tar.bz2
Don't display hidden sets in trainer.
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--inputmethods/handwriting/qimpenhelp.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/inputmethods/handwriting/qimpenhelp.cpp b/inputmethods/handwriting/qimpenhelp.cpp
index 0727931..d0ccd55 100644
--- a/inputmethods/handwriting/qimpenhelp.cpp
+++ b/inputmethods/handwriting/qimpenhelp.cpp
@@ -19,257 +19,258 @@
19**********************************************************************/ 19**********************************************************************/
20 20
21#include "qimpenwidget.h" 21#include "qimpenwidget.h"
22#include "qimpencombining.h" 22#include "qimpencombining.h"
23#include "qimpenmatch.h" 23#include "qimpenmatch.h"
24#include "qimpenhelp.h" 24#include "qimpenhelp.h"
25 25
26#include <qpe/qpeapplication.h> 26#include <qpe/qpeapplication.h>
27#include <qpe/global.h> 27#include <qpe/global.h>
28#include <qpe/config.h> 28#include <qpe/config.h>
29#include <qpe/stringutil.h> 29#include <qpe/stringutil.h>
30 30
31#include <qtextview.h> 31#include <qtextview.h>
32#include <qlabel.h> 32#include <qlabel.h>
33#include <qlistbox.h> 33#include <qlistbox.h>
34#include <qcombobox.h> 34#include <qcombobox.h>
35#include <qpushbutton.h> 35#include <qpushbutton.h>
36#include <qlayout.h> 36#include <qlayout.h>
37#include <qtimer.h> 37#include <qtimer.h>
38#include <qtextstream.h> 38#include <qtextstream.h>
39 39
40/* XPM */ 40/* XPM */
41static const char * const left_xpm[] = { 41static const char * const left_xpm[] = {
42"16 16 2 1", 42"16 16 2 1",
43" c None", 43" c None",
44". c #000000", 44". c #000000",
45" ", 45" ",
46" ", 46" ",
47" ", 47" ",
48" . ", 48" . ",
49" .. ", 49" .. ",
50" ... ", 50" ... ",
51" .... ", 51" .... ",
52" ..... ", 52" ..... ",
53" ...... ", 53" ...... ",
54" ..... ", 54" ..... ",
55" .... ", 55" .... ",
56" ... ", 56" ... ",
57" .. ", 57" .. ",
58" . ", 58" . ",
59" ", 59" ",
60" "}; 60" "};
61 61
62 62
63/* XPM */ 63/* XPM */
64static const char * const right_xpm[] = { 64static const char * const right_xpm[] = {
65"16 16 2 1", 65"16 16 2 1",
66" c None", 66" c None",
67". c #000000", 67". c #000000",
68" ", 68" ",
69" ", 69" ",
70" ", 70" ",
71" . ", 71" . ",
72" .. ", 72" .. ",
73" ... ", 73" ... ",
74" .... ", 74" .... ",
75" ..... ", 75" ..... ",
76" ...... ", 76" ...... ",
77" ..... ", 77" ..... ",
78" .... ", 78" .... ",
79" ... ", 79" ... ",
80" .. ", 80" .. ",
81" . ", 81" . ",
82" ", 82" ",
83" "}; 83" "};
84 84
85class CharListItem : public QListBoxText 85class CharListItem : public QListBoxText
86{ 86{
87public: 87public:
88 CharListItem( const QString &text, uint c ) 88 CharListItem( const QString &text, uint c )
89 : QListBoxText( text ) 89 : QListBoxText( text )
90 { 90 {
91 _code = c; 91 _code = c;
92 } 92 }
93 93
94 uint code() const { return _code; } 94 uint code() const { return _code; }
95 95
96protected: 96protected:
97 uint _code; 97 uint _code;
98}; 98};
99 99
100HandwritingHelp::HandwritingHelp( QIMPenProfile *p, QWidget *parent, const char *name, WFlags f ) 100HandwritingHelp::HandwritingHelp( QIMPenProfile *p, QWidget *parent, const char *name, WFlags f )
101 : QTabWidget( parent, name, f ) 101 : QTabWidget( parent, name, f )
102{ 102{
103 setCaption( tr("Handwriting Help") ); 103 setCaption( tr("Handwriting Help") );
104 QTextView *help = new QTextView( this ); 104 QTextView *help = new QTextView( this );
105 help->setFrameStyle( QFrame::NoFrame ); 105 help->setFrameStyle( QFrame::NoFrame );
106 help->setText( 106 help->setText(
107 tr( "<ul><li>When you start to use the handwriting recogniser " 107 tr( "<ul><li>When you start to use the handwriting recogniser "
108 "write slowly, accurately and firmly." 108 "write slowly, accurately and firmly."
109 "<li>Use the guide lines when drawing your characters." 109 "<li>Use the guide lines when drawing your characters."
110 "<li>When drawing a character with multiple strokes, each " 110 "<li>When drawing a character with multiple strokes, each "
111 "successive stroke must be drawn before the grayed strokes are erased." 111 "successive stroke must be drawn before the grayed strokes are erased."
112 "<li>Practice your handwriting using the handwriting trainer." 112 "<li>Practice your handwriting using the handwriting trainer."
113 "<li>When adding your own character templates make sure they " 113 "<li>When adding your own character templates make sure they "
114 "are sufficiently different from other characters' templates." 114 "are sufficiently different from other characters' templates."
115 "</ul>") ); 115 "</ul>") );
116 116
117 addTab( help, tr("Tips") ); 117 addTab( help, tr("Tips") );
118 118
119 HandwritingTrainer *trainer = new HandwritingTrainer( p, this ); 119 HandwritingTrainer *trainer = new HandwritingTrainer( p, this );
120 addTab( trainer, tr("Trainer") ); 120 addTab( trainer, tr("Trainer") );
121} 121}
122 122
123void HandwritingHelp::showEvent( QShowEvent * ) 123void HandwritingHelp::showEvent( QShowEvent * )
124{ 124{
125 Global::hideInputMethod(); 125 Global::hideInputMethod();
126} 126}
127 127
128void HandwritingHelp::hideEvent( QHideEvent * ) 128void HandwritingHelp::hideEvent( QHideEvent * )
129{ 129{
130 Global::showInputMethod(); 130 Global::showInputMethod();
131} 131}
132 132
133//--------------------------------------------------------------------------- 133//---------------------------------------------------------------------------
134 134
135HandwritingTrainer::HandwritingTrainer( QIMPenProfile *p, QWidget *parent, const char *name ) 135HandwritingTrainer::HandwritingTrainer( QIMPenProfile *p, QWidget *parent, const char *name )
136 : QWidget( parent, name ), profile(p) 136 : QWidget( parent, name ), profile(p)
137{ 137{
138 QGridLayout *gl = new QGridLayout( this, 4, 2, 0, 4 ); 138 QGridLayout *gl = new QGridLayout( this, 4, 2, 0, 4 );
139 gl->setColStretch( 1, 1 ); 139 gl->setColStretch( 1, 1 );
140 gl->setRowStretch(3, 1); 140 gl->setRowStretch(3, 1);
141 141
142 charSetCombo = new QComboBox( this ); 142 charSetCombo = new QComboBox( this );
143 gl->addMultiCellWidget( charSetCombo, 0, 0, 0, 1 ); 143 gl->addMultiCellWidget( charSetCombo, 0, 0, 0, 1 );
144 connect( charSetCombo, SIGNAL(activated(int)), SLOT(selectCharSet(int))); 144 connect( charSetCombo, SIGNAL(activated(int)), SLOT(selectCharSet(int)));
145 QIMPenCharSetIterator it( profile->charSets() ); 145 QIMPenCharSetIterator it( profile->charSets() );
146 for ( ; it.current(); ++it ) { 146 for ( ; it.current(); ++it ) {
147 charSetCombo->insertItem( it.current()->description() ); 147 if ( ! it.current()->hidden() )
148 charSetCombo->insertItem( it.current()->description() );
148 } 149 }
149 150
150 charList = new QListBox( this ); 151 charList = new QListBox( this );
151 charList->setHScrollBarMode( QListBox::AlwaysOff ); 152 charList->setHScrollBarMode( QListBox::AlwaysOff );
152 charList->setFixedWidth(80); 153 charList->setFixedWidth(80);
153 connect( charList, SIGNAL(highlighted(int)), this, SLOT(selectChar(int)) ); 154 connect( charList, SIGNAL(highlighted(int)), this, SLOT(selectChar(int)) );
154 gl->addWidget(charList, 1, 0); 155 gl->addWidget(charList, 1, 0);
155 156
156 result = new QLabel( this ); 157 result = new QLabel( this );
157 result->setAlignment(AlignLeft | AlignVCenter | WordBreak); 158 result->setAlignment(AlignLeft | AlignVCenter | WordBreak);
158 result->setText( 159 result->setText(
159 tr( "Select a reference character from the list. Practice writing in " 160 tr( "Select a reference character from the list. Practice writing in "
160 "the area on the right.")); 161 "the area on the right."));
161 gl->addMultiCellWidget(result, 1, 2, 1, 1); 162 gl->addMultiCellWidget(result, 1, 2, 1, 1);
162 163
163 matcher = new QIMPenMatch( this ); 164 matcher = new QIMPenMatch( this );
164 matcher->setCharSet( currentSet ); 165 matcher->setCharSet( currentSet );
165 connect( matcher, SIGNAL(noMatch()), this, SLOT(noMatch()) ); 166 connect( matcher, SIGNAL(noMatch()), this, SLOT(noMatch()) );
166 connect( matcher, SIGNAL(matchedCharacters(const QIMPenCharMatchList&)), 167 connect( matcher, SIGNAL(matchedCharacters(const QIMPenCharMatchList&)),
167 this, SLOT(matched(const QIMPenCharMatchList&)) ); 168 this, SLOT(matched(const QIMPenCharMatchList&)) );
168 169
169 QHBoxLayout *hb = new QHBoxLayout(); 170 QHBoxLayout *hb = new QHBoxLayout();
170 gl->addLayout( hb, 2, 0 ); 171 gl->addLayout( hb, 2, 0 );
171 prevBtn = new QPushButton( this ); 172 prevBtn = new QPushButton( this );
172 prevBtn->setPixmap( QPixmap( (const char **)left_xpm ) ); 173 prevBtn->setPixmap( QPixmap( (const char **)left_xpm ) );
173 connect( prevBtn, SIGNAL(clicked()), SLOT(prevChar())); 174 connect( prevBtn, SIGNAL(clicked()), SLOT(prevChar()));
174 hb->addWidget( prevBtn ); 175 hb->addWidget( prevBtn );
175 176
176 nextBtn = new QPushButton( this ); 177 nextBtn = new QPushButton( this );
177 nextBtn->setPixmap( QPixmap( (const char **)right_xpm ) ); 178 nextBtn->setPixmap( QPixmap( (const char **)right_xpm ) );
178 connect( nextBtn, SIGNAL(clicked()), SLOT(nextChar())); 179 connect( nextBtn, SIGNAL(clicked()), SLOT(nextChar()));
179 hb->addWidget( nextBtn ); 180 hb->addWidget( nextBtn );
180 181
181 refPw = new QIMPenWidget( this ); 182 refPw = new QIMPenWidget( this );
182 refPw->setReadOnly( TRUE ); 183 refPw->setReadOnly( TRUE );
183 gl->addWidget( refPw, 3, 0 ); 184 gl->addWidget( refPw, 3, 0 );
184 185
185 pracPw = new QIMPenWidget( this ); 186 pracPw = new QIMPenWidget( this );
186 connect( matcher, SIGNAL(removeStroke()), pracPw, SLOT(removeStroke()) ); 187 connect( matcher, SIGNAL(removeStroke()), pracPw, SLOT(removeStroke()) );
187 connect( pracPw, SIGNAL(beginStroke()), 188 connect( pracPw, SIGNAL(beginStroke()),
188 this, SLOT(beginStroke()) ); 189 this, SLOT(beginStroke()) );
189 connect( pracPw, SIGNAL(stroke(QIMPenStroke*)), 190 connect( pracPw, SIGNAL(stroke(QIMPenStroke*)),
190 this, SLOT(strokeEntered(QIMPenStroke*)) ); 191 this, SLOT(strokeEntered(QIMPenStroke*)) );
191 connect( pracPw, SIGNAL(beginStroke()), 192 connect( pracPw, SIGNAL(beginStroke()),
192 matcher, SLOT(beginStroke()) ); 193 matcher, SLOT(beginStroke()) );
193 connect( pracPw, SIGNAL(stroke(QIMPenStroke*)), 194 connect( pracPw, SIGNAL(stroke(QIMPenStroke*)),
194 matcher, SLOT(strokeEntered(QIMPenStroke*)) ); 195 matcher, SLOT(strokeEntered(QIMPenStroke*)) );
195 gl->addWidget( pracPw, 3, 1 ); 196 gl->addWidget( pracPw, 3, 1 );
196 197
197 redrawTimer = new QTimer( this ); 198 redrawTimer = new QTimer( this );
198 connect( redrawTimer, SIGNAL(timeout()), this, SLOT(redrawChar()) ); 199 connect( redrawTimer, SIGNAL(timeout()), this, SLOT(redrawChar()) );
199 redrawTimer->start( 5000 ); 200 redrawTimer->start( 5000 );
200 201
201 currentSet = 0; 202 currentSet = 0;
202 charSetCombo->setCurrentItem( 1 ); 203 charSetCombo->setCurrentItem( 1 );
203 selectCharSet( 1 ); 204 selectCharSet( 1 );
204} 205}
205 206
206HandwritingTrainer::~HandwritingTrainer() 207HandwritingTrainer::~HandwritingTrainer()
207{ 208{
208} 209}
209 210
210void HandwritingTrainer::showEvent( QShowEvent * ) 211void HandwritingTrainer::showEvent( QShowEvent * )
211{ 212{
212 redrawChar(); 213 redrawChar();
213 redrawTimer->start( 5000 ); 214 redrawTimer->start( 5000 );
214} 215}
215 216
216void HandwritingTrainer::setCurrentChar( QIMPenChar *c ) 217void HandwritingTrainer::setCurrentChar( QIMPenChar *c )
217{ 218{
218 currentChar = c; 219 currentChar = c;
219 refPw->showCharacter( currentChar ); 220 refPw->showCharacter( currentChar );
220 pracPw->clear(); 221 pracPw->clear();
221 if ( currentChar ) { 222 if ( currentChar ) {
222 prevBtn->setEnabled( findPrev() != 0 ); 223 prevBtn->setEnabled( findPrev() != 0 );
223 nextBtn->setEnabled( findNext() != 0 ); 224 nextBtn->setEnabled( findNext() != 0 );
224 } 225 }
225 redrawTimer->start( 5000 ); 226 redrawTimer->start( 5000 );
226} 227}
227 228
228void HandwritingTrainer::selectChar( int i ) 229void HandwritingTrainer::selectChar( int i )
229{ 230{
230 static int last_char = 0; 231 static int last_char = 0;
231 232
232 if (last_char != i) { 233 if (last_char != i) {
233 result->setText(""); 234 result->setText("");
234 } 235 }
235 236
236 currentChar = 0; 237 currentChar = 0;
237 currentCode = ((CharListItem *)charList->item(i))->code(); 238 currentCode = ((CharListItem *)charList->item(i))->code();
238 QIMPenCharIterator it(currentSet->characters() ); 239 QIMPenCharIterator it(currentSet->characters() );
239 for ( ; it.current(); ++it ) { 240 for ( ; it.current(); ++it ) {
240 if ( it.current()->character() == currentCode && 241 if ( it.current()->character() == currentCode &&
241 !it.current()->testFlag( QIMPenChar::Deleted ) ) { 242 !it.current()->testFlag( QIMPenChar::Deleted ) ) {
242 setCurrentChar( it.current() ); 243 setCurrentChar( it.current() );
243 break; 244 break;
244 } 245 }
245 } 246 }
246 if ( !it.current() ) 247 if ( !it.current() )
247 setCurrentChar( 0 ); 248 setCurrentChar( 0 );
248} 249}
249 250
250void HandwritingTrainer::selectCharSet( int i ) 251void HandwritingTrainer::selectCharSet( int i )
251{ 252{
252 if ( currentSet ) { 253 if ( currentSet ) {
253 refPw->removeCharSet( 0 ); 254 refPw->removeCharSet( 0 );
254 pracPw->removeCharSet( 0 ); 255 pracPw->removeCharSet( 0 );
255 result->setText(""); 256 result->setText("");
256 } 257 }
257 currentSet = profile->charSets().at( i ); 258 currentSet = profile->charSets().at( i );
258 fillCharList(); 259 fillCharList();
259 refPw->insertCharSet( currentSet ); 260 refPw->insertCharSet( currentSet );
260 pracPw->insertCharSet( currentSet ); 261 pracPw->insertCharSet( currentSet );
261 matcher->setCharSet( currentSet ); 262 matcher->setCharSet( currentSet );
262 if ( charList->count() ) { 263 if ( charList->count() ) {
263 charList->setSelected( 0, TRUE ); 264 charList->setSelected( 0, TRUE );
264 selectChar(0); 265 selectChar(0);
265 } 266 }
266} 267}
267 268
268void HandwritingTrainer::noMatch() 269void HandwritingTrainer::noMatch()
269{ 270{
270 result->setText( tr("No match") ); 271 result->setText( tr("No match") );
271} 272}
272 273
273void HandwritingTrainer::matched( const QIMPenCharMatchList &ml ) 274void HandwritingTrainer::matched( const QIMPenCharMatchList &ml )
274{ 275{
275 int maxErr = 20000 + (*ml.begin()).penChar->strokeLength(0) * 1000; 276 int maxErr = 20000 + (*ml.begin()).penChar->strokeLength(0) * 1000;