windows: Revert "windows: Fix ascent/descent calculations (#40103)" (#40175)
Cole Miller
created 2 months ago
This reverts commit f1db1f3a3c933d8b4d35d83f6bbc49fd46749519.
This seems to have affected the vertical positioning of text that
doesn't contain emojis in a way that was unintended.
Release Notes:
- N/A
Change summary
crates/gpui/src/platform/windows/direct_write.rs | 22 ++++++++---------
1 file changed, 10 insertions(+), 12 deletions(-)
Detailed changes
@@ -606,21 +606,19 @@ impl DirectWriteState {
};
let mut first_run = true;
- let mut max_ascent = 0.0_f32;
- let mut max_descent = 0.0_f32;
+ let mut ascent = Pixels::default();
+ let mut descent = Pixels::default();
for run in font_runs {
- let font_info = &self.fonts[run.font_id.0];
- let mut metrics = std::mem::zeroed();
- font_info.font_face.GetMetrics(&mut metrics);
- let font_scale = font_size.0 / metrics.Base.designUnitsPerEm as f32;
- max_ascent = max_ascent.max(metrics.Base.ascent as f32 * font_scale);
- max_descent = max_descent.max(-(metrics.Base.descent as f32 * font_scale));
-
if first_run {
first_run = false;
+ let mut metrics = vec![DWRITE_LINE_METRICS::default(); 4];
+ let mut line_count = 0u32;
+ text_layout.GetLineMetrics(Some(&mut metrics), &mut line_count as _)?;
+ ascent = px(metrics[0].baseline);
+ descent = px(metrics[0].height - metrics[0].baseline);
continue;
}
-
+ let font_info = &self.fonts[run.font_id.0];
let current_text = &text[utf8_offset..(utf8_offset + run.len)];
utf8_offset += run.len;
let current_text_utf16_length = current_text.encode_utf16().count() as u32;
@@ -662,8 +660,8 @@ impl DirectWriteState {
Ok(LineLayout {
font_size,
width,
- ascent: max_ascent.into(),
- descent: max_descent.into(),
+ ascent,
+ descent,
runs,
len: text.len(),
})