#vector #2d-vector #component #implemented #traits #spoon

vector2d

The spoon of 2D vector libraries, intended for simple game development

6 stable releases

3.1.1 Jan 5, 2025
3.0.0 Jan 5, 2025
2.2.0 Mar 18, 2019
2.0.1 Mar 16, 2019
1.1.3 Mar 16, 2019

#92 in Game dev

Download history 176/week @ 2024-09-28 492/week @ 2024-10-05 519/week @ 2024-10-12 448/week @ 2024-10-19 329/week @ 2024-10-26 533/week @ 2024-11-02 505/week @ 2024-11-09 364/week @ 2024-11-16 643/week @ 2024-11-23 502/week @ 2024-11-30 426/week @ 2024-12-07 328/week @ 2024-12-14 112/week @ 2024-12-21 142/week @ 2024-12-28 598/week @ 2025-01-04 574/week @ 2025-01-11

1,488 downloads per month
Used in 6 crates

Unlicense

32KB
721 lines

vector2d

A simple and convenient 2D vector type without excessive use of external dependencies. If other vector crates are swiss-army knives, vector2d is a spoon; safe, intuitive, and convenient. As an added bonus, you won't run into any excursions with the law using this library thanks to the awfully permissive Unlicense.

Using vector2d

You probably don't need any documentation to get by with the Vector2D type; functions like dot, length, and angle are hopefully all named intuitively enough for you feel them out. If you do find yourself wondering about certain bits of functionality, then be sure to take a look at the documentation, where you can find examples and explanations of everything on offer.


lib.rs:

vector2d

A simple and convenient 2D vector library without excessive use of external dependencies. If other vector crates are swiss-army knives, vector2d is a spoon; safe, intuitive, and convenient. As an added bonus, you won't run into any excursions with the law using this library thanks to the awfully permissive Unlicense.

The only type in this crate is Vector2D, which is highly generic; shifting functionality depending upon the traits implemented by its internal components' types.

Example

use vector2d::Vector2D;

// Vectors have fields X and Y, these can be of any type
let v1: Vector2D<i32> = Vector2D { x: 10, y: 5 };

// Alternatively you can use new(..) to condense instantiation
let v2: Vector2D<f64> = Vector2D::new(13.0, 11.5);

// There are two ways to cast between Vector2Ds, depending on the source
// and target types.
//
// If the target type has a implementation of From<SourceType>, then you
// can either use source.into_vec2d() or Vector2D::from_vec2d(source).
assert_eq!(Vector2D::new(10.0, 5.0), v1.into_vec2d());
assert_eq!(Vector2D::new(10.0, 5.0), Vector2D::from_vec2d(v1));

// If there is no From or Into implementation, then you're out of luck
// unless you are using specific primitives, such as i32 and f64. In
// this case you can use specialised functions, as shown below:
assert_eq!(Vector2D::new(13, 11), v2.as_i32s());

// The full list of interoperable primitives is as follows:
//   - i32, i64, isize
//   - u32, u64, usize
//   - f32, f64

// As primitives generally implement From/Into for lossless casts,
// an as_Ts() function is not available for those types, and
// from(..)/into() should be favoured.
//
// Casts between signed and unsigned primitives will perform bounds
// checking, so casting the vector (-10.0, 2.0) to a Vector2D<u32> will
// result in the vector (0, 2).

// For types with an Add and Mul implementation, the functions dot() and
// length_squared() are available. For access to length(), normalise(),
// or angle() however, you must be using either Vector2D<f32> or
// Vector2D<f64>.
let _v1_len_sq = v1.length_squared();
let v2_len = v2.length();
let v2_dir = v2.normalise();

// Assuming the operator traits are implemented for the types involved,
// you can add and subtract Vector2Ds from one-another, as well as
// multiply and divide them with scalar values.
assert_eq!(v2, v2_dir * v2_len);
assert_eq!(Vector2D::new(23.0, 16.5),  v2 + v1.into_vec2d()) ;

// If you feel the need to multiply or divide individual components of
// vectors with the same type, you can use mul_components(...) or
// div_components(...) provided that their types can be multiplied or
// divided.

// For any Vector2D<T>, there is an implementation of
// From<(T, T)> and From<[T; 2]>
let v4: Vector2D<f64> = Vector2D::new(1.5, 2.3);
assert_eq!(v4, (1.5, 2.3).into());
assert_eq!(v4, [1.5, 2.3].into());

// Additionally, there is an Into<(T, T)> implementation for any types
// that the vector components have their own Into implementations for
assert_eq!((1.5, 2.3), v4.into());

// If you want the normal of a vector you can just call normal()
let v5 = Vector2D::new(-10.0, -2.3);
assert_eq!(Vector2D::new(2.3, -10.0), v5.normal());

// You can get a vector consisting of only the horizontal or vertical
// component of a vector by calling horizontal() or vertical()
// respectively
let v6 = Vector2D::new(12.3, 83.2);
assert_eq!(Vector2D::new(12.3, 0.0), v6.horizontal());
assert_eq!(Vector2D::new(0.0, 83.2), v6.vertical());

No runtime deps