diff options
Diffstat (limited to 'backend')
| -rw-r--r-- | backend/drm/drm.c | 43 | ||||
| -rw-r--r-- | backend/wayland/output.c | 11 | ||||
| -rw-r--r-- | backend/wayland/wl_seat.c | 2 | 
3 files changed, 45 insertions, 11 deletions
| diff --git a/backend/drm/drm.c b/backend/drm/drm.c index fc376b54..9e5346a1 100644 --- a/backend/drm/drm.c +++ b/backend/drm/drm.c @@ -469,7 +469,8 @@ static void wlr_drm_connector_transform(struct wlr_output *output,  }  static bool wlr_drm_connector_set_cursor(struct wlr_output *output, -		const uint8_t *buf, int32_t stride, uint32_t width, uint32_t height) { +		const uint8_t *buf, int32_t stride, uint32_t width, uint32_t height, +		int32_t hotspot_x, int32_t hotspot_y) {  	struct wlr_drm_connector *conn = (struct wlr_drm_connector *)output;  	struct wlr_drm_backend *drm = conn->drm;  	struct wlr_drm_renderer *renderer = &drm->renderer; @@ -534,6 +535,37 @@ static bool wlr_drm_connector_set_cursor(struct wlr_output *output,  		}  	} +	switch (output->transform) { +	case WL_OUTPUT_TRANSFORM_90: +		output->cursor.hotspot_x = hotspot_x; +		output->cursor.hotspot_y = -plane->surf.height + hotspot_y; +		break; +	case WL_OUTPUT_TRANSFORM_180: +		output->cursor.hotspot_x = plane->surf.width - hotspot_x; +		output->cursor.hotspot_y = plane->surf.height - hotspot_y; +		break; +	case WL_OUTPUT_TRANSFORM_270: +		output->cursor.hotspot_x = -plane->surf.height + hotspot_x; +		output->cursor.hotspot_y = hotspot_y; +		break; +	case WL_OUTPUT_TRANSFORM_FLIPPED: +		output->cursor.hotspot_x = plane->surf.width - hotspot_x; +		output->cursor.hotspot_y = hotspot_y; +		break; +	case WL_OUTPUT_TRANSFORM_FLIPPED_90: +		output->cursor.hotspot_x = hotspot_x; +		output->cursor.hotspot_y = -hotspot_y; +		break; +	case WL_OUTPUT_TRANSFORM_FLIPPED_180: +		output->cursor.hotspot_x = hotspot_x; +		output->cursor.hotspot_y = plane->surf.height - hotspot_y; +		break; +	case WL_OUTPUT_TRANSFORM_FLIPPED_270: +		output->cursor.hotspot_x = -plane->surf.height + hotspot_x; +		output->cursor.hotspot_y = plane->surf.width - hotspot_y; +		break; +	} +  	struct gbm_bo *bo = plane->cursor_bo;  	uint32_t bo_width = gbm_bo_get_width(bo);  	uint32_t bo_height = gbm_bo_get_height(bo); @@ -581,23 +613,22 @@ static bool wlr_drm_connector_move_cursor(struct wlr_output *output,  	switch (output->transform) {  	case WL_OUTPUT_TRANSFORM_NORMAL: +	case WL_OUTPUT_TRANSFORM_FLIPPED: +	case WL_OUTPUT_TRANSFORM_FLIPPED_180:  		// nothing to do  		break;  	case WL_OUTPUT_TRANSFORM_270: +	case WL_OUTPUT_TRANSFORM_FLIPPED_270:  		tmp = x;  		x = y;  		y = -(tmp - width);  		break;  	case WL_OUTPUT_TRANSFORM_90: +	case WL_OUTPUT_TRANSFORM_FLIPPED_90:  		tmp = x;  		x = -(y - height);  		y = tmp;  		break; -	default: -		// TODO other transformations -		wlr_log(L_ERROR, "TODO: handle surface to crtc for transformation = %d", -			output->transform); -		break;  	}  	return drm->iface->crtc_move_cursor(drm, conn->crtc, x, y); diff --git a/backend/wayland/output.c b/backend/wayland/output.c index ba04aede..062a91a1 100644 --- a/backend/wayland/output.c +++ b/backend/wayland/output.c @@ -53,7 +53,8 @@ static void wlr_wl_output_transform(struct wlr_output *_output,  }  static bool wlr_wl_output_set_cursor(struct wlr_output *_output, -		const uint8_t *buf, int32_t stride, uint32_t width, uint32_t height) { +		const uint8_t *buf, int32_t stride, uint32_t width, uint32_t height, +		int32_t hotspot_x, int32_t hotspot_y) {  	struct wlr_wl_backend_output *output = (struct wlr_wl_backend_output *)_output;  	struct wlr_wl_backend *backend = output->backend; @@ -110,7 +111,8 @@ static bool wlr_wl_output_set_cursor(struct wlr_output *_output,  	wl_surface_damage(output->cursor_surface, 0, 0, width, height);  	wl_surface_commit(output->cursor_surface); -	wlr_wl_output_update_cursor(output, output->enter_serial); +	wlr_wl_output_update_cursor(output, output->enter_serial, +		hotspot_x, hotspot_y);  	return true;  } @@ -143,10 +145,11 @@ static void wlr_wl_output_destroy(struct wlr_output *_output) {  	free(output);  } -void wlr_wl_output_update_cursor(struct wlr_wl_backend_output *output, uint32_t serial) { +void wlr_wl_output_update_cursor(struct wlr_wl_backend_output *output, +			uint32_t serial, int32_t hotspot_x, int32_t hotspot_y) {  	if (output->cursor_surface && output->backend->pointer && serial) {  		wl_pointer_set_cursor(output->backend->pointer, serial, -			output->cursor_surface, 0, 0); +			output->cursor_surface, hotspot_x, hotspot_y);  	}  } diff --git a/backend/wayland/wl_seat.c b/backend/wayland/wl_seat.c index ba3feb8d..e834f8b4 100644 --- a/backend/wayland/wl_seat.c +++ b/backend/wayland/wl_seat.c @@ -24,7 +24,7 @@ static void pointer_handle_enter(void *data, struct wl_pointer *wl_pointer,  	assert(output);  	wlr_wl_pointer->current_output = output;  	wlr_wl_pointer->current_output->enter_serial = serial; -	wlr_wl_output_update_cursor(wlr_wl_pointer->current_output, serial); +	wlr_wl_output_update_cursor(wlr_wl_pointer->current_output, serial, 0, 0);  }  static void pointer_handle_leave(void *data, struct wl_pointer *wl_pointer, | 
