cursor-renderer/native: Scale hotspot correctly
This got lost during the switch to the KMS cursor manager.
Fixes: e52641c4b6
("cursor-renderer/native: Replace HW cursor with KMS cursor manager")
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3147>
This commit is contained in:
parent
730efb17d7
commit
6ea816184d
@ -562,6 +562,25 @@ create_cursor_drm_buffer (MetaGpuKms *gpu_kms,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
calculate_crtc_cursor_hotspot (MetaCursorSprite *cursor_sprite,
|
||||||
|
float scale,
|
||||||
|
MetaMonitorTransform transform,
|
||||||
|
graphene_point_t *hotspot)
|
||||||
|
{
|
||||||
|
int hot_x, hot_y;
|
||||||
|
int width, height;
|
||||||
|
|
||||||
|
meta_cursor_sprite_get_hotspot (cursor_sprite, &hot_x, &hot_y);
|
||||||
|
width = meta_cursor_sprite_get_width (cursor_sprite);
|
||||||
|
height = meta_cursor_sprite_get_height (cursor_sprite);
|
||||||
|
meta_monitor_transform_transform_point (transform,
|
||||||
|
width, height,
|
||||||
|
hot_x, hot_y,
|
||||||
|
&hot_x, &hot_y);
|
||||||
|
*hotspot = GRAPHENE_POINT_INIT (hot_x * scale, hot_y * scale);
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
load_cursor_sprite_gbm_buffer_for_crtc (MetaCursorRendererNative *native,
|
load_cursor_sprite_gbm_buffer_for_crtc (MetaCursorRendererNative *native,
|
||||||
MetaCrtcKms *crtc_kms,
|
MetaCrtcKms *crtc_kms,
|
||||||
@ -571,6 +590,7 @@ load_cursor_sprite_gbm_buffer_for_crtc (MetaCursorRendererNative *native,
|
|||||||
uint height,
|
uint height,
|
||||||
int rowstride,
|
int rowstride,
|
||||||
float scale,
|
float scale,
|
||||||
|
MetaMonitorTransform transform,
|
||||||
uint32_t gbm_format)
|
uint32_t gbm_format)
|
||||||
{
|
{
|
||||||
MetaCursorRendererNativePrivate *priv =
|
MetaCursorRendererNativePrivate *priv =
|
||||||
@ -588,7 +608,7 @@ load_cursor_sprite_gbm_buffer_for_crtc (MetaCursorRendererNative *native,
|
|||||||
MetaCursorRendererNativeGpuData *cursor_renderer_gpu_data;
|
MetaCursorRendererNativeGpuData *cursor_renderer_gpu_data;
|
||||||
g_autoptr (MetaDeviceFile) device_file = NULL;
|
g_autoptr (MetaDeviceFile) device_file = NULL;
|
||||||
g_autoptr (GError) error = NULL;
|
g_autoptr (GError) error = NULL;
|
||||||
int hot_x, hot_y;
|
graphene_point_t hotspot;
|
||||||
|
|
||||||
cursor_renderer_gpu_data =
|
cursor_renderer_gpu_data =
|
||||||
meta_cursor_renderer_native_gpu_data_from_gpu (gpu_kms);
|
meta_cursor_renderer_native_gpu_data_from_gpu (gpu_kms);
|
||||||
@ -632,12 +652,13 @@ load_cursor_sprite_gbm_buffer_for_crtc (MetaCursorRendererNative *native,
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
meta_cursor_sprite_get_hotspot (cursor_sprite, &hot_x, &hot_y);
|
calculate_crtc_cursor_hotspot (cursor_sprite, scale, transform, &hotspot);
|
||||||
|
|
||||||
kms_crtc = meta_crtc_kms_get_kms_crtc (crtc_kms);
|
kms_crtc = meta_crtc_kms_get_kms_crtc (crtc_kms);
|
||||||
meta_kms_cursor_manager_update_sprite (kms_cursor_manager,
|
meta_kms_cursor_manager_update_sprite (kms_cursor_manager,
|
||||||
kms_crtc,
|
kms_crtc,
|
||||||
buffer,
|
buffer,
|
||||||
&GRAPHENE_POINT_INIT (hot_x, hot_y));
|
&hotspot);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -768,6 +789,7 @@ load_scaled_and_transformed_cursor_sprite (MetaCursorRendererNative *native,
|
|||||||
cairo_image_surface_get_width (surface),
|
cairo_image_surface_get_width (surface),
|
||||||
cairo_image_surface_get_stride (surface),
|
cairo_image_surface_get_stride (surface),
|
||||||
relative_scale,
|
relative_scale,
|
||||||
|
relative_transform,
|
||||||
GBM_FORMAT_ARGB8888);
|
GBM_FORMAT_ARGB8888);
|
||||||
|
|
||||||
cairo_surface_destroy (surface);
|
cairo_surface_destroy (surface);
|
||||||
@ -782,6 +804,7 @@ load_scaled_and_transformed_cursor_sprite (MetaCursorRendererNative *native,
|
|||||||
height,
|
height,
|
||||||
rowstride,
|
rowstride,
|
||||||
relative_scale,
|
relative_scale,
|
||||||
|
relative_transform,
|
||||||
gbm_format);
|
gbm_format);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user