Expand description
Opinionated 2D math library for building GUIs.
Includes vectors, positions, rectangles etc.
Conventions (unless otherwise specified):
- All angles are in radians
- X+ is right and Y+ is down.
- (0,0) is left top.
- Dimension order is always x y
Integrating with other math libraries.
emath does not strive to become a general purpose or all-powerful math library.
For that, use something else (glam, nalgebra, …)
and enable the mint feature flag in emath to enable implicit conversion to/from emath.
Feature flags
- 
extra_debug_asserts— Enable additional checks if debug assertions are enabled (debug builds).
- 
extra_asserts— Always enable additional checks.
Optional dependencies
Re-exports
Modules
- One- and two-dimensional alignment (Align::Center,Align2::LEFT_TOPetc).
- Find “simple” numbers is some range. Used by sliders.
Macros
- An assert that is only active whenemathis compiled with theextra_assertsfeature or with theextra_debug_assertsfeature in debug builds.
Structs
- This struct tracks recent values of some time series.
- A position on screen.
- Inclusive range of floats, i.e.min..=max, but more ergonomic thanRangeInclusive.
- A rectangular region of space.
- Linearly transforms positions from oneRectto another.
- Represents a rotation in the 2D plane. A rotation of 𝞃/4 = 90° rotates the X axis to the Y axis. Normally aRot2is normalized (unit-length). If not, it will also scale vectors.
- A vector has a direction and length. AVec2is often used to represent a size.
- Two bools, one for each axis (X and Y).
Traits
- Implemented for all builtin numeric types
Functions
- Return true when arguments are the same within some rounding error.
- Calculate a lerp-factor for exponential smoothing using a time step.
- Where in the range is this value? Returns 0-1 if within the range.
- Linear interpolation.
- Wrap angle to[-PI, PI]range.
- pos2(x, y) == Pos2::new(x, y)
- Linearly remap a value from one range to another, so that whenx == from.start()returnsto.start()and whenx == from.end()returnsto.end().
- Likeremap, but also clamps the value so that the returned value is always in thetorange.
- Round a value to the given number of decimal places.
- vec2(x, y) == Vec2::new(x, y)