diff options
author | Romain Guy <romainguy@google.com> | 2011-10-07 15:03:24 -0700 |
---|---|---|
committer | Romain Guy <romainguy@google.com> | 2011-10-07 15:03:24 -0700 |
commit | 5a6d3a4c0311318e6f1d4ee06aa47606e055a81b (patch) | |
tree | 58c483c6db1c6e1205ab3d44ee03dfe3c551c8f4 | |
parent | 2eaa0d73fab087b2309269f463f395705d236c78 (diff) | |
download | frameworks_base-5a6d3a4c0311318e6f1d4ee06aa47606e055a81b.zip frameworks_base-5a6d3a4c0311318e6f1d4ee06aa47606e055a81b.tar.gz frameworks_base-5a6d3a4c0311318e6f1d4ee06aa47606e055a81b.tar.bz2 |
Stupid fixed point math.
Bug #5423215
Change-Id: I39379e1f8fb4d59de4ede6e4fe7cf7a2c7cc625a
-rw-r--r-- | libs/hwui/FontRenderer.cpp | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/libs/hwui/FontRenderer.cpp b/libs/hwui/FontRenderer.cpp index dd05e61..a077cbc 100644 --- a/libs/hwui/FontRenderer.cpp +++ b/libs/hwui/FontRenderer.cpp @@ -185,7 +185,7 @@ void Font::render(SkPaint* paint, const char* text, uint32_t start, uint32_t len return; } - SkFixed penX = SkIntToFixed(x); + float penX = x; int penY = y; int glyphsLeft = 1; if (numGlyphs > 0) { @@ -193,7 +193,7 @@ void Font::render(SkPaint* paint, const char* text, uint32_t start, uint32_t len } SkFixed prevRsbDelta = 0; - penX += SK_Fixed1 / 2; + penX += 0.5f; text += start; @@ -206,25 +206,25 @@ void Font::render(SkPaint* paint, const char* text, uint32_t start, uint32_t len } CachedGlyphInfo* cachedGlyph = getCachedGlyph(paint, glyph); - penX += SkAutoKern_AdjustF(prevRsbDelta, cachedGlyph->mLsbDelta); + penX += SkFixedToFloat(SkAutoKern_AdjustF(prevRsbDelta, cachedGlyph->mLsbDelta)); prevRsbDelta = cachedGlyph->mRsbDelta; // If it's still not valid, we couldn't cache it, so we shouldn't draw garbage if (cachedGlyph->mIsValid) { switch(mode) { case FRAMEBUFFER: - drawCachedGlyph(cachedGlyph, SkFixedFloor(penX), penY); + drawCachedGlyph(cachedGlyph, (int) floorf(penX), penY); break; case BITMAP: - drawCachedGlyph(cachedGlyph, SkFixedFloor(penX), penY, bitmap, bitmapW, bitmapH); + drawCachedGlyph(cachedGlyph, (int) floorf(penX), penY, bitmap, bitmapW, bitmapH); break; case MEASURE: - measureCachedGlyph(cachedGlyph, SkFixedFloor(penX), penY, bounds); + measureCachedGlyph(cachedGlyph, (int) floorf(penX), penY, bounds); break; } } - penX += cachedGlyph->mAdvanceX; + penX += SkFixedToFloat(cachedGlyph->mAdvanceX); // If we were given a specific number of glyphs, decrement if (numGlyphs > 0) { |