slint/sixtyfps_runtime/corelib/item_rendering.rs
Olivier Goffart adaadc30a9 Remove the "Rendering..." debug message.
This just polute the output while debugging other stuff
2020-06-04 12:49:33 +02:00

63 lines
2.2 KiB
Rust

use super::abi::datastructures::ItemRefMut;
use super::graphics::{
Frame, GraphicsBackend, HasRenderingPrimitive, RenderingCache, RenderingPrimitivesBuilder,
};
use super::EvaluationContext;
use cgmath::{Matrix4, SquareMatrix, Vector3};
pub(crate) fn update_item_rendering_data<Backend: GraphicsBackend>(
context: &EvaluationContext,
mut item: ItemRefMut<'_>,
rendering_cache: &mut RenderingCache<Backend>,
rendering_primitives_builder: &mut Backend::RenderingPrimitivesBuilder,
) {
let item_rendering_primitive = item.rendering_primitive(context);
let rendering_data = item.cached_rendering_data_offset_mut();
let last_rendering_primitive =
rendering_data.low_level_rendering_primitive(&rendering_cache).map(|ll| ll.primitive());
if let Some(last_rendering_primitive) = last_rendering_primitive {
if *last_rendering_primitive == item_rendering_primitive {
//println!("Keeping ... {:?}", item_rendering_info);
return;
}
}
println!(
"Updating rendering primitives for ... {:?} (old data: {:?})",
item_rendering_primitive, last_rendering_primitive
);
rendering_data.cache_index = rendering_cache
.allocate_entry(rendering_primitives_builder.create(item_rendering_primitive));
rendering_data.cache_ok = true;
}
pub(crate) fn render_component_items<Backend: GraphicsBackend>(
component: vtable::VRef<'_, crate::abi::datastructures::ComponentVTable>,
context: &EvaluationContext,
frame: &mut Backend::Frame,
rendering_cache: &RenderingCache<Backend>,
) {
let transform = Matrix4::identity();
crate::abi::datastructures::visit_items(
component,
|item, transform| {
let origin = item.geometry(context).origin;
let transform =
transform * Matrix4::from_translation(Vector3::new(origin.x, origin.y, 0.));
let cached_rendering_data = item.cached_rendering_data_offset();
if cached_rendering_data.cache_ok {
let primitive = rendering_cache.entry_at(cached_rendering_data.cache_index);
frame.render_primitive(&primitive, &transform);
}
transform
},
transform,
);
}