diff options
| author | heavydemon21 <nielsstunnebrink1@gmail.com> | 2024-12-19 13:58:58 +0100 | 
|---|---|---|
| committer | heavydemon21 <nielsstunnebrink1@gmail.com> | 2024-12-19 13:58:58 +0100 | 
| commit | b5c4879189a8ff55434c8c04c14163dfda83de65 (patch) | |
| tree | 17595782d04038818f7ed4f6bb2199949ebd30a0 /src/crepe/facade/SDLContext.cpp | |
| parent | ebe2fcfce52d9a303c5fa19d79554e20ac7f0bac (diff) | |
| parent | 794efc4ef7a44b190a4d9ecc2dd84a66c62ab005 (diff) | |
Merge branch 'master' into niels/UI
Diffstat (limited to 'src/crepe/facade/SDLContext.cpp')
| -rw-r--r-- | src/crepe/facade/SDLContext.cpp | 15 | 
1 files changed, 12 insertions, 3 deletions
| diff --git a/src/crepe/facade/SDLContext.cpp b/src/crepe/facade/SDLContext.cpp index d352adc..642aef8 100644 --- a/src/crepe/facade/SDLContext.cpp +++ b/src/crepe/facade/SDLContext.cpp @@ -141,6 +141,8 @@ SDL_FRect SDLContext::get_dst_rect(const DestinationRectangleData & ctx) const {  		= (ctx.sprite.aspect_ratio == 0) ? ctx.texture.get_ratio() : ctx.sprite.aspect_ratio;  	vec2 size = data.size; +	vec2 screen_pos = ctx.pos + data.position_offset; +  	if (data.size.x == 0 && data.size.y != 0) {  		size.x = data.size.y * aspect_ratio;  	} @@ -149,9 +151,16 @@ SDL_FRect SDLContext::get_dst_rect(const DestinationRectangleData & ctx) const {  	}  	size *= cam_aux_data.render_scale * ctx.img_scale * data.scale_offset; -	vec2 screen_pos = (ctx.pos - cam_aux_data.cam_pos + (cam_aux_data.zoomed_viewport) / 2) -						  * cam_aux_data.render_scale -					  - size / 2 + cam_aux_data.bar_size; +	if (ctx.sprite.data.world_space) { +		vec2 multiplier = cam_aux_data.cam_pos +						  + (cam_aux_data.zoomed_viewport / 2) * cam_aux_data.render_scale +						  - size / 2 + cam_aux_data.bar_size; +		screen_pos += multiplier; +	} else { +		vec2 multiplier = (cam_aux_data.zoomed_viewport / 2) * cam_aux_data.render_scale +						  - size / 2 + cam_aux_data.bar_size; +		screen_pos += multiplier; +	}  	return SDL_FRect{  		.x = screen_pos.x, |