Struct Tabs

Source
pub struct Tabs { /* private fields */ }
Expand description

Creates a tab which can contain widgets

Implementations§

Source§

impl Tabs

Source

pub fn new<'a, T: Into<Option<&'a str>>>( x: i32, y: i32, width: i32, height: i32, title: T, ) -> Tabs

Creates a new widget, takes an x, y coordinates, as well as a width and height, plus a title

§Arguments
  • x - The x coordinate in the screen
  • y - The y coordinate in the screen
  • width - The width of the widget
  • heigth - The height of the widget
  • title - The title or label of the widget

To use dynamic strings use with_label(self, &str) or set_label(&mut self, &str). labels support special symbols preceded by an @ sign and for the associated formatting.

Source

pub fn default_fill() -> Self

Constructs a widget with the size of its parent

Examples found in repository?
examples/tabs.rs (line 13)
12fn draw_gallery() {
13    let mut tab = Tabs::default_fill();
14
15    let mut grp1 = Flex::default_fill().with_label("Tab1\t\t").row();
16    let mut col = Flex::default().column();
17    grp1.fixed(&col, 160);
18    col.set_pad(10);
19    col.set_margin(10);
20    let _but1 = Button::default().with_label("Button");
21    let _but2 = RoundButton::default().with_label("Round");
22    let _but3 = CheckButton::default().with_label("Check");
23    let _but4 = LightButton::default().with_label("Light");
24    let mut but5 = MenuButton::default().with_label("Menu");
25    but5.add_choice("Hello|World|From|Rust");
26    let _but6 = ReturnButton::default().with_label("Return");
27    let mut chce = Choice::default();
28    chce.add_choice("Hello");
29    let _inp = Input::default();
30    let mut out = Output::default();
31    out.set_value("output");
32    col.end();
33    grp1.end();
34
35    let grp2 = Flex::default_fill().with_label("Tab2\t\t").row();
36    grp2.end();
37    tab.end();
38    tab.auto_layout();
39}
Source§

impl Tabs

Source

pub fn value(&self) -> Option<impl GroupExt>

Gets the currently visible group

Source

pub fn set_value<Grp: GroupExt>(&mut self, w: &Grp) -> Result<(), FltkError>

Sets the currently visible group

§Errors

Errors when the value can’t be set for the group widget

Source

pub fn push(&self) -> Option<impl GroupExt>

Returns the tab group for the tab the user has currently down-clicked

Source

pub fn set_push<Grp: GroupExt>(&mut self, w: &Grp) -> Result<(), FltkError>

This is called by the tab widget’s handle() method to set the tab group widget the user last pushed

§Errors

Errors if set_push can’t be set for the group widget

Source

pub fn client_area(&self) -> (i32, i32, i32, i32)

Returns the position and size available to be used by its children

Source

pub fn set_tab_align(&mut self, a: Align)

Sets the tab label alignment

Examples found in repository?
examples/closable_tab.rs (line 16)
11fn main() {
12    let app = app::App::default();
13    let mut win = window::Window::default().with_size(800, 600);
14    let row = group::Flex::default_fill().row();
15    let mut tabs = group::Tabs::default();
16    tabs.set_tab_align(enums::Align::Right);
17    tabs.handle_overflow(group::TabsOverflow::Compress);
18    // first tab
19    {
20        let mut col1 = group::Flex::default().with_label("\t\ttab1").column();
21        col1.set_when(When::Closed);
22        col1.set_callback(tab_close_cb);
23        // widgets
24        col1.end();
25    }
26    // end first tab
27
28    // second tab
29    {
30        let mut col2 = group::Flex::default().with_label("\t\ttab2").column();
31        col2.set_when(When::Closed);
32        col2.set_callback(tab_close_cb);
33        // widgets
34        col2.end();
35    }
36    // end second tab
37    tabs.end();
38    tabs.auto_layout();
39    row.end();
40    win.end();
41    win.show();
42    app.run().unwrap();
43}
Source

pub fn tab_align(&self) -> Align

Gets the tab label alignment.

Source

pub fn auto_layout(&mut self)

Auto layout a tabs widget

