Index: bench/LineBench.cpp |
diff --git a/bench/LineBench.cpp b/bench/LineBench.cpp |
index 67dc5648be9db4f83443c9011c195d1e2cbb4472..3127d4efeca5e8078a63c6bf24a27c0f52110713 100644 |
--- a/bench/LineBench.cpp |
+++ b/bench/LineBench.cpp |
@@ -21,19 +21,33 @@ class LineBench : public Benchmark { |
bool fDoAA; |
SkString fName; |
enum { |
- PTS = 500, |
+ LINES = 500, |
}; |
- SkPoint fPts[PTS]; |
+ SkPoint fStartPts[LINES]; |
+ SkPoint fEndPts[LINES]; |
public: |
- LineBench(SkScalar width, bool doAA) { |
+ enum LineType { |
+ SH, // Straight + horizontally |
+ SV, // Straight + vertically |
+ RAND, |
+ }; |
+ LineBench(SkScalar width, bool doAA, LineType type) { |
fStrokeWidth = width; |
fDoAA = doAA; |
- fName.printf("lines_%g_%s", width, doAA ? "AA" : "BW"); |
+ fName.printf("lines_%g_%s_%s", width, doAA ? "AA" : "BW", |
+ type == SH ? "SH" : (type == SV ? "SV" : "RAND")); |
SkRandom rand; |
- for (int i = 0; i < PTS; ++i) { |
- fPts[i].set(rand.nextUScalar1() * 640, rand.nextUScalar1() * 480); |
+ for (int i = 0; i < LINES; ++i) { |
+ fStartPts[i].set(rand.nextUScalar1() * 640, rand.nextUScalar1() * 480); |
+ if (type == SH) { |
+ fEndPts[i].set(rand.nextUScalar1() * 640, fStartPts[i].y()); |
+ } else if (type == SV) { |
+ fEndPts[i].set(fStartPts[i].x(), rand.nextUScalar1() * 480); |
+ } else { |
+ fEndPts[i].set(rand.nextUScalar1() * 640, rand.nextUScalar1() * 480); |
+ } |
} |
} |
@@ -51,7 +65,7 @@ protected: |
paint.setStrokeWidth(fStrokeWidth); |
for (int i = 0; i < loops; i++) { |
- canvas->drawPoints(SkCanvas::kLines_PointMode, PTS, fPts, paint); |
+ canvas->drawLine(fStartPts[i].x(), fStartPts[i].y(), fEndPts[i].x(), fEndPts[i].y(), paint); |
} |
} |
@@ -59,8 +73,21 @@ private: |
typedef Benchmark INHERITED; |
}; |
-DEF_BENCH(return new LineBench(0, false);) |
-DEF_BENCH(return new LineBench(SK_Scalar1, false);) |
-DEF_BENCH(return new LineBench(0, true);) |
-DEF_BENCH(return new LineBench(SK_Scalar1/2, true);) |
-DEF_BENCH(return new LineBench(SK_Scalar1, true);) |
+DEF_BENCH(return new LineBench(0, false, LineBench::SH);) |
+DEF_BENCH(return new LineBench(SK_Scalar1, false, LineBench::SH);) |
+DEF_BENCH(return new LineBench(0, true, LineBench::SH);) |
+DEF_BENCH(return new LineBench(SK_Scalar1/2, true, LineBench::SH);) |
+DEF_BENCH(return new LineBench(SK_Scalar1, true, LineBench::SH);) |
+DEF_BENCH(return new LineBench(SK_Scalar1*10,true, LineBench::SH);) |
+DEF_BENCH(return new LineBench(0, false, LineBench::SV);) |
+DEF_BENCH(return new LineBench(SK_Scalar1, false, LineBench::SV);) |
+DEF_BENCH(return new LineBench(0, true, LineBench::SV);) |
+DEF_BENCH(return new LineBench(SK_Scalar1/2, true, LineBench::SV);) |
+DEF_BENCH(return new LineBench(SK_Scalar1, true, LineBench::SV);) |
+DEF_BENCH(return new LineBench(SK_Scalar1*10,true, LineBench::SV);) |
+DEF_BENCH(return new LineBench(0, false, LineBench::RAND);) |
+DEF_BENCH(return new LineBench(SK_Scalar1, false, LineBench::RAND);) |
+DEF_BENCH(return new LineBench(0, true, LineBench::RAND);) |
+DEF_BENCH(return new LineBench(SK_Scalar1/2, true, LineBench::RAND);) |
+DEF_BENCH(return new LineBench(SK_Scalar1, true, LineBench::RAND);) |
+DEF_BENCH(return new LineBench(SK_Scalar1*10,true, LineBench::RAND);) |