am f6c9c420: Merge "Correct stride for drawing to cached glyph bitmap"
* commit 'f6c9c4204c2f8f86277d081112c9dd863ddaa778': Correct stride for drawing to cached glyph bitmap
This commit is contained in:
@@ -213,18 +213,28 @@ void Font::drawCachedGlyphBitmap(CachedGlyphInfo* glyph, int x, int y, uint8_t*
|
||||
int dstY = y + glyph->mBitmapTop;
|
||||
|
||||
CacheTexture* cacheTexture = glyph->mCacheTexture;
|
||||
|
||||
uint32_t cacheWidth = cacheTexture->getWidth();
|
||||
uint32_t startY = glyph->mStartY * cacheWidth;
|
||||
uint32_t endY = startY + (glyph->mBitmapHeight * cacheWidth);
|
||||
|
||||
PixelBuffer* pixelBuffer = cacheTexture->getPixelBuffer();
|
||||
|
||||
uint32_t formatSize = PixelBuffer::formatSize(pixelBuffer->getFormat());
|
||||
uint32_t cacheWidth = cacheTexture->getWidth();
|
||||
uint32_t srcStride = formatSize * cacheWidth;
|
||||
uint32_t startY = glyph->mStartY * srcStride;
|
||||
uint32_t endY = startY + (glyph->mBitmapHeight * srcStride);
|
||||
|
||||
const uint8_t* cacheBuffer = pixelBuffer->map();
|
||||
|
||||
for (uint32_t cacheY = startY, bitmapY = dstY * bitmapWidth; cacheY < endY;
|
||||
cacheY += cacheWidth, bitmapY += bitmapWidth) {
|
||||
memcpy(&bitmap[bitmapY + dstX], &cacheBuffer[cacheY + glyph->mStartX], glyph->mBitmapWidth);
|
||||
cacheY += srcStride, bitmapY += bitmapWidth) {
|
||||
|
||||
if (formatSize == 1) {
|
||||
memcpy(&bitmap[bitmapY + dstX], &cacheBuffer[cacheY + glyph->mStartX], glyph->mBitmapWidth);
|
||||
} else {
|
||||
for (uint32_t i = 0; i < glyph->mBitmapWidth; ++i) {
|
||||
bitmap[bitmapY + dstX + i] = cacheBuffer[cacheY + (glyph->mStartX + i)*formatSize];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
void Font::drawCachedGlyph(CachedGlyphInfo* glyph, float x, float hOffset, float vOffset,
|
||||
|
||||
Reference in New Issue
Block a user