makeTriangle()
Part of the @remotion/shapes package.
Generates an SVG path for a triangle with the same length on all sides.
Example
triangle.tstsxmakeTriangle } 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'
triangle.tstsxmakeTriangle } 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.
| 0will lead to a rotated triangle being drawn inside the natural dimensions of the triangle. | |
| Math.sqrt(2) - 1will draw a circle. | |
| 1will draw a shape similar to a "squircle" but as a triangle. | |
| Values below 0and above1may 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.