diff --git a/src/lib.rs b/src/lib.rs index a13ee14e62e7c271609c4c77b066df407fe742e3..a3febca20c58b8fb0065d97936e47fab7ba099a0 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -21,7 +21,7 @@ use input::{input_kb, input_mouse, undo_redo, ClickTimer}; use input::{poll_wasm_paste, WasmPaste, WasmPasteAsyncChannel}; use render::{ blink_cursor, cosmic_edit_redraw_buffer, freeze_cursor_blink, hide_inactive_or_readonly_cursor, - on_scale_factor_change, CursorBlinkTimer, CursorVisibility, SwashCacheState, + on_scale_factor_change, set_initial_scale, CursorBlinkTimer, CursorVisibility, SwashCacheState, }; #[cfg(feature = "multicam")] @@ -73,6 +73,8 @@ pub enum CosmicTextPosition { pub struct CosmicTextChanged(pub (Entity, String)); // TODO docs +const DEFAULT_SCALE_PLACEHOLDER: f32 = 0.696969; + #[derive(Clone, Component)] pub struct CosmicMetrics { pub font_size: f32, @@ -85,7 +87,7 @@ impl Default for CosmicMetrics { Self { font_size: 12., line_height: 12., - scale_factor: 1., + scale_factor: DEFAULT_SCALE_PLACEHOLDER, } } } @@ -288,9 +290,13 @@ impl Plugin for CosmicEditPlugin { app.add_systems( First, ( - cosmic_editor_builder, - placeholder_builder, - on_scale_factor_change, + set_initial_scale, + ( + cosmic_editor_builder, + placeholder_builder, + on_scale_factor_change, + ) + .after(set_initial_scale), render::cosmic_ui_to_canvas, render::cosmic_sprite_to_canvas, ), diff --git a/src/render.rs b/src/render.rs index cb585f6028b8818963b41d77aca7c4469d8f6b6b..e76e6d87bee7971a0fa8e3780f1d9d59a7743cda 100644 --- a/src/render.rs +++ b/src/render.rs @@ -12,7 +12,7 @@ use image::{imageops::FilterType, GenericImageView}; use crate::{ get_text_size, get_x_offset_center, get_y_offset_center, CosmicAttrs, CosmicBackground, CosmicCanvas, CosmicEditor, CosmicFontSystem, CosmicMetrics, CosmicMode, CosmicTextPosition, - FillColor, Focus, Placeholder, ReadOnly, XOffset, + FillColor, Focus, Placeholder, ReadOnly, XOffset, DEFAULT_SCALE_PLACEHOLDER, }; #[derive(Resource)] @@ -430,6 +430,19 @@ pub(crate) fn hide_inactive_or_readonly_cursor( } } +pub(crate) fn set_initial_scale( + window_q: Query<&Window, With<PrimaryWindow>>, + mut metrics_q: Query<&mut CosmicMetrics, Added<CosmicMetrics>>, +) { + let scale = window_q.single().scale_factor() as f32; + + for mut metrics in metrics_q.iter_mut() { + if metrics.scale_factor == DEFAULT_SCALE_PLACEHOLDER { + metrics.scale_factor = scale; + } + } +} + pub(crate) fn on_scale_factor_change( mut scale_factor_changed: EventReader<WindowScaleFactorChanged>, mut cosmic_query: Query<(&mut CosmicEditor, &CosmicMetrics, &mut XOffset)>,