Examples found in repository?
examples/closable_tab.rs (line 38)
11fn main() {
12    let app = app::App::default();
13    let mut win = window::Window::default().with_size(800, 600);
14    let row = group::Flex::default_fill().row();
15    let mut tabs = group::Tabs::default();
16    tabs.set_tab_align(enums::Align::Right);
17    tabs.handle_overflow(group::TabsOverflow::Compress);
18    // first tab
19    {
20        let mut col1 = group::Flex::default().with_label("\t\ttab1").column();
21        col1.set_when(When::Closed);
22        col1.set_callback(tab_close_cb);
23        // widgets
24        col1.end();
25    }
26    // end first tab
27
28    // second tab
29    {
30        let mut col2 = group::Flex::default().with_label("\t\ttab2").column();
31        col2.set_when(When::Closed);
32        col2.set_callback(tab_close_cb);
33        // widgets
34        col2.end();
35    }
36    // end second tab
37    tabs.end();
38    tabs.auto_layout();
39    row.end();
40    win.end();
41    win.show();
42    app.run().unwrap();
43}
More examples
Hide additional examples
examples/tabs.rs (line 38)
12fn draw_gallery() {
13    let mut tab = Tabs::default_fill();
14
15    let mut grp1 = Flex::default_fill().with_label("Tab1\t\t").row();
16    let mut col = Flex::default().column();
17    grp1.fixed(&col, 160);
18    col.set_pad(10);
19    col.set_margin(10);
20    let _but1 = Button::default().with_label("Button");
21    let _but2 = RoundButton::default().with_label("Round");
22    let _but3 = CheckButton::default().with_label("Check");
23    let _but4 = LightButton::default().with_label("Light");
24    let mut but5 = MenuButton::default().with_label("Menu");
25    but5.add_choice("Hello|World|From|Rust");
26    let _but6 = ReturnButton::default().with_label("Return");
27    let mut chce = Choice::default();
28    chce.add_choice("Hello");
29    let _inp = Input::default();
30    let mut out = Output::default();
31    out.set_value("output");
32    col.end();
33    grp1.end();
34
35    let grp2 = Flex::default_fill().with_label("Tab2\t\t").row();
36    grp2.end();
37    tab.end();
38    tab.auto_layout();
39}
Source

pub fn handle_overflow(&mut self, ov: TabsOverflow)

Sets how the Tabs handles overflow

Examples found in repository?
examples/closable_tab.rs (line 17)
11fn main() {
12    let app = app::App::default();
13    let mut win = window::Window::default().with_size(800, 600);
14    let row = group::Flex::default_fill().row();
15    let mut tabs = group::Tabs::default();
16    tabs.set_tab_align(enums::Align::Right);
17    tabs.handle_overflow(group::TabsOverflow::Compress);
18    // first tab
19    {
20        let mut col1 = group::Flex::default().with_label("\t\ttab1").column();
21        col1.set_when(When::Closed);
22        col1.set_callback(tab_close_cb);
23        // widgets
24        col1.end();
25    }
26    // end first tab
27
28    // second tab
29    {
30        let mut col2 = group::Flex::default().with_label("\t\ttab2").column();
31        col2.set_when(When::Closed);
32        col2.set_callback(tab_close_cb);
33        // widgets
34        col2.end();
35    }
36    // end second tab
37    tabs.end();
38    tabs.auto_layout();
39    row.end();
40    win.end();
41    win.show();
42    app.run().unwrap();
43}

Trait Implementations§

Source§

impl Clone for Tabs

Source§

fn clone(&self) -> Tabs

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 Tabs

Source§

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

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

impl Default for Tabs

Source§

fn default() -> Self

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

impl GroupExt for Tabs

Source§

fn begin(&self)

Begins a group, used for widgets implementing the group trait
Source§

fn end(&self)

Ends a group, used for widgets implementing the group trait
Source§

fn clear(&mut self)

Clear a group from all widgets
Source§

fn children(&self) -> i32

Return the number of children in a group
Source§

fn child(&self, idx: i32) -> Option<Widget>

Return child widget by index
Source§

fn find<W: WidgetExt>(&self, widget: &W) -> i32

Find a widget within a group and return its index
Source§

fn add<W: WidgetExt>(&mut self, widget: &W)

Add a widget to a group
Source§

fn insert<W: WidgetExt>(&mut self, widget: &W, index: i32)

Insert a widget to a group at a certain index
Source§

fn remove<W: WidgetExt>(&mut self, widget: &W)

Remove a widget from a group, but does not delete it
Source§

fn remove_by_index(&mut self, idx: i32)

Remove a child widget by its index
Source§

