2019-03-15 18:22:51 +00:00
|
|
|
// Copyright 2019 Google LLC.
|
|
|
|
// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.
|
|
|
|
#include "fiddle/examples.h"
|
|
|
|
// HASH=bc9c7ea424d10bbcd1e5a88770d4794e
|
2019-03-18 20:06:34 +00:00
|
|
|
REG_FIDDLE(Alpha_Constants_a, 256, 128, false, 1) {
|
2019-03-15 18:22:51 +00:00
|
|
|
void draw(SkCanvas* canvas) {
|
|
|
|
std::vector<int32_t> srcPixels;
|
|
|
|
srcPixels.resize(source.height() * source.rowBytes());
|
|
|
|
SkPixmap pixmap(SkImageInfo::MakeN32Premul(source.width(), source.height()),
|
|
|
|
&srcPixels.front(), source.rowBytes());
|
|
|
|
source.readPixels(pixmap, 0, 0);
|
|
|
|
for (int y = 0; y < 16; ++y) {
|
|
|
|
for (int x = 0; x < 16; ++x) {
|
|
|
|
int32_t* blockStart = &srcPixels.front() + y * source.width() * 16 + x * 16;
|
|
|
|
size_t transparentCount = 0;
|
|
|
|
for (int fillY = 0; fillY < source.height() / 16; ++fillY) {
|
|
|
|
for (int fillX = 0; fillX < source.width() / 16; ++fillX) {
|
|
|
|
const SkColor color = SkUnPreMultiply::PMColorToColor(blockStart[fillX]);
|
|
|
|
transparentCount += SkColorGetA(color) == SK_AlphaTRANSPARENT;
|
|
|
|
}
|
|
|
|
blockStart += source.width();
|
|
|
|
}
|
|
|
|
if (transparentCount > 200) {
|
|
|
|
blockStart = &srcPixels.front() + y * source.width() * 16 + x * 16;
|
|
|
|
for (int fillY = 0; fillY < source.height() / 16; ++fillY) {
|
|
|
|
for (int fillX = 0; fillX < source.width() / 16; ++fillX) {
|
|
|
|
blockStart[fillX] = SK_ColorRED;
|
|
|
|
}
|
|
|
|
blockStart += source.width();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
SkBitmap bitmap;
|
|
|
|
bitmap.installPixels(pixmap);
|
|
|
|
canvas->drawBitmap(bitmap, 0, 0);
|
|
|
|
}
|
|
|
|
} // END FIDDLE
|