pathLength
SVG Elements
- A
- B-C
- D
- E
- F
<feBlend>
<feColorMatrix>
<feComponentTransfer>
<feComposite>
<feConvolveMatrix>
<feDiffuseLighting>
<feDisplacementMap>
<feDistantLight>
<feFlood>
<feFuncA>
<feFuncB>
<feFuncG>
<feFuncR>
<feGaussianBlur>
<feImage>
<feMerge>
<feMergeNode>
<feMorphology>
<feOffset>
<fePointLight>
<feSpecularLighting>
<feSpotLight>
<feTile>
<feTurbulence>
<filter>
<font>
<font-face>
<font-face-format>
<font-face-name>
<font-face-src>
<font-face-uri>
<foreignObject>
- G
- H
- I
- J-L
- M
- N-P
- Q-R
- S
- T
- U
- V-Z
The pathLength
attribute lets authors specify a total length for the path, in user units. This value is then used to calibrate the browser's distance calculations with those of the author, by scaling all distance computations using the ratio pathLength
/(computed value of path length).
This can affect the actual rendered lengths of paths; including text paths, animation paths, and various stroke operations. Basically, all computations that require the length of the path. stroke-dasharray
, for example, will assume the start of the path being 0 and the end point the value defined in the pathLength
attribute.
You can use this attribute with the following SVG elements:
Example
<svg viewBox="0 0 100 60" xmlns="http://www.w3.org/2000/svg">
<style>
path {
fill: none;
stroke: black;
stroke-width: 2;
stroke-dasharray: 10;
}
</style>
<!-- No pathLength, the real length of the path is used. In that case, 100 user units -->
<path d="M 0,10 h100"/>
<!-- compute everything like if the path length was 90 user units long -->
<path d="M 0,20 h100" pathLength="90"/>
<!-- compute everything like if the path length was 50 user units long -->
<path d="M 0,30 h100" pathLength="50"/>
<!-- compute everything like if the path length was 30 user units long -->
<path d="M 0,40 h100" pathLength="30"/>
<!-- compute everything like if the path length was 10 user units long -->
<path d="M 0,50 h100" pathLength="10"/>
</svg>
circle
For <circle>
, pathLength
lets authors specify a total length for the circle, in user units.
Value | <number> |
---|---|
Default value | none |
Animatable | Yes |
ellipse
For <ellipse>
, pathLength
lets authors specify a total length for the ellipse, in user units.
Value | <number> |
---|---|
Default value | none |
Animatable | Yes |
line
For <line>
, pathLength
lets authors specify a total length for the line, in user units.
Value | <number> |
---|---|
Default value | none |
Animatable | Yes |
path
For <path>
, pathLength
lets authors specify a total length for the path, in user units.
Value | <number> |
---|---|
Default value | none |
Animatable | Yes |
polygon
For <polygon>
, pathLength
lets authors specify a total length for the shape, in user units.
Value | <number> |
---|---|
Default value | none |
Animatable | Yes |
polyline
For <polyline>
, pathLength
lets authors specify a total length for the shape, in user units.
Value | <number> |
---|---|
Default value | none |
Animatable | Yes |
rect
For <rect>
, pathLength
lets authors specify a total length for the rectangle, in user units.
Value | <number> |
---|---|
Default value | none |
Animatable | Yes |
Specifications
Specification | Status | Comment |
---|---|---|
Scalable Vector Graphics (SVG) 2 The definition of 'pathLength' in that specification. |
Candidate Recommendation | |
Scalable Vector Graphics (SVG) 1.1 (Second Edition) The definition of 'pathLength' in that specification. |
Recommendation | Initial definition |