From f0b29a9d23791105e157280c492eecd223c1f631 Mon Sep 17 00:00:00 2001 From: sebcrozet Date: Sun, 7 Oct 2018 06:31:41 +0200 Subject: [PATCH] Fix glm::clamp. Fix #434. --- nalgebra-glm/src/common.rs | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/nalgebra-glm/src/common.rs b/nalgebra-glm/src/common.rs index d35ad834..45b94336 100644 --- a/nalgebra-glm/src/common.rs +++ b/nalgebra-glm/src/common.rs @@ -101,13 +101,33 @@ pub fn clamp(x: &TVec, min_val: N, max_val: N) -> /// Returns `min(max(x[i], min_val[i]), max_val[i])` for each component in `x` /// using the components of `min_val` and `max_val` as bounds. /// +/// # Examples: +/// +/// ``` +/// # use nalgebra_glm as glm; +/// let min_bounds = glm::vec2(1.0, 3.0); +/// let max_bounds = glm::vec2(5.0, 6.0); +/// assert_eq!(glm::vec2(1.0, 6.0), +/// glm::clamp_vec(&glm::vec2(0.0, 7.0), +/// &min_bounds, +/// &max_bounds)); +/// assert_eq!(glm::vec2(2.0, 6.0), +/// glm::clamp_vec(&glm::vec2(2.0, 7.0), +/// &min_bounds, +/// &max_bounds)); +/// assert_eq!(glm::vec2(1.0, 4.0), +/// glm::clamp_vec(&glm::vec2(0.0, 4.0), +/// &min_bounds, +/// &max_bounds)); +/// ``` +/// /// # See also: /// /// * [`clamp_scalar`](fn.clamp_scalar.html) /// * [`clamp`](fn.clamp.html) pub fn clamp_vec(x: &TVec, min_val: &TVec, max_val: &TVec) -> TVec where DefaultAllocator: Alloc { - na::clamp(x.clone(), min_val.clone(), max_val.clone()) + x.zip_zip_map(min_val, max_val, |a, min, max| na::clamp(a, min, max)) } /// Returns a signed integer value representing the encoding of a floating-point value.