두 개의 div가 있다고 가정해 보겠습니다. 하나는 내부 div이고 다른 하나는 외부 div입니다.
내부 div는 확대/축소 및 이동(CSS 변환, 번역 및 크기 조정을 사용하여 수행됨)을 담당합니다.
이제 드래그 앤 드롭으로 내부 div에 새 div를 추가할 수 있습니다. 드롭 이벤트는 externaldiv
에 의해 허용됩니다.이제 드롭 이벤트 중에 clientX, clientY 위치를 얻습니다. 이제 이를 사용하여 내부 div를 기준으로 올바른 드롭 위치를 찾습니다.
가능한 해결책은 다음과 같습니다(단, 확대/축소 시 최종 위치가 오프셋되었습니다)
handleDrop = (e) => { const canvasContainerRect = outerDivBoundingRect() // const canvasRect = innerDivBoundingRect() let finalPosition = { x: (e.clientX - canvasContainerRect.left - translateX) / zoom, y: (e.clientY - canvasContainerRect.top - translateY) / zoom, } console.log("final: ", finalPosition) }
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3