зеркало из https://github.com/mozilla/moz-skia.git
abort drawing if srcRect is outside of the bitmap bounds
git-svn-id: http://skia.googlecode.com/svn/trunk@951 2bbb7eff-a529-9590-31e7-b0007b416f81
This commit is contained in:
Родитель
6ecc33d794
Коммит
2ade0863c3
|
@ -1305,7 +1305,9 @@ void SkCanvas::drawBitmapRect(const SkBitmap& bitmap, const SkIRect* src,
|
|||
SkIRect tmpISrc;
|
||||
if (src) {
|
||||
tmpISrc.set(0, 0, bitmap.width(), bitmap.height());
|
||||
tmpISrc.intersect(*src);
|
||||
if (!tmpISrc.intersect(*src)) {
|
||||
return;
|
||||
}
|
||||
src = &tmpISrc;
|
||||
}
|
||||
this->internalDrawBitmap(*bitmapPtr, src, matrix, paint);
|
||||
|
|
|
@ -0,0 +1,47 @@
|
|||
#include "Test.h"
|
||||
#include "SkBitmap.h"
|
||||
#include "SkCanvas.h"
|
||||
|
||||
static bool check_for_all_zeros(const SkBitmap& bm) {
|
||||
SkAutoLockPixels alp(bm);
|
||||
|
||||
size_t count = bm.width() * bm.bytesPerPixel();
|
||||
for (int y = 0; y < bm.height(); y++) {
|
||||
const uint8_t* ptr = reinterpret_cast<const uint8_t*>(bm.getAddr(0, y));
|
||||
for (size_t i = 0; i < count; i++) {
|
||||
if (ptr[i]) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
static const int gWidth = 256;
|
||||
static const int gHeight = 256;
|
||||
|
||||
static void create(SkBitmap* bm, SkBitmap::Config config, SkColor color) {
|
||||
bm->setConfig(config, gWidth, gHeight);
|
||||
bm->allocPixels();
|
||||
bm->eraseColor(color);
|
||||
}
|
||||
|
||||
static void TestDrawBitmapRect(skiatest::Reporter* reporter) {
|
||||
SkBitmap src, dst;
|
||||
|
||||
create(&src, SkBitmap::kARGB_8888_Config, 0xFFFFFFFF);
|
||||
create(&dst, SkBitmap::kARGB_8888_Config, 0);
|
||||
|
||||
SkCanvas canvas(dst);
|
||||
|
||||
SkIRect srcR = { gWidth, 0, gWidth + 16, 16 };
|
||||
SkRect dstR = { 0, 0, SkIntToScalar(16), SkIntToScalar(16) };
|
||||
|
||||
canvas.drawBitmapRect(src, &srcR, dstR, NULL);
|
||||
|
||||
// ensure that we draw nothing if srcR does not intersect the bitmap
|
||||
REPORTER_ASSERT(reporter, check_for_all_zeros(dst));
|
||||
}
|
||||
|
||||
#include "TestClassDef.h"
|
||||
DEFINE_TESTCLASS("DrawBitmapRect", TestDrawBitmapRectClass, TestDrawBitmapRect)
|
|
@ -6,6 +6,7 @@ SOURCE := \
|
|||
ClipStackTest.cpp \
|
||||
ClipperTest.cpp \
|
||||
DequeTest.cpp \
|
||||
DrawBitmapRectTest.cpp \
|
||||
FillPathTest.cpp \
|
||||
FlateTest.cpp \
|
||||
GeometryTest.cpp \
|
||||
|
|
Загрузка…
Ссылка в новой задаче