웹 프론트엔드 CSS 튜토리얼 CSS 3D 변환에서 '관점' 순서가 중요한 이유는 무엇입니까?

CSS 3D 변환에서 '관점' 순서가 중요한 이유는 무엇입니까?

Nov 23, 2024 am 10:24 AM

Why Does the Order of `perspective` in CSS 3D Transformations Matter?

원근법을 사용한 CSS 3D 변환 마지막: 이유 이해

CSS 3D 변환을 사용하면 웹 요소에 복잡한 애니메이션과 원근감 효과를 구현할 수 있습니다. 그러나 관점 속성이 변환 목록의 끝에 배치되었을 때 흥미로운 관찰이 나타났습니다.

문제:

제공된 스니펫에서 두 상자의 마우스 커서가 서로 다릅니다. 행동. 원근 속성은 첫 번째 상자의 변환 목록 끝에 배치되고 두 번째 상자의 변환 앞에 배치됩니다.

box:nth-child(1):hover {
  transform: perspective(1000px) translate3d(0, 0, -100px);
}

box:nth-child(2):hover {
  transform: translate3d(0, 0, 100px) perspective(1000px);
}
로그인 후 복사

이로 인해 두 변환이 겉으로는 동일해 보여도 시각적 결과가 달라집니다.

답변:

이 동작을 이해하는 열쇠는 변환 행렬의 순서에 있습니다. 계산되었습니다. CSS Transform 사양에 따라 행렬은 다음과 같이 계산됩니다.

  1. 항등 행렬로 시작합니다.
  2. transform-origin의 계산된 X와 Y로 변환합니다.
  3. 변환 속성의 각 변환 함수를 왼쪽에서 오른쪽으로 곱합니다.
  4. 부정 계산된 X와 변형 원점의 Y 값.

설명:

3단계에서는 왼쪽에서 오른쪽으로. 즉, 원근법이 목록 끝에 배치되면 원근법이 적용되기 전에 번역이 수행됩니다.

결과적으로 원근감 효과가 없는 상태에서 번역이 발생하므로 결과는 다음과 같습니다. 움직임은 평면적이고 깊이가 없는 것처럼 보입니다.

의미:

    항상 관점을 배치하세요. 속성을 변환 목록 시작 부분에 추가하여 다른 변환보다 먼저 적용되도록 하세요.
  • 변환하려는 요소 내에서는 원근감 속성을 적용하지 마세요. 효과가 없으므로 적용하지 마세요.
이러한 지침을 따르면 원근감 속성을 올바르게 적용하여 원하는 3D 변형 효과를 얻을 수 있습니다.

위 내용은 CSS 3D 변환에서 '관점' 순서가 중요한 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

vue 3 vue 3 Apr 02, 2025 pm 06:32 PM

그것은#039; VUE 팀에게 그것을 끝내는 것을 축하합니다. 나는 그것이 막대한 노력과 오랜 시간이라는 것을 알고 있습니다. 모든 새로운 문서도 있습니다.

브라우저에서 유효한 CSS 속성 값을 얻을 수 있습니까? 브라우저에서 유효한 CSS 속성 값을 얻을 수 있습니까? Apr 02, 2025 pm 06:17 PM

나는 누군가이 매우 합법적 인 질문으로 글을 썼습니다. Lea는 브라우저에서 유효한 CSS 속성 자체를 얻는 방법에 대해 블로그를 작성했습니다. 이는 이와 같습니다.

CI/CD에 약간 CI/CD에 약간 Apr 02, 2025 pm 06:21 PM

"웹 사이트"는 "모바일 앱"보다 더 잘 맞지만 Max Lynch 의이 프레임이 마음에 듭니다.

끈적 끈적한 포지셔닝 및 대시 Sass가있는 쌓인 카드 끈적 끈적한 포지셔닝 및 대시 Sass가있는 쌓인 카드 Apr 03, 2025 am 10:30 AM

다른 날, 나는 Corey Ginnivan의 웹 사이트에서 스크롤 할 때 카드 모음이 서로 쌓이는 것을 발견했습니다.

WordPress 블록 편집기에서 Markdown 및 현지화 사용 WordPress 블록 편집기에서 Markdown 및 현지화 사용 Apr 02, 2025 am 04:27 AM

WordPress 편집기에서 사용자에게 직접 문서를 표시 해야하는 경우 가장 좋은 방법은 무엇입니까?

반응 형 디자인을위한 브라우저 비교 반응 형 디자인을위한 브라우저 비교 Apr 02, 2025 pm 06:25 PM

목표가 귀하의 사이트를 동시에 다른 크기로 표시하는 이러한 데스크탑 앱이 많이 있습니다. 예를 들어, 글을 쓸 수 있습니다

끈적 끈적한 헤더 및 바닥 글에는 CSS 그리드 사용 방법 끈적 끈적한 헤더 및 바닥 글에는 CSS 그리드 사용 방법 Apr 02, 2025 pm 06:29 PM

CSS 그리드는 레이아웃이 그 어느 때보 다 쉽게 레이아웃을 만들 수 있도록 설계된 속성 모음입니다. 어쨌든, 약간의 학습 곡선이 있지만 그리드는

Google 글꼴 변수 글꼴 Google 글꼴 변수 글꼴 Apr 09, 2025 am 10:42 AM

Google Fonts가 새로운 디자인 (트윗)을 출시 한 것을 볼 수 있습니다. 마지막 큰 재 설계와 비교할 때 이것은 훨씬 더 반복적 인 느낌이 듭니다. 차이를 간신히 말할 수 있습니다

See all articles