- From: therahedwig via GitHub <sysbot+gh@w3.org>
- Date: Sun, 30 Oct 2022 13:14:07 +0000
- To: public-svg-issues@w3.org
therahedwig has just created a new issue for https://github.com/w3c/svgwg: == Right to left text on path and trailing text. == I've been doing tests, and this time, I found a problem with right-to-left textPaths, in particular when there's a trailing non-text-chunk piece of text. If we take the following SVG: ``` <svg width="230px" height="170px" xmlns="http://www.w3.org/2000/svg" version="2.0"> <defs> <path id="path-horizontal" transform="translate(50, 0)" d="M0 0C10 20 50 20 60 0" /> <path id="path-horizontal2" transform="translate(-20, 20)" d="M0 0C10 20 50 20 60 0" /> <path id="path-vertical" transform="translate(0, 50)" d="M0 0C20 10 20 50 0 60" /> </defs> <g id="testRect"> <text id="test1" transform="translate(20,50)" font-family="DejaVu Sans" fill="blue" font-size="15">Lorem <textPath href="#path-horizontal">ipsum dolor sit </textPath>amet</text> <text id="test1rtl" transform="translate(90,100)" font-family="DejaVu Sans" fill="blue" font-size="15" direction="rtl">اللغة العربية<textPath href="#path-horizontal2" startOffset="100%"> المعيارية </textPath>الحديثة </text> <text id="test1ttb" transform="translate(200,10)" font-family="sans" fill="blue" font-size="15" writing-mode="vertical-rl">ああ芦<textPath href="#path-vertical">芦芦芦あ</textPath>ああ芦 </text> </g> </svg> ``` Chromium 106: data:image/s3,"s3://crabby-images/a977e/a977eef33d4d1e0ee5c2b1f312db3887a2f8e0ea" alt="image" My code currently gives this: data:image/s3,"s3://crabby-images/cbac6/cbac6b2d575105919a98beaabc45194d4d14274e" alt="image" Chromium's result looks correct, however, this is the text-flow: data:image/s3,"s3://crabby-images/1f0cd/1f0cdea0fcae4f9bc45b9060ca136d36294445c3" alt="image" I think this is what is expected, but it's wrong because algorithm-wise that's the start of the path: data:image/s3,"s3://crabby-images/7da96/7da961cdec4de3a076d2b8c2bbcc001b216df3e3" alt="image" So, the [spec says that trailing text](https://svgwg.org/svg2-draft/text.html#TextpathLayoutRules) should be anchored to the end of the path: > After positioning all characters within the ‘[textPath](https://svgwg.org/svg2-draft/text.html#TextPathElement)’, the [current text position](https://svgwg.org/svg2-draft/text.html#TermCurrentTextPosition) is set to the end point of the path, after adjusting for the ‘[startOffset](https://svgwg.org/svg2-draft/text.html#TextPathElementStartOffsetAttribute)’ in the case of paths that are a single closed loop. In other words, text that follows a ‘[textPath](https://svgwg.org/svg2-draft/text.html#TextPathElement)’ element (but is still inside a ‘[text](https://svgwg.org/svg2-draft/text.html#TextElement)’ element) that does not have explicit positioning information (‘[x](https://svgwg.org/svg2-draft/text.html#TextElementXAttribute)’ and ‘[y](https://svgwg.org/svg2-draft/text.html#TextElementYAttribute)’ attributes) is positioned from the end of the path. There's another issue related to this: Every implementation I tried will not show right-to-left text with `text-anchor="start"` unless the startOffset is 100%, this is because the anchoring algorithm moves a right-to-left text to have it's positions in the negative of it's anchoring point, so it's not visible on a path to begin with. My gut tells me that right-to-left text should have the end and start of a path flipped (but not the path itself flipped, because then it results in the effects of the 'side' attribute), though I am unsure how that would look algorithmically. Please view or discuss this issue at https://github.com/w3c/svgwg/issues/898 using your GitHub account -- Sent via github-notify-ml as configured in https://github.com/w3c/github-notify-ml-config
Received on Sunday, 30 October 2022 13:14:09 UTC