use crate::Size; use crate::{CalculatedSize, UiImage}; use bevy_asset::Assets; use bevy_ecs::{ component::Component, query::With, reflect::ReflectComponent, system::{Query, Res}, }; use bevy_reflect::{Reflect, ReflectDeserialize}; use bevy_render::texture::Image; use serde::{Deserialize, Serialize}; /// Describes how to resize the Image node #[derive(Component, Debug, Clone, Reflect, Serialize, Deserialize)] #[reflect_value(Component, Serialize, Deserialize)] pub enum ImageMode { /// Keep the aspect ratio of the image KeepAspect, } impl Default for ImageMode { fn default() -> Self { ImageMode::KeepAspect } } /// Updates calculated size of the node based on the image provided pub fn image_node_system( textures: Res>, mut query: Query<(&mut CalculatedSize, &UiImage), With>, ) { for (mut calculated_size, image) in query.iter_mut() { if let Some(texture) = textures.get(image.0.clone_weak()) { let size = Size { width: texture.texture_descriptor.size.width as f32, height: texture.texture_descriptor.size.height as f32, }; // Update only if size has changed to avoid needless layout calculations if size != calculated_size.size { calculated_size.size = size; } } } }