Created
April 8, 2023 20:49
-
-
Save alperbayram/fa78cf0ad78aeaa30f45d1cabef65b7c to your computer and use it in GitHub Desktop.
How to create center curved path in javascript
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import * as shape from "d3-shape"; | |
import { scale } from "react-native-size-scaling"; | |
//** Path Line */ | |
const line = (width, height) => { | |
const path = shape | |
.line() | |
.x((d) => d.x) | |
.y((d) => d.y)([ | |
{ x: width / 2, y: 0 }, | |
{ x: width, y: 0 }, | |
{ x: width, y: height }, | |
{ x: 0, y: height }, | |
{ x: 0, y: 0 }, | |
{ x: width / 2, y: 0 }, | |
]); | |
return path; | |
}; | |
//** Path Curved*/ | |
const lineCurvedDown = (iPosition, height, circle) => { | |
const position = iPosition; | |
const circleWidth = circle + position; | |
const trim = (position + circleWidth) / 2; | |
const curved = shape | |
.line() | |
.x((d) => d.x) | |
.y((d) => d.y) | |
.curve(shape.curveBasis)([ | |
{ x: position - scale(20), y: 0 }, // border center left | |
{ x: position - scale(10), y: scale(2) }, | |
{ x: position - scale(2), y: scale(10) }, | |
{ x: position, y: scale(17) }, | |
{ x: trim - scale(25), y: height / 2 + scale(2) }, | |
{ x: trim - scale(10), y: height / 2 + scale(10) }, | |
{ x: trim, y: height / 2 + scale(10) }, | |
{ x: trim + scale(10), y: height / 2 + scale(10) }, | |
{ x: trim + scale(25), y: height / 2 + scale(2) }, | |
{ x: circleWidth, y: scale(17) }, // border center right | |
{ x: circleWidth + scale(2), y: scale(10) }, | |
{ x: circleWidth + scale(10), y: 0 }, | |
{ x: circleWidth + scale(20), y: 0 }, | |
]); | |
return curved; | |
}; | |
export const getPathDown = (width, iHeight, centerWidth) => { | |
const height = scale(iHeight); | |
const circleWidth = scale(centerWidth) + scale(16); | |
return `${line(width, height)} ${lineCurvedDown( | |
width / 2 - circleWidth / 2, | |
height, | |
circleWidth | |
)}`; | |
}; |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment