Transformation-in-SVG
Transformation in SVG
- Translation: Move the object from one center point to another
Example:
<svg width="500" height="400">
<rect x="50" y="50" width="100" height="100" fill="blue" transform="translate(100, 50)" />
</svg>
Output:
data:image/s3,"s3://crabby-images/811d1/811d16c4408a4b846d32562b4c60213743bdbf56" alt=""
- Rotation: Rotate the object by a certain angle
Example:
<svg width="500" height="400">
<rect x="150" y="150" width="100" height="100" fill="lightgreen" transform="rotate(45, 200, 200)" />
</svg>
Output:
data:image/s3,"s3://crabby-images/bda19/bda19e2207979b1133eb496fe9379a3d1f905543" alt=""
- Scaling: Resize object
Example:
<svg width="500" height="400">
<rect x="50" y="50" width="100" height="100" fill="red" transform="scale(1.5, 0.5)" />
</svg>
Output:
data:image/s3,"s3://crabby-images/0174f/0174fbbfb8a3d53b6076c7df9ef3a8fa19d21de6" alt=""
- Skewing: Slants object along x and y axis
Example:
<svg width="500" height="400">
<rect x="50" y="50" width="100" height="100" fill="purple" transform="skewX(30)" />
</svg>
Output:
data:image/s3,"s3://crabby-images/4b118/4b118a92925796bd1edc31c499bb937d057e8baa" alt=""
- Animating Transformations: SVG supports animating transformations
Example:
<svg width="500" height="400">
<rect x="150" y="150" width="100" height="100" fill="lightgreen">
<animateTransform attributeName="transform" type="rotate" from="0 200 200" to="360 200 200" dur="5s" repeatCount="indefinite" />
</rect>
</svg>