/* * Copyright 2013 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #include "bench/Benchmark.h" #include "include/core/SkBitmap.h" #include "include/core/SkCanvas.h" #include "include/core/SkShader.h" #include "include/core/SkString.h" static void create_gradient(SkBitmap* bm) { SkASSERT(1 == bm->width()); const int height = bm->height(); float deltaB = 255.0f / height; float blue = 255.0f; for (int y = 0; y < height; y++) { *bm->getAddr32(0, y) = SkColorSetRGB(0, 0, (U8CPU) blue); blue -= deltaB; } } // Test out the special case of a tiled 1xN texture. Test out opacity, // filtering and the different tiling modes class ConstXTileBench : public Benchmark { SkPaint fPaint; SkString fName; bool fDoFilter; bool fDoTrans; bool fDoScale; static const int kWidth = 1; static const int kHeight = 300; public: ConstXTileBench(SkTileMode xTile, SkTileMode yTile, bool doFilter, bool doTrans, bool doScale) : fDoFilter(doFilter) , fDoTrans(doTrans) , fDoScale(doScale) { SkBitmap bm; bm.allocN32Pixels(kWidth, kHeight, true); bm.eraseColor(SK_ColorWHITE); create_gradient(&bm); fPaint.setShader(bm.makeShader(xTile, yTile)); fName.printf("constXTile_"); static const char* gTileModeStr[kSkTileModeCount] = { "C", "R", "M", "D" }; fName.append(gTileModeStr[(unsigned)xTile]); fName.append(gTileModeStr[(unsigned)yTile]); if (doFilter) { fName.append("_filter"); } if (doTrans) { fName.append("_trans"); } if (doScale) { fName.append("_scale"); } } protected: const char* onGetName() override { return fName.c_str(); } void onDraw(int loops, SkCanvas* canvas) override { SkPaint paint(fPaint); this->setupPaint(&paint); paint.setFilterQuality(fDoFilter ? kLow_SkFilterQuality : kNone_SkFilterQuality); if (fDoTrans) { paint.setColor(SkColorSetARGB(0x80, 0xFF, 0xFF, 0xFF)); } SkRect r; if (fDoScale) { r = SkRect::MakeWH(SkIntToScalar(2 * 640), SkIntToScalar(2 * 480)); canvas->scale(SK_ScalarHalf, SK_ScalarHalf); } else { r = SkRect::MakeWH(SkIntToScalar(640), SkIntToScalar(480)); } SkPaint bgPaint; bgPaint.setColor(SK_ColorWHITE); for (int i = 0; i < loops; i++) { if (fDoTrans) { canvas->drawRect(r, bgPaint); } canvas->drawRect(r, paint); } } private: using INHERITED = Benchmark; }; // Scaled benches are trending towards free. Seems like caching. // TODO(mtklein, reed): fix and reenable //DEF_BENCH(return new ConstXTileBench(SkTileMode::kRepeat, SkTileMode::kRepeat, false, false, true)) DEF_BENCH(return new ConstXTileBench(SkTileMode::kClamp, SkTileMode::kClamp, false, false, false)) //DEF_BENCH(return new ConstXTileBench(SkTileMode::kMirror, SkTileMode::kMirror, false, false, true)) DEF_BENCH(return new ConstXTileBench(SkTileMode::kRepeat, SkTileMode::kRepeat, true, false, false)) //DEF_BENCH(return new ConstXTileBench(SkTileMode::kClamp, SkTileMode::kClamp, true, false, true)) DEF_BENCH(return new ConstXTileBench(SkTileMode::kMirror, SkTileMode::kMirror, true, false, false)) //DEF_BENCH(return new ConstXTileBench(SkTileMode::kRepeat, SkTileMode::kRepeat, false, true, true)) DEF_BENCH(return new ConstXTileBench(SkTileMode::kClamp, SkTileMode::kClamp, false, true, false)) //DEF_BENCH(return new ConstXTileBench(SkTileMode::kMirror, SkTileMode::kMirror, false, true, true)) DEF_BENCH(return new ConstXTileBench(SkTileMode::kRepeat, SkTileMode::kRepeat, true, true, false)) //DEF_BENCH(return new ConstXTileBench(SkTileMode::kClamp, SkTileMode::kClamp, true, true, true)) DEF_BENCH(return new ConstXTileBench(SkTileMode::kMirror, SkTileMode::kMirror, true, true, false))