diff options
| author | 2024-05-03 13:51:57 +0200 | |
|---|---|---|
| committer | 2024-05-03 13:51:57 +0200 | |
| commit | a94984d681875146d7af9f568bf8713503c1ca96 (patch) | |
| tree | c0a4eef3b5ab5fc3450b21b37df99542c178f6e0 /wgpu/src/image | |
| parent | 38cf87cb45484c7e52ddf775fb3abd7edbecc652 (diff) | |
| parent | afb4cb99b92a196bf4dd15a09a8f9bd191293fdd (diff) | |
| download | iced-a94984d681875146d7af9f568bf8713503c1ca96.tar.gz iced-a94984d681875146d7af9f568bf8713503c1ca96.tar.bz2 iced-a94984d681875146d7af9f568bf8713503c1ca96.zip | |
Merge pull request #2424 from iced-rs/feature/image-opacity
Introduce dynamic `opacity` support for `Image` and `Svg`
Diffstat (limited to '')
| -rw-r--r-- | wgpu/src/image/mod.rs | 22 | 
1 files changed, 17 insertions, 5 deletions
| diff --git a/wgpu/src/image/mod.rs b/wgpu/src/image/mod.rs index 285eb2f6..063822aa 100644 --- a/wgpu/src/image/mod.rs +++ b/wgpu/src/image/mod.rs @@ -137,16 +137,18 @@ impl Pipeline {                              0 => Float32x2,                              // Center                              1 => Float32x2, -                            // Image size +                            // Scale                              2 => Float32x2,                              // Rotation                              3 => Float32, +                            // Opacity +                            4 => Float32,                              // Atlas position -                            4 => Float32x2, -                            // Atlas scale                              5 => Float32x2, +                            // Atlas scale +                            6 => Float32x2,                              // Layer -                            6 => Sint32, +                            7 => Sint32,                          ),                      }],                  }, @@ -229,6 +231,7 @@ impl Pipeline {                      filter_method,                      bounds,                      rotation, +                    opacity,                  } => {                      if let Some(atlas_entry) =                          cache.upload_raster(device, encoder, handle) @@ -237,6 +240,7 @@ impl Pipeline {                              [bounds.x, bounds.y],                              [bounds.width, bounds.height],                              f32::from(*rotation), +                            *opacity,                              atlas_entry,                              match filter_method {                                  crate::core::image::FilterMethod::Nearest => { @@ -258,6 +262,7 @@ impl Pipeline {                      color,                      bounds,                      rotation, +                    opacity,                  } => {                      let size = [bounds.width, bounds.height]; @@ -268,6 +273,7 @@ impl Pipeline {                              [bounds.x, bounds.y],                              size,                              f32::from(*rotation), +                            *opacity,                              atlas_entry,                              nearest_instances,                          ); @@ -498,6 +504,7 @@ struct Instance {      _center: [f32; 2],      _size: [f32; 2],      _rotation: f32, +    _opacity: f32,      _position_in_atlas: [f32; 2],      _size_in_atlas: [f32; 2],      _layer: u32, @@ -517,6 +524,7 @@ fn add_instances(      image_position: [f32; 2],      image_size: [f32; 2],      rotation: f32, +    opacity: f32,      entry: &atlas::Entry,      instances: &mut Vec<Instance>,  ) { @@ -532,6 +540,7 @@ fn add_instances(                  center,                  image_size,                  rotation, +                opacity,                  allocation,                  instances,              ); @@ -561,7 +570,8 @@ fn add_instances(                  ];                  add_instance( -                    position, center, size, rotation, allocation, instances, +                    position, center, size, rotation, opacity, allocation, +                    instances,                  );              }          } @@ -574,6 +584,7 @@ fn add_instance(      center: [f32; 2],      size: [f32; 2],      rotation: f32, +    opacity: f32,      allocation: &atlas::Allocation,      instances: &mut Vec<Instance>,  ) { @@ -586,6 +597,7 @@ fn add_instance(          _center: center,          _size: size,          _rotation: rotation, +        _opacity: opacity,          _position_in_atlas: [              (x as f32 + 0.5) / atlas::SIZE as f32,              (y as f32 + 0.5) / atlas::SIZE as f32, | 
