aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorGravatar reed@google.com <reed@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-07-20 11:20:32 +0000
committerGravatar reed@google.com <reed@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2012-07-20 11:20:32 +0000
commitca0062ee5e74eddff886ada2a200d25946ea52cf (patch)
tree130654f093ac9557522eccbb1ffdedfad2f10fe7
parent4df7a16f0a423c9cb8609d75fbda3809f2ef0119 (diff)
add SkPaint::getPosTextPath(), with gm to test it
Review URL: https://codereview.appspot.com/6427055 git-svn-id: http://skia.googlecode.com/svn/trunk@4684 2bbb7eff-a529-9590-31e7-b0007b416f81
-rw-r--r--gm/getpostextpath.cpp59
-rw-r--r--gyp/gmslides.gypi1
-rw-r--r--include/core/SkPaint.h3
-rw-r--r--src/core/SkPaint.cpp27
4 files changed, 90 insertions, 0 deletions
diff --git a/gm/getpostextpath.cpp b/gm/getpostextpath.cpp
new file mode 100644
index 0000000000..6ef37caf70
--- /dev/null
+++ b/gm/getpostextpath.cpp
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2012 Google Inc.
+ *
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+#include "gm.h"
+#include "SkCanvas.h"
+#include "SkPaint.h"
+#include "SkRandom.h"
+
+class GetPosTextPathGM : public skiagm::GM {
+public:
+ GetPosTextPathGM() {}
+
+protected:
+ SkString onShortName() {
+ return SkString("getpostextpath");
+ }
+
+ SkISize onISize() { return skiagm::make_isize(480, 780); }
+
+ virtual void onDraw(SkCanvas* canvas) {
+ const char* text = "Hamburgefons";
+ size_t len = strlen(text);
+
+ SkPaint paint;
+ paint.setAntiAlias(true);
+ paint.setTextSize(SkIntToScalar(48));
+
+ SkAutoTArray<SkPoint> pos(len);
+ SkAutoTArray<SkScalar> widths(len);
+ paint.getTextWidths(text, len, &widths[0]);
+
+ SkRandom rand;
+ SkScalar x = SkIntToScalar(20);
+ SkScalar y = SkIntToScalar(100);
+ for (size_t i = 0; i < len; ++i) {
+ pos[i].set(x, y + rand.nextSScalar1() * 24);
+ x += widths[i];
+ }
+
+ canvas->drawPosText(text, len, &pos[0], paint);
+
+ SkPath path;
+ paint.setColor(SK_ColorRED);
+ paint.setStyle(SkPaint::kStroke_Style);
+ paint.getPosTextPath(text, len, &pos[0], &path);
+ canvas->drawPath(path, paint);
+ }
+};
+
+//////////////////////////////////////////////////////////////////////////////
+
+static skiagm::GM* F(void*) { return new GetPosTextPathGM; }
+
+static skiagm::GMRegistry gR(F);
+
diff --git a/gyp/gmslides.gypi b/gyp/gmslides.gypi
index fa4d2bbefc..6a032a1f9d 100644
--- a/gyp/gmslides.gypi
+++ b/gyp/gmslides.gypi
@@ -27,6 +27,7 @@
'../gm/filltypespersp.cpp',
'../gm/fontscaler.cpp',
'../gm/gammatext.cpp',
+ '../gm/getpostextpath.cpp',
'../gm/giantbitmap.cpp',
'../gm/gradients.cpp',
'../gm/gradtext.cpp',
diff --git a/include/core/SkPaint.h b/include/core/SkPaint.h
index 684bc455b1..4defe8b668 100644
--- a/include/core/SkPaint.h
+++ b/include/core/SkPaint.h
@@ -825,6 +825,9 @@ public:
void getTextPath(const void* text, size_t length, SkScalar x, SkScalar y,
SkPath* path) const;
+ void getPosTextPath(const void* text, size_t length,
+ const SkPoint pos[], SkPath* path) const;
+
#ifdef SK_BUILD_FOR_ANDROID
const SkGlyph& getUnicharMetrics(SkUnichar);
const SkGlyph& getGlyphMetrics(uint16_t);
diff --git a/src/core/SkPaint.cpp b/src/core/SkPaint.cpp
index 19abb4b085..f240737f7e 100644
--- a/src/core/SkPaint.cpp
+++ b/src/core/SkPaint.cpp
@@ -1358,6 +1358,33 @@ void SkPaint::getTextPath(const void* textData, size_t length,
}
}
+void SkPaint::getPosTextPath(const void* textData, size_t length,
+ const SkPoint pos[], SkPath* path) const {
+ SkASSERT(length == 0 || textData != NULL);
+
+ const char* text = (const char*)textData;
+ if (text == NULL || length == 0 || path == NULL) {
+ return;
+ }
+
+ SkTextToPathIter iter(text, length, *this, false);
+ SkMatrix matrix;
+ SkPoint prevPos;
+ prevPos.set(0, 0);
+
+ matrix.setScale(iter.getPathScale(), iter.getPathScale());
+ path->reset();
+
+ unsigned int i = 0;
+ const SkPath* iterPath;
+ while ((iterPath = iter.next(NULL)) != NULL) {
+ matrix.postTranslate(pos[i].fX - prevPos.fX, pos[i].fY - prevPos.fY);
+ path->addPath(*iterPath, matrix);
+ prevPos = pos[i];
+ i++;
+ }
+}
+
static void add_flattenable(SkDescriptor* desc, uint32_t tag,
SkFlattenableWriteBuffer* buffer) {
buffer->flatten(desc->addEntry(tag, buffer->size(), NULL));