#[cfg(all(feature="winit", feature="glium"))] #[macro_use] extern crate conrod;
#[cfg(all(feature="winit", feature="glium"))] mod support;
fn main() {
feature::main();
}
#[cfg(all(feature="winit", feature="glium"))]
mod feature {
extern crate find_folder;
extern crate image;
extern crate rand; use conrod::{self, widget, Borderable, Colorable, Positionable, Sizeable, Widget, color};
use conrod::backend::glium::glium;
use conrod::backend::glium::glium::Surface;
use std;
use support;
pub fn main() {
const WIDTH: u32 = 1100;
const HEIGHT: u32 = 560;
let mut events_loop = glium::glutin::EventsLoop::new();
let window = glium::glutin::WindowBuilder::new()
.with_title("Image Button Demonstration")
.with_dimensions(WIDTH, HEIGHT);
let context = glium::glutin::ContextBuilder::new()
.with_vsync(true)
.with_multisampling(4);
let display = glium::Display::new(window, context, &events_loop).unwrap();
let mut ui = conrod::UiBuilder::new([WIDTH as f64, HEIGHT as f64]).build();
let assets = find_folder::Search::KidsThenParents(3, 5).for_folder("assets").unwrap();
let font_path = assets.join("fonts/NotoSans/NotoSans-Regular.ttf");
ui.fonts.insert_from_file(font_path).unwrap();
let mut renderer = conrod::backend::glium::Renderer::new(&display).unwrap();
widget_ids!(struct Ids { canvas, button, rust_logo });
let ids = Ids::new(ui.widget_id_generator());
let mut image_map = conrod::image::Map::new();
struct ImageIds {
normal: conrod::image::Id,
hover: conrod::image::Id,
press: conrod::image::Id,
}
let image_path = assets.join("images");
let rust_logo = load_image(&display, image_path.join("rust.png"));
let (w, h) = (rust_logo.get_width(), rust_logo.get_height().unwrap());
let image_ids = ImageIds {
normal: image_map.insert(rust_logo),
hover: image_map.insert(load_image(&display, image_path.join("rust_hover.png"))),
press: image_map.insert(load_image(&display, image_path.join("rust_press.png"))),
};
let mut bg_color = conrod::color::LIGHT_BLUE;
let mut event_loop = support::EventLoop::new();
'main: loop {
for event in event_loop.next(&mut events_loop) {
if let Some(event) = conrod::backend::winit::convert_event(event.clone(), &display) {
ui.handle_event(event);
event_loop.needs_update();
}
match event {
glium::glutin::Event::WindowEvent { event, .. } => match event {
glium::glutin::WindowEvent::Closed |
glium::glutin::WindowEvent::KeyboardInput {
input: glium::glutin::KeyboardInput {
virtual_keycode: Some(glium::glutin::VirtualKeyCode::Escape),
..
},
..
} => break 'main,
_ => (),
},
_ => (),
}
}
{
let ui = &mut ui.set_widgets();
widget::Canvas::new()
.pad(30.0)
.color(bg_color)
.set(ids.canvas, ui);
if widget::Button::image(image_ids.normal)
.hover_image(image_ids.hover)
.press_image(image_ids.press)
.w_h(w as conrod::Scalar, h as conrod::Scalar)
.middle_of(ids.canvas)
.border(0.0)
.set(ids.button, ui)
.was_clicked()
{
bg_color = color::rgb(rand::random(), rand::random(), rand::random());
}
}
if let Some(primitives) = ui.draw_if_changed() {
renderer.fill(&display, primitives, &image_map);
let mut target = display.draw();
target.clear_color(0.0, 0.0, 0.0, 1.0);
renderer.draw(&display, &mut target, &image_map).unwrap();
target.finish().unwrap();
}
}
}
fn load_image<P>(display: &glium::Display, path: P) -> glium::texture::SrgbTexture2d
where P: AsRef<std::path::Path>,
{
let path = path.as_ref();
let rgba_image = image::open(&std::path::Path::new(&path)).unwrap().to_rgba();
let image_dimensions = rgba_image.dimensions();
let raw_image = glium::texture::RawImage2d::from_raw_rgba_reversed(&rgba_image.into_raw(), image_dimensions);
let texture = glium::texture::SrgbTexture2d::new(display, raw_image).unwrap();
texture
}
}
#[cfg(not(all(feature="winit", feature="glium")))]
mod feature {
pub fn main() {
println!("This example requires the `winit` and `glium` features. \
Try running `cargo run --release --features=\"winit glium\" --example <example_name>`");
}
}