From 23fbeaf978fbf7dfbae8aa989c2d9b37a3884ace Mon Sep 17 00:00:00 2001 From: Max Brunsfeld Date: Mon, 22 Nov 2021 16:37:01 -0800 Subject: [PATCH 1/2] Include scale factor in glyph cache keys --- crates/gpui/src/platform/mac/sprite_cache.rs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/crates/gpui/src/platform/mac/sprite_cache.rs b/crates/gpui/src/platform/mac/sprite_cache.rs index 7d11a3d276..8374a8f32c 100644 --- a/crates/gpui/src/platform/mac/sprite_cache.rs +++ b/crates/gpui/src/platform/mac/sprite_cache.rs @@ -12,6 +12,7 @@ use std::{borrow::Cow, collections::HashMap, sync::Arc}; struct GlyphDescriptor { font_id: FontId, font_size: OrderedFloat, + scale_factor: OrderedFloat, glyph_id: GlyphId, subpixel_variant: (u8, u8), } @@ -86,6 +87,7 @@ impl SpriteCache { .entry(GlyphDescriptor { font_id, font_size: OrderedFloat(font_size), + scale_factor: OrderedFloat(scale_factor), glyph_id, subpixel_variant, }) From 4002be882f4396298fbfe7f9476f4a8bf55b7d5a Mon Sep 17 00:00:00 2001 From: Max Brunsfeld Date: Mon, 22 Nov 2021 16:47:51 -0800 Subject: [PATCH 2/2] Clear sprite cache when scale factor changes --- crates/gpui/src/platform/mac/renderer.rs | 6 ++++-- crates/gpui/src/platform/mac/sprite_cache.rs | 16 +++++++++++++--- crates/gpui/src/platform/mac/window.rs | 19 ++++++++++++++----- 3 files changed, 31 insertions(+), 10 deletions(-) diff --git a/crates/gpui/src/platform/mac/renderer.rs b/crates/gpui/src/platform/mac/renderer.rs index 369696d478..d291c9219e 100644 --- a/crates/gpui/src/platform/mac/renderer.rs +++ b/crates/gpui/src/platform/mac/renderer.rs @@ -40,6 +40,7 @@ impl Renderer { pub fn new( device: metal::Device, pixel_format: metal::MTLPixelFormat, + scale_factor: f32, fonts: Arc, ) -> Self { let library = device @@ -64,7 +65,7 @@ impl Renderer { MTLResourceOptions::StorageModeManaged, ); - let sprite_cache = SpriteCache::new(device.clone(), vec2i(1024, 768), fonts); + let sprite_cache = SpriteCache::new(device.clone(), vec2i(1024, 768), scale_factor, fonts); let image_cache = ImageCache::new(device.clone(), vec2i(1024, 768)); let path_atlases = AtlasAllocator::new(device.clone(), build_path_atlas_texture_descriptor()); @@ -522,6 +523,8 @@ impl Renderer { return; } + self.sprite_cache.set_scale_factor(scale_factor); + let mut sprites_by_atlas = HashMap::new(); for glyph in glyphs { @@ -530,7 +533,6 @@ impl Renderer { glyph.font_size, glyph.id, glyph.origin, - scale_factor, ) { // Snap sprite to pixel grid. let origin = (glyph.origin * scale_factor).floor() + sprite.offset.to_f32(); diff --git a/crates/gpui/src/platform/mac/sprite_cache.rs b/crates/gpui/src/platform/mac/sprite_cache.rs index 8374a8f32c..17fec02066 100644 --- a/crates/gpui/src/platform/mac/sprite_cache.rs +++ b/crates/gpui/src/platform/mac/sprite_cache.rs @@ -12,7 +12,6 @@ use std::{borrow::Cow, collections::HashMap, sync::Arc}; struct GlyphDescriptor { font_id: FontId, font_size: OrderedFloat, - scale_factor: OrderedFloat, glyph_id: GlyphId, subpixel_variant: (u8, u8), } @@ -44,12 +43,14 @@ pub struct SpriteCache { atlases: AtlasAllocator, glyphs: HashMap>, icons: HashMap, + scale_factor: f32, } impl SpriteCache { pub fn new( device: metal::Device, size: Vector2I, + scale_factor: f32, fonts: Arc, ) -> Self { let descriptor = TextureDescriptor::new(); @@ -61,19 +62,29 @@ impl SpriteCache { atlases: AtlasAllocator::new(device, descriptor), glyphs: Default::default(), icons: Default::default(), + scale_factor, } } + pub fn set_scale_factor(&mut self, scale_factor: f32) { + if scale_factor != self.scale_factor { + self.icons.clear(); + self.glyphs.clear(); + self.atlases.clear(); + } + self.scale_factor = scale_factor; + } + pub fn render_glyph( &mut self, font_id: FontId, font_size: f32, glyph_id: GlyphId, target_position: Vector2F, - scale_factor: f32, ) -> Option { const SUBPIXEL_VARIANTS: u8 = 4; + let scale_factor = self.scale_factor; let target_position = target_position * scale_factor; let fonts = &self.fonts; let atlases = &mut self.atlases; @@ -87,7 +98,6 @@ impl SpriteCache { .entry(GlyphDescriptor { font_id, font_size: OrderedFloat(font_size), - scale_factor: OrderedFloat(scale_factor), glyph_id, subpixel_variant, }) diff --git a/crates/gpui/src/platform/mac/window.rs b/crates/gpui/src/platform/mac/window.rs index efceee0ba3..d2662c57dd 100644 --- a/crates/gpui/src/platform/mac/window.rs +++ b/crates/gpui/src/platform/mac/window.rs @@ -205,7 +205,12 @@ impl Window { synthetic_drag_counter: 0, executor, scene_to_render: Default::default(), - renderer: Renderer::new(device.clone(), PIXEL_FORMAT, fonts), + renderer: Renderer::new( + device.clone(), + PIXEL_FORMAT, + get_scale_factor(native_window), + fonts, + ), command_queue: device.new_command_queue(), last_fresh_keydown: None, layer, @@ -405,10 +410,7 @@ impl platform::WindowContext for WindowState { } fn scale_factor(&self) -> f32 { - unsafe { - let screen: id = msg_send![self.native_window, screen]; - NSScreen::backingScaleFactor(screen) as f32 - } + get_scale_factor(self.native_window) } fn titlebar_height(&self) -> f32 { @@ -427,6 +429,13 @@ impl platform::WindowContext for WindowState { } } +fn get_scale_factor(native_window: id) -> f32 { + unsafe { + let screen: id = msg_send![native_window, screen]; + NSScreen::backingScaleFactor(screen) as f32 + } +} + unsafe fn get_window_state(object: &Object) -> Rc> { let raw: *mut c_void = *object.get_ivar(WINDOW_STATE_IVAR); let rc1 = Rc::from_raw(raw as *mut RefCell);