-rw-r--r-- | inputmethods/keyboard/keyboard.cpp | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/inputmethods/keyboard/keyboard.cpp b/inputmethods/keyboard/keyboard.cpp index 9dd24e4..233f08e 100644 --- a/inputmethods/keyboard/keyboard.cpp +++ b/inputmethods/keyboard/keyboard.cpp | |||
@@ -1,100 +1,114 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | 20 | ||
21 | #include "keyboard.h" | 21 | #include "keyboard.h" |
22 | 22 | ||
23 | #include <qpe/global.h> | 23 | #include <qpe/global.h> |
24 | 24 | ||
25 | #include <qwindowsystem_qws.h> | 25 | #include <qwindowsystem_qws.h> |
26 | #include <qpainter.h> | 26 | #include <qpainter.h> |
27 | #include <qfontmetrics.h> | 27 | #include <qfontmetrics.h> |
28 | #include <qtimer.h> | 28 | #include <qtimer.h> |
29 | #include <ctype.h> | 29 | #include <ctype.h> |
30 | 30 | ||
31 | #include <sys/utsname.h> | ||
32 | |||
31 | 33 | ||
32 | #define USE_SMALL_BACKSPACE | 34 | #define USE_SMALL_BACKSPACE |
33 | 35 | ||
34 | Keyboard::Keyboard(QWidget* parent, const char* name, WFlags f) : | 36 | Keyboard::Keyboard(QWidget* parent, const char* name, WFlags f) : |
35 | QFrame(parent, name, f), shift(FALSE), lock(FALSE), ctrl(FALSE), | 37 | QFrame(parent, name, f), shift(FALSE), lock(FALSE), ctrl(FALSE), |
36 | alt(FALSE), useLargeKeys(TRUE), useOptiKeys(0), pressedKey(-1), | 38 | alt(FALSE), useLargeKeys(TRUE), useOptiKeys(0), pressedKey(-1), |
37 | unicode(-1), qkeycode(0), modifiers(0) | 39 | unicode(-1), qkeycode(0), modifiers(0) |
38 | { | 40 | { |
39 | // setPalette(QPalette(QColor(240,240,230))); // Beige! | 41 | // setPalette(QPalette(QColor(240,240,230))); // Beige! |
40 | // setFont( QFont( "Helvetica", 8 ) ); | 42 | // setFont( QFont( "Helvetica", 8 ) ); |
41 | // setPalette(QPalette(QColor(200,200,200))); // Gray | 43 | // setPalette(QPalette(QColor(200,200,200))); // Gray |
42 | setPalette(QPalette(QColor(220,220,220))); // Gray | 44 | setPalette(QPalette(QColor(220,220,220))); // Gray |
43 | 45 | ||
44 | picks = new KeyboardPicks( this ); | 46 | picks = new KeyboardPicks( this ); |
45 | picks->setFont( QFont( "smallsmooth", 9 ) ); | 47 | picks->setFont( QFont( "smallsmooth", 9 ) ); |
46 | setFont( QFont( "smallsmooth", 9 ) ); | 48 | setFont( QFont( "smallsmooth", 9 ) ); |
47 | picks->initialise(); | 49 | picks->initialise(); |
48 | QObject::connect( picks, SIGNAL(key(ushort,ushort,ushort,bool,bool) ), | 50 | QObject::connect( picks, SIGNAL(key(ushort,ushort,ushort,bool,bool) ), |
49 | this, SIGNAL(key(ushort,ushort,ushort,bool,bool)) ); | 51 | this, SIGNAL(key(ushort,ushort,ushort,bool,bool)) ); |
50 | 52 | ||
51 | repeatTimer = new QTimer( this ); | 53 | repeatTimer = new QTimer( this ); |
52 | connect( repeatTimer, SIGNAL(timeout()), this, SLOT(repeat()) ); | 54 | |
55 | // temporary quick and dirty fix for the "sticky keyboard bug" | ||
56 | // on ipaq. | ||
57 | struct utsname name; | ||
58 | if (uname(&name) != -1) | ||
59 | { | ||
60 | QString release=name.release; | ||
61 | qWarning("System release: %s\n", name.release); | ||
62 | if(release.find("embedix",0,TRUE) !=-1) | ||
63 | { | ||
64 | connect( repeatTimer, SIGNAL(timeout()), this, SLOT(repeat()) ); | ||
65 | } | ||
66 | } | ||
53 | } | 67 | } |
54 | 68 | ||
55 | void Keyboard::resizeEvent(QResizeEvent*) | 69 | void Keyboard::resizeEvent(QResizeEvent*) |
56 | { | 70 | { |
57 | int ph = picks->sizeHint().height(); | 71 | int ph = picks->sizeHint().height(); |
58 | picks->setGeometry( 0, 0, width(), ph ); | 72 | picks->setGeometry( 0, 0, width(), ph ); |
59 | keyHeight = (height()-ph)/5; | 73 | keyHeight = (height()-ph)/5; |
60 | int nk; | 74 | int nk; |
61 | if ( useOptiKeys ) { | 75 | if ( useOptiKeys ) { |
62 | nk = 15; | 76 | nk = 15; |
63 | } else if ( useLargeKeys ) { | 77 | } else if ( useLargeKeys ) { |
64 | nk = 15; | 78 | nk = 15; |
65 | } else { | 79 | } else { |
66 | nk = 19; | 80 | nk = 19; |
67 | } | 81 | } |
68 | defaultKeyWidth = width()/nk; | 82 | defaultKeyWidth = width()/nk; |
69 | xoffs = (width()-defaultKeyWidth*nk)/2; | 83 | xoffs = (width()-defaultKeyWidth*nk)/2; |
70 | } | 84 | } |
71 | 85 | ||
72 | void KeyboardPicks::initialise() | 86 | void KeyboardPicks::initialise() |
73 | { | 87 | { |
74 | setSizePolicy(QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Fixed)); | 88 | setSizePolicy(QSizePolicy(QSizePolicy::Expanding,QSizePolicy::Fixed)); |
75 | mode = 0; | 89 | mode = 0; |
76 | dc = new KeyboardConfig(this); | 90 | dc = new KeyboardConfig(this); |
77 | configs.append(dc); | 91 | configs.append(dc); |
78 | } | 92 | } |
79 | 93 | ||
80 | QSize KeyboardPicks::sizeHint() const | 94 | QSize KeyboardPicks::sizeHint() const |
81 | { | 95 | { |
82 | return QSize(240,fontMetrics().lineSpacing()); | 96 | return QSize(240,fontMetrics().lineSpacing()); |
83 | } | 97 | } |
84 | 98 | ||
85 | 99 | ||
86 | void KeyboardConfig::generateText(const QString &s) | 100 | void KeyboardConfig::generateText(const QString &s) |
87 | { | 101 | { |
88 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) | 102 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) |
89 | for (int i=0; i<(int)backspaces; i++) { | 103 | for (int i=0; i<(int)backspaces; i++) { |
90 | parent->emitKey( 0, Qt::Key_Backspace, 0, true, false ); | 104 | parent->emitKey( 0, Qt::Key_Backspace, 0, true, false ); |
91 | parent->emitKey( 0, Qt::Key_Backspace, 0, false, false ); | 105 | parent->emitKey( 0, Qt::Key_Backspace, 0, false, false ); |
92 | } | 106 | } |
93 | for (int i=0; i<(int)s.length(); i++) { | 107 | for (int i=0; i<(int)s.length(); i++) { |
94 | parent->emitKey( s[i].unicode(), 0, 0, true, false ); | 108 | parent->emitKey( s[i].unicode(), 0, 0, true, false ); |
95 | parent->emitKey( s[i].unicode(), 0, 0, false, false ); | 109 | parent->emitKey( s[i].unicode(), 0, 0, false, false ); |
96 | } | 110 | } |
97 | parent->emitKey( 0, Qt::Key_Space, 0, true, false ); | 111 | parent->emitKey( 0, Qt::Key_Space, 0, true, false ); |
98 | parent->emitKey( 0, Qt::Key_Space, 0, false, false ); | 112 | parent->emitKey( 0, Qt::Key_Space, 0, false, false ); |
99 | backspaces = 0; | 113 | backspaces = 0; |
100 | #endif | 114 | #endif |
@@ -716,79 +730,80 @@ void Keyboard::mousePressEvent(QMouseEvent *e) | |||
716 | dc->input.clear(); | 730 | dc->input.clear(); |
717 | dc->resetBackspaces(); | 731 | dc->resetBackspaces(); |
718 | } else { | 732 | } else { |
719 | dc->add(QString(QChar(unicode))); | 733 | dc->add(QString(QChar(unicode))); |
720 | dc->incBackspaces(); | 734 | dc->incBackspaces(); |
721 | } | 735 | } |
722 | } | 736 | } |
723 | 737 | ||
724 | picks->repaint(); | 738 | picks->repaint(); |
725 | 739 | ||
726 | } | 740 | } |
727 | pressedKey = k; | 741 | pressedKey = k; |
728 | if ( need_repaint ) { | 742 | if ( need_repaint ) { |
729 | repaint( FALSE ); | 743 | repaint( FALSE ); |
730 | } else { | 744 | } else { |
731 | QPainter p(this); | 745 | QPainter p(this); |
732 | drawKeyboard( p, pressedKey ); | 746 | drawKeyboard( p, pressedKey ); |
733 | } | 747 | } |
734 | pressTid = startTimer(80); | 748 | pressTid = startTimer(80); |
735 | pressed = TRUE; | 749 | pressed = TRUE; |
736 | } | 750 | } |
737 | 751 | ||
738 | 752 | ||
739 | void Keyboard::mouseReleaseEvent(QMouseEvent*) | 753 | void Keyboard::mouseReleaseEvent(QMouseEvent*) |
740 | { | 754 | { |
741 | if ( pressTid == 0 ) | 755 | if ( pressTid == 0 ) |
742 | clearHighlight(); | 756 | clearHighlight(); |
743 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) | 757 | #if defined(Q_WS_QWS) || defined(_WS_QWS_) |
744 | if ( unicode != -1 ) { | 758 | if ( unicode != -1 ) { |
745 | emit key( unicode, qkeycode, modifiers, false, false ); | 759 | emit key( unicode, qkeycode, modifiers, false, false ); |
746 | repeatTimer->stop(); | 760 | repeatTimer->stop(); |
747 | } | 761 | } |
748 | #endif | 762 | #endif |
749 | pressed = FALSE; | 763 | pressed = FALSE; |
750 | } | 764 | } |
751 | 765 | ||
752 | void Keyboard::timerEvent(QTimerEvent* e) | 766 | void Keyboard::timerEvent(QTimerEvent* e) |
753 | { | 767 | { |
754 | if ( e->timerId() == pressTid ) { | 768 | if ( e->timerId() == pressTid ) { |
755 | killTimer(pressTid); | 769 | killTimer(pressTid); |
756 | pressTid = 0; | 770 | pressTid = 0; |
757 | if ( !pressed ) | 771 | if ( !pressed ) |
758 | clearHighlight(); | 772 | clearHighlight(); |
759 | } | 773 | } |
760 | } | 774 | } |
761 | 775 | ||
762 | void Keyboard::repeat() | 776 | void Keyboard::repeat() |
763 | { | 777 | { |
764 | repeatTimer->start( 150 ); | 778 | |
765 | emit key( unicode, qkeycode, modifiers, true, true ); | 779 | repeatTimer->start( 200 ); |
780 | emit key( unicode, qkeycode, modifiers, true, true ); | ||
766 | } | 781 | } |
767 | 782 | ||
768 | void Keyboard::clearHighlight() | 783 | void Keyboard::clearHighlight() |
769 | { | 784 | { |
770 | if ( pressedKey >= 0 ) { | 785 | if ( pressedKey >= 0 ) { |
771 | int tmp = pressedKey; | 786 | int tmp = pressedKey; |
772 | pressedKey = -1; | 787 | pressedKey = -1; |
773 | QPainter p(this); | 788 | QPainter p(this); |
774 | drawKeyboard( p, tmp ); | 789 | drawKeyboard( p, tmp ); |
775 | } | 790 | } |
776 | } | 791 | } |
777 | 792 | ||
778 | 793 | ||
779 | QSize Keyboard::sizeHint() const | 794 | QSize Keyboard::sizeHint() const |
780 | { | 795 | { |
781 | QFontMetrics fm=fontMetrics(); | 796 | QFontMetrics fm=fontMetrics(); |
782 | int keyHeight = fm.lineSpacing()+2; | 797 | int keyHeight = fm.lineSpacing()+2; |
783 | 798 | ||
784 | if (useOptiKeys) | 799 | if (useOptiKeys) |
785 | keyHeight += 1; | 800 | keyHeight += 1; |
786 | 801 | ||
787 | return QSize( 320, keyHeight * 5 + picks->sizeHint().height() + 1 ); | 802 | return QSize( 320, keyHeight * 5 + picks->sizeHint().height() + 1 ); |
788 | } | 803 | } |
789 | 804 | ||
790 | 805 | ||
791 | void Keyboard::resetState() | 806 | void Keyboard::resetState() |
792 | { | 807 | { |
793 | picks->resetState(); | 808 | picks->resetState(); |
794 | } | 809 | } |