fn resizable<W: WidgetExt>(&self, widget: &W)

The resizable widget defines both the resizing frame and the resizing behavior of the group and its children.
Source§

fn make_resizable(&mut self, val: bool)

Make the group itself resizable, should be called before the widget is shown
Source§

fn add_resizable<W: WidgetExt>(&mut self, widget: &W)

Adds a widget to the group and makes it the resizable widget
Source§

fn set_clip_children(&mut self, flag: bool)

Clips children outside the group boundaries
Source§

fn clip_children(&self) -> bool

Get whether clip_children is set
Source§

fn draw_child<W: WidgetExt>(&self, w: &mut W)

Draw a child widget, the call should be in a WidgetBase::draw method
Source§

fn update_child<W: WidgetExt>(&self, w: &mut W)

Update a child widget, the call should be in a WidgetBase::draw method
Source§

fn draw_outside_label<W: WidgetExt>(&self, w: &mut W)

Draw the outside label, the call should be in a WidgetBase::draw method
Source§

fn draw_children(&mut self)

Draw children, the call should be in a WidgetBase::draw method
Source§

fn init_sizes(&mut self)

Resets the internal array of widget sizes and positions
Source§

fn bounds(&self) -> Vec<(i32, i32, i32, i32)>

Get the bounds of all children widgets (left, upper, right, bottom)
Source§

unsafe fn as_group(&self) -> Group

Converts a widget implementing GroupExt into a Group widget Read more
Source§

impl IntoIterator for Tabs

Source§

type Item = Widget

The type of the elements being iterated over.
Source§

type IntoIter = IntoIter<<Tabs as IntoIterator>::Item>

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> Self::IntoIter

Creates an iterator from a value. Read more
Source§

impl PartialEq for Tabs

Source§

fn eq(&self, other: &Self) -> 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 WidgetBase for Tabs

Source§

fn delete(wid: Self)

Deletes widgets and their children.
Source§

unsafe fn from_widget_ptr(ptr: *mut Fl_Widget) -> Self

transforms a widget pointer to a Widget, for internal use Read more
Source§

unsafe fn from_widget<W: WidgetExt>(w: W) -> Self

Get a widget from base widget Read more
Source§

fn handle<F: FnMut(&mut Self, Event) -> bool + 'static>(&mut self, cb: F)

Set a custom handler, where events are managed manually, akin to Fl_Widget::handle(int). Handled or ignored events should return true, unhandled events should return false. takes the widget as a closure argument. The ability to handle an event might depend on handling other events, as explained here
Source§

fn draw<F: FnMut(&mut Self) + 'static>(&mut self, cb: F)

Set a custom draw method. takes the widget as a closure argument. macOS requires that WidgetBase::draw actually calls drawing functions
Source§

fn resize_callback<F: FnMut(&mut Self, i32, i32, i32, i32) + 'static>( &mut self, cb: F, )

Perform a callback on resize. Avoid resizing the parent or the same widget to avoid infinite recursion
Source§

unsafe fn assume_derived(&mut self)

Makes the widget derived Read more
Source§

fn from_dyn_widget<W: WidgetExt>(w: &W) -> Option<Self>

Cast a type-erased widget back to its original widget
Source§

fn from_dyn_widget_ptr(w: *mut Fl_Widget) -> Option<Self>

Cast a type-erased widget pointer back to its original widget
Source§

impl WidgetExt for Tabs

Source§

fn set_label(&mut self, title: &str)

Sets the widget’s label. labels support special symbols preceded by an @ sign. and for the associated formatting.
Source§

fn unset_label(&mut self)

Unset a widget’s label
Source§

fn redraw(&mut self)

Redraws a widget, necessary for resizing and changing positions
Source§

fn show(&mut self)

Shows the widget
Source§

fn hide(&mut self)

Hides the widget
Source§

fn x(&self) -> i32

Returns the x coordinate of the widget
Source§

fn y(&self) -> i32

Returns the y coordinate of the widget
Source§

fn w(&self) -> i32

Returns the width of the widget
Source§

fn h(&self) -> i32

Returns the height of the widget
Source§

fn label(&self) -> Option<String>

Returns the label of the widget
Source§

fn measure_label(&self) -> (i32, i32)

Measures the label’s width and height
Source§

fn as_widget_ptr(&self) -> *mut Fl_Widget

transforms a widget to a base Fl_Widget, for internal use
Source§

