From: Gerd Hoffmann <kraxel@redhat.com>
To: qemu-devel@nongnu.org
Cc: "Peter Maydell" <peter.maydell@linaro.org>,
"Andreas Färber" <andreas.faerber@web.de>,
"Gerd Hoffmann" <kraxel@redhat.com>,
"Anthony Liguori" <aliguori@amazon.com>
Subject: [Qemu-devel] [PATCH 30/44] input: mouse: switch cocoa ui to new core
Date: Mon, 24 Feb 2014 12:52:37 +0100 [thread overview]
Message-ID: <1393242771-28076-31-git-send-email-kraxel@redhat.com> (raw)
In-Reply-To: <1393242771-28076-1-git-send-email-kraxel@redhat.com>
Build fixes by Peter Maydell.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
---
include/ui/console.h | 2 ++
ui/cocoa.m | 63 ++++++++++++++++++++++++++++++++++------------------
2 files changed, 44 insertions(+), 21 deletions(-)
diff --git a/include/ui/console.h b/include/ui/console.h
index 8543d18..a3062d0 100644
--- a/include/ui/console.h
+++ b/include/ui/console.h
@@ -14,6 +14,8 @@
#define MOUSE_EVENT_LBUTTON 0x01
#define MOUSE_EVENT_RBUTTON 0x02
#define MOUSE_EVENT_MBUTTON 0x04
+#define MOUSE_EVENT_WHEELUP 0x08
+#define MOUSE_EVENT_WHEELDN 0x10
/* identical to the ps/2 keyboard bits */
#define QEMU_SCROLL_LOCK_LED (1 << 0)
diff --git a/ui/cocoa.m b/ui/cocoa.m
index d4af3e5..f20fd1f 100644
--- a/ui/cocoa.m
+++ b/ui/cocoa.m
@@ -27,6 +27,7 @@
#include "qemu-common.h"
#include "ui/console.h"
+#include "ui/input.h"
#include "sysemu/sysemu.h"
#ifndef MAC_OS_X_VERSION_10_4
@@ -49,14 +50,6 @@
#endif
#define cgrect(nsrect) (*(CGRect *)&(nsrect))
-#define COCOA_MOUSE_EVENT \
- if (isTabletEnabled) { \
- kbd_mouse_event((int)(p.x * 0x7FFF / (screen.width - 1)), (int)((screen.height - p.y) * 0x7FFF / (screen.height - 1)), 0, buttons); \
- } else if (isMouseGrabbed) { \
- kbd_mouse_event((int)[event deltaX], (int)[event deltaY], 0, buttons); \
- } else { \
- [NSApp sendEvent:event]; \
- }
typedef struct {
int width;
@@ -67,6 +60,7 @@ typedef struct {
NSWindow *normalWindow;
static DisplayChangeListener *dcl;
+static int last_buttons;
int gArgc;
char **gArgv;
@@ -501,6 +495,7 @@ QemuCocoaView *cocoaView;
int buttons = 0;
int keycode;
+ bool mouse_event = false;
NSPoint p = [event locationInWindow];
switch ([event type]) {
@@ -620,7 +615,7 @@ QemuCocoaView *cocoaView;
}
}
}
- COCOA_MOUSE_EVENT
+ mouse_event = true;
break;
case NSLeftMouseDown:
if ([event modifierFlags] & NSCommandKeyMask) {
@@ -628,15 +623,15 @@ QemuCocoaView *cocoaView;
} else {
buttons |= MOUSE_EVENT_LBUTTON;
}
- COCOA_MOUSE_EVENT
+ mouse_event = true;
break;
case NSRightMouseDown:
buttons |= MOUSE_EVENT_RBUTTON;
- COCOA_MOUSE_EVENT
+ mouse_event = true;
break;
case NSOtherMouseDown:
buttons |= MOUSE_EVENT_MBUTTON;
- COCOA_MOUSE_EVENT
+ mouse_event = true;
break;
case NSLeftMouseDragged:
if ([event modifierFlags] & NSCommandKeyMask) {
@@ -644,19 +639,19 @@ QemuCocoaView *cocoaView;
} else {
buttons |= MOUSE_EVENT_LBUTTON;
}
- COCOA_MOUSE_EVENT
+ mouse_event = true;
break;
case NSRightMouseDragged:
buttons |= MOUSE_EVENT_RBUTTON;
- COCOA_MOUSE_EVENT
+ mouse_event = true;
break;
case NSOtherMouseDragged:
buttons |= MOUSE_EVENT_MBUTTON;
- COCOA_MOUSE_EVENT
+ mouse_event = true;
break;
case NSLeftMouseUp:
if (isTabletEnabled) {
- COCOA_MOUSE_EVENT
+ mouse_event = true;
} else if (!isMouseGrabbed) {
if (p.x > -1 && p.x < screen.width && p.y > -1 && p.y < screen.height) {
[self grabMouse];
@@ -664,18 +659,20 @@ QemuCocoaView *cocoaView;
[NSApp sendEvent:event];
}
} else {
- COCOA_MOUSE_EVENT
+ mouse_event = true;
}
break;
case NSRightMouseUp:
- COCOA_MOUSE_EVENT
+ mouse_event = true;
break;
case NSOtherMouseUp:
- COCOA_MOUSE_EVENT
+ mouse_event = true;
break;
case NSScrollWheel:
if (isTabletEnabled || isMouseGrabbed) {
- kbd_mouse_event(0, 0, -[event deltaY], 0);
+ buttons |= ([event deltaY] < 0) ?
+ MOUSE_EVENT_WHEELUP : MOUSE_EVENT_WHEELDN;
+ mouse_event = true;
} else {
[NSApp sendEvent:event];
}
@@ -683,6 +680,30 @@ QemuCocoaView *cocoaView;
default:
[NSApp sendEvent:event];
}
+
+ if (mouse_event) {
+ if (last_buttons != buttons) {
+ static uint32_t bmap[INPUT_BUTTON_MAX] = {
+ [INPUT_BUTTON_LEFT] = MOUSE_EVENT_LBUTTON,
+ [INPUT_BUTTON_MIDDLE] = MOUSE_EVENT_MBUTTON,
+ [INPUT_BUTTON_RIGHT] = MOUSE_EVENT_RBUTTON,
+ [INPUT_BUTTON_WHEEL_UP] = MOUSE_EVENT_WHEELUP,
+ [INPUT_BUTTON_WHEEL_DOWN] = MOUSE_EVENT_WHEELDN,
+ };
+ qemu_input_update_buttons(dcl->con, bmap, last_buttons, buttons);
+ last_buttons = buttons;
+ }
+ if (isTabletEnabled) {
+ qemu_input_queue_abs(dcl->con, INPUT_AXIS_X, p.x, screen.width);
+ qemu_input_queue_abs(dcl->con, INPUT_AXIS_Y, p.y, screen.height);
+ } else if (isMouseGrabbed) {
+ qemu_input_queue_rel(dcl->con, INPUT_AXIS_X, (int)[event deltaX]);
+ qemu_input_queue_rel(dcl->con, INPUT_AXIS_Y, (int)[event deltaY]);
+ } else {
+ [NSApp sendEvent:event];
+ }
+ qemu_input_event_sync();
+ }
}
- (void) grabMouse
@@ -1017,7 +1038,7 @@ static void cocoa_refresh(DisplayChangeListener *dcl)
COCOA_DEBUG("qemu_cocoa: cocoa_refresh\n");
- if (kbd_mouse_is_absolute()) {
+ if (qemu_input_is_absolute()) {
if (![cocoaView isAbsoluteEnabled]) {
if ([cocoaView isMouseGrabbed]) {
[cocoaView ungrabMouse];
--
1.8.3.1
next prev parent reply other threads:[~2014-02-24 11:53 UTC|newest]
Thread overview: 52+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-02-24 11:52 [Qemu-devel] [PULL v2 00/44] rework input handling, sdl2 support Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 01/44] ui/sdl2 : initial port to SDL 2.0 (v2.0) Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 02/44] sdl2: baum build fix Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 03/44] sdl2: remove text console logic Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 04/44] console: export QemuConsole index, width, height Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 05/44] input: rename file to legacy Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 06/44] input: qapi: define event types Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 07/44] input: qapi: add unmapped key Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 08/44] input: qapi: add pause key Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 09/44] input: add core bits of the new input layer Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 10/44] input: keyboard: add helper functions to core Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 11/44] input: keyboard: switch legacy handlers to new core Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 12/44] input: keyboard: switch qmp_send_key() " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 13/44] input: keyboard: switch gtk ui " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 14/44] input: keyboard: switch sdl " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 15/44] sdl2: switch keyboard handling " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 16/44] input: keyboard: switch vnc ui " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 17/44] input: keyboard: switch spice " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 18/44] input: keyboard: switch curses " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 19/44] input: mouse: add helpers functions to core Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 20/44] input: mouse: add graphic_rotate support Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 21/44] input: mouse: add qemu_input_is_absolute() Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 22/44] input: mouse: switch legacy handlers to new core Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 23/44] input: mouse: switch gtk ui " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 24/44] input: mouse: switch sdl " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 25/44] sdl2: switch mouse handling " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 26/44] input: mouse: switch vnc ui " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 27/44] input: mouse: switch spice " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 28/44] input: mouse: switch monitor " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 29/44] input: keyboard: switch cocoa ui " Gerd Hoffmann
2014-02-24 11:52 ` Gerd Hoffmann [this message]
2014-02-24 12:01 ` [Qemu-devel] [PATCH 30/44] input: mouse: " Andreas Färber
2014-02-24 11:52 ` [Qemu-devel] [PATCH 31/44] input: trace events Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 32/44] input-legacy: remove kbd_put_keycode Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 33/44] input-legacy: remove kbd_mouse_has_absolute Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 34/44] input-legacy: remove kbd_mouse_is_absolute Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 35/44] input-legacy: remove kbd_mouse_event Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 36/44] input: move mouse mode notifier to new core Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 37/44] input: add input_mouse_mode tracepoint Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 38/44] sdl2: simplify keymap handling Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 39/44] sdl2: codestyle fixups Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 40/44] input: move qmp_query_mice to new core Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 41/44] input: move do_mouse_set " Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 42/44] input: remove index_from_keycode (no users) Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 43/44] console: add head to index to qemu consoles Gerd Hoffmann
2014-02-24 11:52 ` [Qemu-devel] [PATCH 44/44] console: add QemuUIInfo Gerd Hoffmann
2014-02-26 20:06 ` [Qemu-devel] [PULL v2 00/44] rework input handling, sdl2 support Peter Maydell
2014-02-27 13:19 ` Gerd Hoffmann
2014-02-27 13:30 ` Peter Maydell
2014-02-27 14:06 ` Gerd Hoffmann
2014-02-27 13:55 ` Eric Blake
2014-02-27 14:04 ` Gerd Hoffmann
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1393242771-28076-31-git-send-email-kraxel@redhat.com \
--to=kraxel@redhat.com \
--cc=aliguori@amazon.com \
--cc=andreas.faerber@web.de \
--cc=peter.maydell@linaro.org \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).