From d1dbc7fe93c8a5c62e275182baffcb82b6c9ca31 Mon Sep 17 00:00:00 2001 From: Juan Linietsky Date: Mon, 20 Jun 2016 19:43:06 -0300 Subject: [PATCH] fix bug decompressing bc texture, closes #4404 (cherry picked from commit 9d4cdc6d8a04cfbd543b5385f68e61dd1b33bd94) --- core/image.cpp | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/core/image.cpp b/core/image.cpp index cb667c9b9fe..bee1108de19 100644 --- a/core/image.cpp +++ b/core/image.cpp @@ -1697,8 +1697,17 @@ Error Image::_decompress_bc() { print_line("decompressing bc"); + int wd=width,ht=height; + if (wd%4!=0) { + wd+=4-(wd%4); + } + if (ht%4!=0) { + ht+=4-(ht%4); + } + + int mm; - int size = _get_dst_image_size(width,height,FORMAT_RGBA,mm,mipmaps); + int size = _get_dst_image_size(wd,ht,FORMAT_RGBA,mm,mipmaps); DVector newdata; newdata.resize(size); @@ -1708,7 +1717,8 @@ Error Image::_decompress_bc() { int rofs=0; int wofs=0; - int wd=width,ht=height; + + print_line("width: "+itos(wd)+" height: "+itos(ht)); for(int i=0;i<=mm;i++) { @@ -2013,6 +2023,11 @@ Error Image::_decompress_bc() { data=newdata; format=FORMAT_RGBA; + if (wd!=width || ht!=height) { + //todo, crop + width=wd; + height=ht; + } return OK; }