fn activate(&mut self)

Activates the widget
Source§

fn deactivate(&mut self)

Deactivates the widget
Source§

fn redraw_label(&mut self)

Redraws the label of the widget
Source§

fn resize(&mut self, x: i32, y: i32, width: i32, height: i32)

Resizes and/or moves the widget, takes x, y, width and height
Source§

fn widget_resize(&mut self, x: i32, y: i32, width: i32, height: i32)

Does a simple resize ignoring class-specific resize functionality
Source§

fn tooltip(&self) -> Option<String>

Returns the tooltip text
Source§

fn set_tooltip(&mut self, txt: &str)

Sets the tooltip text
Source§

fn color(&self) -> Color

Returns the widget color
Source§

fn set_color(&mut self, color: Color)

Sets the widget’s color
Source§

fn label_color(&self) -> Color

Returns the widget label’s color
Source§

fn set_label_color(&mut self, color: Color)

Sets the widget label’s color
Source§

fn label_font(&self) -> Font

Returns the widget label’s font
Source§

fn set_label_font(&mut self, font: Font)

Sets the widget label’s font
Source§

fn label_size(&self) -> i32

Returns the widget label’s size
Source§

fn set_label_size(&mut self, sz: i32)

Sets the widget label’s size
Source§

fn label_type(&self) -> LabelType

Returns the widget label’s type
Source§

fn set_label_type(&mut self, typ: LabelType)

Sets the widget label’s type
Source§

fn frame(&self) -> FrameType

Returns the widget’s frame type
Source§

fn set_frame(&mut self, typ: FrameType)

Sets the widget’s frame type
Source§

fn changed(&self) -> bool

Returns whether the widget was changed
Source§

fn set_changed(&mut self)

Mark the widget as changed
Source§

fn clear_changed(&mut self)

Clears the changed status of the widget
Source§

fn align(&self) -> Align

Returns the alignment of the widget
Source§

fn set_align(&mut self, align: Align)

Sets the alignment of the widget
Source§

fn set_when(&mut self, trigger: When)

Sets the default callback trigger for a widget, equivalent to when()
Source§

fn when(&self) -> When

Return the callback trigger, equivalent to when()
Source§

fn parent(&self) -> Option<Group>

Returns the parent of the widget
Source§

fn selection_color(&self) -> Color

Gets the selection color of the widget
Source§

fn set_selection_color(&mut self, color: Color)

Sets the selection color of the widget
Source§

fn do_callback(&mut self)

Runs the already registered callback
Source§

fn window(&self) -> Option<Box<dyn WindowExt>>

Returns the direct window holding the widget
Source§

fn top_window(&self) -> Option<Box<dyn WindowExt>>

Returns the topmost window holding the widget
Source§

fn takes_events(&self) -> bool

Checks whether a widget is capable of taking events
Source§

fn take_focus(&mut self) -> Result<(), FltkError>

Make the widget take focus Read more
Source§

fn set_visible_focus(&mut self)

Set the widget to have visible focus
Source§

fn clear_visible_focus(&mut self)

Clear visible focus
Source§

fn visible_focus(&mut self, v: bool)

Set the visible focus using a flag
Source§

fn has_visible_focus(&self) -> bool

Return whether the widget has visible focus
Source§

fn has_focus(&self) -> bool

Return whether the widget has focus
Source§

fn was_deleted(&self) -> bool

Check if a widget was deleted
Source§

fn damage(&self) -> bool

Return whether the widget was damaged
Source§

fn set_damage(&mut self, flag: bool)

Signal the widget as damaged and it should be redrawn in the next event loop cycle
Source§

fn damage_type(&self) -> Damage

Return the damage mask
Source§

fn set_damage_type(&mut self, mask: Damage)

Signal the type of damage a widget received
Source§

fn set_damage_area(&mut self, mask: Damage, x: i32, y: i32, w: i32, h: i32)

Signal damage for an area inside the widget
Source§

fn clear_damage(&mut self)

Clear the damaged flag
Source§

fn as_window(&self) -> Option<Box<dyn WindowExt>>

Return the widget as a window if it’s a window
Source§

fn as_group(&self) -> Option<Group>

Return the widget as a group widget if it’s a group widget
Source§

fn inside<W: WidgetExt>(&self, wid: &W) -> bool

Checks whether the self widget is inside another widget
Source§

fn get_type<T: WidgetType>(&self) -> T

