Struct freya_elements::elements::rect
source · pub struct rect;
Expand description
Implementations§
source§impl rect
impl rect
sourcepub const height: AttributeDescription = _
pub const height: AttributeDescription = _
Specify the width and height for the given element.
See syntax in Size Units
.
§Example
fn app() -> Element {
rsx!(
rect {
background: "red",
width: "15",
height: "50",
}
)
}
pub const width: AttributeDescription = _
sourcepub const min_height: AttributeDescription = _
pub const min_height: AttributeDescription = _
§min_width & min_height
rect
supports specifying a minimum width and height, this can be useful if you use it alongside a percentage for the target size.
See syntax for Size Units
.
§Usage
fn app() -> Element {
rsx!(
rect {
background: "red",
min_width: "100",
min_height: "100",
width: "50%",
height: "50%",
}
)
}
pub const min_width: AttributeDescription = _
sourcepub const max_height: AttributeDescription = _
pub const max_height: AttributeDescription = _
§max_width & max_height
rect
supports specifying a maximum width and height.
See syntax for Size Units
.
§Usage
fn app() -> Element {
rsx!(
rect {
background: "red",
max_width: "50%",
max_height: "50%",
width: "500",
height: "500",
}
)
}
pub const max_width: AttributeDescription = _
sourcepub const margin: AttributeDescription = _
pub const margin: AttributeDescription = _
Specify the margin of an element. You can do so by four different ways, just like in CSS.
§Example
fn app() -> Element {
rsx!(
rect {
margin: "25", // 25 in all sides
margin: "100 50", // 100 in top and bottom, and 50 in left and right
margin: "2 15 25", // 2 in top, 15 in left and right, and 25 in bottom
margin: "5 7 3 9" // 5 in top, 7 in right, 3 in bottom and 9 in left
}
)
}
sourcepub const padding: AttributeDescription = _
pub const padding: AttributeDescription = _
Specify the inner paddings of an element. You can do so by four different ways, just like in CSS.
§Example
fn app() -> Element {
rsx!(
rect {
padding: "25", // 25 in all sides
padding: "100 50", // 100 in top and bottom, and 50 in left and right
padding: "2 15 25", // 2 in top, 15 in left and right, and 25 in bottom
padding: "5 7 3 9" // 5 in top, 7 in right, 3 in bottom and 9 in left
}
)
}
sourcepub const position: AttributeDescription = _
pub const position: AttributeDescription = _
Specify how you want the element to be positioned inside it’s parent area.
Accepted values:
stacked
(default)absolute
When using the absolute
mode, you can also combine it with the following attributes:
position_top
position_right
position_bottom
position_left
These only support pixels.
§Example
fn app() -> Element {
rsx!(
rect {
width: "100%",
height: "100%",
rect {
position: "absolute",
position_bottom: "15",
position_right: "15",
background: "black",
width: "100",
height: "100",
}
}
)
}
pub const position_top: AttributeDescription = _
pub const position_right: AttributeDescription = _
pub const position_bottom: AttributeDescription = _
pub const position_left: AttributeDescription = _
pub const layer: AttributeDescription = _
sourcepub const direction: AttributeDescription = _
pub const direction: AttributeDescription = _
Control how the inner elements stack.
Accepted values:
vertical
(default)horizontal
§Usage
fn app() -> Element {
rsx!(
rect {
width: "100%",
height: "100%",
direction: "vertical",
rect {
width: "100%",
height: "50%",
background: "red"
},
rect {
width: "100%",
height: "50%",
background: "green"
}
}
)
}
sourcepub const content: AttributeDescription = _
pub const content: AttributeDescription = _
Specify how you want the automatic (e.g width: auto
) bounds in the cross axis to be constrained for the inner elements.
Accepted values:
normal
(default): Uses parent bounds.fit
: Uses parent bounds but later shrunks to the size of the biggest element inside.
The fit
mode will allow the inner elements using width: fill-min
to expand to the biggest element inside this element.
§Example
fn app() -> Element {
rsx!(
rect {
content: "fit",
height: "100%",
rect {
width: "fill-min", // Will have a width of 300px
height: "25%",
background: "red",
}
rect {
width: "150", // Will have a width of 150px
height: "25%",
background: "green",
}
rect {
width: "fill-min", // Will have a width of 300px
height: "25%",
background: "blue",
}
rect {
width: "300", // Biggest element, will have a width of 300px
height: "25%",
background: "black",
}
}
)
}
sourcepub const main_align: AttributeDescription = _
pub const main_align: AttributeDescription = _
§main_align & cross_align
Control how the inner elements are positioned inside the element. You can combine it with the direction
attribute to create complex flows.
Accepted values for main_align
:
start
(default): At the begining of the axiscenter
: At the center of the axisend
: At the end of the axisspace-between
(only formain_align
): Distributed among the available spacespace-around
(only formain_align
): Distributed among the available space with small margins in the sidesspace-evenly
(only formain_align
): Distributed among the available space with the same size of margins in the sides and in between the elements.
Accepted values for cross_align
:
start
(default): At the begining of the axis (same as inmain_align
)center
: At the center of the axis (same as inmain_align
)end
: At the end of the axis (same as inmain_align
)
When using the vertical
direction, main_align
will be the Y axis and cross_align
will be the X axis. But when using the horizontal
direction, the
main_align
will be the X axis and the cross_align
will be the Y axis.
Example on how to center the inner elements in both axis:
fn app() -> Element {
rsx!(
rect {
width: "100%",
height: "100%",
main_align: "center",
cross_align: "center",
rect {
width: "50%",
height: "50%",
background: "red"
},
}
)
}
pub const cross_align: AttributeDescription = _
sourcepub const spacing: AttributeDescription = _
pub const spacing: AttributeDescription = _
Specify a space between the inner elements. Think it as a margin for every element but defined by its parent. It only applies to the side of the direction.
§Example
fn app() -> Element {
rsx!(
rect {
direction: "vertical",
spacing: "20",
// Not before
rect {
width: "100",
height: "100",
background: "red",
}
// There will be a space between these two elements of 20 pixels
rect {
width: "100",
height: "100",
background: "blue",
}
// Here as well
rect {
width: "100",
height: "100",
background: "green",
}
// But not after
}
)
}
sourcepub const overflow: AttributeDescription = _
pub const overflow: AttributeDescription = _
Specify how overflow should be handled.
Accepted values:
clip
none
§Example
fn app() -> Element {
rsx!(
rect {
overflow: "clip",
width: "100",
height: "100%",
rect {
width: "500",
height: "100%",
background: "red",
}
}
)
}
pub const offset_x: AttributeDescription = _
pub const offset_y: AttributeDescription = _
sourcepub const background: AttributeDescription = _
pub const background: AttributeDescription = _
Specify a color as the background of an element.
You can learn about the syntax of this attribute in Color Syntax
.
§Example
fn app() -> Element {
rsx!(
rect {
background: "red"
}
)
}
sourcepub const border: AttributeDescription = _
pub const border: AttributeDescription = _
§border
You can add borders to an element using the border
attribute.
border
syntax:[width] [width?] [width?] [width?] <inner | outer | center> [fill]
.
1-4 width values should be provided with the border
attribute. Widths will be applied to different sides of a rect
depending on the number of values provided:
- One value:
all
- Two values:
vertical
,horizontal
- Three values:
top
horizontal
bottom
- Four values:
top
right
bottom
left
Border alignment determines how the border is positioned relative to the element’s edge. Alignment can be inner
, outer
, or center
.
§Examples
A solid, black border with a width of 2 pixels on every side. Border is aligned to the inside of the rect’s edge.
fn app() -> Element {
rsx!(
rect {
border: "2 inner black",
}
)
}
A solid, red border with different widths on each side. Border is aligned to the center of the rect’s edge.
fn app() -> Element {
rsx!(
rect {
border: "1 2 3 4 center red",
}
)
}
Borders can take any valid fill type, including gradients.
fn app() -> Element {
rsx!(
rect {
border: "1 inner linear-gradient(red, green, yellow 40%, blue)",
}
)
}
Similarly to the shadow
attribute, multiple borders can be drawn on a single element when separated by a comma. Borders specified later in the list are drawn on top of previous ones.
fn app() -> Element {
rsx!(
rect {
border: "6 outer red, 5 outer orange, 4 outer yellow, 3 outer green, 2 outer blue, 1 outer purple",
}
)
}
sourcepub const shadow: AttributeDescription = _
pub const shadow: AttributeDescription = _
Draw a shadow of the element.
Syntax: <x> <y> <intensity> <size> <color>
§Example
fn app() -> Element {
rsx!(
rect {
shadow: "0 0 25 2 rgb(0, 0, 0, 120)"
}
)
}
sourcepub const corner_radius: AttributeDescription = _
pub const corner_radius: AttributeDescription = _
pub const corner_smoothing: AttributeDescription = _
sourcepub const color: AttributeDescription = _
pub const color: AttributeDescription = _
The color
attribute lets you specify the color of the text.
You can learn about the syntax of this attribute in Color Syntax
.
§Example
fn app() -> Element {
rsx!(
label {
color: "green",
"Hello, World!"
}
)
}
Another example showing inheritance:
fn app() -> Element {
rsx!(
rect {
color: "blue",
label {
"Hello, World!"
}
}
)
}
sourcepub const font_size: AttributeDescription = _
pub const font_size: AttributeDescription = _
You can specify the size of the text using font_size
.
§Example
fn app() -> Element {
rsx!(
label {
font_size: "50",
"Hellooooo!"
}
)
}
sourcepub const font_family: AttributeDescription = _
pub const font_family: AttributeDescription = _
With the font_family
you can specify what font you want to use for the inner text.
Check out the custom font example to see how you can load your own fonts.
§Example
fn app() -> Element {
rsx!(
label {
font_family: "Inter",
"Hello, World!"
}
)
}
sourcepub const font_style: AttributeDescription = _
pub const font_style: AttributeDescription = _
You can choose a style for a text using the font_style
attribute.
Accepted values:
upright
(default)italic
oblique
§Example
fn app() -> Element {
rsx!(
label {
font_style: "italic",
"Hello, italic World!"
}
)
}
You can also specify multiple fonts in order of priority, if one is not found it will fallback to the next one.
Example:
fn app() -> Element {
rsx!(
label {
font_family: "DoesntExist Font, Impact",
"Hello, World!"
}
)
}
sourcepub const font_weight: AttributeDescription = _
pub const font_weight: AttributeDescription = _
You can choose a weight for text using the font_weight
attribute.
Accepted values:
invisible
thin
extra-light
light
normal
(default)medium
semi-bold
bold
extra-bold
black
extra-black
50
100
200
300
400
500
600
700
800
900
950
§Example
fn app() -> Element {
rsx!(
label {
font_weight: "bold",
"Hello, bold World!"
}
)
}
sourcepub const font_width: AttributeDescription = _
pub const font_width: AttributeDescription = _
You can choose a width for a text using the font_width
attribute.
⚠️ Only fonts with variable widths will be affected.
Accepted values:
ultra-condensed
extra-condensed
condensed
normal
(default)semi-expanded
expanded
extra-expanded
ultra-expanded
§Example
fn app() -> Element {
rsx!(
label {
font_width: "ultra-expanded",
"Hello, wide World!"
}
)
}
sourcepub const text_align: AttributeDescription = _
pub const text_align: AttributeDescription = _
You can change the alignment of the text using the text_align
attribute.
Accepted values:
center
end
justify
left
(default)right
start
§Example
fn app() -> Element {
rsx!(
label {
text_align: "right",
"Hello, World!"
}
)
}
sourcepub const line_height: AttributeDescription = _
pub const line_height: AttributeDescription = _
sourcepub const text_shadow: AttributeDescription = _
pub const text_shadow: AttributeDescription = _
Specify the shadow of a text.
Syntax: <x> <y> <size> <color>
§Example
fn app() -> Element {
rsx!(
label {
text_shadow: "0 18 12 rgb(0, 0, 0)",
"Hello, World!"
}
)
}
sourcepub const max_lines: AttributeDescription = _
pub const max_lines: AttributeDescription = _
Determines the amount of lines that the text can have. It has unlimited lines by default.
§Example
fn app() -> Element {
rsx!(
label {
"Hello, World! \n Hello, World! \n Hello, world!" // Will show all three lines
}
label {
max_lines: "2",
"Hello, World! \n Hello, World! \n Hello, world!" // Will only show two lines
}
)
}
sourcepub const decoration: AttributeDescription = _
pub const decoration: AttributeDescription = _
Specify the decoration in a text.
Accepted values:
underline
line-through
overline
§Example
fn app() -> Element {
rsx!(
label {
decoration: "line-through",
"Hello, World!"
}
)
}
sourcepub const decoration_style: AttributeDescription = _
pub const decoration_style: AttributeDescription = _
Specify the decoration’s style in a text.
Accepted values:
solid
(default)double
dotted
dashed
wavy
§Example
fn app() -> Element {
rsx!(
label {
decoration: "line-through",
decoration_style: "dotted",
"Hello, World!"
}
)
}
sourcepub const decoration_color: AttributeDescription = _
pub const decoration_color: AttributeDescription = _
Specify the decoration’s color in a text.
You can learn about the syntax of this attribute in Color Syntax
.
§Example
fn app() -> Element {
rsx!(
label {
decoration: "line-through",
decoration_color: "orange",
"Hello, World!"
}
)
}
sourcepub const text_overflow: AttributeDescription = _
pub const text_overflow: AttributeDescription = _
Determines how text is treated when it exceeds its max_lines
count. By default uses the clip
mode, which will cut off any overflowing text, with ellipsis
mode it will show ...
at the end.
Accepted values:
clip
(default)ellipsis
§Example
fn app() -> Element {
rsx!(
label {
max_lines: "3",
text_overflow: "ellipsis",
"Looooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooong text"
}
)
}
sourcepub const letter_spacing: AttributeDescription = _
pub const letter_spacing: AttributeDescription = _
Specify the spacing between characters of the text.
§Example
fn app() -> Element {
rsx!(
label {
letter_spacing: "10",
"Hello, World!"
}
)
}
sourcepub const word_spacing: AttributeDescription = _
pub const word_spacing: AttributeDescription = _
Specify the spacing between words of the text.
§Example
fn app() -> Element {
rsx!(
label {
word_spacing: "10",
"Hello, World!"
}
)
}
sourcepub const text_height: AttributeDescription = _
pub const text_height: AttributeDescription = _
Specify the text height behavior.
Accepted values:
disable-all
(default)all
disable-first-ascent
disable-least-ascent
§Example
fn app() -> Element {
rsx!(
label {
text_height: "disable-all",
"Hello, World!"
}
)
}
sourcepub const opacity: AttributeDescription = _
pub const opacity: AttributeDescription = _
Specify the opacity of an element and all its descendants.
§Example
fn app() -> Element {
rsx!(
rect {
opacity: "0.5", // 50% visible
label {
"I am fading!"
}
}
)
}
pub const canvas_reference: AttributeDescription = _
pub const reference: AttributeDescription = _
pub const cursor_reference: AttributeDescription = _
pub const a11y_id: AttributeDescription = _
pub const a11y_focusable: AttributeDescription = _
pub const a11y_auto_focus: AttributeDescription = _
pub const a11y_name: AttributeDescription = _
pub const a11y_description: AttributeDescription = _
pub const a11y_value: AttributeDescription = _
pub const a11y_access_key: AttributeDescription = _
pub const a11y_keyboard_shortcut: AttributeDescription = _
pub const a11y_language: AttributeDescription = _
pub const a11y_placeholder: AttributeDescription = _
pub const a11y_role_description: AttributeDescription = _
pub const a11y_state_description: AttributeDescription = _
pub const a11y_tooltip: AttributeDescription = _
pub const a11y_url: AttributeDescription = _
pub const a11y_row_index_text: AttributeDescription = _
pub const a11y_column_index_text: AttributeDescription = _
pub const a11y_scroll_x: AttributeDescription = _
pub const a11y_scroll_x_min: AttributeDescription = _
pub const a11y_scroll_x_max: AttributeDescription = _
pub const a11y_scroll_y: AttributeDescription = _
pub const a11y_scroll_y_min: AttributeDescription = _
pub const a11y_scroll_y_max: AttributeDescription = _
pub const a11y_numeric_value: AttributeDescription = _
pub const a11y_min_numeric_value: AttributeDescription = _
pub const a11y_max_numeric_value: AttributeDescription = _
pub const a11y_numeric_value_step: AttributeDescription = _
pub const a11y_numeric_value_jump: AttributeDescription = _
pub const a11y_row_count: AttributeDescription = _
pub const a11y_column_count: AttributeDescription = _
pub const a11y_row_index: AttributeDescription = _
pub const a11y_column_index: AttributeDescription = _
pub const a11y_row_span: AttributeDescription = _
pub const a11y_column_span: AttributeDescription = _
pub const a11y_level: AttributeDescription = _
pub const a11y_size_of_set: AttributeDescription = _
pub const a11y_position_in_set: AttributeDescription = _
pub const a11y_color_value: AttributeDescription = _
pub const a11y_expanded: AttributeDescription = _
pub const a11y_selected: AttributeDescription = _
pub const a11y_hovered: AttributeDescription = _
pub const a11y_linked: AttributeDescription = _
pub const a11y_multiselectable: AttributeDescription = _
pub const a11y_required: AttributeDescription = _
pub const a11y_visited: AttributeDescription = _
pub const a11y_busy: AttributeDescription = _
pub const a11y_live_atomic: AttributeDescription = _
pub const a11y_modal: AttributeDescription = _
pub const a11y_touch_transparent: AttributeDescription = _
pub const a11y_read_only: AttributeDescription = _
pub const a11y_disabled: AttributeDescription = _
pub const a11y_is_spelling_error: AttributeDescription = _
pub const a11y_is_grammar_error: AttributeDescription = _
pub const a11y_is_search_match: AttributeDescription = _
pub const a11y_is_suggestion: AttributeDescription = _
pub const a11y_role: AttributeDescription = _
pub const a11y_invalid: AttributeDescription = _
pub const a11y_toggled: AttributeDescription = _
pub const a11y_live: AttributeDescription = _
pub const a11y_default_action_verb: AttributeDescription = _
pub const a11y_orientation: AttributeDescription = _
pub const a11y_sort_direction: AttributeDescription = _
pub const a11y_current: AttributeDescription = _
pub const a11y_auto_complete: AttributeDescription = _
pub const a11y_has_popup: AttributeDescription = _
pub const a11y_list_style: AttributeDescription = _
pub const a11y_vertical_offset: AttributeDescription = _
Auto Trait Implementations§
impl Freeze for rect
impl RefUnwindSafe for rect
impl Send for rect
impl Sync for rect
impl Unpin for rect
impl UnwindSafe for rect
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more