Struct ColorStyle

Source
pub struct ColorStyle {
    pub front: ColorType,
    pub back: ColorType,
}
Expand description

Possible color style for a cell.

Represents a color pair role to use when printing something.

The current theme will assign each role a foreground and background color.

The Default value is to inherit the parent’s colors.

Fields§

§front: ColorType

Color used for the foreground (the text itself).

§back: ColorType

Color used for the background.

Implementations§

Source§

impl ColorStyle

Source

pub fn new<F, B>(front: F, back: B) -> ColorStyle
where F: Into<ColorType>, B: Into<ColorType>,

Creates a new color style, using the given values for front and back.

§Examples
use cursive::style::ColorStyle;

// `BaseColor` implements `Into<ColorStyle>`
use cursive::style::BaseColor::*;
let red_on_black = ColorStyle::new(Red, Black);

// So does `Color`.
let red_on_black = ColorStyle::new(Red.light(), Black.dark());

// Or `PaletteColor`.
use cursive::style::PaletteColor::*;
let primary = ColorStyle::new(Primary, View);
Source

pub fn front<F>(front: F) -> ColorStyle
where F: Into<ColorType>,

Uses the given color as front, inherits the parent background color.

§Examples
use cursive::style::{BaseColor::*, ColorStyle, ColorType};

let color = ColorStyle::front(Red.dark());

assert_eq!(color, ColorStyle::new(Red.dark(), ColorType::InheritParent));
Source

pub fn back<B>(back: B) -> ColorStyle
where B: Into<ColorType>,

Uses the given color as background, inherits the parent front color.

§Examples
use cursive::style::{BaseColor::*, ColorStyle, ColorType};

let color = ColorStyle::back(Black.dark());

assert_eq!(
    color,
    ColorStyle::new(ColorType::InheritParent, Black.dark())
);
Source

pub const fn invert(self) -> ColorStyle

Returns an inverted color style, with the front and back colors swapped.

§Examples
use cursive::style::BaseColor::*;
use cursive::style::ColorStyle;

let red_on_black = ColorStyle::new(Red.dark(), Black.dark());
let black_on_red = red_on_black.invert();

assert_eq!(black_on_red, ColorStyle::new(Black.dark(), Red.dark()));
Source

pub const fn inherit_parent() -> ColorStyle

Uses ColorType::InheritParent for both front and background.

Source

pub const fn terminal_default() -> ColorStyle

Style set by terminal before entering a Cursive program.

Source

pub const fn background() -> ColorStyle

Application background, where no view is present.

Source

pub const fn shadow() -> ColorStyle

Color used by view shadows. Only background matters.

Source

pub const fn view() -> ColorStyle

Color used by views.

Primary foreground, View background.

Source

pub const fn primary() -> ColorStyle

Main text with default background.

Source

pub const fn secondary() -> ColorStyle

Secondary text color, with default background.

Source

pub const fn tertiary() -> ColorStyle

Tertiary text color, with default background.

Source

pub const fn title_primary() -> ColorStyle

Title text color with default background.

Source

pub const fn title_secondary() -> ColorStyle

Alternative color for a title.

Source

pub const fn highlight() -> ColorStyle

Alternate text with highlight background.

Source

pub const fn highlight_inactive() -> ColorStyle

Highlight color for inactive views (not in focus).

Source

pub const fn merge(old: ColorStyle, new: ColorStyle) -> ColorStyle

Merge the color type new over the color type old.

This merges the front and back color types of a and b.

Source

pub fn resolve(&self, palette: &Palette, previous: ColorPair) -> ColorPair

Return the color pair that this style represents.

Source

pub fn map<F>(self, f: F) -> ColorStyle
where F: FnMut(ColorType) -> ColorType,

Apply a function to both the front and back colors.

Source

pub fn zip_map<F>(self, other: ColorStyle, f: F) -> ColorStyle

Apply a function to each pair of front/back color.

Trait Implementations§

Source§

impl Clone for ColorStyle

Source§

fn clone(&self) -> ColorStyle

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ColorStyle

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Default for ColorStyle

Source§

fn default() -> ColorStyle

Returns the “default value” for a type. Read more
Source§

impl<F, B> From<(F, B)> for ColorStyle
where F: Into<ColorType>, B: Into<ColorType>,

Source§

fn from(_: (F, B)) -> ColorStyle

Converts to this type from the input type.
Source§

impl From<BaseColor> for ColorStyle

Source§

fn from(color: BaseColor) -> ColorStyle

Converts to this type from the input type.
Source§

impl From<Color> for ColorStyle

Source§

fn from(color: Color) -> ColorStyle

Converts to this type from the input type.
Source§

impl From<ColorPair> for ColorStyle

Source§

fn from(color: ColorPair) -> ColorStyle

Converts to this type from the input type.
Source§

impl From<ColorStyle> for Style

Source§

fn from(color: ColorStyle) -> Style

Converts to this type from the input type.
Source§

impl From<ColorStyle> for StyleType

Source§

fn from(color: ColorStyle) -> StyleType

Converts to this type from the input type.
Source§

impl From<ColorType> for ColorStyle

Source§

fn from(color: ColorType) -> ColorStyle

Converts to this type from the input type.
Source§

impl From<PaletteColor> for ColorStyle

Source§

fn from(color: PaletteColor) -> ColorStyle

Converts to this type from the input type.
Source§

impl Hash for ColorStyle

Source§

fn hash<__H>(&self, state: &mut __H)
where __H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for ColorStyle

Source§

fn eq(&self, other: &ColorStyle) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Resolvable for ColorStyle

Source§

fn from_config(config: &Value, context: &Context) -> Result<ColorStyle, Error>

Build from a config (a JSON value). Read more
Source§

fn from_any(any: Box<dyn Any>) -> Option<Self>
where Self: Sized + Any,

Build from an Any variable. Read more
Source§

impl Copy for ColorStyle

Source§

impl Eq for ColorStyle

Source§

impl StructuralPartialEq for ColorStyle

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> With for T

Source§

fn wrap_with<U, F>(self, f: F) -> U
where F: FnOnce(Self) -> U,

Calls the given closure and return the result. Read more
Source§

fn with<F>(self, f: F) -> Self
where F: FnOnce(&mut Self),

Calls the given closure on self.
Source§

fn try_with<E, F>(self, f: F) -> Result<Self, E>
where F: FnOnce(&mut Self) -> Result<(), E>,

Calls the given closure on self.
Source§

fn with_if<F>(self, condition: bool, f: F) -> Self
where F: FnOnce(&mut Self),

Calls the given closure if condition == true.