Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Q&A

Welcome to Software Development on Codidact!

Will you help us build our independent community of developers helping developers? We're small and trying to grow. We welcome questions about all aspects of software development, from design to code to QA and more. Got questions? Got answers? Got code you'd like someone to review? Please join us.

Post History

42%
+1 −2
Q&A How does PathData work?

I was dealing with random Path. I had written a code like this : <path android:pathData="M 5 100 75 50 50 92 100 10 50 50 50 50 30 30" android:fillColor="#FFFFFF"/> As we know, there's ...

posted 3y ago by Anonymous‭  ·  edited 3y ago by Anonymous‭

Answer
#4: Post edited by user avatar Anonymous‭ · 2021-09-28T07:44:55Z (over 3 years ago)
  • I was dealing with random Path. I had written a code like this :
  • ```vector
  • <path
  • android:pathData="M 5 100 75 50 50 92 100 10 50 50 50 50 30 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • As we know, there's two axes.
  • 1. X axis.
  • 2. Y axis.
  • First value after "M" is representing X axis when the X axis gets very plain then sometime X axis "rotate" (very negligible) the icon (not directly rotation but it's illusion; I am testing and writing what I can see). When your X axis variable is less than 100 than the ray (cord is better maybe! I just used Google Translate since I didn't have idea of this word) will be changed in 2nd and 3rd Quadrant but when your X axis is 100 than you can't see any "icon" (icon, image whatever). When your X axis is greater than 100 than it will be affected in 1st and 4th Quadrant.
  • I have drawn an absolute right triangle
  • ```vector
  • <path
  • android:pathData="M 5 100 100 100 100 100 100 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • ![triangle](https://imgur.com/qCWlz9V.png)
  • When your Y axis is `1000000` then Y axis is absolute perpendicular (when your icon won't be shown). Seems like Y axis doesn't let you rotate to 3rd and 4th Quadrant. The angle of it is forever between 0-π.
  • And there must be two axis otherwise your image won't be shown cause if an axis is 0 than it becomes 1 dimensional which isn't visible to us. And every single number points out a point in an object.
  • **Remember** : 1st and 2nd is respectively X and Y axis.
  • <h2>Some more notation</h2>
  • <h3>Moveto</h3>
  • Capital letter is absolute and Small Letter is always relative
  • <blockquote>
  • <table>
  • <thead>
  • <tr>
  • <th>Command</th>
  • <th>Name</th>
  • <th>Parameters</th>
  • <th>Description</th>
  • </tr>
  • </thead>
  • <tbody>
  • <tr>
  • <td>M (absolute)
  • m (relative)</td>
  • <td>moveto</td>
  • <td>(x y)+</td>
  • <td>Start a new sub-path at the given (x,y) coordinates. M (uppercase) indicates that absolute coordinates will follow; m (lowercase) indicates that relative coordinates will follow. If a moveto is followed by multiple pairs of coordinates, the subsequent pairs are treated as implicit lineto commands. Hence, implicit lineto commands will be relative if the moveto is relative, and absolute if the moveto is absolute. If a relative moveto (m) appears as the first element of the path, then it is treated as a pair of absolute coordinates. In this case, subsequent pairs of coordinates are treated as relative even though the initial moveto is interpreted as an absolute moveto.</td>
  • </tr>
  • </tbody>
  • </table>
  • ~ <a href="https://www.w3.org/TR/SVG/paths.html#PathDataMovetoCommands">Move to</a> (given by Dana)
  • </blockquote>
  • <hr/>
  • <h2>Available Letters <a href="https://www.w3.org/TR/SVG/paths.html#PathDataBNF">Taken</a></h2>
  • - L or l - line to
  • - M or m - move to
  • - H or h - horizontal line to
  • - V or v - vertical line to
  • - C or c - curve to
  • - S or s - shorthand/smooth curve to
  • - Q or q - quadratic Bézier curve to
  • - T or t - Shorthand/smooth quadratic Bézier curve to
  • - A or a - elliptical arc
  • - Z - Close path
  • <h2>Beauty of Path</h2>
  • If you look at triangle properly then you will notice triangle has 6 Coordinate so you need 6 variables to make a triangle. I have figured out the triangle
  • ```vector
  • <path
  • android:pathData="M 50 50 50 0 0 0"
  • android:fillColor="#FFFFFF"/>
  • ```
  • So rectangle needs 8 Coordinate (8 variables).
  • ```vector
  • <path
  • android:pathData="M 50 50 50 0 0 0 0 50"
  • android:fillColor="#FFFFFF"/>
  • ```
  • ![rectangle](https://imgur.com/k1oudT9.png)
  • <span class="hide" id="coordinate_explanation">
  • <h3>Explain Coordinates separately <a href="#coordinate_explanation">#</a></h3>
  • It's easier to understand rectangle coordinate rather than triangle. I can't understand "pulling", "pushing" for triangle.
  • The first variable (**works on bottom-right from right side**) in rectangle code actually <b>pull bottom-right from right side when it is greater than 50 and push when it is less than 50. disturbs left-bottom coordinate when it is negative or less or 0.</b>
  • </span>
  • <hr/>
  • [License under CC0](https://creativecommons.org/share-your-work/public-domain/cc0/)
  • I was dealing with random Path. I had written a code like this :
  • ```vector
  • <path
  • android:pathData="M 5 100 75 50 50 92 100 10 50 50 50 50 30 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • As we know, there's two axes.
  • 1. X axis.
  • 2. Y axis.
  • First value after "M" is representing X axis when the X axis gets very plain then sometime X axis "rotate" (very negligible) the icon (not directly rotation but it's illusion; I am testing and writing what I can see). When your X axis variable is less than 100 than the ray (cord is better maybe! I just used Google Translate since I didn't have idea of this word) will be changed in 2nd and 3rd Quadrant but when your X axis is 100 than you can't see any "icon" (icon, image whatever). When your X axis is greater than 100 than it will be affected in 1st and 4th Quadrant.
  • I have drawn an absolute right triangle
  • ```vector
  • <path
  • android:pathData="M 5 100 100 100 100 100 100 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • ![triangle](https://imgur.com/qCWlz9V.png)
  • When your Y axis is `1000000` then Y axis is absolute perpendicular (when your icon won't be shown). Seems like Y axis doesn't let you rotate to 3rd and 4th Quadrant. The angle of it is forever between 0-π.
  • And there must be two axis otherwise your image won't be shown cause if an axis is 0 than it becomes 1 dimensional which isn't visible to us. And every single number points out a point in an object.
  • **Remember** : 1st and 2nd is respectively X and Y axis.
  • <h2>Some more notation</h2>
  • <h3>Moveto</h3>
  • Capital letter is absolute and Small Letter is always relative
  • <blockquote>
  • <table>
  • <thead>
  • <tr>
  • <th>Command</th>
  • <th>Name</th>
  • <th>Parameters</th>
  • <th>Description</th>
  • </tr>
  • </thead>
  • <tbody>
  • <tr>
  • <td>M (absolute)
  • m (relative)</td>
  • <td>moveto</td>
  • <td>(x y)+</td>
  • <td>Start a new sub-path at the given (x,y) coordinates. M (uppercase) indicates that absolute coordinates will follow; m (lowercase) indicates that relative coordinates will follow. If a moveto is followed by multiple pairs of coordinates, the subsequent pairs are treated as implicit lineto commands. Hence, implicit lineto commands will be relative if the moveto is relative, and absolute if the moveto is absolute. If a relative moveto (m) appears as the first element of the path, then it is treated as a pair of absolute coordinates. In this case, subsequent pairs of coordinates are treated as relative even though the initial moveto is interpreted as an absolute moveto.</td>
  • </tr>
  • </tbody>
  • </table>
  • ~ <a href="https://www.w3.org/TR/SVG/paths.html#PathDataMovetoCommands">Move to</a> (given by Dana)
  • </blockquote>
  • <hr/>
  • <h2>Available Letters <a href="https://www.w3.org/TR/SVG/paths.html#PathDataBNF">Taken</a></h2>
  • - L or l - line to
  • - M or m - move to
  • - H or h - horizontal line to
  • - V or v - vertical line to
  • - C or c - curve to
  • - S or s - shorthand/smooth curve to
  • - Q or q - quadratic Bézier curve to
  • - T or t - Shorthand/smooth quadratic Bézier curve to
  • - A or a - elliptical arc
  • - Z - Close path
  • <h2>Beauty of Path</h2>
  • If you look at triangle properly then you will notice triangle has 6 Coordinate so you need 6 variables to make a triangle. I have figured out the triangle
  • ```vector
  • <path
  • android:pathData="M 50 50 50 0 0 0"
  • android:fillColor="#FFFFFF"/>
  • ```
  • So rectangle needs 8 Coordinate (8 variables).
  • ```vector
  • <path
  • android:pathData="M 50 50 50 0 0 0 0 50"
  • android:fillColor="#FFFFFF"/>
  • ```
  • ![rectangle](https://imgur.com/k1oudT9.png)
  • <span class="hide" id="coordinate_explanation">
  • <h3>Explain Coordinates separately <a href="#coordinate_explanation">#</a></h3>
  • It's easier to understand rectangle coordinate rather than triangle. I can't understand "pulling", "pushing" for triangle.
  • The first variable (**works on bottom-right from right side**) in rectangle code actually <b>pull bottom-right from right side when it is greater than 50 and push when it is less than 50. disturbs left-bottom coordinate when it is negative or less or 0.</b>
  • </span>
  • <hr/>
  • It's not possible to convert SVG text to vector directly. Even some websites can't do that job properly also (Like as : svg2vector.com)
  • If you have a SVG file and if your SVG file contains texts than you have to convert them to path Adobe can do that. But there's another way to do that. At first you have to upload your file in https://cloudconvert.com/ and convert that SVG to SVG. In options, you have to select text to Path
  • ![text to Path](https://imgur.com/w9ZmG9r.png) then you can put that SVG in Android Studio by following the task : File -> Vector Asset -> Local File -> Select your SVG -> OK.
  • You will find your Vector image in drawable. Then you can use it anywhere.
  • [reference](https://stackoverflow.com/a/61015876/16897106)
  • If you don't have idea of creating SVG file than you can do it by simple illustration : https://yqnn.github.io/svg-path-editor/
  • To view : https://shapeshifter.design/
  • You can check Animation in shapeshifter also.
  • <hr/>
  • [License under CC0](https://creativecommons.org/share-your-work/public-domain/cc0/)
#3: Post edited by user avatar Anonymous‭ · 2021-09-27T16:44:56Z (over 3 years ago)
  • I was dealing with random Path. I had written a code like this :
  • ```vector
  • <path
  • android:pathData="M 5 100 75 50 50 92 100 10 50 50 50 50 30 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • As we know, there's two axes.
  • 1. X axis.
  • 2. Y axis.
  • First value after "M" is representing X axis when the X axis gets very plain then sometime X axis "rotate" (very negligible) the icon (not directly rotation but it's illusion; I am testing and writing what I can see). When your X axis variable is less than 100 than the ray (cord is better maybe! I just used Google Translate since I didn't have idea of this word) will be changed in 2nd and 3rd Quadrant but when your X axis is 100 than you can't see any "icon" (icon, image whatever). When your X axis is greater than 100 than it will be affected in 1st and 4th Quadrant.
  • I have drawn an absolute right triangle
  • ```vector
  • <path
  • android:pathData="M 5 100 100 100 100 100 100 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • ![triangle](https://imgur.com/qCWlz9V.png)
  • When your Y axis is `1000000` then Y axis is absolute perpendicular (when your icon won't be shown). Seems like Y axis doesn't let you rotate to 3rd and 4th Quadrant. The angle of it is forever between 0-π.
  • And there must be two axis otherwise your image won't be shown cause if an axis is 0 than it becomes 1 dimensional which isn't visible to us. And every single number points out a point in an object.
  • **Remember** : 1st and 2nd is respectively X and Y axis.
  • <h2>Some more notation</h2>
  • <h3>Moveto</h3>
  • Capital letter is absolute and Small Letter is always relative
  • <blockquote>
  • <table>
  • <thead>
  • <tr>
  • <th>Command</th>
  • <th>Name</th>
  • <th>Parameters</th>
  • <th>Description</th>
  • </tr>
  • </thead>
  • <tbody>
  • <tr>
  • <td>M (absolute)
  • m (relative)</td>
  • <td>moveto</td>
  • <td>(x y)+</td>
  • <td>Start a new sub-path at the given (x,y) coordinates. M (uppercase) indicates that absolute coordinates will follow; m (lowercase) indicates that relative coordinates will follow. If a moveto is followed by multiple pairs of coordinates, the subsequent pairs are treated as implicit lineto commands. Hence, implicit lineto commands will be relative if the moveto is relative, and absolute if the moveto is absolute. If a relative moveto (m) appears as the first element of the path, then it is treated as a pair of absolute coordinates. In this case, subsequent pairs of coordinates are treated as relative even though the initial moveto is interpreted as an absolute moveto.</td>
  • </tr>
  • </tbody>
  • </table>
  • ~ <a href="https://www.w3.org/TR/SVG/paths.html#PathDataMovetoCommands">Move to</a> (given by Dana)
  • </blockquote>
  • <hr/>
  • <h2>Available Letters <a href="https://www.w3.org/TR/SVG/paths.html#PathDataBNF">Taken</a></h2>
  • - L or l - line to
  • - M or m - move to
  • - H or h - horizontal line to
  • - V or v - vertical line to
  • - C or c - curve to
  • - S or s - shorthand/smooth curve to
  • - Q or q - quadratic Bézier curve to
  • - T or t - Shorthand/smooth quadratic Bézier curve to
  • - A or a - elliptical arc
  • - Z - Close path
  • <hr/>
  • [License under CC0](https://creativecommons.org/share-your-work/public-domain/cc0/)
  • I was dealing with random Path. I had written a code like this :
  • ```vector
  • <path
  • android:pathData="M 5 100 75 50 50 92 100 10 50 50 50 50 30 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • As we know, there's two axes.
  • 1. X axis.
  • 2. Y axis.
  • First value after "M" is representing X axis when the X axis gets very plain then sometime X axis "rotate" (very negligible) the icon (not directly rotation but it's illusion; I am testing and writing what I can see). When your X axis variable is less than 100 than the ray (cord is better maybe! I just used Google Translate since I didn't have idea of this word) will be changed in 2nd and 3rd Quadrant but when your X axis is 100 than you can't see any "icon" (icon, image whatever). When your X axis is greater than 100 than it will be affected in 1st and 4th Quadrant.
  • I have drawn an absolute right triangle
  • ```vector
  • <path
  • android:pathData="M 5 100 100 100 100 100 100 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • ![triangle](https://imgur.com/qCWlz9V.png)
  • When your Y axis is `1000000` then Y axis is absolute perpendicular (when your icon won't be shown). Seems like Y axis doesn't let you rotate to 3rd and 4th Quadrant. The angle of it is forever between 0-π.
  • And there must be two axis otherwise your image won't be shown cause if an axis is 0 than it becomes 1 dimensional which isn't visible to us. And every single number points out a point in an object.
  • **Remember** : 1st and 2nd is respectively X and Y axis.
  • <h2>Some more notation</h2>
  • <h3>Moveto</h3>
  • Capital letter is absolute and Small Letter is always relative
  • <blockquote>
  • <table>
  • <thead>
  • <tr>
  • <th>Command</th>
  • <th>Name</th>
  • <th>Parameters</th>
  • <th>Description</th>
  • </tr>
  • </thead>
  • <tbody>
  • <tr>
  • <td>M (absolute)
  • m (relative)</td>
  • <td>moveto</td>
  • <td>(x y)+</td>
  • <td>Start a new sub-path at the given (x,y) coordinates. M (uppercase) indicates that absolute coordinates will follow; m (lowercase) indicates that relative coordinates will follow. If a moveto is followed by multiple pairs of coordinates, the subsequent pairs are treated as implicit lineto commands. Hence, implicit lineto commands will be relative if the moveto is relative, and absolute if the moveto is absolute. If a relative moveto (m) appears as the first element of the path, then it is treated as a pair of absolute coordinates. In this case, subsequent pairs of coordinates are treated as relative even though the initial moveto is interpreted as an absolute moveto.</td>
  • </tr>
  • </tbody>
  • </table>
  • ~ <a href="https://www.w3.org/TR/SVG/paths.html#PathDataMovetoCommands">Move to</a> (given by Dana)
  • </blockquote>
  • <hr/>
  • <h2>Available Letters <a href="https://www.w3.org/TR/SVG/paths.html#PathDataBNF">Taken</a></h2>
  • - L or l - line to
  • - M or m - move to
  • - H or h - horizontal line to
  • - V or v - vertical line to
  • - C or c - curve to
  • - S or s - shorthand/smooth curve to
  • - Q or q - quadratic Bézier curve to
  • - T or t - Shorthand/smooth quadratic Bézier curve to
  • - A or a - elliptical arc
  • - Z - Close path
  • <h2>Beauty of Path</h2>
  • If you look at triangle properly then you will notice triangle has 6 Coordinate so you need 6 variables to make a triangle. I have figured out the triangle
  • ```vector
  • <path
  • android:pathData="M 50 50 50 0 0 0"
  • android:fillColor="#FFFFFF"/>
  • ```
  • So rectangle needs 8 Coordinate (8 variables).
  • ```vector
  • <path
  • android:pathData="M 50 50 50 0 0 0 0 50"
  • android:fillColor="#FFFFFF"/>
  • ```
  • ![rectangle](https://imgur.com/k1oudT9.png)
  • <span class="hide" id="coordinate_explanation">
  • <h3>Explain Coordinates separately <a href="#coordinate_explanation">#</a></h3>
  • It's easier to understand rectangle coordinate rather than triangle. I can't understand "pulling", "pushing" for triangle.
  • The first variable (**works on bottom-right from right side**) in rectangle code actually <b>pull bottom-right from right side when it is greater than 50 and push when it is less than 50. disturbs left-bottom coordinate when it is negative or less or 0.</b>
  • </span>
  • <hr/>
  • [License under CC0](https://creativecommons.org/share-your-work/public-domain/cc0/)
#2: Post edited by user avatar Anonymous‭ · 2021-09-27T16:15:11Z (over 3 years ago)
  • I was dealing with random Path. I had written a code like this :
  • ```vector
  • <path
  • android:pathData="M 5 100 75 50 50 92 100 10 50 50 50 50 30 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • As we know, there's two axes.
  • 1. X axis.
  • 2. Y axis.
  • First value after "M" is representing X axis when the X axis gets very plain then sometime X axis "rotate" (very negligible) the icon (not directly rotation but it's illusion; I am testing and writing what I can see). When your X axis variable is less than 100 than the ray (cord is better maybe! I just used Google Translate since I didn't have idea of this word) will be changed in 2nd and 3rd Quadrant but when your X axis is 100 than you can't see any "icon" (icon, image whatever). When your X axis is greater than 100 than it will be affected in 1st and 4th Quadrant.
  • I have drawn an absolute right triangle
  • ```vector
  • <path
  • android:pathData="M 5 100 100 100 100 100 100 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • ![triangle](https://imgur.com/qCWlz9V.png)
  • When your Y axis is `1000000` then Y axis is absolute perpendicular (when your icon won't be shown). Seems like Y axis doesn't let you rotate to 3rd and 4th Quadrant. The angle of it is forever between 0-π.
  • And there must be two axis otherwise your image won't be shown cause if an axis is 0 than it becomes 1 dimensional which isn't visible to us. And every single number points out a point in an object.
  • **Remember** : 1st and 2nd is respectively X and Y axis.
  • <h2>Some more notation</h2>
  • <h3>Moveto</h3>
  • Capital letter is absolute and Small Letter is always relative
  • <blockquote>
  • <table>
  • <thead>
  • <tr>
  • <th>Command</th>
  • <th>Name</th>
  • <th>Parameters</th>
  • <th>Description</th>
  • </tr>
  • </thead>
  • <tbody>
  • <tr>
  • <td>M (absolute)
  • m (relative)</td>
  • <td>moveto</td>
  • <td>(x y)+</td>
  • <td>Start a new sub-path at the given (x,y) coordinates. M (uppercase) indicates that absolute coordinates will follow; m (lowercase) indicates that relative coordinates will follow. If a moveto is followed by multiple pairs of coordinates, the subsequent pairs are treated as implicit lineto commands. Hence, implicit lineto commands will be relative if the moveto is relative, and absolute if the moveto is absolute. If a relative moveto (m) appears as the first element of the path, then it is treated as a pair of absolute coordinates. In this case, subsequent pairs of coordinates are treated as relative even though the initial moveto is interpreted as an absolute moveto.</td>
  • </tr>
  • </tbody>
  • </table>
  • ~ <a href="https://www.w3.org/TR/SVG/paths.html#PathDataMovetoCommands">Move to</a> (given by Dana)
  • </blockquote>
  • <hr/>
  • <h2>Available Letters <a href="https://www.w3.org/TR/SVG/paths.html#PathDataBNF">Taken</a></h2>
  • - L or l - line to
  • - M or m - move to
  • - H or h - horizontal line to
  • - V or v - vertical line to
  • - C or c - curve to
  • - S or s - shorthand/smooth curve to
  • - Q or q - quadratic Bézier curve to
  • - T or t - Shorthand/smooth quadratic Bézier curve to
  • - A or a - elliptical arc
  • - Z - Close path
  • I was dealing with random Path. I had written a code like this :
  • ```vector
  • <path
  • android:pathData="M 5 100 75 50 50 92 100 10 50 50 50 50 30 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • As we know, there's two axes.
  • 1. X axis.
  • 2. Y axis.
  • First value after "M" is representing X axis when the X axis gets very plain then sometime X axis "rotate" (very negligible) the icon (not directly rotation but it's illusion; I am testing and writing what I can see). When your X axis variable is less than 100 than the ray (cord is better maybe! I just used Google Translate since I didn't have idea of this word) will be changed in 2nd and 3rd Quadrant but when your X axis is 100 than you can't see any "icon" (icon, image whatever). When your X axis is greater than 100 than it will be affected in 1st and 4th Quadrant.
  • I have drawn an absolute right triangle
  • ```vector
  • <path
  • android:pathData="M 5 100 100 100 100 100 100 30"
  • android:fillColor="#FFFFFF"/>
  • ```
  • ![triangle](https://imgur.com/qCWlz9V.png)
  • When your Y axis is `1000000` then Y axis is absolute perpendicular (when your icon won't be shown). Seems like Y axis doesn't let you rotate to 3rd and 4th Quadrant. The angle of it is forever between 0-π.
  • And there must be two axis otherwise your image won't be shown cause if an axis is 0 than it becomes 1 dimensional which isn't visible to us. And every single number points out a point in an object.
  • **Remember** : 1st and 2nd is respectively X and Y axis.
  • <h2>Some more notation</h2>
  • <h3>Moveto</h3>
  • Capital letter is absolute and Small Letter is always relative
  • <blockquote>
  • <table>
  • <thead>
  • <tr>
  • <th>Command</th>
  • <th>Name</th>
  • <th>Parameters</th>
  • <th>Description</th>
  • </tr>
  • </thead>
  • <tbody>
  • <tr>
  • <td>M (absolute)
  • m (relative)</td>
  • <td>moveto</td>
  • <td>(x y)+</td>
  • <td>Start a new sub-path at the given (x,y) coordinates. M (uppercase) indicates that absolute coordinates will follow; m (lowercase) indicates that relative coordinates will follow. If a moveto is followed by multiple pairs of coordinates, the subsequent pairs are treated as implicit lineto commands. Hence, implicit lineto commands will be relative if the moveto is relative, and absolute if the moveto is absolute. If a relative moveto (m) appears as the first element of the path, then it is treated as a pair of absolute coordinates. In this case, subsequent pairs of coordinates are treated as relative even though the initial moveto is interpreted as an absolute moveto.</td>
  • </tr>
  • </tbody>
  • </table>
  • ~ <a href="https://www.w3.org/TR/SVG/paths.html#PathDataMovetoCommands">Move to</a> (given by Dana)
  • </blockquote>
  • <hr/>
  • <h2>Available Letters <a href="https://www.w3.org/TR/SVG/paths.html#PathDataBNF">Taken</a></h2>
  • - L or l - line to
  • - M or m - move to
  • - H or h - horizontal line to
  • - V or v - vertical line to
  • - C or c - curve to
  • - S or s - shorthand/smooth curve to
  • - Q or q - quadratic Bézier curve to
  • - T or t - Shorthand/smooth quadratic Bézier curve to
  • - A or a - elliptical arc
  • - Z - Close path
  • <hr/>
  • [License under CC0](https://creativecommons.org/share-your-work/public-domain/cc0/)
#1: Initial revision by user avatar Anonymous‭ · 2021-09-27T16:10:40Z (over 3 years ago)
I was dealing with random Path. I had written a code like this :

```vector
<path
android:pathData="M 5 100 75 50 50 92 100 10 50 50 50 50 30 30"
android:fillColor="#FFFFFF"/>
```

As we know, there's two axes.

1. X axis.
2. Y axis.

First value after "M" is representing X axis when the X axis gets very plain then sometime X axis "rotate" (very negligible) the icon (not directly rotation but it's illusion; I am testing and writing what I can see). When your X axis variable is less than 100 than the ray (cord is better maybe! I just used Google Translate since I didn't have idea of this word) will be changed in 2nd and 3rd Quadrant but when your X axis is 100 than you can't see any "icon" (icon, image whatever). When your X axis is greater than 100 than it will be affected in 1st and 4th Quadrant. 

I have drawn an absolute right triangle

```vector
<path
        android:pathData="M 5 100 100 100 100 100 100 30"
        android:fillColor="#FFFFFF"/>
```
![triangle](https://imgur.com/qCWlz9V.png)

When your Y axis is `1000000` then Y axis is absolute perpendicular (when your icon won't be shown). Seems like Y axis doesn't let you rotate to 3rd and 4th Quadrant. The angle of it is forever between 0-π.

And there must be two axis otherwise your image won't be shown cause if an axis is 0 than it becomes 1 dimensional which isn't visible to us. And every single number points out a point in an object. 

**Remember** : 1st and 2nd is respectively X and Y axis.

<h2>Some more notation</h2>

<h3>Moveto</h3>
Capital letter is absolute and Small Letter is always relative


<blockquote>
<table>
<thead>
<tr>
<th>Command</th>
<th>Name</th>
<th>Parameters</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>M (absolute)
m (relative)</td>
<td>moveto</td>
<td>(x y)+</td>
<td>Start a new sub-path at the given (x,y) coordinates. M (uppercase) indicates that absolute coordinates will follow; m (lowercase) indicates that relative coordinates will follow. If a moveto is followed by multiple pairs of coordinates, the subsequent pairs are treated as implicit lineto commands. Hence, implicit lineto commands will be relative if the moveto is relative, and absolute if the moveto is absolute. If a relative moveto (m) appears as the first element of the path, then it is treated as a pair of absolute coordinates. In this case, subsequent pairs of coordinates are treated as relative even though the initial moveto is interpreted as an absolute moveto.</td>
</tr>
</tbody>
</table>
~ <a href="https://www.w3.org/TR/SVG/paths.html#PathDataMovetoCommands">Move to</a> (given by Dana)
</blockquote>

<hr/>

<h2>Available Letters <a href="https://www.w3.org/TR/SVG/paths.html#PathDataBNF">Taken</a></h2>

- L or l - line to
- M or m - move to
- H or h - horizontal line to
- V or v - vertical line to
- C or c - curve to
- S or s - shorthand/smooth curve to
- Q or q - quadratic Bézier curve to
- T or t - Shorthand/smooth quadratic Bézier curve to
- A or a - elliptical arc
- Z - Close path