UNPKG

html-squircle

Version:

Utilities for generating superellipse squircles in the form of SVG strings, to be used in clip-path and background inline styles.

27 lines (26 loc) 864 B
/** Get squircle SVG path. */ export const getPath = ( width: number, height: number, cShift: number, rShift: number, ): string => // Curve runs clockwise // Start at top left pre-curve `M 0 ${height - cShift} ` + // Curve to top left post-curve `C 0 ${height - rShift} ${rShift} ${height} ${cShift} ${height} ` + // Line to top right pre-curve `L ${width - cShift} ${height} ` + // Curve to top right post-curve `C ${width - rShift} ${height} ${width} ${height - rShift} ${width} ${height - cShift} ` + // Line to bottom right pre-curve `L ${width} ${cShift} ` + // Curve to bottom right post-curve `C ${width} ${rShift} ${width - rShift} 0 ${width - cShift} 0 ` + // Line to bottom left pre-curve `L ${cShift} 0 ` + // Curve to bottom left post-curve `C ${rShift} 0 0 ${rShift} 0 ${cShift} ` + // Close the path `Z`