diff options
author | Michele Calgaro <michele.calgaro@yahoo.it> | 2021-03-13 21:39:00 +0900 |
---|---|---|
committer | Michele Calgaro <michele.calgaro@yahoo.it> | 2021-03-13 21:39:00 +0900 |
commit | 00e207e95d5aab6bbc37c8178bd189b0c0619be6 (patch) | |
tree | d7ce4d55e87a33ec2bb9e20ed209fedae90e4096 /src/VButton.cpp | |
parent | fb22ce0a5666025d9964522561f83d9b6008e4ad (diff) | |
download | kvkbd-00e207e95d5aab6bbc37c8178bd189b0c0619be6.tar.gz kvkbd-00e207e95d5aab6bbc37c8178bd189b0c0619be6.zip |
Fixed key text display when shift is used (caps is still broken) as well
as several improvements to the code.
Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it>
Diffstat (limited to 'src/VButton.cpp')
-rw-r--r-- | src/VButton.cpp | 75 |
1 files changed, 41 insertions, 34 deletions
diff --git a/src/VButton.cpp b/src/VButton.cpp index b4870f1..cabedd1 100644 --- a/src/VButton.cpp +++ b/src/VButton.cpp @@ -23,33 +23,12 @@ VButton::~VButton() void VButton::shiftPressed(bool press) { - if (press==true){ - TQString tu=l.upper(); - if (tu.compare(l)==0){ - //TQPushButton::setText(tu); - TQPushButton::setText(u); - } - else{ - TQPushButton::setText(tu); - } + if (press) + { + TQPushButton::setText(u); } - else{ - TQPushButton::setText(l); - } -} - -void VButton::capsPressed(bool press) -{ - if (press==true){ - TQString tu=l.upper(); - if (tu.compare(l)==0){ - TQPushButton::setText(tu); - } - else{ - TQPushButton::setText(u); - } - } - else{ + else + { TQPushButton::setText(l); } } @@ -107,34 +86,62 @@ void VButton::res() orig_size=geometry(); } -void VButton::mousePressEvent(TQMouseEvent * e) +void VButton::enterEvent(TQEvent *e) +{ + TQPushButton::enterEvent(e); + inside = true; +} + +void VButton::leaveEvent(TQEvent *e) +{ + TQPushButton::leaveEvent(e); + inside = false; +} + +void VButton::mousePressEvent(TQMouseEvent *e) { press=true; TQPushButton::mousePressEvent(e); - sendKey(); - startTimer(500); + if (!isToggleButton()) + { + // non toggle buttons need to send the key here + sendKey(); + startTimer(500); + } } -void VButton::mouseReleaseEvent(TQMouseEvent * e) +void VButton::mouseReleaseEvent(TQMouseEvent *e) { press=false; TQPushButton::mouseReleaseEvent(e); - TQT_TQOBJECT(this)->killTimers(); + if (hitButton(e->pos()) && isToggleButton()) + { + // toggle buttons need to send the key here because the underlying pushbutton state + // is only updated on mouse release + sendKey(); + } + killTimers(); inrpt=false; } void VButton::timerEvent(TQTimerEvent *) { - if (!press){ + if (!press) + { inrpt=false; return; } - if (press && !inrpt) { + if (press && !inrpt) + { inrpt=true; startTimer(120); return; } - sendKey(); + if (inside) + { + // Send key only if the mouse is still inside the button rectangle + sendKey(); + } } #include "VButton.moc" |