Bitmaps: use original size for caching
Fixes https://gitlab.com/kicad/code/kicad/-/issues/13486
This commit is contained in:
parent
253122dc78
commit
05b578a9bb
|
@ -159,8 +159,10 @@ GLuint GL_BITMAP_CACHE::cacheBitmap( const BITMAP_BASE* aBitmap )
|
||||||
{
|
{
|
||||||
CACHED_BITMAP bmp;
|
CACHED_BITMAP bmp;
|
||||||
|
|
||||||
bmp.w = aBitmap->GetSizePixels().x;
|
const wxImage& imgData = *aBitmap->GetOriginalImageData();
|
||||||
bmp.h = aBitmap->GetSizePixels().y;
|
|
||||||
|
bmp.w = imgData.GetSize().x;
|
||||||
|
bmp.h = imgData.GetSize().y;
|
||||||
|
|
||||||
// The bitmap size needs to be a multiple of 4.
|
// The bitmap size needs to be a multiple of 4.
|
||||||
// This is easiest to achieve by ensuring that each row
|
// This is easiest to achieve by ensuring that each row
|
||||||
|
@ -186,8 +188,6 @@ GLuint GL_BITMAP_CACHE::cacheBitmap( const BITMAP_BASE* aBitmap )
|
||||||
bmp.size = ( bmp.w + extra_w ) * bmp.h * 4;
|
bmp.size = ( bmp.w + extra_w ) * bmp.h * 4;
|
||||||
auto buf = std::make_unique<uint8_t[]>( bmp.size );
|
auto buf = std::make_unique<uint8_t[]>( bmp.size );
|
||||||
|
|
||||||
const wxImage& imgData = *aBitmap->GetOriginalImageData();
|
|
||||||
|
|
||||||
for( int y = 0; y < bmp.h; y++ )
|
for( int y = 0; y < bmp.h; y++ )
|
||||||
{
|
{
|
||||||
for( int x = 0; x < bmp.w; x++ )
|
for( int x = 0; x < bmp.w; x++ )
|
||||||
|
|
Loading…
Reference in New Issue