This article mainly introduces the css3 carousel. The editor thinks it is quite good. Now I will share it with you and give you a reference. Let’s follow the editor to take a look
1. Perspective
The perspective attribute includes two attributes: none and the length value with unit.
The default value of the perspective attribute is none, which means that the 3D object looks flat from infinite angles. Another value,
2. transform: translateZ(length)
Assuming that perspective: 300px is set, the smaller the value of translateZ is set, the smaller the size of the sub-element will be. When the value is set When it is close to 300px, it seems that the element is in front of you. When it exceeds 300px, it reaches the back of your field of view and the element is invisible.
The core of the above example:
1. First, all the image containers have position:absolute, superimpose them together, and then set rotateY to 40*i respectively, i= 0, 1, 2 ...9; All pictures will intersect into a flower-like shape
2. Then set translateZ for the container of each picture. All pictures will move outward from the corresponding angle and expand into a large circle, that is The effect of the above picture.
html:
<!DOCTYPE html> <html> <head> <title></title> <meta charset="utf-8"/> <link href="css/reset.css" rel="stylesheet" type="text/css"/> <script type="text/javascript" src="../../jquery-1.8.3.js"></script> <script type="text/javascript"> // alert( 64 / Math.tan(20 / 180 * Math.PI)); var transform = function (element, value, key) { key = key || "Transform"; ["Moz", "O", "Ms", "Webkit", ""].forEach(function (prefix) { element.style[prefix + key] = value; }); return element; } $(function () { var deg = -40 , i = 1; $("#container").click(function () { transform($(this)[0], "rotateY(" + (deg * i++) + "deg)") }); }); </script> </head> <body> <p id="stage"> <ul id="container"> <li> <img src="/static/imghwm/default1.png" data-src="img/1.jpg" class="lazy" / alt="Example tutorial of css3 carousel" > <span>Do one thing at a time, and do well..</span> </li> <li> <img src="/static/imghwm/default1.png" data-src="img/2.jpg" class="lazy" / alt="Example tutorial of css3 carousel" > <span>Do one thing at a time, and do well..</span> </li> <li> <img src="/static/imghwm/default1.png" data-src="img/3.jpg" class="lazy" / alt="Example tutorial of css3 carousel" > <span>Keep on going never give up.</span> </li> <li> <img src="/static/imghwm/default1.png" data-src="img/4.jpg" class="lazy" / alt="Example tutorial of css3 carousel" > <span>Whatever is worth doing is worth doing well.</span> </li> <li> <img src="/static/imghwm/default1.png" data-src="img/5.jpg" class="lazy" / alt="Example tutorial of css3 carousel" > <span>Believe in yourself.</span> </li> <li> <img src="/static/imghwm/default1.png" data-src="img/6.jpg" class="lazy" / alt="Example tutorial of css3 carousel" > <span>Action speak louder than words.</span> </li> <li> <img src="/static/imghwm/default1.png" data-src="img/7.jpg" class="lazy" / alt="Example tutorial of css3 carousel" > <span>Never put off what you can do today until tomorrow.</span> </li> <li> <img src="/static/imghwm/default1.png" data-src="img/8.jpg" class="lazy" / alt="Example tutorial of css3 carousel" > <span>Jack of all trades and master of none.</span> </li> <li> <img src="/static/imghwm/default1.png" data-src="img/9.jpg" class="lazy" / alt="Example tutorial of css3 carousel" > <span>Judge not from appearances.</span> </li> </ul> </p> </body> </html>
CSS:
li { width: 128px; box-shadow: 0 1px 3px rgba(0, 0, 0, .5); position: absolute; bottom: 0; } li img { width: 128px; box-shadow: 0 1px 3px rgba(0, 0, 0, .5); vertical-align: middle; } li span { display: block; width: 128px; text-align: center; color: #333; font-size: 8px; } #stage { width: 900px; min-height: 100px; margin-left: auto; margin-right: auto; padding: 100px 50px; -webkit-perspective: 1200px; position: relative; } #container { background: url("img/xawl.jpg") no-repeat 0 0; margin-top: 200px; width: 128px; box-shadow: 0 1px 3px rgba(0, 0, 0, 5); height: 100px; margin-left: -64px; -webkit-transition: -webkit-transform 1s; transition: transform 1s; -webkit-transform-style: preserve-3d; position: absolute; left: 50%; } li:nth-child(0) { -webkit-transform: rotateY(0deg) translateZ(300px); } li:nth-child(1) { -webkit-transform: rotateY(40deg) translateZ(300px); } li:nth-child(2) { -webkit-transform: rotateY(80deg) translateZ(300px); } li:nth-child(3) { -webkit-transform: rotateY(120deg) translateZ(300px); } li:nth-child(4) { -webkit-transform: rotateY(160deg) translateZ(300px); } li:nth-child(5) { -webkit-transform: rotateY(200deg) translateZ(300px); } li:nth-child(6) { -webkit-transform: rotateY(240deg) translateZ(300px); } li:nth-child(7) { -webkit-transform: rotateY(280deg) translateZ(300px); } li:nth-child(8) { -webkit-transform: rotateY(320deg) translateZ(300px); } li:nth-child(9) { -webkit-transform: rotateY(360deg) translateZ(300px); }
p#stage as the stage, set perspective, set rotateY for each li, and translateZ; then we will p#container set -webkit-transform-style: preserve-3d;
transform-style: flat | preserve-3d
where flat The value is the default value, which means that all child elements are rendered on the 2D plane. preserve-3d means that all child elements are rendered in 3D space. If the transform-style value is set to preserve-3d for an element, it means that the flattening operation is not performed and all its child elements are located in 3D space. Under normal circumstances, this attribute is used for the execution element of 3D animation effects, that is, it is to apply 3D animation effects, so its child elements should all be in 3D space.
One thing to note: In this example, the animation effect is actually due to mouse click, p#Container is changing rotateY inappropriately, all picture elements are in p#container, and have been displayed as a carousel Effect, what you need to do now is to rotate the Trojan, so you only need to change the rotateY 40 angle of p#container each time.
The above is the detailed content of Example tutorial of css3 carousel. For more information, please follow other related articles on the PHP Chinese website!

I got this question the other day. My first thought is: weird question! Specificity is about selectors, and at-rules are not selectors, so... irrelevant?

Yes, you can, and it doesn't really matter in what order. A CSS preprocessor is not required. It works in regular CSS.

You should for sure be setting far-out cache headers on your assets like CSS and JavaScript (and images and fonts and whatever else). That tells the browser

Many developers write about how to maintain a CSS codebase, yet not a lot of them write about how they measure the quality of that codebase. Sure, we have

Have you ever had a form that needed to accept a short, arbitrary bit of text? Like a name or whatever. That's exactly what is for. There are lots of

I'm so excited to be heading to Zürich, Switzerland for Front Conference (Love that name and URL!). I've never been to Switzerland before, so I'm excited

One of my favorite developments in software development has been the advent of serverless. As a developer who has a tendency to get bogged down in the details

In this post, we’ll be using an ecommerce store demo I built and deployed to Netlify to show how we can make dynamic routes for incoming data. It’s a fairly


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SublimeText3 Chinese version
Chinese version, very easy to use