![]() |
||
---|---|---|
.. | ||
res | ||
util | ||
Cargo.toml | ||
README.md | ||
animation.rs | ||
border.rs | ||
button.rs | ||
calculator.rs | ||
config.rs | ||
countdown.rs | ||
cursor.rs | ||
extend_view.rs | ||
focus.rs | ||
gradient.rs | ||
headless.rs | ||
icon.rs | ||
image.rs | ||
layer.rs | ||
localize.rs | ||
markdown.rs | ||
respawn.rs | ||
scroll.rs | ||
shortcut.rs | ||
text.rs | ||
transform.rs | ||
window.rs |
README.md
animation
data:image/s3,"s3://crabby-images/50e53/50e53c0c071747c4b2f9afd11c8d0c633a18a726" alt="headless screenshot"
Source: animation.rs
cargo do run animation
Demonstrates animation, easing functions.
border
data:image/s3,"s3://crabby-images/55763/557635e72a4980df118f90f651177c483bcef0e5" alt="headless screenshot"
Source: border.rs
cargo do run border
Demonstrates borders, corner radius, multiple borders per widget and clip-to-bounds.
button
data:image/s3,"s3://crabby-images/c585b/c585befe831a5860af63e288c5c4ac499e309f54" alt="headless screenshot"
Source: button.rs
cargo do run button
Demonstrates the button widget.
calculator
data:image/s3,"s3://crabby-images/2f6e7/2f6e7b703963515a20c6914add245372547449e0" alt="headless screenshot"
Source: calculator.rs
cargo do run calculator
Simple calculator, demonstrates Grid layout, data context.
config
data:image/s3,"s3://crabby-images/cb744/cb744d0493cf474884851cefc1b4027d52e2fd5a" alt="headless screenshot"
Source: config.rs
cargo do run config
Demonstrates the CONFIG service, live updating config between processes.
countdown
Source: countdown.rs
cargo do run countdown
Demonstrates the TIMERS service, variable mapping.
cursor
data:image/s3,"s3://crabby-images/c202c/c202ce8126f8c11725edcfd83d9e0a8805d2120d" alt="headless screenshot"
Source: cursor.rs
cargo do run cursor
Demonstrates each CursorIcon
, tooltip anchored to cursor.
extend_view
Source: extend_view.rs
cargo do run extend_view
Demonstrates the zng-view
extension API and render extensions API.
focus
data:image/s3,"s3://crabby-images/5a862/5a8625bc92e8e82bf9a65e1e155ac5d58c8267a5" alt="headless screenshot"
Source: focus.rs
cargo do run focus
Demonstrates the focus service, logical and directional navigation.
gradient
data:image/s3,"s3://crabby-images/f839b/f839b9542af833593dc46494d1e592a86d4d0d98" alt="headless screenshot"
Source: gradient.rs
cargo do run gradient
Demonstrates gradient rendering.
headless
data:image/s3,"s3://crabby-images/2a613/2a613c0519ddb2b619ca167226a08f19897c317e" alt="headless screenshot"
Source: headless.rs
cargo do run headless
Demonstrates headless apps, image and video rendering.
icon
data:image/s3,"s3://crabby-images/0bad7/0bad7402d4cf09929cfa8f70071daf89a91ee473" alt="headless screenshot"
Source: icon.rs
cargo do run icon
Search and copy Material Icons constants.
image
data:image/s3,"s3://crabby-images/06531/06531e3f6bd9cdd717c2d3d4b63a14b1dba556d9" alt="headless screenshot"
Source: image.rs
cargo do run image
Demonstrates image loading, displaying, animated sprites, rendering, pasting.
layer
data:image/s3,"s3://crabby-images/f1d18/f1d18cf4783075469646b0d852ab0957a830fb28" alt="headless screenshot"
Source: layer.rs
cargo do run layer
Demonstrates the LAYERS service.
localize
data:image/s3,"s3://crabby-images/ebb7d/ebb7d2f01113648a0ca69dbec435bb7c91b0720f" alt="headless screenshot"
Source: localize.rs
cargo do run localize
Demonstrates localization.
markdown
data:image/s3,"s3://crabby-images/d37c5/d37c5f1d872b427dd0cb0830cfb1781cb49330be" alt="headless screenshot"
Source: markdown.rs
cargo do run markdown
Demonstrates the Markdown!
widget.
respawn
data:image/s3,"s3://crabby-images/27675/27675ee219bd062910d6a47f0fc39aa91e58d113" alt="headless screenshot"
Source: respawn.rs
cargo do run respawn
Demonstrates app-process crash handler and view-process respawn.
scroll
data:image/s3,"s3://crabby-images/26f11/26f118ce40bcacada1676756bf48e4cd199abf24" alt="headless screenshot"
Source: scroll.rs
cargo do run scroll
Demonstrates the Scroll!
widget and scroll commands.
shortcut
data:image/s3,"s3://crabby-images/64626/646269c2d143c177547cd3340be867aa4fa2b39b" alt="headless screenshot"
Source: shortcut.rs
cargo do run shortcut
Small utility that displays the pressed key gestures.
text
data:image/s3,"s3://crabby-images/81108/81108497de96bd02f6ccda117b09799e21605d52" alt="headless screenshot"
Source: text.rs
cargo do run text
Demonstrates the Text!
and TextInput!
widgets. Text rendering, text editor.
transform
data:image/s3,"s3://crabby-images/bd0a1/bd0a102c441e0261bcd8663c27874bbccc5f15c7" alt="headless screenshot"
Source: transform.rs
cargo do run transform
Demonstrates 2D and 3D transforms, touch transforms.
window
data:image/s3,"s3://crabby-images/2ab19/2ab199d39c9615ea234f57c8bee9746cd5a0331d" alt="headless screenshot"
Source: window.rs
cargo do run window
Demonstrates the window widget, service, state and commands.
Adding an Example
Add the new example in examples/<example-name>.rs
:
//! Demonstrates foo, bar.
#![cfg_attr(not(debug_assertions), windows_subsystem = "windows")]
use zng::prelude::*;
use zng::view_process::prebuilt as view_process;
fn main() {
examples_util::print_info();
// view_process::run_same_process(app_main);
view_process::init();
app_main();
}
fn app_main() {
APP.defaults().run_window(async {
Window! {
title = "Foo Example";
child = Text!("Bar");
}
})
}
Register it in examples/Cargo.toml
:
[[example]]
name = "<example-name>"
path = "<example-name>.rs"
Run the example and test it.
cargo do run <example-name>
Optionally, take a screenshot and save it to examples/res/screenshots/<example-name>.png
. You can take a screenshot using
the inspector window, press Ctrl+Shift+I
then click the "Save Screenshot" menu.
Run oxipng
or another minifier on the screenshot before committing.
oxipng -o max --strip safe --alpha "examples/res/screenshots/<example-name>.png"
Update the auto generated README:
cargo do doc --readme-examples
Done. You can run the new example using:
cargo do run <example-name>
Local Example
You can create local examples for manual testing in /examples/examples/<test>.rs
. These
files are git-ignored and can be run using cargo do run <test>
without needing to register.