make label into a macro
This commit is contained in:
parent
c2c94ddda5
commit
ef4f0908f2
6 changed files with 75 additions and 74 deletions
|
@ -1,7 +1,7 @@
|
|||
use std::sync::Arc;
|
||||
|
||||
use crate::{
|
||||
layout,
|
||||
label, layout,
|
||||
layout::{show_popup, LayoutOptions, Region},
|
||||
math::{clamp, remap_clamp, vec2},
|
||||
mesher::Vertex,
|
||||
|
@ -47,10 +47,11 @@ fn show_font_sizes(font_sizes: &mut FontSizes, gui: &mut Region) {
|
|||
}
|
||||
|
||||
fn show_font_texture(texture: &Texture, gui: &mut Region) {
|
||||
gui.add(label(format!(
|
||||
gui.add(label!(
|
||||
"Font texture size: {} x {} (hover to zoom)",
|
||||
texture.width, texture.height
|
||||
)));
|
||||
texture.width,
|
||||
texture.height
|
||||
));
|
||||
let mut size = vec2(texture.width as f32, texture.height as f32);
|
||||
if size.x > gui.width() {
|
||||
size *= gui.width() / size.x;
|
||||
|
@ -192,11 +193,24 @@ impl Emigui {
|
|||
});
|
||||
|
||||
region.foldable("Stats", |gui| {
|
||||
gui.add(label(format!("num_vertices: {}", self.stats.num_vertices)));
|
||||
gui.add(label(format!(
|
||||
"num_triangles: {}",
|
||||
self.stats.num_triangles
|
||||
)));
|
||||
gui.add(label!(
|
||||
"Screen size: {} x {} points, pixels_per_point: {}",
|
||||
gui.input().screen_size.x,
|
||||
gui.input().screen_size.y,
|
||||
gui.input().pixels_per_point,
|
||||
));
|
||||
gui.add(label!(
|
||||
"mouse_pos: {} x {}",
|
||||
gui.input().mouse_pos.x,
|
||||
gui.input().mouse_pos.y,
|
||||
));
|
||||
gui.add(label!(
|
||||
"gui cursor: {} x {}",
|
||||
gui.cursor().x,
|
||||
gui.cursor().y,
|
||||
));
|
||||
gui.add(label!("num_vertices: {}", self.stats.num_vertices));
|
||||
gui.add(label!("num_triangles: {}", self.stats.num_triangles));
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
|
@ -9,7 +9,7 @@ use crate::{
|
|||
fonts::{Fonts, TextStyle},
|
||||
math::*,
|
||||
types::*,
|
||||
widgets::{label, Widget},
|
||||
widgets::{Label, Widget},
|
||||
};
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
|
@ -85,7 +85,7 @@ impl GuiResponse {
|
|||
/// Show this text if the item was hovered
|
||||
pub fn tooltip_text<S: Into<String>>(&mut self, text: S) -> &mut Self {
|
||||
self.tooltip(|popup| {
|
||||
popup.add(label(text));
|
||||
popup.add(Label::new(text));
|
||||
})
|
||||
}
|
||||
}
|
||||
|
@ -437,8 +437,8 @@ impl Region {
|
|||
/// Temporarily split split a vertical layout into several columns.
|
||||
///
|
||||
/// region.columns(2, |columns| {
|
||||
/// columns[0].add(emigui::widgets::label("First column"));
|
||||
/// columns[1].add(emigui::widgets::label("Second column"));
|
||||
/// columns[0].add(emigui::widgets::label!("First column"));
|
||||
/// columns[1].add(emigui::widgets::label!("Second column"));
|
||||
/// });
|
||||
pub fn columns<F, R>(&mut self, num_columns: usize, add_contents: F) -> R
|
||||
where
|
||||
|
|
|
@ -40,8 +40,11 @@ impl Label {
|
|||
}
|
||||
}
|
||||
|
||||
pub fn label<S: Into<String>>(text: S) -> Label {
|
||||
Label::new(text)
|
||||
/// Usage: label!("Foo: {}", bar)
|
||||
#[macro_export]
|
||||
macro_rules! label {
|
||||
($fmt:expr) => (Label::new($fmt));
|
||||
($fmt:expr, $($arg:tt)*) => (Label::new(format!($fmt, $($arg)*)));
|
||||
}
|
||||
|
||||
impl Widget for Label {
|
||||
|
@ -264,7 +267,7 @@ impl<'a> Widget for Slider<'a> {
|
|||
|
||||
columns[1].available_space.y = response.rect.size().y;
|
||||
columns[1].horizontal(Align::Center, |region| {
|
||||
region.add(label(full_text));
|
||||
region.add(Label::new(full_text));
|
||||
});
|
||||
|
||||
response
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
use emigui::{math::*, types::*, widgets::*, Align, Region, TextStyle};
|
||||
use emigui::{label, math::*, types::*, widgets::*, Align, Region, TextStyle};
|
||||
|
||||
pub struct App {
|
||||
checked: bool,
|
||||
|
@ -25,62 +25,46 @@ impl Default for App {
|
|||
|
||||
impl App {
|
||||
pub fn show_gui(&mut self, gui: &mut Region) {
|
||||
gui.add(label("Emigui").text_style(TextStyle::Heading));
|
||||
gui.add(label("Emigui is an Immediate mode GUI written in Rust, compiled to WebAssembly, rendered with WebGL."));
|
||||
gui.add(label!("Emigui").text_style(TextStyle::Heading));
|
||||
gui.add(label!("Emigui is an Immediate mode GUI written in Rust, compiled to WebAssembly, rendered with WebGL."));
|
||||
gui.add(Separator::new());
|
||||
|
||||
gui.add(label(format!(
|
||||
"Screen size: {} x {}, pixels_per_point: {}",
|
||||
gui.input().screen_size.x,
|
||||
gui.input().screen_size.y,
|
||||
gui.input().pixels_per_point,
|
||||
)));
|
||||
gui.add(label(format!(
|
||||
"mouse_pos: {} x {}",
|
||||
gui.input().mouse_pos.x,
|
||||
gui.input().mouse_pos.y,
|
||||
)));
|
||||
gui.add(label(format!(
|
||||
"gui cursor: {} x {}",
|
||||
gui.cursor().x,
|
||||
gui.cursor().y,
|
||||
)));
|
||||
gui.foldable("Widget examples", |gui| {
|
||||
gui.horizontal(Align::Min, |gui| {
|
||||
gui.add(label!("Text can have").text_color(srgba(110, 255, 110, 255)));
|
||||
gui.add(label!("color").text_color(srgba(128, 140, 255, 255)));
|
||||
gui.add(label!("and tooltips (hover me)")).tooltip_text(
|
||||
"This is a multiline tooltip that demonstrates that you can easily add tooltips to any element.\nThis is the second line.\nThis is the third.",
|
||||
);
|
||||
});
|
||||
|
||||
gui.horizontal(Align::Min, |gui| {
|
||||
gui.add(label("Text can have").text_color(srgba(110, 255, 110, 255)));
|
||||
gui.add(label("color").text_color(srgba(128, 140, 255, 255)));
|
||||
});
|
||||
gui.add(Checkbox::new(&mut self.checked, "checkbox"));
|
||||
|
||||
gui.add(label("Hover me")).tooltip_text(
|
||||
"This is a multiline tooltip that demonstrates that you can easily add tooltips to any element.\nThis is the second line.\nThis is the third.",
|
||||
);
|
||||
gui.horizontal(Align::Min, |gui| {
|
||||
if gui.add(radio(self.radio == 0, "First")).clicked {
|
||||
self.radio = 0;
|
||||
}
|
||||
if gui.add(radio(self.radio == 1, "Second")).clicked {
|
||||
self.radio = 1;
|
||||
}
|
||||
if gui.add(radio(self.radio == 2, "Final")).clicked {
|
||||
self.radio = 2;
|
||||
}
|
||||
});
|
||||
|
||||
gui.add(Checkbox::new(&mut self.checked, "checkbox"));
|
||||
|
||||
gui.horizontal(Align::Min, |gui| {
|
||||
if gui.add(radio(self.radio == 0, "First")).clicked {
|
||||
self.radio = 0;
|
||||
}
|
||||
if gui.add(radio(self.radio == 1, "Second")).clicked {
|
||||
self.radio = 1;
|
||||
}
|
||||
if gui.add(radio(self.radio == 2, "Final")).clicked {
|
||||
self.radio = 2;
|
||||
}
|
||||
});
|
||||
|
||||
gui.horizontal(Align::Min, |gui| {
|
||||
if gui
|
||||
.add(Button::new("Click me"))
|
||||
.tooltip_text("This will just increase a counter.")
|
||||
.clicked
|
||||
{
|
||||
self.count += 1;
|
||||
}
|
||||
gui.add(label(format!(
|
||||
"The button have been clicked {} times",
|
||||
self.count
|
||||
)));
|
||||
gui.horizontal(Align::Min, |gui| {
|
||||
if gui
|
||||
.add(Button::new("Click me"))
|
||||
.tooltip_text("This will just increase a counter.")
|
||||
.clicked
|
||||
{
|
||||
self.count += 1;
|
||||
}
|
||||
gui.add(label!(
|
||||
"The button have been clicked {} times",
|
||||
self.count
|
||||
));
|
||||
});
|
||||
});
|
||||
|
||||
gui.foldable("Test box rendering", |gui| {
|
||||
|
|
|
@ -5,7 +5,7 @@ extern crate wasm_bindgen;
|
|||
|
||||
extern crate emigui;
|
||||
|
||||
use emigui::{widgets::label, Align, Emigui, RawInput};
|
||||
use emigui::{label, widgets::Label, Align, Emigui, RawInput};
|
||||
|
||||
use wasm_bindgen::prelude::*;
|
||||
|
||||
|
@ -48,12 +48,12 @@ impl State {
|
|||
self.app.show_gui(&mut region);
|
||||
self.emigui.example(&mut region);
|
||||
|
||||
region.add(label("WebGl painter info:"));
|
||||
region.add(label!("WebGl painter info:"));
|
||||
region.indent(|region| {
|
||||
region.add(label(self.webgl_painter.debug_info()));
|
||||
region.add(label!(self.webgl_painter.debug_info()));
|
||||
});
|
||||
|
||||
region.add(label(format!("Everything: {:.1} ms", self.everything_ms)));
|
||||
region.add(label!("Everything: {:.1} ms", self.everything_ms));
|
||||
|
||||
let frame = self.emigui.paint();
|
||||
let result =
|
||||
|
|
|
@ -49,8 +49,8 @@ impl Painter {
|
|||
gl.bind_texture(Gl::TEXTURE_2D, Some(&gl_texture));
|
||||
gl.tex_parameteri(Gl::TEXTURE_2D, Gl::TEXTURE_WRAP_S, Gl::CLAMP_TO_EDGE as i32);
|
||||
gl.tex_parameteri(Gl::TEXTURE_2D, Gl::TEXTURE_WRAP_T, Gl::CLAMP_TO_EDGE as i32);
|
||||
gl.tex_parameteri(Gl::TEXTURE_2D, Gl::TEXTURE_MIN_FILTER, Gl::NEAREST as i32);
|
||||
gl.tex_parameteri(Gl::TEXTURE_2D, Gl::TEXTURE_MAG_FILTER, Gl::NEAREST as i32);
|
||||
gl.tex_parameteri(Gl::TEXTURE_2D, Gl::TEXTURE_MIN_FILTER, Gl::LINEAR as i32);
|
||||
gl.tex_parameteri(Gl::TEXTURE_2D, Gl::TEXTURE_MAG_FILTER, Gl::LINEAR as i32);
|
||||
|
||||
// --------------------------------------------------------------------
|
||||
|
||||
|
|
Loading…
Reference in a new issue