css3+jquery制作3d旋转相册
首先来看一下今天的炫酷效果:

首先分析一下这张图片:
1.每张图片都有倒影
2.这11张图片呈圆形均匀排列
3.可旋转,上下移动(当然这是效果做出来以后,图片是分析不出来的)
那下面就开始吧。
一。准备
新建三个文件夹分别命名为css,js,img分别存放demo.css,jquery.js、demo.js,11张示例图片。新建demo.html将demo.css,jquery.js,demo.js引入。
二。图片倒影制作
<div id="wrap">
<img src="img/1.jpg">
<img src="img/2.jpg">
<img src="img/3.jpg">
<img src="img/4.jpg">
<img src="img/5.jpg">
<img src="img/6.jpg">
<img src="img/7.jpg">
<img src="img/8.jpg">
<img src="img/9.jpg">
<img src="img/10.jpg">
<img src="img/11.jpg">
</div>
首先我们新建一个大的div来包裹这11张图片
*{
padding:;
margin:;
}
body{
background:#000;
overflow:hidden;
}
#wrap{
width:133px;
height:200px;
margin: 200px auto;
position:relative;
transform-style:preserve-3d;
transform:perspective(900px) rotateX(-10deg) rotateY(0deg);
}
#wrap img{
position:absolute;
top:;
left:;
box-shadow: 0 0 10px #FFFFFF;
border-radius:10px;
box-reflect:below 8px linear-gradient(top,rgba(0,0,0,0) 40%,rgba(0,0,0,.7) 100%);
-webkit-box-reflect:below 8px -webkit-linear-gradient(top,rgba(0,0,0,0) 40%,rgba(0,0,0,.7) 100%);
}
(1)*这里就不多说了,是为了消除浏览器默认的间距。
(2)body属性设置背景颜色为黑色,溢出隐藏(这里主要是为了不出现滚动条影响图片整体效果)。
(3)#wrap它的宽高大家一定很好奇为什么会那么小,他的宽高是等同于一张图片的宽高,这里是为了使后期制作旋转时候它能够以图片自身旋转而不跑偏(这里大家不明白的话,可以写完所有代码后设置一个较大的值,试试就知道了哦)。
margin主要是为了让图片水平居中距上下200px。
transform-style:preserve-3d主要是让图片展示出3d效果。
transform:perspective(900px)[这个属性设置镜头到元素平面的距离(大家如果不好理解的话就记住这个是利用近大远小的道理后期可以调节他的大小实验哦)] rotateX(-10deg)[围绕x轴旋转-10°] rotateY(0deg)[围绕y轴旋转0°]。告诉大家一个简单易懂的方法,画一个平面直角坐标系,这是非常直观的。
(4)#wrap img是规定了#wrap里面的img属性,前面的绝对定位是为了让所有图片重叠在一起。
box-shadow设置设置了他的阴影效果
border-radius设置了它的圆角大小
box-reflect设置它的倒影效果
这里就不过多陈述css3属性的用法了,大家可以在w3c查看。
二。使图片均匀分布
$(function(){
$('#wrap img').each(function(i) {
//遍历 $('#wrap img')----改变他们的css样式
$(this).css('transform', 'rotateY('+ i*Deg +'deg) translateZ(350px)').attr('ondragstart','return false');
//旋转以及禁止拖拽复制
});
})
如果设置css属性有疑问的话,可以这样想:translateZ(350px)设置了Z轴的距离,把他看成以(0,0)为圆心,350px为半径的圆,把图片均匀分布在圆上。
这里设置了图片禁止拖拽的属性,与之相呼应的是我们需要的html页面加上这个属性
<html onselectstart='return false'>
不加这个的话页面会报错。当然如果不加的话不影响现在图片的显示,但是会影响下面做图片的旋转。
进行到这步为止,图片上的效果就展示出来了,但是现在是生硬的,没有动画,只是静态的显示。
三。旋转、移动图片
思路:
当鼠标按下并滑动的时候wrap的整体也是跟着滑动的,所以需要记录鼠标开始到结束的位置,根据鼠标x轴和y轴之间的差值,计算#wrap需要旋转和移动的大小
$(function(){
var imgL = $('#wrap img').length;
//获取当前的img 长度
var Deg = 360 / imgL;
// 360/imgL 和角度有关系
var roY = 0,roX = -10,xN,yN;
$(document).mousedown(function(ev){
//绑定事件 鼠标按下时触发的时间
var x_ = ev.clientX;
//获取当前鼠标相对于浏览器页面(或客户区)的 x 方向的位置 保存在变量 x_
var y_ = ev.clientY;
//………………y方向的位置 保存在变量y_
$(this).bind('mousemove',function(ev){
//给当前元素 (这里的当前元素是document )绑定 mousemove(鼠标在当前元素内移动的事件)
var x = ev.clientX;
//获取当前鼠标相对于浏览器页面(或客户区)的 x 方向的位置 保存在变量 x
var y = ev.clientY;
//………………y方向的位置 保存在变量y
xN = x - x_;
//计算鼠标在当前元素内 相对 上次鼠标按下时的 x轴距离 并保存在变量
yN = y - y_;
//计算鼠标在当前元素内 相对 上次鼠标按下时的 y轴距离 并保存在变量
roY += xN*0.2;
//按照比例换算 并在变量基础上增加(围绕Y轴旋转的角度,之所以乘0.2是为了不让自己的鼠标动作太敏感,可以改变数值试一下,理解个中含义)
roX +=yN*0.07;
//按照比例换算 并在变量基础上增加(围绕x轴旋转的角度,意义同上)
$('#wrap').css('transform','perspective(800px) rotateX('+ roX +'deg) rotateY('+ roY +'deg)');
//$('#wrap') 改变css动画transform样式 值为…………角度是变量roY,roX的
x_ = ev.clientX;
//并将鼠标按下的位置设置成当前移动到的位置
y_ = ev.clientY;
//并将鼠标按下的位置设置成当前移动到的位置
});
}).mouseup(function(){
//绑定事件 鼠标松开时触发的时间
$(this).unbind('mousemove');
// 移除 当前元素(这里的当前元素是document )的 mousemove(鼠标在当前元素内移动的事件)
});
});
注释讲的很清楚,这里就不过多赘述了,到现在已经可以看到效果了,按住鼠标左键上下拖动试试吧。
但是到此为止看到的效果又显得很生硬,不流畅,所以为他加个定时器,来让图片真正的转动起来。
$(function(){
var imgL = $('#wrap img').size();
//获取当前的img 长度
console.log($('#wrap img').size());
var Deg = 360 / imgL;
// 360/imgL 和角度有关系
var roY = 0,roX = -10,xN,yN,play=null;
//挨个赋值
$('#wrap img').each(function(i) {
//遍历 $('#wrap img')----改变他们的css样式
$(this).css('transform', 'rotateY('+ i*Deg +'deg) translateZ(350px)')
.attr('ondragstart','return false');
//旋转以及禁止拖拽复制
});
$(document).mousedown(function(ev){
//绑定事件 鼠标按下时触发的时间
clearInterval( play );
//关闭计时器(play)
var x_ = ev.clientX;
//获取当前鼠标相对于浏览器页面(或客户区)的 x 方向的位置 保存在变量 x_
var y_ = ev.clientY;
//………………y方向的位置 保存在变量y_
$(this).bind('mousemove',function(ev){
//给当前元素 (这里的当前元素是document )绑定 mousemove(鼠标在当前元素内移动的事件)
var x = ev.clientX;
//获取当前鼠标相对于浏览器页面(或客户区)的 x 方向的位置 保存在变量 x
var y = ev.clientY;
//………………y方向的位置 保存在变量y
xN = x - x_;
//计算鼠标在当前元素内 相对 上次鼠标按下时的 x轴距离 并保存在变量
yN = y - y_;
//计算鼠标在当前元素内 相对 上次鼠标按下时的 y轴距离 并保存在变量
roY += xN*0.2;
//按照比例换算 并在变量基础上增加
roX +=yN*0.07;
//按照比例换算 并在变量基础上增加
$('#wrap').css('transform','perspective(800px) rotateX('+ roX +'deg) rotateY('+ roY +'deg)');
//$('#wrap') 改变css动画transform样式 值为…………角度是变量roY,roX的
x_ = ev.clientX;
//并将鼠标按下的位置设置成当前移动到的位置
y_ = ev.clientY;
//并将鼠标按下的位置设置成当前移动到的位置
});
}).mouseup(function(){
//绑定事件 鼠标松开时触发的时间
$(this).unbind('mousemove');
// 移除 当前元素(这里的当前元素是document )的 mousemove(鼠标在当前元素内移动的事件)
play = setInterval(function(){
//开始周期性计时器
xN = xN * 0.95;
//按照比例换算
yN = yN * 0.95;
//按照比例换算
if ( Math.abs(xN) <= 0.5 && Math.abs(yN)<= 0.5 )
//判断 (xN的绝对值<=0.5)而且 yN的绝对值也要<= 0.5)的时候就执行下面的语句
{
clearInterval( play );
//关闭计时器(play)
}
roY += xN*0.2;
//按照比例换算 并在变量基础上增加
roX +=yN*0.07;
//按照比例换算 并在变量基础上增加
$('#wrap').css('transform','perspective(800px) rotateX('+ roX +'deg) rotateY('+ roY +'deg)');
//$('#wrap') 改变css动画transform样式 值为…………角度是变量roY,roX的
},30);
//计时器每30毫秒触发一次
});
});
这里为了比较直观定时器放在哪里,重复了上面的代码。
解释一下定时器:
当鼠标松开的时候如果没有定时器的话,旋转就到此为止了,但是这并不是这个效果想要的,当鼠标滑动幅度较大的时候,图片整体也会旋转不同角度,距离越大旋转的角度也就越大,并且到一定数值后让定时器停下来,代码与上面旋转的类似,这里不过多赘述。这里注意的是,一定要定时器停下来。乘不同数值会有不同的效果,如果不是很理解的话,改变数值看效果是你最好的选择,最近状态不好,思路可能没有之前写的好,请见谅/(ㄒoㄒ)/~~
css3+jquery制作3d旋转相册的更多相关文章
- CSS3特效----制作3D旋转导航
大致思路:首先给 three-d-box 设置一个 transition是不可少的 然后每个 a 标签里面有两个 span 一个叫 font 一个叫 back,默认状态下 font 旋转0度,也就是没 ...
- css3制作3d旋转相册
此处只是记录,解析可见原文:http://www.cnblogs.com/skyblue-li/p/6092799.html <!DOCTYPE html> <html xmlns= ...
- CSS3特效----制作3D旋转照片展示区
任务一.制作多背景 提示:上层有一个径向渐变,渐变图像farthest-side ellipse at center, rgba(246,241,232,.85) 39%,rgba(212,204, ...
- 一款基于jQuery和CSS3炫酷3D旋转画廊特效插件
这是一款效果炫酷的jQuery和CSS3 3D旋转画廊特效插件.该3D画廊插件可以通过前后导航按钮来切换图片,效果就像旋转木马一样.它还带有点击放大图片,显示图片标题和用键盘操作等功能. 在线预览 ...
- 使用 CSS3 & jQuery 制作漂亮的书签动画
今天的教程是关于创建使用 CSS 旋转变换和 JavaScript 制作动画书签效果.我们的想法是展现出样书状结构,使单一的色板或列表点击切换.当点击其中一项,我们就会旋转以显示所选择的项目. 在线演 ...
- 纯CSS3超酷3D旋转立方体动画特效
简要教程 这是一款神奇的纯 CSS3 立方体动画特效插件.使用CSS3来制作动画效果已经成为WEB前端开发的一种时尚,从简单的颜色和尺寸动画,到复杂的旋转.翻转动画, CSS3 展现了它无穷的魅力.使 ...
- CSS3制作3D旋转视频展示区
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- CSS3实现3D旋转相册
静态效果图: 代码如下: <!doctype html><html lang="en"><head> <meta charset=&quo ...
- 3D旋转相册(适合新手)
<!DOCTYPE HTML> <html onselectstart="return false"> <head> <meta char ...
随机推荐
- iOS微信第三方登录实现
iOS微信第三方登录实现 一.接入微信第三方登录准备工作.移动应用微信登录是基于OAuth2.0协议标准构建的微信OAuth2.0授权登录系统.在进行微信OAuth2.0授权登录接入之前,在微信开 ...
- [OC] NSURLSession
有的程序员老了,还没听过NSURLSession 有的程序员还嫩,没用过NSURLConnection 有的程序员很单纯,他只知道AFN. NSURLConnection在iOS9被宣布弃用,NSUR ...
- js实现四大经典排序算法
为了方便测试,这里写了一个创建长度为n的随机数组 function createArr(n) { var arr = []; while (n--) { arr.push(~~(Math.random ...
- 绿色版的Linux.NET——“Jws.Mono”(续)
在前一篇文章中,我们简略的介绍了jws.mono的安装使用,以及我们如何自己动手做一个jws.mono出来. 在文章发表之后的几天里,我一直觉得有点不妥之处,直到后来猛然的意识到:我们自己动手做的jw ...
- AutoMapper(五)
返回总目录 Dynamic和ExpandoObject映射 AutoMapper不用任何配置就可以从dynamic(动态)对象映射或映射到dynamic对象. namespace FifthAutoM ...
- 【初码干货】在Window Server 2016中使用Web Deploy方式发布.NET Web应用的重新梳理
在学习和工作的过程中,发现很多同事.朋友,在做.NET Web应用发布的时候,依然在走 生成-复制到服务器 这样的方式,稍微高级一点的,就是先发布到本地,再上传到服务器 这种方式不仅效率低下,而且不易 ...
- ASP.NET MVC Model绑定(六)
ASP.NET MVC Model绑定(六) 前言 前面的篇幅对于IValueProvider的使用做个基础的示例讲解,但是没并没有对 IValueProvider类型的实现做详细的介绍,然而MVC框 ...
- 实现ABP中Person类的权限功能
菜单项的显示功能已经完全OK了.那么我们就开始制作视图功能吧. 首先测试接口是否正常 我们通过代码生成器将权限和application中大部分功能已经实现了.那么我们来测试下这些接口ok不. 浏览/a ...
- 创建Github远程仓库
如何创建github远程仓库 首先, 你有先到github网站注册账号https://github.com 然后创建一个项目, Create a new repository 之后在在Reposito ...
- idea报错:error java compilation failed internal java compiler error
idea下面报如下问题 error java compilation failed internal java compiler error 解决办法:Setting->Compiler-> ...