summaryrefslogtreecommitdiffstats
path: root/src/VButton.cpp
diff options
context:
space:
mode:
authorMichele Calgaro <[email protected]>2021-03-13 21:39:00 +0900
committerMichele Calgaro <[email protected]>2021-03-13 21:40:38 +0900
commit18657676cc04c0d2d50edf5bf23d690b0915f27c (patch)
tree7a60b097af43e531b7f174a750e865adf3a55f4f /src/VButton.cpp
parentfb507b7f3fce6a680ab0f5767f4ea58b62e40fba (diff)
downloadkvkbd-18657676cc04c0d2d50edf5bf23d690b0915f27c.tar.gz
kvkbd-18657676cc04c0d2d50edf5bf23d690b0915f27c.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 <[email protected]> (cherry picked from commit 00e207e95d5aab6bbc37c8178bd189b0c0619be6)
Diffstat (limited to 'src/VButton.cpp')
-rw-r--r--src/VButton.cpp75
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"