mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-10 17:35:59 +00:00
d3d12videosink: Handle mouse double click and modifier
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6693>
This commit is contained in:
parent
824c70d35a
commit
8e4fe98361
2 changed files with 52 additions and 9 deletions
|
@ -176,7 +176,7 @@ static void gst_d3d12_video_sink_set_orientation (GstD3D12VideoSink * self,
|
||||||
static void gst_d3d12_video_sink_key_event (GstD3D12Window * window,
|
static void gst_d3d12_video_sink_key_event (GstD3D12Window * window,
|
||||||
const gchar * event, const gchar * key, GstD3D12VideoSink * self);
|
const gchar * event, const gchar * key, GstD3D12VideoSink * self);
|
||||||
static void gst_d3d12_video_sink_mouse_event (GstD3D12Window * window,
|
static void gst_d3d12_video_sink_mouse_event (GstD3D12Window * window,
|
||||||
const gchar * event, gint button, gdouble x, gdouble y,
|
const gchar * event, gint button, gdouble x, gdouble y, guint modifier,
|
||||||
GstD3D12VideoSink * self);
|
GstD3D12VideoSink * self);
|
||||||
static void gst_d3d12_video_sink_on_fullscreen (GstD3D12Window * window,
|
static void gst_d3d12_video_sink_on_fullscreen (GstD3D12Window * window,
|
||||||
gboolean is_fullscreen, GstD3D12VideoSink * self);
|
gboolean is_fullscreen, GstD3D12VideoSink * self);
|
||||||
|
@ -683,7 +683,7 @@ gst_d3d12_video_sink_key_event (GstD3D12Window * window, const gchar * event,
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_d3d12_video_sink_mouse_event (GstD3D12Window * window, const gchar * event,
|
gst_d3d12_video_sink_mouse_event (GstD3D12Window * window, const gchar * event,
|
||||||
gint button, gdouble x, gdouble y, GstD3D12VideoSink * self)
|
gint button, gdouble x, gdouble y, guint modifier, GstD3D12VideoSink * self)
|
||||||
{
|
{
|
||||||
GstEvent *mouse_event;
|
GstEvent *mouse_event;
|
||||||
|
|
||||||
|
@ -691,13 +691,16 @@ gst_d3d12_video_sink_mouse_event (GstD3D12Window * window, const gchar * event,
|
||||||
"send mouse event %s, button %d (%.1f, %.1f)", event, button, x, y);
|
"send mouse event %s, button %d (%.1f, %.1f)", event, button, x, y);
|
||||||
if (g_strcmp0 ("mouse-button-press", event) == 0) {
|
if (g_strcmp0 ("mouse-button-press", event) == 0) {
|
||||||
mouse_event = gst_navigation_event_new_mouse_button_press (button, x, y,
|
mouse_event = gst_navigation_event_new_mouse_button_press (button, x, y,
|
||||||
GST_NAVIGATION_MODIFIER_NONE);
|
(GstNavigationModifierType) modifier);
|
||||||
} else if (g_strcmp0 ("mouse-button-release", event) == 0) {
|
} else if (g_strcmp0 ("mouse-button-release", event) == 0) {
|
||||||
mouse_event = gst_navigation_event_new_mouse_button_release (button, x, y,
|
mouse_event = gst_navigation_event_new_mouse_button_release (button, x, y,
|
||||||
GST_NAVIGATION_MODIFIER_NONE);
|
(GstNavigationModifierType) modifier);
|
||||||
} else if (g_strcmp0 ("mouse-move", event) == 0) {
|
} else if (g_strcmp0 ("mouse-move", event) == 0) {
|
||||||
mouse_event = gst_navigation_event_new_mouse_move (x, y,
|
mouse_event = gst_navigation_event_new_mouse_move (x, y,
|
||||||
GST_NAVIGATION_MODIFIER_NONE);
|
(GstNavigationModifierType) modifier);
|
||||||
|
} else if (g_strcmp0 ("mouse-double-click", event) == 0) {
|
||||||
|
mouse_event = gst_navigation_event_new_mouse_double_click (button, x, y,
|
||||||
|
(GstNavigationModifierType) modifier);
|
||||||
} else {
|
} else {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,6 +50,15 @@ GST_DEBUG_CATEGORY_STATIC (gst_d3d12_window_debug);
|
||||||
|
|
||||||
#define BACK_BUFFER_COUNT 3
|
#define BACK_BUFFER_COUNT 3
|
||||||
|
|
||||||
|
/* windowsx.h */
|
||||||
|
#ifndef GET_X_LPARAM
|
||||||
|
#define GET_X_LPARAM(lp) ((int)(short)LOWORD(lp))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef GET_Y_LPARAM
|
||||||
|
#define GET_Y_LPARAM(lp) ((int)(short)HIWORD(lp))
|
||||||
|
#endif
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
SIGNAL_KEY_EVENT,
|
SIGNAL_KEY_EVENT,
|
||||||
|
@ -260,7 +269,8 @@ gst_d3d12_window_class_init (GstD3D12WindowClass * klass)
|
||||||
d3d12_window_signals[SIGNAL_MOUSE_EVENT] =
|
d3d12_window_signals[SIGNAL_MOUSE_EVENT] =
|
||||||
g_signal_new ("mouse-event", G_TYPE_FROM_CLASS (klass),
|
g_signal_new ("mouse-event", G_TYPE_FROM_CLASS (klass),
|
||||||
G_SIGNAL_RUN_LAST, 0, nullptr, nullptr, nullptr,
|
G_SIGNAL_RUN_LAST, 0, nullptr, nullptr, nullptr,
|
||||||
G_TYPE_NONE, 4, G_TYPE_STRING, G_TYPE_INT, G_TYPE_DOUBLE, G_TYPE_DOUBLE);
|
G_TYPE_NONE, 5, G_TYPE_STRING, G_TYPE_INT, G_TYPE_DOUBLE, G_TYPE_DOUBLE,
|
||||||
|
G_TYPE_UINT);
|
||||||
|
|
||||||
d3d12_window_signals[SIGNAL_FULLSCREEN] =
|
d3d12_window_signals[SIGNAL_FULLSCREEN] =
|
||||||
g_signal_new ("fullscreen", G_TYPE_FROM_CLASS (klass),
|
g_signal_new ("fullscreen", G_TYPE_FROM_CLASS (klass),
|
||||||
|
@ -319,6 +329,7 @@ gst_d3d12_window_on_mouse_event (GstD3D12Window * self, UINT msg, WPARAM wparam,
|
||||||
auto priv = self->priv;
|
auto priv = self->priv;
|
||||||
gint button = 0;
|
gint button = 0;
|
||||||
const gchar *event = nullptr;
|
const gchar *event = nullptr;
|
||||||
|
guint modifier = 0;
|
||||||
|
|
||||||
switch (msg) {
|
switch (msg) {
|
||||||
case WM_MOUSEMOVE:
|
case WM_MOUSEMOVE:
|
||||||
|
@ -333,6 +344,10 @@ gst_d3d12_window_on_mouse_event (GstD3D12Window * self, UINT msg, WPARAM wparam,
|
||||||
button = 1;
|
button = 1;
|
||||||
event = "mouse-button-release";
|
event = "mouse-button-release";
|
||||||
break;
|
break;
|
||||||
|
case WM_LBUTTONDBLCLK:
|
||||||
|
button = 1;
|
||||||
|
event = "mouse-double-click";
|
||||||
|
break;
|
||||||
case WM_RBUTTONDOWN:
|
case WM_RBUTTONDOWN:
|
||||||
button = 2;
|
button = 2;
|
||||||
event = "mouse-button-press";
|
event = "mouse-button-press";
|
||||||
|
@ -341,6 +356,10 @@ gst_d3d12_window_on_mouse_event (GstD3D12Window * self, UINT msg, WPARAM wparam,
|
||||||
button = 2;
|
button = 2;
|
||||||
event = "mouse-button-release";
|
event = "mouse-button-release";
|
||||||
break;
|
break;
|
||||||
|
case WM_RBUTTONDBLCLK:
|
||||||
|
button = 2;
|
||||||
|
event = "mouse-double-click";
|
||||||
|
break;
|
||||||
case WM_MBUTTONDOWN:
|
case WM_MBUTTONDOWN:
|
||||||
button = 3;
|
button = 3;
|
||||||
event = "mouse-button-press";
|
event = "mouse-button-press";
|
||||||
|
@ -349,10 +368,25 @@ gst_d3d12_window_on_mouse_event (GstD3D12Window * self, UINT msg, WPARAM wparam,
|
||||||
button = 3;
|
button = 3;
|
||||||
event = "mouse-button-release";
|
event = "mouse-button-release";
|
||||||
break;
|
break;
|
||||||
|
case WM_MBUTTONDBLCLK:
|
||||||
|
button = 3;
|
||||||
|
event = "mouse-double-click";
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((wparam & MK_CONTROL) != 0)
|
||||||
|
modifier |= GST_NAVIGATION_MODIFIER_CONTROL_MASK;
|
||||||
|
if ((wparam & MK_LBUTTON) != 0)
|
||||||
|
modifier |= GST_NAVIGATION_MODIFIER_BUTTON1_MASK;
|
||||||
|
if ((wparam & MK_RBUTTON) != 0)
|
||||||
|
modifier |= GST_NAVIGATION_MODIFIER_BUTTON2_MASK;
|
||||||
|
if ((wparam & MK_MBUTTON) != 0)
|
||||||
|
modifier |= GST_NAVIGATION_MODIFIER_BUTTON3_MASK;
|
||||||
|
if ((wparam & MK_SHIFT) != 0)
|
||||||
|
modifier |= GST_NAVIGATION_MODIFIER_SHIFT_MASK;
|
||||||
|
|
||||||
GstVideoRectangle output_rect = { };
|
GstVideoRectangle output_rect = { };
|
||||||
GstVideoOrientationMethod orientation;
|
GstVideoOrientationMethod orientation;
|
||||||
gint in_w, in_h;
|
gint in_w, in_h;
|
||||||
|
@ -363,8 +397,8 @@ gst_d3d12_window_on_mouse_event (GstD3D12Window * self, UINT msg, WPARAM wparam,
|
||||||
in_w = priv->input_info.width;
|
in_w = priv->input_info.width;
|
||||||
in_h = priv->input_info.height;
|
in_h = priv->input_info.height;
|
||||||
}
|
}
|
||||||
auto xpos = LOWORD (lparam);
|
auto xpos = GET_X_LPARAM (lparam);
|
||||||
auto ypos = HIWORD (lparam);
|
auto ypos = GET_Y_LPARAM (lparam);
|
||||||
|
|
||||||
if (in_w <= 0 || in_h <= 0 || xpos < output_rect.x ||
|
if (in_w <= 0 || in_h <= 0 || xpos < output_rect.x ||
|
||||||
xpos >= output_rect.x + output_rect.w || ypos < output_rect.y ||
|
xpos >= output_rect.x + output_rect.w || ypos < output_rect.y ||
|
||||||
|
@ -432,7 +466,7 @@ gst_d3d12_window_on_mouse_event (GstD3D12Window * self, UINT msg, WPARAM wparam,
|
||||||
}
|
}
|
||||||
|
|
||||||
g_signal_emit (self, d3d12_window_signals[SIGNAL_MOUSE_EVENT], 0,
|
g_signal_emit (self, d3d12_window_signals[SIGNAL_MOUSE_EVENT], 0,
|
||||||
event, button, final_x, final_y);
|
event, button, final_x, final_y, modifier);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -656,6 +690,9 @@ gst_d3d12_window_proc (HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam)
|
||||||
case WM_MBUTTONDOWN:
|
case WM_MBUTTONDOWN:
|
||||||
case WM_MBUTTONUP:
|
case WM_MBUTTONUP:
|
||||||
case WM_MOUSEMOVE:
|
case WM_MOUSEMOVE:
|
||||||
|
case WM_LBUTTONDBLCLK:
|
||||||
|
case WM_RBUTTONDBLCLK:
|
||||||
|
case WM_MBUTTONDBLCLK:
|
||||||
{
|
{
|
||||||
auto self = gst_d3d12_window_from_hwnd (hwnd);
|
auto self = gst_d3d12_window_from_hwnd (hwnd);
|
||||||
if (self) {
|
if (self) {
|
||||||
|
@ -884,6 +921,9 @@ sub_class_proc (HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam)
|
||||||
case WM_MBUTTONDOWN:
|
case WM_MBUTTONDOWN:
|
||||||
case WM_MBUTTONUP:
|
case WM_MBUTTONUP:
|
||||||
case WM_MOUSEMOVE:
|
case WM_MOUSEMOVE:
|
||||||
|
case WM_LBUTTONDBLCLK:
|
||||||
|
case WM_RBUTTONDBLCLK:
|
||||||
|
case WM_MBUTTONDBLCLK:
|
||||||
if (priv->enable_navigation)
|
if (priv->enable_navigation)
|
||||||
gst_d3d12_window_on_mouse_event (self, msg, wparam, lparam);
|
gst_d3d12_window_on_mouse_event (self, msg, wparam, lparam);
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue