summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--inputmethods/multikey/keyboard.cpp30
1 files changed, 24 insertions, 6 deletions
diff --git a/inputmethods/multikey/keyboard.cpp b/inputmethods/multikey/keyboard.cpp
index d5a7afd..7098a6b 100644
--- a/inputmethods/multikey/keyboard.cpp
+++ b/inputmethods/multikey/keyboard.cpp
@@ -257,104 +257,122 @@ void Keyboard::mousePressEvent(QMouseEvent *e)
257{ 257{
258 int row = (e->y() - (usePicks ? picks->height() : 0)) / keyHeight + 1; 258 int row = (e->y() - (usePicks ? picks->height() : 0)) / keyHeight + 1;
259 if (row > 5) row = 5; 259 if (row > 5) row = 5;
260 260
261 // figure out the column 261 // figure out the column
262 int col = 0; 262 int col = 0;
263 for (int w = 0; e->x() >= w; col++) 263 for (int w = 0; e->x() >= w; col++)
264 if (col < keys->numKeys(row)) // it segfaults if it trys to read past numKeys 264 if (col < keys->numKeys(row)) // it segfaults if it trys to read past numKeys
265 w += keys->width(row,col) * defaultKeyWidth; 265 w += keys->width(row,col) * defaultKeyWidth;
266 else break; 266 else break;
267 267
268 if (col <= 0) return; 268 if (col <= 0) return;
269 269
270 col --; // rewind one... 270 col --; // rewind one...
271 271
272 qkeycode = keys->qcode(row, col); 272 qkeycode = keys->qcode(row, col);
273 unicode = keys->uni(row, col); 273 unicode = keys->uni(row, col);
274 274
275 // might need to repaint if two or more of the same keys. 275 // might need to repaint if two or more of the same keys.
276 // should be faster if just paint one key even though multiple keys exist. 276 // should be faster if just paint one key even though multiple keys exist.
277 bool need_repaint = FALSE; 277 bool need_repaint = FALSE;
278 278
279 if (unicode == 0) { // either Qt char, or nothing 279 if (unicode == 0) { // either Qt char, or nothing
280 280
281 if (qkeycode == Qt::Key_F1) { // toggle the pickboard 281 if (qkeycode == Qt::Key_F1) { // toggle the pickboard
282 282
283 if ( configdlg ) { 283 if ( configdlg ) {
284 delete (ConfigDlg *) configdlg; 284 delete (ConfigDlg *) configdlg;
285 configdlg = 0; 285 configdlg = 0;
286 } 286 }
287 else { 287 else {
288 configdlg = new ConfigDlg (); 288 configdlg = new ConfigDlg ();
289 connect(configdlg, SIGNAL(setMapToDefault()), 289 connect(configdlg, SIGNAL(setMapToDefault()),
290 this, SLOT(setMapToDefault())); 290 this, SLOT(setMapToDefault()));
291 connect(configdlg, SIGNAL(setMapToFile(QString)), 291 connect(configdlg, SIGNAL(setMapToFile(QString)),
292 this, SLOT(setMapToFile(QString))); 292 this, SLOT(setMapToFile(QString)));
293 connect(configdlg, SIGNAL(pickboardToggled(bool)), 293 connect(configdlg, SIGNAL(pickboardToggled(bool)),
294 this, SLOT(togglePickboard(bool))); 294 this, SLOT(togglePickboard(bool)));
295 connect(configdlg, SIGNAL(repeatToggled(bool)), 295 connect(configdlg, SIGNAL(repeatToggled(bool)),
296 this, SLOT(toggleRepeat(bool))); 296 this, SLOT(toggleRepeat(bool)));
297 connect(configdlg, SIGNAL(reloadKeyboard()), 297 connect(configdlg, SIGNAL(reloadKeyboard()),
298 this, SLOT(reloadKeyboard())); 298 this, SLOT(reloadKeyboard()));
299 configdlg->showMaximized(); 299 configdlg->showMaximized();
300 configdlg->show(); 300 configdlg->show();
301 configdlg->raise(); 301 configdlg->raise();
302 } 302 }
303 303
304 } else if (qkeycode == Qt::Key_Control) { 304 } else if (qkeycode == Qt::Key_Control) {
305 ctrl = keys->pressedPtr(row, col); 305
306 need_repaint = TRUE; 306 if (ctrl) {
307 *ctrl = !keys->pressed(row, col); 307
308 *ctrl = 0;
309 ctrl = 0;
310
311 } else {
312
313 ctrl = keys->pressedPtr(row, col);
314 need_repaint = TRUE;
315 *ctrl = !keys->pressed(row, col);
316
317 }
308 318
309 } else if (qkeycode == Qt::Key_Alt) { 319 } else if (qkeycode == Qt::Key_Alt) {
310 alt = keys->pressedPtr(row, col); 320
311 need_repaint = TRUE; 321 if (alt) {
312 *alt = !keys->pressed(row, col); 322 *alt = 0;
323 alt = 0;
324
325 } else {
326
327 alt = keys->pressedPtr(row, col);
328 need_repaint = TRUE;
329 *alt = !keys->pressed(row, col);
330 }
313 331
314 } else if (qkeycode == Qt::Key_Shift) { 332 } else if (qkeycode == Qt::Key_Shift) {
315 need_repaint = TRUE; 333 need_repaint = TRUE;
316 334
317 if (shift) { 335 if (shift) {
318 *shift = 0; 336 *shift = 0;
319 shift = 0; 337 shift = 0;
320 } 338 }
321 else { 339 else {
322 shift = keys->pressedPtr(row, col); 340 shift = keys->pressedPtr(row, col);
323 *shift = 1; 341 *shift = 1;
324 if (lock) { 342 if (lock) {
325 *lock = 0; 343 *lock = 0;
326 lock = 0; 344 lock = 0;
327 } 345 }
328 } 346 }
329 347
330 } else if (qkeycode == Qt::Key_CapsLock) { 348 } else if (qkeycode == Qt::Key_CapsLock) {
331 need_repaint = TRUE; 349 need_repaint = TRUE;
332 350
333 if (lock) { 351 if (lock) {
334 *lock = 0; 352 *lock = 0;
335 lock = 0; 353 lock = 0;
336 } 354 }
337 else { 355 else {
338 lock = keys->pressedPtr(row, col);; 356 lock = keys->pressedPtr(row, col);;
339 *lock = 1; 357 *lock = 1;
340 if (shift) { 358 if (shift) {
341 *shift = 0; 359 *shift = 0;
342 shift = 0; 360 shift = 0;
343 } 361 }
344 } 362 }
345 363
346 } 364 }
347 365
348 } 366 }
349 else { // normal char 367 else { // normal char
350 if ((shift || lock) && keys->shift(unicode)) { 368 if ((shift || lock) && keys->shift(unicode)) {
351 unicode = keys->shift(unicode); 369 unicode = keys->shift(unicode);
352 } 370 }
353 } 371 }
354 372
355 // korean parsing 373 // korean parsing
356 if (keys->lang == "ko") { 374 if (keys->lang == "ko") {
357 375
358 unicode = parseKoreanInput(unicode); 376 unicode = parseKoreanInput(unicode);
359 } 377 }
360 378