cursive/src/view/box_view.rs

75 lines
2.0 KiB
Rust
Raw Normal View History

use std::cmp;
use vec::Vec2;
use super::{View, ViewWrapper};
2016-06-28 05:40:11 +00:00
/// `BoxView` is a wrapper around an other view, with a given minimum size.
///
/// # Example
///
/// ```
/// # use cursive::view::{BoxView,TextView};
/// // Creates a 20x4 BoxView with a TextView content.
/// let view = BoxView::fixed_size((20,4), TextView::new("Hello!"));
/// ```
pub struct BoxView<T: View> {
width: Option<usize>,
height: Option<usize>,
view: T,
}
2016-06-25 23:36:22 +00:00
impl<T: View> BoxView<T> {
/// Wraps `view` in a neww `BoxView` with the given size.
pub fn fixed_size<S: Into<Vec2>>(size: S, view: T) -> Self {
let size = size.into();
BoxView::new(Some(size.x), Some(size.y), view)
}
/// Creates a new `BoxView` with the given width and height requirements.
///
/// `None` values will use the wrapped view's preferences.
pub fn new(width: Option<usize>, height: Option<usize>, view: T) -> Self {
BoxView {
width: width,
height: height,
view: view,
}
}
/// Wraps `view` in a new `BoxView` with fixed width.
pub fn fixed_width(width: usize, view: T) -> Self {
BoxView::new(Some(width), None, view)
}
/// Wraps `view` in a new `BoxView` with fixed height.
pub fn fixed_height(height: usize, view: T) -> Self {
BoxView::new(None, Some(height), view)
}
}
fn min<T: Ord>(a: T, b: Option<T>) -> T {
match b {
Some(b) => cmp::min(a, b),
None => a,
}
}
2016-06-25 23:36:22 +00:00
impl<T: View> ViewWrapper for BoxView<T> {
wrap_impl!(&self.view);
fn wrap_get_min_size(&mut self, req: Vec2) -> Vec2 {
if let (Some(w), Some(h)) = (self.width, self.height) {
Vec2::new(w, h)
} else {
let req = Vec2::new(min(req.x, self.width),
min(req.y, self.height));
let child_size = self.view.get_min_size(req);
Vec2::new(self.width.unwrap_or(child_size.x),
self.height.unwrap_or(child_size.y))
2016-03-15 22:37:57 +00:00
}
}
}