"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 이 문제를 해결할 수 있나요?

이 문제를 해결할 수 있나요?

2024-09-26에 게시됨
검색:286

Can you solve this problem?

두 개의 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)
}
릴리스 선언문 이 글은 https://dev.to/paul_freeman/can-you-solve-this-problem-e22?1에서 복제됩니다.1 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3