add debugging test for building SkDescriptor
update some samples
git-svn-id: http://skia.googlecode.com/svn/trunk@1237 2bbb7eff-a529-9590-31e7-b0007b416f81
diff --git a/samplecode/SampleTestGL.cpp b/samplecode/SampleTestGL.cpp
deleted file mode 100644
index a0dfea3..0000000
--- a/samplecode/SampleTestGL.cpp
+++ /dev/null
@@ -1,242 +0,0 @@
-#include "SampleCode.h"
-#include "SkView.h"
-#include "SkCanvas.h"
-#include "SkCornerPathEffect.h"
-#include "SkCullPoints.h"
-#include "SkGradientShader.h"
-#include "SkPath.h"
-#include "SkRegion.h"
-#include "SkShader.h"
-#include "SkUtils.h"
-
-#include <AGL/agl.h>
-#include <OpenGL/gl.h>
-
-static void test_draw_gl(SkCanvas* canvas) {
- const float verts[] = {
- 10, 10, 250, 250, 490, 10
- };
- const float texs[] = {
- 0, 0, 0.5f, 0, 1, 1
- };
- const uint8_t colors[] = {
- 0, 0, 0, 1,
- 128, 0, 0, 1,
- 255, 255, 0, 1
- };
-
- glEnableClientState(GL_VERTEX_ARRAY);
- glVertexPointer(2, GL_FLOAT, 0, verts);
-
- glDisableClientState(GL_TEXTURE_COORD_ARRAY);
-// glTexCoordPointer(2, GL_FLOAT, 0, texs);
-
- glEnableClientState(GL_COLOR_ARRAY);
- glColorPointer(4, GL_UNSIGNED_BYTE, 0, colors);
-
- glDrawArrays(GL_TRIANGLES, 0, 3);
-}
-
-static const char* gVertShaderText =
- "varying vec2 uv;"
- "void main(void) {"
- " gl_Position = gl_ModelViewProjectionMatrix * gl_Vertex;"
- " uv = vec2(gl_Color);"
- "}";
-
-static const char* gFragShaderText =
- "varying vec2 uv;"
- "void main(void) {"
- " float u = uv.x;"
- " float v = uv.y;"
- " if (u*u > v) {"
-" gl_FragColor = vec4(0.0, 0, 0, 0.0);"
- " } else {"
- " gl_FragColor = vec4(0, 1.0, 0, 1.0);"
- "}"
- "}";
-
-static bool compile_shader(GLuint shader) {
- glCompileShader(shader);
-
- GLint success;
- glGetShaderiv(shader, GL_COMPILE_STATUS, &success);
- if (!success) {
- GLchar buffer[256];
- glGetShaderInfoLog(shader, sizeof(buffer), NULL, buffer);
- SkDebugf("---- glCompileShader failed: %s\n", buffer);
- return false;
- }
- return true;
-}
-
-static bool link_program(GLuint program) {
- glLinkProgram(program);
- GLint success;
- glGetProgramiv(program, GL_LINK_STATUS, &success);
- if (!success) {
- GLchar buffer[256];
- glGetProgramInfoLog(program, sizeof(buffer), NULL, buffer);
- SkDebugf("---- glLinkProgram failed: %s\n", buffer);
- return false;
- }
- return true;
-}
-
-static void test_glshader(SkCanvas* canvas) {
- GLuint vertShader = glCreateShader(GL_VERTEX_SHADER);
- GLuint fragShader = glCreateShader(GL_FRAGMENT_SHADER);
-
- glShaderSource(vertShader, 1, &gVertShaderText, NULL);
- glShaderSource(fragShader, 1, &gFragShaderText, NULL);
-
- if (!compile_shader(vertShader)) { return; }
- if (!compile_shader(fragShader)) { return; }
-
- GLuint program = glCreateProgram();
- glAttachShader(program, vertShader);
- glAttachShader(program, fragShader);
- if (link_program(program)) {
- glUseProgram(program);
- test_draw_gl(canvas);
- glUseProgram(0);
- }
- glDeleteProgram(program);
- glDeleteShader(vertShader);
- glDeleteShader(fragShader);
-}
-
-static void setmatrix6(SkMatrix* matrix, const float val[]) {
- matrix->reset();
- for (int i = 0; i < 6; i++) {
- matrix->set(i, val[i]);
- }
-}
-
-static void testinvert() {
- SkMatrix matrix;
-
- const float vals[] = { 0,9,.000001,10000,0,0 };
- setmatrix6(&matrix, vals);
-
- const float vals2[] = { 0,100,71,9,0,7 };
- SkMatrix tmp;
- setmatrix6(&tmp, vals2);
-
- matrix.preConcat(tmp);
- matrix.dump();
-
- SkMatrix inverse;
- matrix.invert(&inverse);
- inverse.dump();
-
- matrix.preConcat(inverse);
- matrix.dump();
-
-// o2dContext.setTransform(0,9,.000001,10000,0,0);
-// o2dContext.transform(0,100,71,9,0,7);
-// o2dContext.setTransform(0,6,95,4,1,0);
-}
-
-/*
- [0] 9.9999997e-005 float
- [1] 9.0000003e-006 float
- [2] 7.0000001e-006 float
- [3] 1000000.0 float
- [4] 90639.000 float
- [5] 70000.000 float
- [6] 0.00000000 float
- [7] 0.00000000 float
- [8] 1.0000000 float
- */
-static void testinvert2() {
- const float val[] = {
- 9.9999997e-005, 9.0000003e-006, 7.0000001e-006,
- 1000000.0, 90639.000, 70000.000
- };
- SkMatrix matrix;
- setmatrix6(&matrix, val);
- matrix.dump();
-
- SkMatrix inverse;
- matrix.invert(&inverse);
- inverse.dump();
-
- matrix.preConcat(inverse);
- matrix.dump();
- // result is that matrix[3] is 49550 instead of 0 :(
-}
-
-static void show_ramp(SkCanvas* canvas, const SkRect& r) {
- SkPoint pts[] = { r.fLeft, 0, r.fRight, 0 };
- SkColor colors[] = { SK_ColorRED, SK_ColorBLUE };
- SkShader* s = SkGradientShader::CreateLinear(pts, colors, NULL, 2,
- SkShader::kRepeat_TileMode);
- SkPaint p;
- p.setShader(s)->unref();
- canvas->drawRect(r, p);
- canvas->translate(r.width() + SkIntToScalar(8), 0);
- p.setDither(true);
- canvas->drawRect(r, p);
-}
-
-class TestGLView : public SkView {
-public:
- TestGLView() {
- testinvert2();
- }
-
-protected:
- // overrides from SkEventSink
- virtual bool onQuery(SkEvent* evt) {
- if (SampleCode::TitleQ(*evt)) {
- SampleCode::TitleR(evt, "TestGL");
- return true;
- }
- return this->INHERITED::onQuery(evt);
- }
-
- void drawBG(SkCanvas* canvas) {
- canvas->drawColor(0xFFDDDDDD);
- }
-
- virtual void onDraw(SkCanvas* canvas) {
- drawBG(canvas);
-
- if (canvas->getViewport(NULL)) {
- test_glshader(canvas);
- return;
- }
-
- SkRect r;
- r.set(0, 0, 100, 100);
-
- canvas->translate(SkIntToScalar(20), SkIntToScalar(20));
-
- SkPaint paint;
- paint.setAntiAlias(false);
- paint.setColor(SK_ColorRED);
-
- canvas->drawRect(r, paint);
-
- canvas->translate(r.width() + SkIntToScalar(20), 0);
- paint.setStyle(SkPaint::kStroke_Style);
- canvas->drawRect(r, paint);
-
- canvas->translate(r.width() + SkIntToScalar(20), 0);
- paint.setStrokeWidth(SkIntToScalar(5));
- canvas->drawRect(r, paint);
-
- canvas->translate(r.width() * 10/9, 0);
- show_ramp(canvas, r);
- }
-
-private:
- typedef SkView INHERITED;
-};
-
-//////////////////////////////////////////////////////////////////////////////
-
-static SkView* MyFactory() { return new TestGLView; }
-static SkViewRegister reg(MyFactory);
-
diff --git a/samplecode/SampleTextBox.cpp b/samplecode/SampleTextBox.cpp
index a2db011..37a6be0 100644
--- a/samplecode/SampleTextBox.cpp
+++ b/samplecode/SampleTextBox.cpp
@@ -32,7 +32,7 @@
"a decent respect to the opinions of mankind requires that they should "
"declare the causes which impel them to the separation.";
-class TextBoxView : public SkView {
+class TextBoxView : public SampleView {
public:
TextBoxView() {
#ifdef SK_BUILD_FOR_WIN
@@ -60,13 +60,7 @@
return this->INHERITED::onQuery(evt);
}
- void drawBG(SkCanvas* canvas) {
- canvas->drawColor(SK_ColorWHITE);
- }
-
- virtual void onDraw(SkCanvas* canvas) {
- this->drawBG(canvas);
-
+ virtual void onDrawContent(SkCanvas* canvas) {
SkScalar margin = 20;
SkTextBox tbox;
tbox.setMode(SkTextBox::kLineBreak_Mode);
diff --git a/samplecode/SampleTinyBitmap.cpp b/samplecode/SampleTinyBitmap.cpp
index ffbff25..0841474 100644
--- a/samplecode/SampleTinyBitmap.cpp
+++ b/samplecode/SampleTinyBitmap.cpp
@@ -30,11 +30,12 @@
return bm;
}
-class TinyBitmapView : public SkView {
+class TinyBitmapView : public SampleView {
SkBitmap fBM;
public:
TinyBitmapView() {
fBM = make_bitmap();
+ this->setBGColor(0xFFDDDDDD);
}
protected:
@@ -47,14 +48,6 @@
return this->INHERITED::onQuery(evt);
}
- void drawBG(SkCanvas* canvas) {
- SkIPoint size;
- if (canvas->getViewport(&size)) {
- SkDebugf("");
- }
- canvas->drawColor(0xFFDDDDDD);
- }
-
static void setBitmapOpaque(SkBitmap* bm, bool isOpaque) {
SkAutoLockPixels alp(*bm); // needed for ctable
bm->setIsOpaque(isOpaque);
@@ -64,9 +57,7 @@
}
}
- virtual void onDraw(SkCanvas* canvas) {
- drawBG(canvas);
-
+ virtual void onDrawContent(SkCanvas* canvas) {
SkShader* s = SkShader::CreateBitmapShader(fBM, SkShader::kRepeat_TileMode,
SkShader::kMirror_TileMode);
SkPaint paint;
diff --git a/src/core/SkPaint.cpp b/src/core/SkPaint.cpp
index 95b8ed3..14c0397 100644
--- a/src/core/SkPaint.cpp
+++ b/src/core/SkPaint.cpp
@@ -1315,6 +1315,10 @@
#define MIN_SIZE_FOR_EFFECT_BUFFER 1024
+#ifdef SK_DEBUG
+ #define TEST_DESC
+#endif
+
void SkPaint::descriptorProc(const SkMatrix* deviceMatrix,
void (*proc)(const SkDescriptor*, void*),
void* context, bool ignoreGamma) const {
@@ -1376,6 +1380,49 @@
SkASSERT(descSize == desc->getLength());
desc->computeChecksum();
+#ifdef TEST_DESC
+ {
+ // Check that we completely write the bytes in desc (our key), and that
+ // there are no uninitialized bytes. If there were, then we would get
+ // false-misses (or worse, false-hits) in our fontcache.
+ //
+ // We do this buy filling 2 others, one with 0s and the other with 1s
+ // and create those, and then check that all 3 are identical.
+ SkAutoDescriptor ad1(descSize);
+ SkAutoDescriptor ad2(descSize);
+ SkDescriptor* desc1 = ad1.getDesc();
+ SkDescriptor* desc2 = ad2.getDesc();
+
+ memset(desc1, 0x00, descSize);
+ memset(desc2, 0xFF, descSize);
+
+ desc1->init();
+ desc2->init();
+ desc1->addEntry(kRec_SkDescriptorTag, sizeof(rec), &rec);
+ desc2->addEntry(kRec_SkDescriptorTag, sizeof(rec), &rec);
+
+ if (pe) {
+ add_flattenable(desc1, kPathEffect_SkDescriptorTag, &peBuffer);
+ add_flattenable(desc2, kPathEffect_SkDescriptorTag, &peBuffer);
+ }
+ if (mf) {
+ add_flattenable(desc1, kMaskFilter_SkDescriptorTag, &mfBuffer);
+ add_flattenable(desc2, kMaskFilter_SkDescriptorTag, &mfBuffer);
+ }
+ if (ra) {
+ add_flattenable(desc1, kRasterizer_SkDescriptorTag, &raBuffer);
+ add_flattenable(desc2, kRasterizer_SkDescriptorTag, &raBuffer);
+ }
+
+ SkASSERT(descSize == desc1->getLength());
+ SkASSERT(descSize == desc2->getLength());
+ desc1->computeChecksum();
+ desc2->computeChecksum();
+ SkASSERT(!memcmp(desc, desc1, descSize));
+ SkASSERT(!memcmp(desc, desc2, descSize));
+ }
+#endif
+
proc(desc, context);
}