「CSS3 」3D效果 & 透视_html/css_WEB-ITnose
随着浏览器的不断进步和更新,许多的新特性也崭露头角。
许许多多以前需要用 gif 图片或者是 flash 实现的效果,现在使用 CSS 就可以实现了。消耗部分计算能力,从而大大减少了流量的交换。
今天要介绍的是 CSS3 中的3D效果,以及非常新的透视功能。
3D变换效果
CSS3 的3D效果是使用 transform 属性的 rotateX(Y, Z), translateX(Y, Z), scaleX(Y, Z)方法进行设置的。
一个元素如果进行3D变换,它在3D空间的初始位置是这样的:
// 下图有错,正在更改
上图使用了立方体来更好的说明位置,如果只是单单一个元素的话,它的形状是一个平面区域。
下面来分别介绍一下 transform 属性的3D相关方法。由于这些方法非常易于理解,所以我不赘述。
rotateX (Y, Z)
这个方法使得元素绕着X、Y或Z轴进行轴旋转,需要注意的是,所有的旋转都是已逆时针方向为正方向。
translateX (Y, Z)
translateX 和 translateY 和2D空间的平移是一样的,重点说一下 translateZ。
由于默认开启的是平行投影,所以当你更改一个元素的Z值的时候,视觉上没有任何变化。如何开启透视投影?不急,先慢慢看,后面会介绍到。
scaleX (Y, Z)
在X、Y或Z轴上对图像进行缩放,不多说。
CSS属性: transform-style
!这是一个非常重要的属性,值可以是:
flat(default)
preserve-3d
这里许许多多的文章都没有说清楚,不才在这里尝试解释一下。
设置了 preserve-3d 属性的元素会生成一个3D的空间,将所有的子元素(不是后代元素)都囊括在这个3D空间内。
对于父元素的 transform 属性,会应用到生成的3D空间中,对整个空间进行缩放,平移,旋转。
最后将所有的元素平行投影到屏幕上(不是父元素)。
请自己看上面的一段文字,如果能够理解,那么尝试分析 flat:
子元素并没有在父元素的3D空间内,它们独立的,各自做自己的3D变换,然后按照先后次序(即translateZ无效)投影到父元素(不是屏幕)上。
由于所有的子元素都投影到父元素上,那么父元素的 transform 属性在视觉效果上是对父元素这个平面区域进行的。
// DEMO:case1
通过这个DEMO我们可以看到 flat 和 preserve-3d 的区别,更加理解上面的文字。
transform: translateX(10px) rotateZ(90deg);
你以为是先平移10px再相对于以Z轴为旋转轴旋转90度吗?
其实并不是,tranform 的属性是从右边的方法依次应用到左边的方法的。
/*
* 中场休息: 先好好消化一下上面的内容吧!
*/
透视投影
透视投影模拟人眼的图像观察方式,这种方式能够对物体的远近,方位进行判断,从视觉上来说更加接近人类所熟悉的效果。
perspective: none | <length>;
transform: perspective(<length>) method(p) method(p) ...;
第一种方法: 将 perspective 属性更改为 >0 的数值,便可以将这个空间设置为透视投影,即所有子元素(仅仅是, 不包括自身)的投影到屏幕的方式变为透视投影。
第二种方法: 将perspective(
注意,这个透视投影的像平面和Z=0平面是重合的,原理图如下:
其中,焦点到z=0平面的距离是 perspective 的值。
从上图我们可以看出,当 perspective 的值越小的时候,Z值对于视觉效果的影响更加强烈,越大的时候,Z值对于视觉的影响更加细微。一般来说,在500px到1000px的时候视觉上更加合理。
当元素的Z值使得元素在焦点之后,元素则不会被捕捉到。
// DEMO: case2(perspective: 500px;)
可以自己思考一下,左图中为什么上下两个面会显示。(画出它的投影)
我们还可以调整焦点的位置(默认在中心):
perspective-origin: x y;
其中x的值可以是: 长度、百分比,left(相当于0)、center(相当于50%, 默认)、right(相当于100%);
其中y的值可以是: 长度、百分比,top(相当于0)、center(相当于50%, 默认)、bottom(相当于100%)。
// DEMO: case3(perspective-origin: 0 0;)
DEMO
[重要提示]请不要忘记推荐和收藏 (??□′)?? ┴─┴
git clone https://github.com/JasonKid/fezone.git
搜索 3D效果 & 透视

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











이 기사는 HTML & lt; Progress & Gt에 대해 설명합니다. 요소, 그 목적, 스타일 및 & lt; meter & gt의 차이; 요소. 주요 초점은 & lt; progress & gt; 작업 완료 및 & lt; meter & gt; Stati의 경우

이 기사는 HTML & LT; Datalist & GT에 대해 논의합니다. 자동 완성 제안을 제공하고, 사용자 경험을 향상시키고, 오류를 줄임으로써 양식을 향상시키는 요소. 문자 수 : 159

기사는 HTML5 크로스 브라우저 호환성을 보장하기위한 모범 사례에 대해 논의하고 기능 감지, 점진적 향상 및 테스트 방법에 중점을 둡니다.

이 기사는 HTML & lt; meter & gt에 대해 설명합니다. 범위 내에 스칼라 또는 분수 값을 표시하는 데 사용되는 요소 및 웹 개발의 일반적인 응용 프로그램. & lt; meter & gt; & lt; Progress & Gt; 그리고 Ex

이 기사에서는 브라우저에서 직접 사용자 입력을 검증하기 위해 필요한, Pattern, Min, Max 및 Length 한계와 같은 HTML5 양식 검증 속성을 사용하는 것에 대해 설명합니다.

이 기사는 모바일 장치의 반응 형 웹 디자인에 필수적인 Viewport Meta Tag에 대해 설명합니다. 적절한 사용이 최적의 컨텐츠 스케일링 및 사용자 상호 작용을 보장하는 방법을 설명하는 반면, 오용은 설계 및 접근성 문제로 이어질 수 있습니다.

이 기사는 & lt; iframe & gt; 외부 컨텐츠를 웹 페이지, 공통 용도, 보안 위험 및 객체 태그 및 API와 같은 대안을 포함시키는 태그의 목적.

GiteEpages 정적 웹 사이트 배포 실패 : 404 오류 문제 해결 및 해결시 Gitee ...
