Index: bench/PremulAndUnpremulAlphaOpsBench.cpp |
diff --git a/bench/PremulAndUnpremulAlphaOpsBench.cpp b/bench/PremulAndUnpremulAlphaOpsBench.cpp |
new file mode 100644 |
index 0000000000000000000000000000000000000000..a29bf7b4b6134b5317b168d3bda2325c3448599b |
--- /dev/null |
+++ b/bench/PremulAndUnpremulAlphaOpsBench.cpp |
@@ -0,0 +1,74 @@ |
+ |
+/* |
+ * 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 "SkBenchmark.h" |
+#include "SkCanvas.h" |
+#include "SkConfig8888.h" |
+ |
+class PremulAndUnpremulAlphaOpsBench : public SkBenchmark { |
+public: |
+ PremulAndUnpremulAlphaOpsBench(void* param, SkCanvas::Config8888 config, |
+ const char* name) |
+ : INHERITED(param) { |
+ unPremulConfig = config; |
+ benchName = name; |
+ } |
+ |
+protected: |
+ virtual const char* onGetName() SK_OVERRIDE { |
+ return benchName; |
+ } |
+ |
+ virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE { |
+ canvas->clear(SK_ColorBLACK); |
+ SkISize size = canvas->getDeviceSize(); |
+ |
+ SkBitmap bmp1; |
+ bmp1.setConfig(SkBitmap::kARGB_8888_Config, size.width(), |
+ size.height()); |
+ bmp1.allocPixels(); |
+ SkAutoLockPixels alp(bmp1); |
+ uint32_t* pixels = reinterpret_cast<uint32_t*>(bmp1.getPixels()); |
+ for (int h = 0; h < size.height(); ++h) { |
+ for (int w = 0; w < size.width(); ++w) |
+ pixels[h * size.width() + w] = SkPackConfig8888(unPremulConfig, |
+ h & 0xFF, w & 0xFF, w & 0xFF, w & 0xFF); |
+ } |
+ |
+ SkBitmap bmp2; |
+ bmp2.setConfig(SkBitmap::kARGB_8888_Config, size.width(), |
+ size.height()); |
+ |
+ static const int kLoopCount = SkBENCHLOOP(10); |
+ for (int loop = 0; loop < kLoopCount; ++loop) { |
+ // Unpremul -> Premul |
+ canvas->writePixels(bmp1, 0, 0, unPremulConfig); |
+ // Premul -> Unpremul |
+ canvas->readPixels(&bmp2, 0, 0, unPremulConfig); |
+ } |
+ } |
+ |
+private: |
+ SkCanvas::Config8888 unPremulConfig; |
+ const char* benchName; |
tomhudson
2013/06/12 09:23:34
I wasn't reading carefully enough earlier - anothe
Jun Jiang
2013/06/12 16:59:26
Done.
|
+ typedef SkBenchmark INHERITED; |
+}; |
+ |
+static SkBenchmark* fact0(void* p) { |
+ return new PremulAndUnpremulAlphaOpsBench(p, |
+ SkCanvas::kRGBA_Unpremul_Config8888, |
+ "premul_and_unpremul_alpha_RGBA8888"); |
+} |
+static SkBenchmark* fact1(void* p) { |
+ return new PremulAndUnpremulAlphaOpsBench(p, |
+ SkCanvas::kNative_Unpremul_Config8888, |
+ "premul_and_unpremul_alpha_Native8888"); |
+} |
+ |
+static BenchRegistry gReg0(fact0); |
+static BenchRegistry gReg1(fact1); |