makeTriangle()
Part of the @remotion/shapes
package.
Generates an SVG path for a triangle with the same length on all sides.
Example
triangle.tstsx
import {makeTriangle } from "@remotion/shapes";const {path ,width ,height ,transformOrigin } =makeTriangle ({length : 100,direction : "right",});console .log (path ); // M 0 0 L 0 100 L 86.60254037844386 50 zconsole .log (width ); // 86.60254037844386console .log (height ); // 100console .log (transformOrigin ); // '28.867513459481287 50'
Arguments
length
number
The length of one triangle side.
direction
"left" | "right" | "up" | "down"
The direction of the triangle.
edgeRoundness
null | number
Allows to modify the shape by rounding the edges using bezier curves. Default null
.
0 will lead to a rotated triangle being drawn inside the natural dimensions of the triangle. | |
Math.sqrt(2) - 1 will draw a circle. | |
1 will draw a shape similar to a "squircle" but as a triangle. | |
Values below 0 and above 1 may result in other interesting shapes. Pictured: 2 . |
Cannot be used together with cornerRadius
.
Return type
path
A string that is suitable as an argument for d
in a <path>
element.
width
The width of the triangle. Suitable for defining the viewBox
of an <svg>
tag.
height
The height of the triangle. Suitable for defining the viewBox
of an <svg>
tag.
instructions
An array with SVG instructions. The type for a instruction can be seen by importing Instruction
from @remotion/shapes
.
transformOrigin
A string representing the point of origin if a shape should be rotated around itself.
If you want to rotate the shape around its center, use the transform-origin
CSS property and pass this value, and also add transform-box: fill-box
. This is the default for <Triangle />
.
Credits
Source code partially taken from this StackBlitz.