Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fltk-rs/fltk-theme
A theming crate for fltk-rs
https://github.com/fltk-rs/fltk-theme
Last synced: 3 days ago
JSON representation
A theming crate for fltk-rs
- Host: GitHub
- URL: https://github.com/fltk-rs/fltk-theme
- Owner: fltk-rs
- License: mit
- Created: 2021-07-21T17:24:25.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-08-14T06:18:46.000Z (5 months ago)
- Last Synced: 2024-12-17T22:01:18.824Z (17 days ago)
- Language: Rust
- Size: 1020 KB
- Stars: 106
- Watchers: 3
- Forks: 9
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# fltk-theme
A theming crate for fltk-rs.
- The widget themes are based on work by [Remy Oukaour](https://github.com/roukaour/viz-brain-visualizer) and [Rangi42](https://github.com/Rangi42/tilemap-studio).
- The color themes are based on work by [Greg Ercolano](https://groups.google.com/g/fltkgeneral/c/3A5VC_854ok/m/sDpJsmuLBAAJ).
- Some of the widget schemes are based on work by the NTK GUI library, others are nouveau.## Definitions
### Color theme
- A color theme modify FLTK's color map without modifying any of the drawing routines of the widgets.### Widget scheme
- A widget scheme modifies FLTK's drawing routines for widgets, thus changing their appearance, without changing their colors.### Widget theme
- A widget theme modifies FLTK's drawing routines for widgets, as well as the color map, or default colors used for drawing widgets.As such, color themes can be combined with widget schemes. Widget schemes also enable individually changing the colors and selection colors of each widget. While widget themes have a fixed coloring for widgets, and these usually follow the theme they're named after.
## Usage
```toml
[dependencies]
fltk = "1.4"
fltk-theme = "0.7"
```## Example
Setting the color theme:
```rust,no_run
use fltk::{prelude::*, *};
use fltk_theme::{ColorTheme, color_themes};fn main() {
let a = app::App::default().with_scheme(app::Scheme::Gtk);
let theme = ColorTheme::new(color_themes::BLACK_THEME);
theme.apply();
let mut win = window::Window::default().with_size(400, 300);
let mut btn = button::Button::new(160, 200, 80, 40, "Hello");
btn.set_color(btn.color().lighter());
win.end();
win.show();
a.run().unwrap();
}
```Setting the widget theme:
```rust,no_run
use fltk::{prelude::*, *};
use fltk_theme::{widget_themes, WidgetTheme, ThemeType};fn main() {
let a = app::App::default();
let widget_theme = WidgetTheme::new(ThemeType::AquaClassic);
widget_theme.apply();
let mut win = window::Window::default().with_size(400, 300);
let mut btn = button::Button::new(160, 200, 80, 30, "Hello");
btn.set_frame(widget_themes::OS_DEFAULT_BUTTON_UP_BOX);
win.end();
win.show();
a.run().unwrap();
}
```Setting the widget scheme:
```rust,no_run
use fltk::{prelude::*, *};
use fltk_theme::{WidgetScheme, SchemeType};fn main() {
let a = app::App::default();
let widget_scheme = WidgetScheme::new(SchemeType::Clean);
widget_scheme.apply();
let mut win = window::Window::default().with_size(400, 300);
let mut btn = button::Button::new(160, 200, 80, 30, "Hello");
win.end();
win.show();
a.run().unwrap();
}
```## Widget themes
- Classic (old Windows theme)
- ![alt_test](screenshots/classic.jpg)- Aero (Windows 7 theme)
- ![alt_test](screenshots/aero.jpg)- AquaClassic (classic MacOS theme),
- ![alt_test](screenshots/aqua_classic.jpg)- Dark
- ![alt_test](screenshots/dark.jpg)- High Contrast
- ![alt_test](screenshots/high_contrast.jpg)- Blue
- ![alt_test](screenshots/blue.jpg)- Metro (Windows 8 theme)
- ![alt_test](screenshots/metro.jpg)- Greybird (Gnome xfce)
- ![alt_test](screenshots/greybird.jpg)## Theme FrameTypes
Choosing a WidgetTheme will also define a set of FrameTypes which can be used for your widgets.
```ignore
OS_BUTTON_UP_BOX
OS_CHECK_DOWN_BOX
OS_BUTTON_UP_FRAME
OS_CHECK_DOWN_FRAME
OS_PANEL_THIN_UP_BOX
OS_SPACER_THIN_DOWN_BOX
OS_PANEL_THIN_UP_FRAME
OS_SPACER_THIN_DOWN_FRAME
OS_RADIO_ROUND_DOWN_BOX
OS_HOVERED_UP_BOX
OS_DEPRESSED_DOWN_BOX
OS_HOVERED_UP_FRAME
OS_DEPRESSED_DOWN_FRAME
OS_INPUT_THIN_DOWN_BOX
OS_INPUT_THIN_DOWN_FRAME
OS_MINI_BUTTON_UP_BOX
OS_MINI_DEPRESSED_DOWN_BOX
OS_MINI_BUTTON_UP_FRAME
OS_MINI_DEPRESSED_DOWN_FRAME
OS_DEFAULT_BUTTON_UP_BOX
OS_DEFAULT_HOVERED_UP_BOX
OS_DEFAULT_DEPRESSED_DOWN_BOX
OS_TOOLBAR_BUTTON_HOVER_BOX
OS_TABS_BOX
OS_SWATCH_BOX
OS_SWATCH_FRAME
OS_BG_BOX
```You can check the frames example to see all `FrameType`'s you can apply to you widgets.
- ![alt_test](screenshots/frames.jpg)## Color themes
- Black theme
- ![alt_test](screenshots/black.jpg)- Dark theme
- ![alt_test](screenshots/dark_color.jpg)- Plain gray theme
- ![alt_test](screenshots/plain-gray.jpg)- Tan theme
- ![alt_test](screenshots/tan.jpg)- Shake theme
- ![alt_test](screenshots/shake.jpg)## Widget Schemes
These provide schemes for widgets without color theming. Currently there are 6 schemes:
- Clean: Taken from NTK's clear scheme.
- ![alt_test](screenshots/clean.jpg)- Crystal: Taken from NTK's crystal scheme.
- ![alt_test](screenshots/crystal.jpg)- Gleam: Taken from NTK's gleam scheme.
- ![alt_test](screenshots/gleam.jpg)- Aqua: Tries to mimic the modern MacOS's styles.
- ![alt_test](screenshots/aqua_scheme.jpg)
- ![alt_test](screenshots/aqua_scheme2.jpg)- Fluent: Tries to mimic Window's 10 styles.
- ![alt_test](screenshots/fluent.jpg)
- ![alt_test](screenshots/fluent2.jpg)- SvgBased: This overrides FLTK's Base scheme round/rounded/oval FrameTypes which are drawn using scalable vector graphics.
- ![alt_test](screenshots/svgbased.jpg)## Colors
The crate also provides colors, namely html colors and aqua colors.
The aqua colors are provided as static values and are named after the cocoa NSColor properties (such as windowBackgroundColor, systemBlueColor, controlAccentColor...etc). The html colors are provided in a static HashMap and can be accessed by their [html names](https://www.w3schools.com/tags/ref_colornames.asp). Refer to the html_colors and aqua_dark examples to see how the colors are used.- ![alt_test](screenshots/html_colors.jpg)
Colors and Color themes can also be used with widget schemes or even in a regular fltk-rs application.