13 releases

0.3.2 Aug 2, 2024
0.3.1 Jul 29, 2023
0.3.0 Mar 31, 2023
0.2.2 Mar 18, 2023
0.1.6 Nov 30, 2021

#1315 in GUI

Download history 46/week @ 2024-07-22 107/week @ 2024-07-29 31/week @ 2024-08-05 19/week @ 2024-08-12 2/week @ 2024-08-19 8/week @ 2024-08-26 1/week @ 2024-09-09 32/week @ 2024-09-16 85/week @ 2024-09-23 21/week @ 2024-09-30 4/week @ 2024-10-07 9/week @ 2024-10-14 23/week @ 2024-10-28 24/week @ 2024-11-04

56 downloads per month
Used in 2 crates

MIT license

140KB
541 lines

fltk-table

A smart table widget for fltk-rs. It aims to reduce the amount of boilerplate required to create a table.

Usage

[dependencies]
fltk = "1.4"
fltk-table = "0.3"

Example

use fltk::{
    app, enums,
    prelude::{GroupExt, WidgetExt},
    window,
};
use fltk_table::{SmartTable, TableOpts};

fn main() {
    let app = app::App::default().with_scheme(app::Scheme::Gtk);
    let mut wind = window::Window::default().with_size(800, 600);

    /// We pass the rows and columns thru the TableOpts field
    let mut table = SmartTable::default()
    .with_size(790, 590)
    .center_of_parent()
    .with_opts(TableOpts {
        rows: 30,
        cols: 15,
        editable: true,
        ..Default::default()
    });
    
    wind.end();
    wind.show();

    // Just filling the vec with some values
    for i in 0..30 {
        for j in 0..15 {
            table.set_cell_value(i, j, &(i + j).to_string());
        }
    }

    // set the value at the row,column 4,5 to "another", notice that indices start at 0
    table.set_cell_value(3, 4, "another");

    assert_eq!(table.cell_value(3, 4), "another");

    // To avoid closing the window on hitting the escape key
    wind.set_callback(move |_| {
        if app::event() == enums::Event::Close {
            app.quit();
        }
    });

    app.run().unwrap();
}

You can retrieve a copy of the data using the SmartTable::data() method.

The TableOpts struct also takes styling elements for cells and headers:

let mut table = SmartTable::default(TableOpts {
        rows: 30,
        cols: 15,
        cell_selection_color: Color::Red.inactive(),
        header_frame: FrameType::FlatBox,
        header_color: Color::BackGround.lighter(),
        cell_border_color: Color::White,
        ..Default::default()
    });

image

The row/column header strings can also be changed using the set_row_header_value() and set_col_header_value() methods, which take an index to the required row/column.

Dependencies

~14MB
~310K SLoC