summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--nuttx/graphics/nxmu/nxmu_mouse.c32
-rw-r--r--nuttx/graphics/nxsu/nx_mousein.c14
2 files changed, 35 insertions, 11 deletions
diff --git a/nuttx/graphics/nxmu/nxmu_mouse.c b/nuttx/graphics/nxmu/nxmu_mouse.c
index 5650c8dd2..922b12c93 100644
--- a/nuttx/graphics/nxmu/nxmu_mouse.c
+++ b/nuttx/graphics/nxmu/nxmu_mouse.c
@@ -106,16 +106,30 @@ void nxmu_mousereport(struct nxbe_window_s *wnd)
struct nxclimsg_mousein_s outmsg;
int ret;
- outmsg.msgid = NX_CLIMSG_MOUSEIN;
- outmsg.wnd = wnd;
- outmsg.pos.x = g_mpos.x;
- outmsg.pos.y = g_mpos.y;
- outmsg.buttons = g_mbutton;
-
- ret = mq_send(wnd->conn->swrmq, outmsg, sizeof(struct nxclimsg_mousein_s), NX_SVRMSG_PRIO);
- if (ret < 0)
+ /* Does this window support mouse callbacks? */
+
+ if (win->cb->mousein)
{
- gdbg("mq_send failed: %d\n", errno);
+ /* Yes.. Does the mount position lie within the window? */
+
+ if (nxgl_rectinside(wnd->bounds, g_mpos))
+ {
+ /* Yes... Convert the mouse position to window relative
+ * coordinates and send it to the client
+ */
+
+ outmsg.msgid = NX_CLIMSG_MOUSEIN;
+ outmsg.wnd = wnd;
+ outmsg.buttons = g_mbutton;
+ nxgl_vectsubtract(&outmsg.pos, g_mpos, wnd->origin);
+
+ ret = mq_send(wnd->conn->swrmq, outmsg,
+ sizeof(struct nxclimsg_mousein_s), NX_SVRMSG_PRIO);
+ if (ret < 0)
+ {
+ gdbg("mq_send failed: %d\n", errno);
+ }
+ }
}
}
diff --git a/nuttx/graphics/nxsu/nx_mousein.c b/nuttx/graphics/nxsu/nx_mousein.c
index 2ae753b94..31c9483d2 100644
--- a/nuttx/graphics/nxsu/nx_mousein.c
+++ b/nuttx/graphics/nxsu/nx_mousein.c
@@ -103,11 +103,21 @@ void nxsu_mouseinit(int x, int y)
void nxsu_mousereport(struct nxbe_window_s *wnd)
{
- /* Give the keypad event only to the top child */
+ struct nxgl_point_s relpos;
+
+ /* Does this window support mouse callbacks? */
if (win->cb->mousein)
{
- win->cb->mousein((NXWINDOW)wnd, &g_mpos, g_mbutton, wnd->arg);
+ /* Yes.. Does the mount position lie within the window? */
+
+ if (nxgl_rectinside(wnd->bounds, g_mpos))
+ {
+ /* Yes... Convert the mouse position to window relative coordinates */
+
+ nxgl_vectsubtract(&relpos, g_mpos, wnd->origin);
+ win->cb->mousein((NXWINDOW)wnd, &relpos, g_mbutton, wnd->arg);
+ }
}
}