author | harlekin <harlekin> | 2002-05-02 10:59:23 (UTC) |
---|---|---|
committer | harlekin <harlekin> | 2002-05-02 10:59:23 (UTC) |
commit | 3e4ce540942b6342a00c272dac171e729ae2b08b (patch) (unidiff) | |
tree | 9251a7389328a4d581b9e1c9848f8d6dc139a555 /inputmethods/keyboard | |
parent | 9b22572f07ec954e9dda33e99f7fc681e3c50827 (diff) | |
download | opie-3e4ce540942b6342a00c272dac171e729ae2b08b.zip opie-3e4ce540942b6342a00c272dac171e729ae2b08b.tar.gz opie-3e4ce540942b6342a00c272dac171e729ae2b08b.tar.bz2 |
removed the hack that limited the bad influence of the sticky bug on ipaq, since it is not needed any more. Sticky bug is fixed in 2.4.18-rmk3 hh6
-rw-r--r-- | inputmethods/keyboard/keyboard.cpp | 72 |
1 files changed, 36 insertions, 36 deletions
diff --git a/inputmethods/keyboard/keyboard.cpp b/inputmethods/keyboard/keyboard.cpp index a04c45a..0f0b188 100644 --- a/inputmethods/keyboard/keyboard.cpp +++ b/inputmethods/keyboard/keyboard.cpp | |||
@@ -51,22 +51,22 @@ Keyboard::Keyboard(QWidget* parent, const char* _name, WFlags f) : | |||
51 | this, SIGNAL(key(ushort,ushort,ushort,bool,bool)) ); | 51 | this, SIGNAL(key(ushort,ushort,ushort,bool,bool)) ); |
52 | 52 | ||
53 | repeatTimer = new QTimer( this ); | 53 | repeatTimer = new QTimer( this ); |
54 | 54 | ||
55 | // temporary quick and dirty fix for the "sticky keyboard bug" | 55 | // temporary quick and dirty fix for the "sticky keyboard bug" |
56 | // on ipaq. | 56 | // on ipaq. |
57 | struct utsname name; | 57 | // struct utsname name; |
58 | if (uname(&name) != -1) | 58 | // if (uname(&name) != -1) |
59 | { | 59 | // { |
60 | QString release=name.release; | 60 | //QString release=name.release; |
61 | qWarning("System release: %s\n", name.release); | 61 | //qWarning("System release: %s\n", name.release); |
62 | if(release.find("embedix",0,TRUE) !=-1) | 62 | //if(release.find("embedix",0,TRUE) !=-1) |
63 | { | 63 | // { |
64 | connect( repeatTimer, SIGNAL(timeout()), this, SLOT(repeat()) ); | 64 | connect( repeatTimer, SIGNAL(timeout()), this, SLOT(repeat()) ); |
65 | } | 65 | // } |
66 | } | 66 | // } |
67 | } | 67 | } |
68 | 68 | ||
69 | void Keyboard::resizeEvent(QResizeEvent*) | 69 | void Keyboard::resizeEvent(QResizeEvent*) |
70 | { | 70 | { |
71 | int ph = picks->sizeHint().height(); | 71 | int ph = picks->sizeHint().height(); |
72 | picks->setGeometry( 0, 0, width(), ph ); | 72 | picks->setGeometry( 0, 0, width(), ph ); |
@@ -116,24 +116,24 @@ void KeyboardConfig::generateText(const QString &s) | |||
116 | 116 | ||
117 | 117 | ||
118 | //PC keyboard layout and scancodes | 118 | //PC keyboard layout and scancodes |
119 | 119 | ||
120 | /* | 120 | /* |
121 | Format: length, code, length, code, ..., 0 | 121 | Format: length, code, length, code, ..., 0 |
122 | 122 | ||
123 | length is measured in half the width of a standard key. | 123 | length is measured in half the width of a standard key. |
124 | If code < 0x80 we have length/2 consecutive standard keys, | 124 | If code < 0x80 we have length/2 consecutive standard keys, |
125 | starting with scancode code. | 125 | starting with scancode code. |
126 | 126 | ||
127 | Special keys are hardcoded, one at a time, with length of key | 127 | Special keys are hardcoded, one at a time, with length of key |
128 | and code >= 0x80, these are NOT standard PC scancodes, but are looked | 128 | and code >= 0x80, these are NOT standard PC scancodes, but are looked |
129 | up in specialM[]. (The special keys are not keymappable.) | 129 | up in specialM[]. (The special keys are not keymappable.) |
130 | 130 | ||
131 | */ | 131 | */ |
132 | 132 | ||
133 | static const uchar * const keyboard_opti[5] = { | 133 | static const uchar * const keyboard_opti[5] = { |
134 | (const uchar *const) "\001\223\003\240\002\20\002\41\002\26\002\62\002\56\002\45\002\54\003\200\001\223\002\226\002\235\002\234\002\236", | 134 | (const uchar *const) "\001\223\003\240\002\20\002\41\002\26\002\62\002\56\002\45\002\54\003\200\001\223\002\226\002\235\002\234\002\236", |
135 | (const uchar *const) "\001\223\003\201\004\207\002\30\002\24\002\43\004\207\003\203\001\223\006\002\002\065", | 135 | (const uchar *const) "\001\223\003\201\004\207\002\30\002\24\002\43\004\207\003\203\001\223\006\002\002\065", |
136 | (const uchar *const) "\001\223\003\202\002\60\002\37\002\23\002\22\002\36\002\21\002\55\003\203\001\223\006\005\002\055", | 136 | (const uchar *const) "\001\223\003\202\002\60\002\37\002\23\002\22\002\36\002\21\002\55\003\203\001\223\006\005\002\055", |
137 | (const uchar *const) "\001\223\003\205\004\207\002\27\002\61\002\40\004\207\003\204\001\223\006\010\002\014", | 137 | (const uchar *const) "\001\223\003\205\004\207\002\27\002\61\002\40\004\207\003\204\001\223\006\010\002\014", |
138 | (const uchar *const) "\001\223\003\206\002\44\002\31\002\57\002\42\002\46\002\25\002\207\003\204\001\223\002\013\002\064\002\015\002\230" | 138 | (const uchar *const) "\001\223\003\206\002\44\002\31\002\57\002\42\002\46\002\25\002\207\003\204\001\223\002\013\002\064\002\015\002\230" |
139 | }; | 139 | }; |
@@ -149,20 +149,20 @@ static const uchar * const keyboard_standard[5] = { | |||
149 | //~ + 123...+ BACKSPACE //+ INSERT + HOME + PGUP | 149 | //~ + 123...+ BACKSPACE //+ INSERT + HOME + PGUP |
150 | 150 | ||
151 | (const uchar *const)"\003\201\002q\002w\002e\002r\002t\002y\002u\002i\002o\002p\002[\002]\002\\\001\224\002\223\002\221\002\220\002\222", | 151 | (const uchar *const)"\003\201\002q\002w\002e\002r\002t\002y\002u\002i\002o\002p\002[\002]\002\\\001\224\002\223\002\221\002\220\002\222", |
152 | //TAB + qwerty.. + backslash //+ DEL + END + PGDN | 152 | //TAB + qwerty.. + backslash //+ DEL + END + PGDN |
153 | 153 | ||
154 | (const uchar *const)"\004\202\002a\002s\002d\002f\002g\002h\002j\002k\002l\002;\002'\004\203", | 154 | (const uchar *const)"\004\202\002a\002s\002d\002f\002g\002h\002j\002k\002l\002;\002'\004\203", |
155 | //CAPS + asdf.. + RETURN | 155 | //CAPS + asdf.. + RETURN |
156 | 156 | ||
157 | (const uchar *const)"\005\204\002z\002x\002c\002v\002b\002n\002m\002,\002.\002/\005\204\002\223\002\223\002\211", | 157 | (const uchar *const)"\005\204\002z\002x\002c\002v\002b\002n\002m\002,\002.\002/\005\204\002\223\002\223\002\211", |
158 | //SHIFT + zxcv... //+ UP | 158 | //SHIFT + zxcv... //+ UP |
159 | 159 | ||
160 | (const uchar *const)"\003\205\003\206\022\207\003\206\003\205\002\223\002\212\002\213\002\214" | 160 | (const uchar *const)"\003\205\003\206\022\207\003\206\003\205\002\223\002\212\002\213\002\214" |
161 | //CTRL + ALT + SPACE //+ LEFT + DOWN + RIGHT | 161 | //CTRL + ALT + SPACE //+ LEFT + DOWN + RIGHT |
162 | 162 | ||
163 | }; | 163 | }; |
164 | 164 | ||
165 | 165 | ||
166 | struct ShiftMap { | 166 | struct ShiftMap { |
167 | char normal; | 167 | char normal; |
168 | char shifted; | 168 | char shifted; |
@@ -391,13 +391,13 @@ static const char * const escape_xpm[]={ | |||
391 | ".a...a.a.", | 391 | ".a...a.a.", |
392 | ".aa.aa.aa", | 392 | ".aa.aa.aa", |
393 | ".........", | 393 | ".........", |
394 | "........."}; | 394 | "........."}; |
395 | 395 | ||
396 | 396 | ||
397 | enum { BSCode = 0x80, TabCode, CapsCode, RetCode, | 397 | enum { BSCode = 0x80, TabCode, CapsCode, RetCode, |
398 | ShiftCode, CtrlCode, AltCode, SpaceCode, BackSlash, | 398 | ShiftCode, CtrlCode, AltCode, SpaceCode, BackSlash, |
399 | UpCode, LeftCode, DownCode, RightCode, Blank, Expand, | 399 | UpCode, LeftCode, DownCode, RightCode, Blank, Expand, |
400 | Opti, ResetDict, | 400 | Opti, ResetDict, |
401 | Divide, Multiply, Add, Subtract, Decimal, Equal, | 401 | Divide, Multiply, Add, Subtract, Decimal, Equal, |
402 | Percent, Sqrt, Inverse, Escape }; | 402 | Percent, Sqrt, Inverse, Escape }; |
403 | 403 | ||
@@ -432,13 +432,13 @@ static const SpecialMap specialM[] = { | |||
432 | { Qt::Key_Delete, 0,"X", delete_xpm }, | 432 | { Qt::Key_Delete, 0,"X", delete_xpm }, |
433 | { Qt::Key_PageDown, 0,"D", pagedown_xpm }, | 433 | { Qt::Key_PageDown, 0,"D", pagedown_xpm }, |
434 | { Blank, 0," ", NULL }, | 434 | { Blank, 0," ", NULL }, |
435 | { Expand, 0,"->", expand_xpm }, | 435 | { Expand, 0,"->", expand_xpm }, |
436 | { Opti, 0,"#", NULL }, | 436 | { Opti, 0,"#", NULL }, |
437 | { ResetDict, 0,"R", NULL }, | 437 | { ResetDict, 0,"R", NULL }, |
438 | 438 | ||
439 | // number pad stuff | 439 | // number pad stuff |
440 | { Divide, 0,"/", NULL }, | 440 | { Divide, 0,"/", NULL }, |
441 | { Multiply, 0,"*", NULL }, | 441 | { Multiply, 0,"*", NULL }, |
442 | { Add, 0,"+", NULL }, | 442 | { Add, 0,"+", NULL }, |
443 | { Subtract, 0,"-", NULL }, | 443 | { Subtract, 0,"-", NULL }, |
444 | { Decimal, 0,".", NULL }, | 444 | { Decimal, 0,".", NULL }, |
@@ -452,55 +452,55 @@ static const SpecialMap specialM[] = { | |||
452 | 452 | ||
453 | 453 | ||
454 | static int keycode( int i2, int j, const uchar **keyboard ) | 454 | static int keycode( int i2, int j, const uchar **keyboard ) |
455 | { | 455 | { |
456 | if ( j <0 || j >= 5 ) | 456 | if ( j <0 || j >= 5 ) |
457 | return 0; | 457 | return 0; |
458 | 458 | ||
459 | const uchar *row = keyboard[j]; | 459 | const uchar *row = keyboard[j]; |
460 | 460 | ||
461 | while ( *row && *row <= i2 ) { | 461 | while ( *row && *row <= i2 ) { |
462 | i2 -= *row; | 462 | i2 -= *row; |
463 | row += 2; | 463 | row += 2; |
464 | } | 464 | } |
465 | 465 | ||
466 | if ( !*row ) return 0; | 466 | if ( !*row ) return 0; |
467 | 467 | ||
468 | int k; | 468 | int k; |
469 | if ( row[1] >= 0x80 ) { | 469 | if ( row[1] >= 0x80 ) { |
470 | k = row[1]; | 470 | k = row[1]; |
471 | } else { | 471 | } else { |
472 | k = row[1]+i2/2; | 472 | k = row[1]+i2/2; |
473 | } | 473 | } |
474 | 474 | ||
475 | return k; | 475 | return k; |
476 | } | 476 | } |
477 | 477 | ||
478 | 478 | ||
479 | /* | 479 | /* |
480 | return scancode and width of first key in row \a j if \a j >= 0, | 480 | return scancode and width of first key in row \a j if \a j >= 0, |
481 | or next key on current row if \a j < 0. | 481 | or next key on current row if \a j < 0. |
482 | 482 | ||
483 | */ | 483 | */ |
484 | 484 | ||
485 | int Keyboard::getKey( int &w, int j ) { | 485 | int Keyboard::getKey( int &w, int j ) { |
486 | static const uchar *row = 0; | 486 | static const uchar *row = 0; |
487 | static int key_i = 0; | 487 | static int key_i = 0; |
488 | static int scancode = 0; | 488 | static int scancode = 0; |
489 | static int half = 0; | 489 | static int half = 0; |
490 | 490 | ||
491 | if ( j >= 0 && j < 5 ) { | 491 | if ( j >= 0 && j < 5 ) { |
492 | if (useOptiKeys) | 492 | if (useOptiKeys) |
493 | row = keyboard_opti[j]; | 493 | row = keyboard_opti[j]; |
494 | else | 494 | else |
495 | row = keyboard_standard[j]; | 495 | row = keyboard_standard[j]; |
496 | half=0; | 496 | half=0; |
497 | } | 497 | } |
498 | 498 | ||
499 | if ( !row || !*row ) { | 499 | if ( !row || !*row ) { |
500 | return 0; | 500 | return 0; |
501 | } else if ( row[1] >= 0x80 ) { | 501 | } else if ( row[1] >= 0x80 ) { |
502 | scancode = row[1]; | 502 | scancode = row[1]; |
503 | w = (row[0] * w + (half++&1)) / 2; | 503 | w = (row[0] * w + (half++&1)) / 2; |
504 | row += 2; | 504 | row += 2; |
505 | return scancode; | 505 | return scancode; |
506 | } else if ( key_i <= 0 ) { | 506 | } else if ( key_i <= 0 ) { |
@@ -509,13 +509,13 @@ int Keyboard::getKey( int &w, int j ) { | |||
509 | } | 509 | } |
510 | key_i--; | 510 | key_i--; |
511 | if ( key_i <= 0 ) | 511 | if ( key_i <= 0 ) |
512 | row += 2; | 512 | row += 2; |
513 | return scancode++; | 513 | return scancode++; |
514 | } | 514 | } |
515 | 515 | ||
516 | 516 | ||
517 | void Keyboard::paintEvent(QPaintEvent* e) | 517 | void Keyboard::paintEvent(QPaintEvent* e) |
518 | { | 518 | { |
519 | QPainter painter(this); | 519 | QPainter painter(this); |
520 | painter.setClipRect(e->rect()); | 520 | painter.setClipRect(e->rect()); |
521 | drawKeyboard( painter ); | 521 | drawKeyboard( painter ); |
@@ -537,13 +537,13 @@ void Keyboard::drawKeyboard( QPainter &p, int key ) | |||
537 | QColor keycolor_pressed = cg.mid(); | 537 | QColor keycolor_pressed = cg.mid(); |
538 | QColor keycolor_lo = cg.dark(); | 538 | QColor keycolor_lo = cg.dark(); |
539 | QColor keycolor_hi = cg.light(); | 539 | QColor keycolor_hi = cg.light(); |
540 | QColor textcolor = QColor(0,0,0); // cg.text(); | 540 | QColor textcolor = QColor(0,0,0); // cg.text(); |
541 | 541 | ||
542 | int margin = threeD ? 1 : 0; | 542 | int margin = threeD ? 1 : 0; |
543 | 543 | ||
544 | // p.fillRect( 0, , kw-1, keyHeight-2, keycolor_pressed ); | 544 | // p.fillRect( 0, , kw-1, keyHeight-2, keycolor_pressed ); |
545 | 545 | ||
546 | for ( int j = 0; j < 5; j++ ) { | 546 | for ( int j = 0; j < 5; j++ ) { |
547 | int y = j * keyHeight + picks->height() + 1; | 547 | int y = j * keyHeight + picks->height() + 1; |
548 | int x = xoffs; | 548 | int x = xoffs; |
549 | int kw = defaultKeyWidth; | 549 | int kw = defaultKeyWidth; |
@@ -551,31 +551,31 @@ void Keyboard::drawKeyboard( QPainter &p, int key ) | |||
551 | while ( k ) { | 551 | while ( k ) { |
552 | if ( key < 0 || k == key ) { | 552 | if ( key < 0 || k == key ) { |
553 | QString s; | 553 | QString s; |
554 | bool pressed = (k == pressedKey); | 554 | bool pressed = (k == pressedKey); |
555 | bool blank = (k == 0223); | 555 | bool blank = (k == 0223); |
556 | const char * const * xpm = NULL; | 556 | const char * const * xpm = NULL; |
557 | 557 | ||
558 | if ( k >= 0x80 ) { | 558 | if ( k >= 0x80 ) { |
559 | s = specialM[k - 0x80].label; | 559 | s = specialM[k - 0x80].label; |
560 | 560 | ||
561 | xpm = specialM[k - 0x80].xpm; | 561 | xpm = specialM[k - 0x80].xpm; |
562 | 562 | ||
563 | if ( k == ShiftCode ) { | 563 | if ( k == ShiftCode ) { |
564 | pressed = shift; | 564 | pressed = shift; |
565 | } else if ( k == CapsCode ) { | 565 | } else if ( k == CapsCode ) { |
566 | pressed = lock; | 566 | pressed = lock; |
567 | } else if ( k == CtrlCode ) { | 567 | } else if ( k == CtrlCode ) { |
568 | pressed = ctrl; | 568 | pressed = ctrl; |
569 | } else if ( k == AltCode ) { | 569 | } else if ( k == AltCode ) { |
570 | pressed = alt; | 570 | pressed = alt; |
571 | } | 571 | } |
572 | } else { | 572 | } else { |
573 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) | 573 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) |
574 | /* | 574 | /* |
575 | s = QChar( shift^lock ? QWSServer::keyMap()[k].shift_unicode : | 575 | s = QChar( shift^lock ? QWSServer::keyMap()[k].shift_unicode : |
576 | QWSServer::keyMap()[k].unicode); | 576 | QWSServer::keyMap()[k].unicode); |
577 | */ | 577 | */ |
578 | // ### Fixme, bad code, needs improving, whole thing needs to | 578 | // ### Fixme, bad code, needs improving, whole thing needs to |
579 | // be re-coded to get rid of the way it did things with scancodes etc | 579 | // be re-coded to get rid of the way it did things with scancodes etc |
580 | char shifted = k; | 580 | char shifted = k; |
581 | if ( !isalpha( k ) ) { | 581 | if ( !isalpha( k ) ) { |
@@ -618,22 +618,22 @@ void Keyboard::drawKeyboard( QPainter &p, int key ) | |||
618 | if (xpm) { | 618 | if (xpm) { |
619 | p.drawPixmap( x + 1, y + 2, QPixmap((const char**)xpm) ); | 619 | p.drawPixmap( x + 1, y + 2, QPixmap((const char**)xpm) ); |
620 | } else { | 620 | } else { |
621 | p.setPen(textcolor); | 621 | p.setPen(textcolor); |
622 | p.drawText( x - 1, y, kw, keyHeight-2, AlignCenter, s ); | 622 | p.drawText( x - 1, y, kw, keyHeight-2, AlignCenter, s ); |
623 | } | 623 | } |
624 | 624 | ||
625 | if ( threeD ) { | 625 | if ( threeD ) { |
626 | p.setPen(keycolor_hi); | 626 | p.setPen(keycolor_hi); |
627 | p.drawLine( x, y, x+kw-1, y ); | 627 | p.drawLine( x, y, x+kw-1, y ); |
628 | } | 628 | } |
629 | 629 | ||
630 | // bottom | 630 | // bottom |
631 | p.setPen(keycolor_lo); | 631 | p.setPen(keycolor_lo); |
632 | p.drawLine( x, y+keyHeight-1, x+kw-1, y+keyHeight-1 ); | 632 | p.drawLine( x, y+keyHeight-1, x+kw-1, y+keyHeight-1 ); |
633 | 633 | ||
634 | } else { | 634 | } else { |
635 | p.fillRect( x, y, kw, keyHeight, cg.background() ); | 635 | p.fillRect( x, y, kw, keyHeight, cg.background() ); |
636 | } | 636 | } |
637 | } | 637 | } |
638 | 638 | ||
639 | x += kw; | 639 | x += kw; |
@@ -686,13 +686,13 @@ void Keyboard::mousePressEvent(QMouseEvent *e) | |||
686 | qk = QWSServer::keyMap()[k].key_code; | 686 | qk = QWSServer::keyMap()[k].key_code; |
687 | if ( qk != Key_unknown ) { | 687 | if ( qk != Key_unknown ) { |
688 | if ( ctrl ) | 688 | if ( ctrl ) |
689 | u = QWSServer::keyMap()[k].ctrl_unicode; | 689 | u = QWSServer::keyMap()[k].ctrl_unicode; |
690 | else if ( shift^lock ) | 690 | else if ( shift^lock ) |
691 | u = QWSServer::keyMap()[k].shift_unicode; | 691 | u = QWSServer::keyMap()[k].shift_unicode; |
692 | else | 692 | else |
693 | u = QWSServer::keyMap()[k].unicode; | 693 | u = QWSServer::keyMap()[k].unicode; |
694 | } | 694 | } |
695 | */ | 695 | */ |
696 | char shifted = k; | 696 | char shifted = k; |
697 | if ( !isalpha( k ) ) { | 697 | if ( !isalpha( k ) ) { |
698 | // ### Fixme, bad code, needs improving, whole thing needs to | 698 | // ### Fixme, bad code, needs improving, whole thing needs to |
@@ -772,13 +772,13 @@ void Keyboard::timerEvent(QTimerEvent* e) | |||
772 | clearHighlight(); | 772 | clearHighlight(); |
773 | } | 773 | } |
774 | } | 774 | } |
775 | 775 | ||
776 | void Keyboard::repeat() | 776 | void Keyboard::repeat() |
777 | { | 777 | { |
778 | 778 | ||
779 | repeatTimer->start( 200 ); | 779 | repeatTimer->start( 200 ); |
780 | emit key( unicode, qkeycode, modifiers, true, true ); | 780 | emit key( unicode, qkeycode, modifiers, true, true ); |
781 | } | 781 | } |
782 | 782 | ||
783 | void Keyboard::clearHighlight() | 783 | void Keyboard::clearHighlight() |
784 | { | 784 | { |
@@ -795,13 +795,13 @@ QSize Keyboard::sizeHint() const | |||
795 | { | 795 | { |
796 | QFontMetrics fm=fontMetrics(); | 796 | QFontMetrics fm=fontMetrics(); |
797 | int keyHeight = fm.lineSpacing()+2; | 797 | int keyHeight = fm.lineSpacing()+2; |
798 | 798 | ||
799 | if (useOptiKeys) | 799 | if (useOptiKeys) |
800 | keyHeight += 1; | 800 | keyHeight += 1; |
801 | 801 | ||
802 | return QSize( 320, keyHeight * 5 + picks->sizeHint().height() + 1 ); | 802 | return QSize( 320, keyHeight * 5 + picks->sizeHint().height() + 1 ); |
803 | } | 803 | } |
804 | 804 | ||
805 | 805 | ||
806 | void Keyboard::resetState() | 806 | void Keyboard::resetState() |
807 | { | 807 | { |