libs/libnx/nxtk/nxtk_events: Fix an error in handling mouse events for framed windows. When drawing, NX may report mouse positions outside of the Window. The is only for NX windows, but the outside-the-side positions were being discarded by nxtk_events().
This commit is contained in:
parent
0ac8b5b8f6
commit
a312503ed2
3 changed files with 48 additions and 9 deletions
|
@ -54,6 +54,10 @@
|
|||
* Private Data
|
||||
****************************************************************************/
|
||||
|
||||
/* REVISIT: These globals will prevent this code from being used in an
|
||||
* environment with more than one display. FIX ME!
|
||||
*/
|
||||
|
||||
static struct nxgl_point_s g_mpos;
|
||||
static struct nxgl_point_s g_mrange;
|
||||
static uint8_t g_mbutton;
|
||||
|
@ -198,7 +202,7 @@ int nxmu_mousein(FAR struct nxmu_state_s *nxmu,
|
|||
y = g_mrange.y - 1;
|
||||
}
|
||||
|
||||
/* Look any change in values */
|
||||
/* Look for any change in values */
|
||||
|
||||
if (x != g_mpos.x || y != g_mpos.y || buttons != g_mbutton)
|
||||
{
|
||||
|
@ -211,13 +215,13 @@ int nxmu_mousein(FAR struct nxmu_state_s *nxmu,
|
|||
|
||||
/* If a button is already down, regard this as part of a mouse drag
|
||||
* event. Pass all the following events to the window where the drag
|
||||
* started in.
|
||||
* started in, including the final button release event.
|
||||
*/
|
||||
|
||||
if (oldbuttons)
|
||||
if (oldbuttons != 0)
|
||||
{
|
||||
g_mwnd = nxmu_revalidate_g_mwnd(nxmu->be.topwnd);
|
||||
if (g_mwnd && g_mwnd->cb->mousein)
|
||||
if (g_mwnd != NULL && g_mwnd->cb->mousein)
|
||||
{
|
||||
struct nxclimsg_mousein_s outmsg;
|
||||
outmsg.msgid = NX_CLIMSG_MOUSEIN;
|
||||
|
|
|
@ -67,7 +67,7 @@ int nx_mousein(NXHANDLE handle, nxgl_coord_t x, nxgl_coord_t y, uint8_t buttons)
|
|||
FAR struct nxmu_conn_s *conn = (FAR struct nxmu_conn_s *)handle;
|
||||
struct nxsvrmsg_mousein_s outmsg;
|
||||
|
||||
/* Inform the server that this client no longer exists */
|
||||
/* Inform the server of the new mouse position */
|
||||
|
||||
outmsg.msgid = NX_SVRMSG_MOUSEIN;
|
||||
outmsg.pt.x = x;
|
||||
|
|
|
@ -204,7 +204,7 @@ static void nxtk_position(NXWINDOW hwnd, FAR const struct nxgl_size_s *size,
|
|||
|
||||
#ifdef CONFIG_NX_XYINPUT
|
||||
static void nxtk_mousein(NXWINDOW hwnd, FAR const struct nxgl_point_s *pos,
|
||||
uint8_t buttons, FAR void *arg)
|
||||
uint8_t buttons, FAR void *arg)
|
||||
{
|
||||
FAR struct nxtk_framedwindow_s *fwnd = (FAR struct nxtk_framedwindow_s *)hwnd;
|
||||
struct nxgl_point_s abspos;
|
||||
|
@ -256,15 +256,50 @@ static void nxtk_mousein(NXWINDOW hwnd, FAR const struct nxgl_point_s *pos,
|
|||
|
||||
/* Is the mouse position inside of the client window region? */
|
||||
|
||||
if (fwnd->fwcb->mousein && nxgl_rectinside(&fwnd->fwrect, &fwnd->mpos))
|
||||
if (fwnd->fwcb->mousein != NULL &&
|
||||
nxgl_rectinside(&fwnd->fwrect, &fwnd->mpos))
|
||||
{
|
||||
nxgl_vectsubtract(&relpos, &abspos, &fwnd->fwrect.pt1);
|
||||
fwnd->fwcb->mousein((NXTKWINDOW)fwnd, &relpos, buttons, fwnd->fwarg);
|
||||
}
|
||||
|
||||
/* If the mouse position inside the toobar region? */
|
||||
/* If the mouse position inside the toolbar region? */
|
||||
|
||||
else if (fwnd->tbcb->mousein && nxgl_rectinside(&fwnd->tbrect, &fwnd->mpos))
|
||||
else if (fwnd->tbcb->mousein != NULL &&
|
||||
nxgl_rectinside(&fwnd->tbrect, &fwnd->mpos))
|
||||
{
|
||||
nxgl_vectsubtract(&relpos, &abspos, &fwnd->tbrect.pt1);
|
||||
fwnd->tbcb->mousein((NXTKWINDOW)fwnd, &relpos, buttons, fwnd->tbarg);
|
||||
}
|
||||
|
||||
/* REVISIT: Missing logic to detect border events.
|
||||
*
|
||||
* NOTE that the following logic is completely redundant! All of the
|
||||
* above tests could be eliminated and only the following performed with
|
||||
* the same result. These tests are separated from the above only to
|
||||
* guarantee a spot for future border mouse event event detection which
|
||||
* would go about here.
|
||||
*/
|
||||
|
||||
/* As a complexity, when dragging mouse events outside of the containing
|
||||
* raw window will be sent to this function as well. We will need to pass
|
||||
* these outside-the-window reports as well.
|
||||
*
|
||||
* If the mouse report is below the toolbar, then we will report this
|
||||
* as a main window event.
|
||||
*/
|
||||
|
||||
else if (fwnd->fwcb->mousein != NULL &&
|
||||
pos->y >= fwnd->tbheight + CONFIG_NXTK_BORDERWIDTH)
|
||||
{
|
||||
nxgl_vectsubtract(&relpos, &abspos, &fwnd->fwrect.pt1);
|
||||
fwnd->fwcb->mousein((NXTKWINDOW)fwnd, &relpos, buttons, fwnd->fwarg);
|
||||
}
|
||||
|
||||
/* Otherwise, we will report this as a toolbar event. */
|
||||
|
||||
else if (fwnd->tbcb->mousein != NULL &&
|
||||
pos->y < fwnd->tbheight + CONFIG_NXTK_BORDERWIDTH)
|
||||
{
|
||||
nxgl_vectsubtract(&relpos, &abspos, &fwnd->tbrect.pt1);
|
||||
fwnd->tbcb->mousein((NXTKWINDOW)fwnd, &relpos, buttons, fwnd->tbarg);
|
||||
|
|
Loading…
Reference in a new issue