diff options
| author | 2023-11-29 22:28:31 +0100 | |
|---|---|---|
| committer | 2023-11-29 22:28:31 +0100 | |
| commit | e09b4e24dda51b8212d8ece52431dacaa3922a7b (patch) | |
| tree | 7005e181528134ebdde5bbbe5909273db9f30174 /examples/screenshot/src | |
| parent | 83c7870c569a2976923ee6243a19813094d44673 (diff) | |
| parent | 7f8b17604a31e00becc43130ec516c1a53552c88 (diff) | |
| download | iced-e09b4e24dda51b8212d8ece52431dacaa3922a7b.tar.gz iced-e09b4e24dda51b8212d8ece52431dacaa3922a7b.tar.bz2 iced-e09b4e24dda51b8212d8ece52431dacaa3922a7b.zip | |
Merge branch 'master' into feat/multi-window-support
Diffstat (limited to '')
| -rw-r--r-- | examples/screenshot/src/main.rs | 45 | 
1 files changed, 23 insertions, 22 deletions
| diff --git a/examples/screenshot/src/main.rs b/examples/screenshot/src/main.rs index 7658384b..20d34be6 100644 --- a/examples/screenshot/src/main.rs +++ b/examples/screenshot/src/main.rs @@ -4,16 +4,15 @@ use iced::widget::{button, column, container, image, row, text, text_input};  use iced::window::screenshot::{self, Screenshot};  use iced::{alignment, window};  use iced::{ -    event, executor, keyboard, subscription, Alignment, Application, Command, -    ContentFit, Element, Event, Length, Rectangle, Renderer, Subscription, -    Theme, +    event, executor, keyboard, Alignment, Application, Command, ContentFit, +    Element, Event, Length, Rectangle, Renderer, Subscription, Theme,  };  use ::image as img;  use ::image::ColorType;  fn main() -> iced::Result { -    env_logger::builder().format_timestamp(None).init(); +    tracing_subscriber::fmt::init();      Example::run(iced::Settings::default())  } @@ -188,8 +187,8 @@ impl Application for Example {                  .align_items(Alignment::Center);          if let Some(crop_error) = &self.crop_error { -            crop_controls = crop_controls -                .push(text(format!("Crop error! \n{}", crop_error))); +            crop_controls = +                crop_controls.push(text(format!("Crop error! \n{crop_error}")));          }          let mut controls = column![ @@ -225,9 +224,9 @@ impl Application for Example {          if let Some(png_result) = &self.saved_png_path {              let msg = match png_result { -                Ok(path) => format!("Png saved as: {:?}!", path), +                Ok(path) => format!("Png saved as: {path:?}!"),                  Err(msg) => { -                    format!("Png could not be saved due to:\n{:?}", msg) +                    format!("Png could not be saved due to:\n{msg:?}")                  }              }; @@ -257,7 +256,7 @@ impl Application for Example {      }      fn subscription(&self) -> Subscription<Self::Message> { -        subscription::events_with(|event, status| { +        event::listen_with(|event, status| {              if let event::Status::Captured = status {                  return None;              } @@ -277,15 +276,20 @@ impl Application for Example {  async fn save_to_png(screenshot: Screenshot) -> Result<String, PngError> {      let path = "screenshot.png".to_string(); -    img::save_buffer( -        &path, -        &screenshot.bytes, -        screenshot.size.width, -        screenshot.size.height, -        ColorType::Rgba8, -    ) -    .map(|_| path) -    .map_err(|err| PngError(format!("{:?}", err))) + +    tokio::task::spawn_blocking(move || { +        img::save_buffer( +            &path, +            &screenshot.bytes, +            screenshot.size.width, +            screenshot.size.height, +            ColorType::Rgba8, +        ) +        .map(|_| path) +        .map_err(|err| PngError(format!("{err:?}"))) +    }) +    .await +    .expect("Blocking task to finish")  }  #[derive(Clone, Debug)] @@ -297,10 +301,7 @@ fn numeric_input(  ) -> Element<'_, Option<u32>> {      text_input(          placeholder, -        &value -            .as_ref() -            .map(ToString::to_string) -            .unwrap_or_else(String::new), +        &value.as_ref().map(ToString::to_string).unwrap_or_default(),      )      .on_input(move |text| {          if text.is_empty() { | 
