Commit 87bc6aac authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

dwrite: Correct return glyph origins for RTL runs.

parent 7315afbc
...@@ -1551,76 +1551,48 @@ static HRESULT WINAPI dwritefactory4_TranslateColorGlyphRun(IDWriteFactory7 *ifa ...@@ -1551,76 +1551,48 @@ static HRESULT WINAPI dwritefactory4_TranslateColorGlyphRun(IDWriteFactory7 *ifa
} }
static HRESULT compute_glyph_origins(DWRITE_GLYPH_RUN const *run, DWRITE_MEASURING_MODE measuring_mode, static HRESULT compute_glyph_origins(DWRITE_GLYPH_RUN const *run, DWRITE_MEASURING_MODE measuring_mode,
D2D1_POINT_2F baseline_origin, DWRITE_MATRIX const *transform, D2D1_POINT_2F *origins) D2D1_POINT_2F baseline_origin, DWRITE_MATRIX const *transform, D2D1_POINT_2F *origins)
{ {
IDWriteFontFace1 *fontface1 = NULL; struct dwrite_fontface *font_obj;
DWRITE_FONT_METRICS metrics; unsigned int i;
FLOAT rtl_factor; float advance;
HRESULT hr;
UINT32 i;
rtl_factor = run->bidiLevel & 1 ? -1.0f : 1.0f; font_obj = unsafe_impl_from_IDWriteFontFace(run->fontFace);
if (run->fontFace) { for (i = 0; i < run->glyphCount; ++i)
IDWriteFontFace_GetMetrics(run->fontFace, &metrics); {
if (FAILED(hr = IDWriteFontFace_QueryInterface(run->fontFace, &IID_IDWriteFontFace1, (void **)&fontface1))) origins[i] = baseline_origin;
WARN("Failed to get IDWriteFontFace1, %#x.\n", hr);
}
for (i = 0; i < run->glyphCount; i++) { if (run->bidiLevel & 1)
FLOAT advance; {
advance = fontface_get_scaled_design_advance(font_obj, measuring_mode, run->fontEmSize,
1.0f, transform, run->glyphIndices[i], run->isSideways);
/* Use nominal advances if not provided by caller. */ origins[i].x -= advance;
if (run->glyphAdvances)
advance = rtl_factor * run->glyphAdvances[i];
else {
INT32 a;
advance = 0.0f; if (run->glyphOffsets)
switch (measuring_mode)
{ {
case DWRITE_MEASURING_MODE_NATURAL: origins[i].x -= run->glyphOffsets[i].advanceOffset;
if (SUCCEEDED(IDWriteFontFace1_GetDesignGlyphAdvances(fontface1, 1, run->glyphIndices + i, &a, origins[i].y -= run->glyphOffsets[i].ascenderOffset;
run->isSideways)))
advance = rtl_factor * get_scaled_advance_width(a, run->fontEmSize, &metrics);
break;
case DWRITE_MEASURING_MODE_GDI_CLASSIC:
case DWRITE_MEASURING_MODE_GDI_NATURAL:
if (SUCCEEDED(IDWriteFontFace1_GetGdiCompatibleGlyphAdvances(fontface1, run->fontEmSize,
1.0f, transform, measuring_mode == DWRITE_MEASURING_MODE_GDI_NATURAL,
run->isSideways, 1, run->glyphIndices + i, &a)))
advance = rtl_factor * floorf(a * run->fontEmSize / metrics.designUnitsPerEm + 0.5f);
break;
default:
;
} }
}
origins[i] = baseline_origin; baseline_origin.x -= run->glyphAdvances ? run->glyphAdvances[i] : advance;
}
else
{
if (run->glyphOffsets)
{
origins[i].x += run->glyphOffsets[i].advanceOffset;
origins[i].y -= run->glyphOffsets[i].ascenderOffset;
}
/* Apply offsets. */ baseline_origin.x += run->glyphAdvances ? run->glyphAdvances[i] :
if (run->glyphOffsets) { fontface_get_scaled_design_advance(font_obj, measuring_mode, run->fontEmSize, 1.0f, transform,
FLOAT advanceoffset = rtl_factor * run->glyphOffsets[i].advanceOffset; run->glyphIndices[i], run->isSideways);
FLOAT ascenderoffset = -run->glyphOffsets[i].ascenderOffset;
if (run->isSideways) {
origins[i].x += ascenderoffset;
origins[i].y += advanceoffset;
}
else {
origins[i].x += advanceoffset;
origins[i].y += ascenderoffset;
}
} }
if (run->isSideways)
baseline_origin.y += advance;
else
baseline_origin.x += advance;
} }
if (fontface1)
IDWriteFontFace1_Release(fontface1);
return S_OK; return S_OK;
} }
......
...@@ -8468,7 +8468,6 @@ static void test_ComputeGlyphOrigins(void) ...@@ -8468,7 +8468,6 @@ static void test_ComputeGlyphOrigins(void)
ok(hr == S_OK, "%u: failed to compute glyph origins, hr %#x.\n", i, hr); ok(hr == S_OK, "%u: failed to compute glyph origins, hr %#x.\n", i, hr);
for (j = 0; j < run.glyphCount; ++j) for (j = 0; j < run.glyphCount; ++j)
{ {
todo_wine_if(run.bidiLevel & 1)
ok(!memcmp(&origins[j], &expected_origins[j], sizeof(origins[j])), ok(!memcmp(&origins[j], &expected_origins[j], sizeof(origins[j])),
"%u: unexpected origin[%u] (%f, %f) - (%f, %f).\n", i, j, origins[j].x, origins[j].y, "%u: unexpected origin[%u] (%f, %f) - (%f, %f).\n", i, j, origins[j].x, origins[j].y,
expected_origins[j].x, expected_origins[j].y); expected_origins[j].x, expected_origins[j].y);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment