Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(570)

Unified Diff: tests/PathUtilsTest.cpp

Issue 16829003: Adding my Bitmap2Path sample for 1on1 meeting. (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: fixed more trybot errors. Created 7 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/utils/SkPathUtils.cpp ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/PathUtilsTest.cpp
diff --git a/tests/PathUtilsTest.cpp b/tests/PathUtilsTest.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..0d3e236fc1301f65553a9ddea078dc13b0f2e11e
--- /dev/null
+++ b/tests/PathUtilsTest.cpp
@@ -0,0 +1,137 @@
+
+/*
+ * 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 "Test.h"
+
+#include "SkBitmap.h"
+#include "SkCanvas.h"
+#include "SkPathUtils.h"
+#include "SkRandom.h"
+#include "SkTime.h"
+
+#define NUM_IT 100000
+#define ON 0xFF000000 // black pixel
+#define OFF 0x00000000 // transparent pixel
+
+class SkBitmap;
+
+//this function is redefined for sample, test, and bench. is there anywhere
+// I can put it to avoid code duplcation?
+static void fillRandomBits( int chars, char* bits ){
+ SkTime time;
+ SkMWCRandom rand = SkMWCRandom( time.GetMSecs() );
+
+ for (int i = 0; i < chars; ++i){
+ bits[i] = rand.nextU();
+ }
+}
+
+//also defined within PathUtils.cpp, but not in scope here. Anyway to call it
+// without re-defining it?
+static int getBit( const char* buffer, int x ) {
+ int byte = x >> 3;
+ int bit = x & 7;
+
+ return buffer[byte] & (1 << bit);
+}
+
+static void bin2SkBitmap(const char* bin_bmp, SkBitmap* sk_bmp,
+ int h, int w, int stride){
+ //init the SkBitmap
+ sk_bmp->setConfig(SkBitmap::kARGB_8888_Config, w, h);
+ sk_bmp->allocPixels();
+
+ for (int y = 0; y < h; ++y) { // for every row
+
+ const char* curLine = &bin_bmp[y * stride];
+ for (int x = 0; x < w; ++x) {// for every pixel
+ if (getBit(curLine, x)) {
+ *sk_bmp->getAddr32(x,y) = ON;
+ }
+ else {
+ *sk_bmp->getAddr32(x,y) = OFF;
+ }
+ }
+ }
+}
+
+static bool test_bmp(skiatest::Reporter* reporter,
+ const SkBitmap* bmp1, const SkBitmap* bmp2,
+ int h, int w) {
+ for (int y = 0; y < h; ++y) { // loop through all pixels
+ for (int x = 0; x < w; ++x) {
+ REPORTER_ASSERT( reporter, *bmp1->getAddr32(x,y) == *bmp1->getAddr32(x,y) );
+ }
+ }
+ return true;
+}
+
+static void test_path_eq(skiatest::Reporter* reporter, const SkPath* path,
+ const SkBitmap* truth, int h, int w){
+ // make paint
+ SkPaint bmpPaint;
+ bmpPaint.setAntiAlias(true); // Black paint for bitmap
+ bmpPaint.setStyle(SkPaint::kFill_Style);
+ bmpPaint.setColor(SK_ColorBLACK);
+
+ // make bmp
+ SkBitmap bmp;
+ bmp.setConfig(SkBitmap::kARGB_8888_Config, w, h);
+ bmp.allocPixels();
+ SkCanvas(bmp).drawPath(*path, bmpPaint);
+
+ // test bmp
+ test_bmp(reporter, &bmp, truth, h, w);
+}
+
+static void test_path(skiatest::Reporter* reporter, const SkBitmap* truth,
+ const char* bin_bmp, int h, int w, int stride){
+ // make path
+ SkPath path;
+ SkPathUtils::BitsToPath_Path(&path, bin_bmp, h, w, stride);
+
+ //test for correctness
+ test_path_eq(reporter, &path, truth, h, w);
+}
+
+static void test_region(skiatest::Reporter* reporter, const SkBitmap* truth,
+ const char* bin_bmp, int h, int w, int stride){
+ //generate bitmap
+ SkPath path;
+ SkPathUtils::BitsToPath_Region(&path, bin_bmp, h, w, stride);
+
+ //test for correctness
+ test_path_eq(reporter, &path, truth, h, w);
+}
+
+static void TestPathUtils(skiatest::Reporter* reporter) {
+ const int w[4] = {4, 8, 12, 16};
+ int h = 8, stride = 4;
+ char bits[ h * stride ];
+ static char* bin_bmp = &bits[0];
+
+ //loop to run randomized test lots of times
+ for (int it = 0; it < NUM_IT; ++it)
+ {
+ // generate a random binary bitmap
+ fillRandomBits( h * stride, bin_bmp); // generate random bitmap
+
+ // for each bitmap width, use subset of binary bitmap
+ for (int i = 0; i < 4; ++i) {
+ // generate truth bitmap
+ SkBitmap bmpTruth;
+ bin2SkBitmap(bin_bmp, &bmpTruth, h, w[i], stride);
+
+ test_path(reporter, &bmpTruth, bin_bmp, h, w[i], stride);
+ test_region(reporter, &bmpTruth, bin_bmp, h, w[i], stride);
+ }
+ }
+}
+
+#include "TestClassDef.h"
+DEFINE_TESTCLASS("PathUtils", PathUtils, TestPathUtils)
« no previous file with comments | « src/utils/SkPathUtils.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698