Returns the widget type when applicable
Source§

fn set_type<T: WidgetType>(&mut self, typ: T)

Sets the widget type
Source§

fn set_image<I: ImageExt>(&mut self, image: Option<I>)

Sets the image of the widget
Source§

fn set_image_scaled<I: ImageExt>(&mut self, image: Option<I>)

Sets the image of the widget scaled to the widget’s size
Source§

fn image(&self) -> Option<Box<dyn ImageExt>>

Gets the image associated with the widget
Source§

fn set_deimage<I: ImageExt>(&mut self, image: Option<I>)

Sets the deactivated image of the widget
Source§

fn set_deimage_scaled<I: ImageExt>(&mut self, image: Option<I>)

Sets the deactivated image of the widget scaled to the widget’s size
Source§

fn deimage(&self) -> Option<Box<dyn ImageExt>>

Gets the deactivated image associated with the widget
Source§

fn set_callback<F: FnMut(&mut Self) + 'static>(&mut self, cb: F)

Sets the callback when the widget is triggered (clicks for example) takes the widget as a closure argument
Source§

fn emit<T: 'static + Clone + Send + Sync>(&mut self, sender: Sender<T>, msg: T)

Emits a message on callback using a sender
Source§

unsafe fn as_widget<W: WidgetBase>(&self) -> W

Upcast a WidgetExt to some widget type Read more
Source§

fn visible(&self) -> bool

Returns whether a widget is visible
Source§

fn visible_r(&self) -> bool

Returns whether a widget or any of its parents are visible (recursively)
Source§

fn is_same<W: WidgetExt>(&self, other: &W) -> bool

Return whether two widgets object point to the same widget
Source§

fn active(&self) -> bool

Returns whether a widget is active
Source§

fn active_r(&self) -> bool

Returns whether a widget or any of its parents are active (recursively)
Source§

fn handle_event(&mut self, event: Event) -> bool

Handle a specific event
Source§

fn is_derived(&self) -> bool

Check whether a widget is derived
Source§

fn as_base_widget(&self) -> Widget
where Self: Sized,

Upcast a WidgetExt to a Widget
Source§

impl WidgetProps for Tabs

Source§

fn with_pos(self, x: i32, y: i32) -> Self

Initialize to position x, y

Source§

fn with_size(self, width: i32, height: i32) -> Self

Initialize to size width, height

Source§

fn with_label(self, title: &str) -> Self

Initialize with a label

Source§

fn with_align(self, align: Align) -> Self

Initialize with alignment

Source§

fn with_type<T: WidgetType>(self, typ: T) -> Self

Initialize with type

Source§

fn below_of<W: WidgetExt>(self, wid: &W, padding: i32) -> Self

Initialize at bottom of another widget

Source§

fn above_of<W: WidgetExt>(self, wid: &W, padding: i32) -> Self

Initialize above of another widget

Source§

fn right_of<W: WidgetExt>(self, wid: &W, padding: i32) -> Self

Initialize right of another widget

Source§

fn left_of<W: WidgetExt>(self, wid: &W, padding: i32) -> Self

Initialize left of another widget

Source§

fn center_of<W: WidgetExt>(self, w: &W) -> Self

Initialize center of another widget

Source§

fn center_x<W: WidgetExt>(self, w: &W) -> Self

Initialize center of another widget on the x axis

Source§

fn center_y<W: WidgetExt>(self, w: &W) -> Self

Initialize center of another widget on the y axis

Source§

fn center_of_parent(self) -> Self

Initialize center of parent

Source§

fn size_of<W: WidgetExt>(self, w: &W) -> Self

Initialize to the size of another widget

Source§

fn size_of_parent(self) -> Self

Initialize to the size of the parent

Source§

impl Eq for Tabs

Source§

impl Send for Tabs

Available on non-crate feature single-threaded only.
Source§

impl Sync for Tabs

Available on non-crate feature single-threaded only.

Auto Trait Implementations§

§

impl Freeze for Tabs

§

impl RefUnwindSafe for Tabs

§

impl Unpin for Tabs

§

impl UnwindSafe for Tabs

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<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<W> WidgetId<W> for W
where W: WidgetExt + Clone + Send + Sync + 'static,

Source§

fn set_id(&mut self, id: &str)

Set the widget’s Id
Source§

fn with_id(self, id: &str) -> W

Construct a widget with an Id