bevy/crates/bevy_ui/src/node.rs

108 lines
2.7 KiB
Rust
Raw Normal View History

2020-04-06 21:20:53 +00:00
use super::{Anchors, Margins};
2020-06-01 06:39:20 +00:00
use bevy_sprite::Quad;
2020-05-04 02:30:31 +00:00
use glam::Vec2;
2020-01-13 00:51:21 +00:00
#[derive(Debug, Clone)]
enum MarginGrowDirection {
2020-01-13 00:51:21 +00:00
Negative,
Positive,
}
#[derive(Debug, Clone)]
2020-01-13 00:51:21 +00:00
pub struct Node {
pub position: Vec2,
pub anchors: Anchors,
pub margins: Margins,
}
impl Default for Node {
fn default() -> Self {
Node {
position: Vec2::default(),
anchors: Anchors::default(),
margins: Margins::default(),
}
}
}
impl Node {
2020-05-04 02:30:31 +00:00
pub fn new(position: Vec2, anchors: Anchors, margins: Margins) -> Self {
2020-01-13 00:51:21 +00:00
Node {
position,
anchors,
margins,
}
}
2020-05-06 01:44:32 +00:00
pub fn update(
&mut self,
2020-06-01 06:39:20 +00:00
quad: &mut Quad,
parent_size: Vec2,
2020-05-06 01:44:32 +00:00
parent_position: Vec2,
z_index: f32,
) {
2020-06-01 06:39:20 +00:00
let (quad_x, quad_width) = Self::compute_dimension_properties(
2020-01-13 00:51:21 +00:00
self.position.x(),
self.margins.left,
self.margins.right,
self.anchors.left,
self.anchors.right,
parent_size.x(),
2020-01-13 00:51:21 +00:00
);
2020-06-01 06:39:20 +00:00
let (quad_y, quad_height) = Self::compute_dimension_properties(
2020-01-13 00:51:21 +00:00
self.position.y(),
self.margins.bottom,
self.margins.top,
self.anchors.bottom,
self.anchors.top,
parent_size.y(),
2020-01-13 00:51:21 +00:00
);
2020-06-01 06:39:20 +00:00
quad.size = Vec2::new(quad_width, quad_height);
quad.position = Vec2::new(quad_x, quad_y) + parent_position;
quad.z_index = z_index;
2020-01-13 00:51:21 +00:00
}
fn compute_dimension_properties(
offset: f32,
margin0: f32,
margin1: f32,
anchor0: f32,
anchor1: f32,
length: f32,
) -> (f32, f32) {
let anchor_p0 = anchor0 * length;
let anchor_p1 = anchor1 * length;
let p0_grow_direction = if anchor_p0 <= 0.5 {
MarginGrowDirection::Positive
2020-01-13 00:51:21 +00:00
} else {
MarginGrowDirection::Negative
2020-01-13 00:51:21 +00:00
};
let p1_grow_direction = if anchor_p1 <= 0.5 {
MarginGrowDirection::Positive
2020-01-13 00:51:21 +00:00
} else {
MarginGrowDirection::Negative
2020-01-13 00:51:21 +00:00
};
2020-06-01 06:39:20 +00:00
let p0 = Self::compute_quad_position(offset, margin0, anchor_p0, p0_grow_direction);
let p1 = Self::compute_quad_position(offset, margin1, anchor_p1, p1_grow_direction);
2020-01-13 00:51:21 +00:00
let final_width = p1 - p0;
let p = (p0 + p1) / 2.0;
(p, final_width.abs())
2020-01-13 00:51:21 +00:00
}
2020-06-01 06:39:20 +00:00
fn compute_quad_position(
2020-01-13 00:51:21 +00:00
position: f32,
margin: f32,
anchor_position: f32,
grow_direction: MarginGrowDirection,
2020-01-13 00:51:21 +00:00
) -> f32 {
match grow_direction {
MarginGrowDirection::Negative => position + anchor_position - margin,
MarginGrowDirection::Positive => position + anchor_position + margin,
2020-01-13 00:51:21 +00:00
}
}
}