Skip to main content

The "draw_surface_scaled" Function

Syntax#

draw_surface_scaled(surf, x, y, ratio, min, max);
ArgumentTypeDescription
surfsurfaceThe surface to draw scaled
xrealThe horizontal room coordinate at which to draw the surface
yrealThe vertical room coordinate at which to draw the surface
ratiorealPercentage of the view to occupy, as a value ranging from 0-1
minrealMinimum allowable ratio, or percentage of the view
maxrealMaximum allowable ratio, or percentage of the view

Description#

Draws a surface scaled relative to the size of the active view camera. Ratio is calculated as a percentage of view width OR height (whichever is greater), with a value of 1 fully covering the view at any aspect (e.g. for backgrounds).

Because this ratio alone may result in surfaces smaller or larger than desirable on one axis, a min and max ratio can also be supplied to limit size on the other axis than is calculated for the base ratio (e.g. for HUD elements). If max is set to 0, clamping will be disabled.

Also returns the scale multiplier, which can be used to position or scale other elements relative to the drawn surface.

caution

Because surface data is volatile, surfaces are likely to be destroyed if the window is resized. Always check if a surface exists before drawing, and include regeneration code if it does not.

Example#

draw_surface_scaled(my_surf, x, y, 0.25, 0.15, 0.5);