gfx/skia/patches/archive/getpostextpath.patch

Wed, 31 Dec 2014 06:09:35 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 06:09:35 +0100
changeset 0
6474c204b198
permissions
-rw-r--r--

Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.

     1 diff --git a/gfx/skia/include/core/SkPaint.h b/gfx/skia/include/core/SkPaint.h
     2 --- a/gfx/skia/include/core/SkPaint.h
     3 +++ b/gfx/skia/include/core/SkPaint.h
     4 @@ -836,16 +836,19 @@ public:
     6      /** Return the path (outline) for the specified text.
     7          Note: just like SkCanvas::drawText, this will respect the Align setting
     8                in the paint.
     9      */
    10      void getTextPath(const void* text, size_t length, SkScalar x, SkScalar y,
    11                       SkPath* path) const;
    13 +    void getPosTextPath(const void* text, size_t length, 
    14 +                        const SkPoint pos[], SkPath* path) const;
    15 +
    16  #ifdef SK_BUILD_FOR_ANDROID
    17      const SkGlyph& getUnicharMetrics(SkUnichar);
    18      const void* findImage(const SkGlyph&);
    20      uint32_t getGenerationID() const;
    21  #endif
    23      // returns true if the paint's settings (e.g. xfermode + alpha) resolve to
    24 diff --git a/gfx/skia/src/core/SkPaint.cpp b/gfx/skia/src/core/SkPaint.cpp
    25 --- a/gfx/skia/src/core/SkPaint.cpp
    26 +++ b/gfx/skia/src/core/SkPaint.cpp
    27 @@ -1242,16 +1242,43 @@ void SkPaint::getTextPath(const void* te
    28      const SkPath*   iterPath;
    29      while ((iterPath = iter.next(&xpos)) != NULL) {
    30          matrix.postTranslate(xpos - prevXPos, 0);
    31          path->addPath(*iterPath, matrix);
    32          prevXPos = xpos;
    33      }
    34  }
    36 +void SkPaint::getPosTextPath(const void* textData, size_t length,
    37 +                             const SkPoint pos[], SkPath* path) const {
    38 +    SkASSERT(length == 0 || textData != NULL);
    39 +
    40 +    const char* text = (const char*)textData;
    41 +    if (text == NULL || length == 0 || path == NULL) {
    42 +        return;
    43 +    }
    44 +
    45 +    SkTextToPathIter    iter(text, length, *this, false, true);
    46 +    SkMatrix            matrix;
    47 +    SkPoint             prevPos;
    48 +    prevPos.set(0, 0);
    49 +
    50 +    matrix.setScale(iter.getPathScale(), iter.getPathScale());
    51 +    path->reset();
    52 +
    53 +    unsigned int    i = 0;
    54 +    const SkPath*   iterPath;
    55 +    while ((iterPath = iter.next(NULL)) != NULL) {
    56 +        matrix.postTranslate(pos[i].fX - prevPos.fX, pos[i].fY - prevPos.fY);
    57 +        path->addPath(*iterPath, matrix);
    58 +        prevPos = pos[i];
    59 +        i++;
    60 +    }
    61 +}
    62 +
    63  static void add_flattenable(SkDescriptor* desc, uint32_t tag,
    64                              SkFlattenableWriteBuffer* buffer) {
    65      buffer->flatten(desc->addEntry(tag, buffer->size(), NULL));
    66  }
    68  // SkFontHost can override this choice in FilterRec()
    69  static SkMask::Format computeMaskFormat(const SkPaint& paint) {
    70      uint32_t flags = paint.getFlags();

mercurial