use bevy_a11y::{ accesskit::{NodeBuilder, Rect, Role}, AccessibilityNode, }; use bevy_app::{App, Plugin}; use bevy_ecs::{ prelude::Entity, query::{Changed, Or, Without}, system::{Commands, Query}, }; use bevy_hierarchy::Children; use bevy_render::prelude::Camera; use bevy_text::Text; use bevy_transform::prelude::GlobalTransform; use crate::{ prelude::{Button, Label}, Node, UiImage, }; fn calc_name(texts: &Query<&Text>, children: &Children) -> Option> { let mut name = None; for child in children.iter() { if let Ok(text) = texts.get(*child) { let values = text .sections .iter() .map(|v| v.value.to_string()) .collect::>(); name = Some(values.join(" ")); } } name.map(|v| v.into_boxed_str()) } fn calc_bounds( camera: Query<(&Camera, &GlobalTransform)>, mut nodes: Query< (&mut AccessibilityNode, &Node, &GlobalTransform), Or<(Changed, Changed)>, >, ) { if let Ok((camera, camera_transform)) = camera.get_single() { for (mut accessible, node, transform) in &mut nodes { if let Some(translation) = camera.world_to_viewport(camera_transform, transform.translation()) { let bounds = Rect::new( translation.x.into(), translation.y.into(), (translation.x + node.calculated_size.x).into(), (translation.y + node.calculated_size.y).into(), ); accessible.set_bounds(bounds); } } } } fn button_changed( mut commands: Commands, mut query: Query<(Entity, &Children, Option<&mut AccessibilityNode>), Changed