lottie/vector: fixed dasher issue. 04/186204/1
authorsubhransu mohanty <sub.mohanty@samsung.com>
Mon, 6 Aug 2018 06:56:10 +0000 (15:56 +0900)
committersubhransu mohanty <sub.mohanty@samsung.com>
Wed, 8 Aug 2018 04:57:39 +0000 (13:57 +0900)
Change-Id: If602ac7441469c5ed8bfe0500154a585087f433f

src/vector/vdasher.cpp
src/vector/vdasher.h

index 7fa920d7aaa9de2db7b518a9cb9ac9b6eb393157..cd7df4382a898f00978905dfb9281af061c7527d 100644 (file)
@@ -114,7 +114,10 @@ void VDasher::lineTo(const VPointF &p)
     if (length < mCurrentDashLength) {
         mCurrentDashLength -= length;
         if (!mIsCurrentOperationGap) {
-            mDashedPath.moveTo(mCurPt);
+            if (!mNewSegment) {
+                mDashedPath.moveTo(mCurPt);
+                mNewSegment = true;
+            }
             mDashedPath.lineTo(p);
         }
     } else {
@@ -122,7 +125,10 @@ void VDasher::lineTo(const VPointF &p)
             length -= mCurrentDashLength;
             line.splitAtLength(mCurrentDashLength, left, right);
             if (!mIsCurrentOperationGap) {
-                mDashedPath.moveTo(left.p1());
+                if (!mNewSegment) {
+                    mDashedPath.moveTo(left.p1());
+                    mNewSegment = true;
+                }
                 mDashedPath.lineTo(left.p2());
                 mCurrentDashLength = mDashArray[mCurrentDashIndex].gap;
             } else {
@@ -130,6 +136,8 @@ void VDasher::lineTo(const VPointF &p)
                 mCurrentDashLength = mDashArray[mCurrentDashIndex].length;
             }
             mIsCurrentOperationGap = !mIsCurrentOperationGap;
+            if (mIsCurrentOperationGap)
+                mNewSegment = false;
             line = right;
             mCurPt = line.p1();
         }
@@ -144,6 +152,7 @@ void VDasher::lineTo(const VPointF &p)
             if (!mIsCurrentOperationGap) {
                 mIsCurrentOperationGap = true;
                 mCurrentDashLength = mDashArray[mCurrentDashIndex].gap;
+                mNewSegment = false;
             } else {
                 mIsCurrentOperationGap = false;
                 mCurrentDashIndex = (mCurrentDashIndex + 1) % mArraySize;
@@ -163,7 +172,10 @@ void VDasher::cubicTo(const VPointF &cp1, const VPointF &cp2, const VPointF &e)
     if (bezLen < mCurrentDashLength) {
         mCurrentDashLength -= bezLen;
         if (!mIsCurrentOperationGap) {
-            mDashedPath.moveTo(mCurPt);
+            if (!mNewSegment) {
+                mDashedPath.moveTo(mCurPt);
+                mNewSegment = true;
+            }
             mDashedPath.cubicTo(cp1, cp2, e);
         }
     } else {
@@ -171,22 +183,29 @@ void VDasher::cubicTo(const VPointF &cp1, const VPointF &cp2, const VPointF &e)
             bezLen -= mCurrentDashLength;
             b.splitAtLength(mCurrentDashLength, &left, &right);
             if (!mIsCurrentOperationGap) {
-                mDashedPath.moveTo(left.pt1());
+                if (!mNewSegment) {
+                    mDashedPath.moveTo(left.pt1());
+                    mNewSegment = true;
+                }
                 mDashedPath.cubicTo(left.pt2(), left.pt3(), left.pt4());
-                ;
                 mCurrentDashLength = mDashArray[mCurrentDashIndex].gap;
             } else {
                 mCurrentDashIndex = (mCurrentDashIndex + 1) % mArraySize;
                 mCurrentDashLength = mDashArray[mCurrentDashIndex].length;
             }
             mIsCurrentOperationGap = !mIsCurrentOperationGap;
+            if (mIsCurrentOperationGap)
+                mNewSegment = false;
             b = right;
             mCurPt = b.pt1();
         }
         // remainder
         mCurrentDashLength -= bezLen;
         if (!mIsCurrentOperationGap) {
-            mDashedPath.moveTo(b.pt1());
+            if (!mNewSegment) {
+                mDashedPath.moveTo(b.pt1());
+                mNewSegment = true;
+            }
             mDashedPath.cubicTo(b.pt2(), b.pt3(), b.pt4());
         }
         if (mCurrentDashLength < 1.0) {
@@ -194,6 +213,7 @@ void VDasher::cubicTo(const VPointF &cp1, const VPointF &cp2, const VPointF &e)
             if (!mIsCurrentOperationGap) {
                 mIsCurrentOperationGap = true;
                 mCurrentDashLength = mDashArray[mCurrentDashIndex].gap;
+                mNewSegment = false;
             } else {
                 mIsCurrentOperationGap = false;
                 mCurrentDashIndex = (mCurrentDashIndex + 1) % mArraySize;
index 833e8c9e60b0eb9914bc1752fa3abc0b7ee54b32..c50bfb535c9db47564966636ca82422053b06f8f 100644 (file)
@@ -29,6 +29,7 @@ private:
     bool                 mIsCurrentOperationGap;
     float                mDashOffset;
     VPath                mDashedPath;
+    bool                 mNewSegment=false;
 };
 
 V_END_NAMESPACE