From 92096cc72035b770372e79aa3ed24d04c16bc392 Mon Sep 17 00:00:00 2001 From: Max Bradbury Date: Wed, 30 Sep 2020 12:47:07 +0100 Subject: [PATCH] broken wip example --- Cargo.toml | 3 +- src/main.rs | 314 ++++++++++++++++++++++++++++------------------------ 2 files changed, 171 insertions(+), 146 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 00d7a1a..515882e 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -9,6 +9,5 @@ crate_type = "bin" [dependencies] dirs = "^3.0.1" -gio = "^0" -gtk = "^0" +druid = "^0.6.0" rodio = "^0.11.0" diff --git a/src/main.rs b/src/main.rs index 86c18ff..9f29622 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,8 +1,8 @@ #![windows_subsystem = "windows"] -use gio::prelude::*; -use gtk::prelude::*; -use gtk::Orientation; +// use gio::prelude::*; +// use gtk::prelude::*; +// use gtk::Orientation; use rodio::{Sink, Source}; use std::env::args; use std::fs::File; @@ -12,149 +12,175 @@ use std::process::Command; const SPACING: i32 = 16; -fn error_popup(message: &str) { - let popup = gtk::Window::new(gtk::WindowType::Toplevel); - popup.set_title("error"); - popup.set_border_width(SPACING as u32); - popup.set_position(gtk::WindowPosition::Center); - popup.set_default_size(256, 64); +// fn error_popup(message: &str) { +// let popup = gtk::Window::new(gtk::WindowType::Toplevel); +// popup.set_title("error"); +// popup.set_border_width(SPACING as u32); +// popup.set_position(gtk::WindowPosition::Center); +// popup.set_default_size(256, 64); +// +// let vertical = gtk::Box::new(Orientation::Vertical, SPACING); +// popup.add(&vertical); +// +// let message = gtk::Label::new(Some(message)); +// vertical.add(&message); +// +// let button_ok = gtk::Button::with_label("OK"); +// vertical.add(&button_ok); +// +// popup.show_all(); +// +// button_ok.connect_clicked(move |_| unsafe { +// popup.destroy(); +// }); +// } +// +// fn get_data_dir() -> PathBuf { +// let mut data_dir = dirs::data_dir().expect("Couldn't find user data directory"); +// +// data_dir.push("ruin/lull"); +// +// if !data_dir.exists() { +// std::fs::create_dir_all(&data_dir).expect("Couldn't create lull data directory"); +// } +// +// data_dir +// } +// +// fn build_ui(application: >k::Application) { +// let window = gtk::ApplicationWindow::new(application); +// +// window.set_title("lull"); +// window.set_border_width(SPACING as u32); +// window.set_position(gtk::WindowPosition::Center); +// window.set_default_size(256, 256); +// +// let vertical = gtk::Box::new(Orientation::Vertical, SPACING); +// vertical.set_homogeneous(true); +// +// window.add(&vertical); +// +// let device = rodio::default_output_device().unwrap(); +// +// let paths = std::fs::read_dir(get_data_dir()) +// .expect("Couldn't read from lull data directory"); +// +// for path in paths { +// let path = path.unwrap().path(); +// let name: &str = path.file_stem().unwrap().to_str().unwrap(); +// +// let file = File::open(&path) +// .expect("Couldn't open audio file"); +// +// let source = rodio::Decoder::new( +// BufReader::new(file) +// ); +// +// if source.is_err() { +// error_popup(&format!( +// "Couldn't parse file {}. \n{}.", +// path.to_str().unwrap(), +// source.err().unwrap() +// )); +// continue; +// } +// +// let source = source.unwrap().repeat_infinite(); +// +// let sink = Sink::new(&device); +// sink.append(source); +// sink.pause(); +// +// let row = gtk::Box::new(Orientation::Horizontal, SPACING); +// row.set_homogeneous(true); +// +// let label = gtk::Label::new(Some(name)); +// row.add(&label); +// +// let adjustment = gtk::Adjustment::new( +// 0.0, +// 0.0, +// 1.0, +// 0.0, +// 0.0, +// 0.0 +// ); +// +// let slider = gtk::Scale::new( +// Orientation::Horizontal, +// Some(&adjustment) +// ); +// +// slider.set_draw_value(false); +// +// slider.connect_value_changed(move |scale| { +// let volume = scale.get_value(); +// +// if volume == 0. { +// sink.pause(); +// } else { +// sink.play(); +// sink.set_volume(volume as f32); +// } +// }); +// +// row.add(&slider); +// +// vertical.add(&row); +// } +// +// let row_add = gtk::Box::new(Orientation::Horizontal, SPACING); +// row_add.set_homogeneous(true); +// +// let button_manage_sounds = gtk::Button::with_label("manage sounds"); +// +// button_manage_sounds.connect_clicked(|_| { +// let mut file_manager = Command::new("xdg-open"); +// file_manager.arg(get_data_dir()); +// file_manager.output().unwrap(); +// }); +// +// row_add.add(&button_manage_sounds); +// vertical.add(&row_add); +// +// window.show_all(); +// } +// +// fn main() { +// let application = gtk::Application::new( +// Some("dev.tinybird.max.lull"), +// Default::default() +// ).expect("Initialization failed..."); +// +// application.connect_activate(|app| { +// build_ui(app); +// }); +// +// application.run(&args().collect::>()); +// } - let vertical = gtk::Box::new(Orientation::Vertical, SPACING); - popup.add(&vertical); +use druid::{AppLauncher, WindowDesc, Widget, PlatformError}; +use druid::widget::{Label, Padding, Flex, Align, FlexParams, CrossAxisAlignment, Slider}; - let message = gtk::Label::new(Some(message)); - vertical.add(&message); - - let button_ok = gtk::Button::with_label("OK"); - vertical.add(&button_ok); - - popup.show_all(); - - button_ok.connect_clicked(move |_| unsafe { - popup.destroy(); - }); +fn build_ui() -> impl Widget<()> { + Padding::new( + 10.0, + Flex::column() + .with_flex_child( + Flex::row() + .with_flex_child(Align::centered(Label::new("sound 1")), FlexParams::new(1.0, CrossAxisAlignment::End)) + .with_child(Align::centered(Label::new("slider"))), + 1.0 + ) + .with_child( + Flex::row() + .with_flex_child(Label::new("top right"), 1.0) + .with_flex_child(Align::centered(Label::new("bottom right")), 1.0) + ) + ) } -fn get_data_dir() -> PathBuf { - let mut data_dir = dirs::data_dir().expect("Couldn't find user data directory"); - - data_dir.push("ruin/lull"); - - if !data_dir.exists() { - std::fs::create_dir_all(&data_dir).expect("Couldn't create lull data directory"); - } - - data_dir -} - -fn build_ui(application: >k::Application) { - let window = gtk::ApplicationWindow::new(application); - - window.set_title("lull"); - window.set_border_width(SPACING as u32); - window.set_position(gtk::WindowPosition::Center); - window.set_default_size(256, 256); - - let vertical = gtk::Box::new(Orientation::Vertical, SPACING); - vertical.set_homogeneous(true); - - window.add(&vertical); - - let device = rodio::default_output_device().unwrap(); - - let paths = std::fs::read_dir(get_data_dir()) - .expect("Couldn't read from lull data directory"); - - for path in paths { - let path = path.unwrap().path(); - let name: &str = path.file_stem().unwrap().to_str().unwrap(); - - let file = File::open(&path) - .expect("Couldn't open audio file"); - - let source = rodio::Decoder::new( - BufReader::new(file) - ); - - if source.is_err() { - error_popup(&format!( - "Couldn't parse file {}. \n{}.", - path.to_str().unwrap(), - source.err().unwrap() - )); - continue; - } - - let source = source.unwrap().repeat_infinite(); - - let sink = Sink::new(&device); - sink.append(source); - sink.pause(); - - let row = gtk::Box::new(Orientation::Horizontal, SPACING); - row.set_homogeneous(true); - - let label = gtk::Label::new(Some(name)); - row.add(&label); - - let adjustment = gtk::Adjustment::new( - 0.0, - 0.0, - 1.0, - 0.0, - 0.0, - 0.0 - ); - - let slider = gtk::Scale::new( - Orientation::Horizontal, - Some(&adjustment) - ); - - slider.set_draw_value(false); - - slider.connect_value_changed(move |scale| { - let volume = scale.get_value(); - - if volume == 0. { - sink.pause(); - } else { - sink.play(); - sink.set_volume(volume as f32); - } - }); - - row.add(&slider); - - vertical.add(&row); - } - - let row_add = gtk::Box::new(Orientation::Horizontal, SPACING); - row_add.set_homogeneous(true); - - let button_manage_sounds = gtk::Button::with_label("manage sounds"); - - button_manage_sounds.connect_clicked(|_| { - let mut file_manager = Command::new("xdg-open"); - file_manager.arg(get_data_dir()); - file_manager.output().unwrap(); - }); - - row_add.add(&button_manage_sounds); - vertical.add(&row_add); - - window.show_all(); -} - -fn main() { - let application = gtk::Application::new( - Some("dev.tinybird.max.lull"), - Default::default() - ).expect("Initialization failed..."); - - application.connect_activate(|app| { - build_ui(app); - }); - - application.run(&args().collect::>()); +fn main() -> Result<(), PlatformError> { + AppLauncher::with_window(WindowDesc::new(build_ui)).launch(())?; + Ok(()) }