mirror of
https://github.com/FliegendeWurst/cursive.git
synced 2024-11-27 11:16:03 +00:00
Rename Vec4 -> Margins
This commit is contained in:
parent
9bc723ab4a
commit
92c1d1a5b2
58
src/vec.rs
58
src/vec.rs
@ -242,7 +242,7 @@ impl Mul<usize> for XY<usize> {
|
|||||||
|
|
||||||
/// Four values representing each direction.
|
/// Four values representing each direction.
|
||||||
#[derive(Clone, Copy)]
|
#[derive(Clone, Copy)]
|
||||||
pub struct Vec4 {
|
pub struct Margins {
|
||||||
/// Left margin
|
/// Left margin
|
||||||
pub left: usize,
|
pub left: usize,
|
||||||
/// Right margin
|
/// Right margin
|
||||||
@ -253,10 +253,10 @@ pub struct Vec4 {
|
|||||||
pub bottom: usize,
|
pub bottom: usize,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Vec4 {
|
impl Margins {
|
||||||
/// Creates a new Vec4.
|
/// Creates a new Margins.
|
||||||
pub fn new(left: usize, right: usize, top: usize, bottom: usize) -> Self {
|
pub fn new(left: usize, right: usize, top: usize, bottom: usize) -> Self {
|
||||||
Vec4 {
|
Margins {
|
||||||
left: left,
|
left: left,
|
||||||
right: right,
|
right: right,
|
||||||
top: top,
|
top: top,
|
||||||
@ -290,38 +290,38 @@ impl Vec4 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<(usize, usize, usize, usize)> for Vec4 {
|
impl From<(usize, usize, usize, usize)> for Margins {
|
||||||
fn from((left, right, top, bottom): (usize, usize, usize, usize)) -> Vec4 {
|
fn from((left, right, top, bottom): (usize, usize, usize, usize)) -> Margins {
|
||||||
Vec4::new(left, right, top, bottom)
|
Margins::new(left, right, top, bottom)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<(i32, i32, i32, i32)> for Vec4 {
|
impl From<(i32, i32, i32, i32)> for Margins {
|
||||||
fn from((left, right, top, bottom): (i32, i32, i32, i32)) -> Vec4 {
|
fn from((left, right, top, bottom): (i32, i32, i32, i32)) -> Margins {
|
||||||
(left as usize, right as usize, top as usize, bottom as usize).into()
|
(left as usize, right as usize, top as usize, bottom as usize).into()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<((i32, i32), (i32, i32))> for Vec4 {
|
impl From<((i32, i32), (i32, i32))> for Margins {
|
||||||
fn from(((left, right), (top, bottom)): ((i32, i32), (i32, i32))) -> Vec4 {
|
fn from(((left, right), (top, bottom)): ((i32, i32), (i32, i32))) -> Margins {
|
||||||
(left, right, top, bottom).into()
|
(left, right, top, bottom).into()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
impl From<((usize, usize), (usize, usize))> for Vec4 {
|
impl From<((usize, usize), (usize, usize))> for Margins {
|
||||||
fn from(
|
fn from(
|
||||||
((left, right), (top, bottom)): ((usize, usize), (usize, usize))
|
((left, right), (top, bottom)): ((usize, usize), (usize, usize))
|
||||||
) -> Vec4 {
|
) -> Margins {
|
||||||
(left, right, top, bottom).into()
|
(left, right, top, bottom).into()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T: Into<Vec4>> Add<T> for Vec4 {
|
impl<T: Into<Margins>> Add<T> for Margins {
|
||||||
type Output = Vec4;
|
type Output = Margins;
|
||||||
|
|
||||||
fn add(self, other: T) -> Vec4 {
|
fn add(self, other: T) -> Margins {
|
||||||
let ov = other.into();
|
let ov = other.into();
|
||||||
|
|
||||||
Vec4 {
|
Margins {
|
||||||
left: self.left + ov.left,
|
left: self.left + ov.left,
|
||||||
right: self.right + ov.right,
|
right: self.right + ov.right,
|
||||||
top: self.top + ov.top,
|
top: self.top + ov.top,
|
||||||
@ -330,13 +330,13 @@ impl<T: Into<Vec4>> Add<T> for Vec4 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<T: Into<Vec4>> Sub<T> for Vec4 {
|
impl<T: Into<Margins>> Sub<T> for Margins {
|
||||||
type Output = Vec4;
|
type Output = Margins;
|
||||||
|
|
||||||
fn sub(self, other: T) -> Vec4 {
|
fn sub(self, other: T) -> Margins {
|
||||||
let ov = other.into();
|
let ov = other.into();
|
||||||
|
|
||||||
Vec4 {
|
Margins {
|
||||||
left: self.left - ov.left,
|
left: self.left - ov.left,
|
||||||
right: self.right - ov.right,
|
right: self.right - ov.right,
|
||||||
top: self.top - ov.top,
|
top: self.top - ov.top,
|
||||||
@ -345,11 +345,11 @@ impl<T: Into<Vec4>> Sub<T> for Vec4 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Div<usize> for Vec4 {
|
impl Div<usize> for Margins {
|
||||||
type Output = Vec4;
|
type Output = Margins;
|
||||||
|
|
||||||
fn div(self, other: usize) -> Vec4 {
|
fn div(self, other: usize) -> Margins {
|
||||||
Vec4 {
|
Margins {
|
||||||
left: self.left / other,
|
left: self.left / other,
|
||||||
right: self.right / other,
|
right: self.right / other,
|
||||||
top: self.top / other,
|
top: self.top / other,
|
||||||
@ -358,11 +358,11 @@ impl Div<usize> for Vec4 {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Mul<usize> for Vec4 {
|
impl Mul<usize> for Margins {
|
||||||
type Output = Vec4;
|
type Output = Margins;
|
||||||
|
|
||||||
fn mul(self, other: usize) -> Vec4 {
|
fn mul(self, other: usize) -> Margins {
|
||||||
Vec4 {
|
Margins {
|
||||||
left: self.left * other,
|
left: self.left * other,
|
||||||
right: self.right * other,
|
right: self.right * other,
|
||||||
top: self.top * other,
|
top: self.top * other,
|
||||||
|
@ -9,24 +9,21 @@ use view::{AnyView, Selector};
|
|||||||
///
|
///
|
||||||
/// This is what you should implement to define a custom View.
|
/// This is what you should implement to define a custom View.
|
||||||
pub trait View: Any + AnyView {
|
pub trait View: Any + AnyView {
|
||||||
/// Called when a key was pressed.
|
|
||||||
///
|
|
||||||
/// Default implementation just ignores it.
|
|
||||||
fn on_event(&mut self, Event) -> EventResult {
|
|
||||||
EventResult::Ignored
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Returns the minimum size the view requires with the given restrictions.
|
/// Draws the view with the given printer (includes bounds) and focus.
|
||||||
///
|
///
|
||||||
/// If the view is flexible (it has multiple size options), it can try
|
/// This is the only *required* method to implement.
|
||||||
/// to return one that fits the given `constraint`.
|
fn draw(&self, printer: &Printer);
|
||||||
/// It's also fine to ignore it and return a fixed value.
|
|
||||||
|
/// Called once the size for this view has been decided.
|
||||||
///
|
///
|
||||||
/// Default implementation always return `(1,1)`.
|
/// It can be used to pre-compute the configuration of child views.
|
||||||
fn required_size(&mut self, constraint: Vec2) -> Vec2 {
|
///
|
||||||
let _ = constraint;
|
/// View groups should propagate the information to their children.
|
||||||
Vec2::new(1, 1)
|
///
|
||||||
}
|
/// At this point, the given size is final and cannot be negociated.
|
||||||
|
/// It is guaranteed to be the size available for the call to `draw()`.
|
||||||
|
fn layout(&mut self, Vec2) {}
|
||||||
|
|
||||||
/// Returns `true` if the view content changed since last layout phase.
|
/// Returns `true` if the view content changed since last layout phase.
|
||||||
///
|
///
|
||||||
@ -43,13 +40,29 @@ pub trait View: Any + AnyView {
|
|||||||
true
|
true
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Called once the size for this view has been decided,
|
/// Returns the minimum size the view requires with the given restrictions.
|
||||||
///
|
///
|
||||||
/// View groups should propagate the information to their children.
|
/// This is the main way a view communicate its size to its parent.
|
||||||
fn layout(&mut self, Vec2) {}
|
///
|
||||||
|
/// If the view is flexible (it has multiple size options), it can try
|
||||||
|
/// to return one that fits the given `constraint`.
|
||||||
|
/// It's also fine to ignore it and return a fixed value.
|
||||||
|
///
|
||||||
|
/// Default implementation always return `(1,1)`.
|
||||||
|
fn required_size(&mut self, constraint: Vec2) -> Vec2 {
|
||||||
|
let _ = constraint;
|
||||||
|
Vec2::new(1, 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Called when an event is received (key press, mouse event, ...).
|
||||||
|
///
|
||||||
|
/// You can return an `EventResult`, with an optional callback to be run.
|
||||||
|
///
|
||||||
|
/// Default implementation just ignores it.
|
||||||
|
fn on_event(&mut self, Event) -> EventResult {
|
||||||
|
EventResult::Ignored
|
||||||
|
}
|
||||||
|
|
||||||
/// Draws the view with the given printer (includes bounds) and focus.
|
|
||||||
fn draw(&self, printer: &Printer);
|
|
||||||
|
|
||||||
/// Runs a closure on the view identified by the given selector.
|
/// Runs a closure on the view identified by the given selector.
|
||||||
///
|
///
|
||||||
|
@ -9,7 +9,7 @@ use std::cell::Cell;
|
|||||||
use std::cmp::max;
|
use std::cmp::max;
|
||||||
use theme::ColorStyle;
|
use theme::ColorStyle;
|
||||||
use unicode_width::UnicodeWidthStr;
|
use unicode_width::UnicodeWidthStr;
|
||||||
use vec::{Vec2, Vec4};
|
use vec::{Vec2, Margins};
|
||||||
use view::{Selector, View};
|
use view::{Selector, View};
|
||||||
use views::{Button, DummyView, SizedView, TextView, ViewBox};
|
use views::{Button, DummyView, SizedView, TextView, ViewBox};
|
||||||
|
|
||||||
@ -65,10 +65,10 @@ pub struct Dialog {
|
|||||||
buttons: Vec<ChildButton>,
|
buttons: Vec<ChildButton>,
|
||||||
|
|
||||||
// Padding around the inner view.
|
// Padding around the inner view.
|
||||||
padding: Vec4,
|
padding: Margins,
|
||||||
|
|
||||||
// Borders around everything.
|
// Borders around everything.
|
||||||
borders: Vec4,
|
borders: Margins,
|
||||||
|
|
||||||
// The current element in focus
|
// The current element in focus
|
||||||
focus: DialogFocus,
|
focus: DialogFocus,
|
||||||
@ -95,8 +95,8 @@ impl Dialog {
|
|||||||
title: String::new(),
|
title: String::new(),
|
||||||
title_position: HAlign::Center,
|
title_position: HAlign::Center,
|
||||||
focus: DialogFocus::Content,
|
focus: DialogFocus::Content,
|
||||||
padding: Vec4::new(1, 1, 0, 0),
|
padding: Margins::new(1, 1, 0, 0),
|
||||||
borders: Vec4::new(1, 1, 1, 1),
|
borders: Margins::new(1, 1, 1, 1),
|
||||||
align: Align::top_right(),
|
align: Align::top_right(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -214,7 +214,7 @@ impl Dialog {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Sets the padding in the dialog (around content and buttons).
|
/// Sets the padding in the dialog (around content and buttons).
|
||||||
pub fn padding<T: Into<Vec4>>(mut self, padding: T) -> Self {
|
pub fn padding<T: Into<Margins>>(mut self, padding: T) -> Self {
|
||||||
self.padding = padding.into();
|
self.padding = padding.into();
|
||||||
|
|
||||||
self
|
self
|
||||||
|
Loading…
Reference in New Issue
Block a user