mirror of
https://github.com/libsdl-org/SDL.git
synced 2025-05-17 02:08:27 +00:00
render: Restore previous policy for converting window/render coordinates.
Before this commit, it would adjust for the logical presentation settings. Now, it works as it did before the logical presentation render target was removed: it takes current viewport and scale into account, as well. Fixes #10978.
This commit is contained in:
parent
3246df8bd3
commit
191f3ecbbc
2 changed files with 32 additions and 0 deletions
|
@ -2806,6 +2806,10 @@ bool SDL_RenderCoordinatesFromWindow(SDL_Renderer *renderer, float window_x, flo
|
|||
render_y = ((render_y - dst->y) * src->h) / dst->h;
|
||||
}
|
||||
|
||||
const SDL_RenderViewState *view = &renderer->main_view;
|
||||
render_x = (render_x / view->scale.x) - view->viewport.x;
|
||||
render_y = (render_y / view->scale.y) - view->viewport.y;
|
||||
|
||||
if (x) {
|
||||
*x = render_x;
|
||||
}
|
||||
|
@ -2819,6 +2823,10 @@ bool SDL_RenderCoordinatesToWindow(SDL_Renderer *renderer, float x, float y, flo
|
|||
{
|
||||
CHECK_RENDERER_MAGIC(renderer, false);
|
||||
|
||||
const SDL_RenderViewState *view = &renderer->main_view;
|
||||
x = (view->viewport.x + x) * view->scale.x;
|
||||
y = (view->viewport.y + y) * view->scale.y;
|
||||
|
||||
// Convert from render coordinates to pixels within the window
|
||||
if (renderer->logical_presentation_mode != SDL_LOGICAL_PRESENTATION_DISABLED) {
|
||||
const SDL_FRect *src = &renderer->logical_src_rect;
|
||||
|
@ -2861,6 +2869,7 @@ bool SDL_ConvertEventToRenderCoordinates(SDL_Renderer *renderer, SDL_Event *even
|
|||
}
|
||||
|
||||
// Convert from pixels within the view to render coordinates
|
||||
scale = (scale / renderer->main_view.scale.x);
|
||||
event->motion.xrel *= scale;
|
||||
}
|
||||
if (event->motion.yrel != 0.0f) {
|
||||
|
@ -2875,6 +2884,7 @@ bool SDL_ConvertEventToRenderCoordinates(SDL_Renderer *renderer, SDL_Event *even
|
|||
}
|
||||
|
||||
// Convert from pixels within the view to render coordinates
|
||||
scale = (scale / renderer->main_view.scale.y);
|
||||
event->motion.yrel *= scale;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue