<!DOCTYPE html>
<html onselectstart="return false">
<!-- onselectstart="return false" 禁止页面复制-->
<head lang="en">
/*onselectstart="return false"*/
<meta charset="UTF-8">
<title>document</title>
<!--一共用的就是40到50个单词记住即可-->
<!-- div.pic 是创建一个盒子-->
<style>
*{
margin: ;
padding: ;
}
body{
background-color: #;
}
div.pic{
width: 120px;
height: 180px; /* 133:200 约等于 4:6 */
/*border: 1px dotted #f00;*/
margin: 200px auto ;/*上---左右---下 */
position: relative;
transform-style: preserve-3d;
transform: perspective(800px) rotateX(-10deg) rotateY(0deg);
}
div.pic img{
position: absolute;
width: %;
height: %;
border-radius: 5px; /*加上圆角*/
box-shadow: 0px 0px 10px #fff;/*box-shadow 属性向框添加一个或多个阴影*/
-webkit-box-reflect: below 10px -webkit-linear-gradient(top,rgba(,,,) %,rgba(,,,0.5) %); /*box-reflect倒影属性练习*/
/*-webkit-linear-gradient(top,rgba(0,0,0,0),rgba(0,0,0,1) , 这是一个渐变*/
}
div.pic p{
width: 1200px;
height: 1200px;
background: -webkit-radial-gradient(center center,600px 600px,rgba(,,,0.3),rgba(,,,));
left: %;top: %;
margin-top: -50px;
margin-left: -600px;
transform: rotateX(90deg);
border-radius: 600px;
}
</style>
</head>
<body>
<!--div 长方型的区域-->
<div class="pic">
<img src="img/1.jpg" alt="1.jpg"/>
<img src="img/2.jpg" alt="2.jpg"/>
<img src="img/3.jpg" alt="3.jpg"/>
<img src="img/4.jpg" alt="4.jpg"/>
<img src="img/5.jpg" alt="5.jpg"/>
<img src="img/6.jpg" alt="6.jpg"/>
<img src="img/7.jpg" alt="7.jpg"/>
<img src="img/8.jpg" alt="8.jpg"/>
<img src="img/9.jpg" alt="9.jpg"/>
<img src="img/10.jpg" alt="10.jpg"/>
<img src="img/11.jpg" alt="11.jpg"/>
<p></p>
</div>
<script src="js/jquery-2.1.1.min.js"></script>
<script>
$(function(){
//设定初始变化值
var translate=;
//文档添加鼠标滚轮事件,demo没写兼容,不支持火狐
document.addEventListener("mousewheel",function(e){ //缩放
var distance= //每次滚轮缩放变化值
if(e.wheelDelta>){ //方向
clearInterval(play)
translate+=distance //perspective值变化
$("div.pic").css({
transform:'perspective('+translate+'px) rotateX('+toX+'deg) rotateY('+toY+'deg)'
}); //css3变化 }else if(e.wheelDelta<){
clearInterval(play)
translate-=distance
$("div.pic").css({
transform:'perspective('+translate+'px) rotateX('+toX+'deg) rotateY('+toY+'deg)'
});
}
})
var imgL = $("div.pic img").size(); //img数量
// alert(imgL);
var deg = / imgL; //角度
var toY = , toX = -;
var xN = ,yN = ;
var play = null; $("div.pic img").each(function(i){
$(this).css({
'transform':'rotateY('+i*deg+'deg) translateZ(350px)' //css设置,分别设定变化角度,同样的z轴变化,形成一个圆
});
$(this).attr("ondragstart","return false");
/*浏览器禁止拖拽功能*/
});
$(document).mousedown(function(ev){
/*console.log("shu biao an xia le !");*/
var x_ = ev.clientX;
var y_ = ev.clientY;
clearInterval(play);
$(this).bind("mousemove",(function(ev){
/* console.log('yi dong !');*/
var x = ev.clientX;
var y = ev.clientY;
xN = x - x_;
yN = y - y_;
toY += xN*0.2;
toX -= yN*0.1; //$("body").append('<div style="width:5px;height:5px;background:#f00;position:absolute;top:"+y+"px;left:"+x+"px;"></div>')/*打点计数器*/
$("div.pic").css({
transform:'perspective('+translate+'px) rotateX('+toX+'deg) rotateY('+toY+'deg)'
});
x_ = ev.clientX;
y_ = ev.clientY;
}));
}).mouseup(function(){
$(this).unbind("mousemove");
var play = setInterval(function(){
xN *= 0.95;
yN *= 0.95;
if ( Math.abs(xN) < && Math.abs(yN) < )/*Math绝对值*/clearInterval(play);
toY += xN*0.2;
toX -= yN*0.1;
$("div.pic").css({
transform:'perspective('+translate+'px) rotateX('+toX+'deg) rotateY('+toY+'deg)'
});
},);
//return play
});
});
</script>
</body>
</html>

借用的网络分享的一个demo,在上面添加了鼠标滚轮放大缩小(没有写兼容,火狐不支持)效果。
有几个知识点记录下:

1.鼠标滚轮事件

在jquery中没有滚轮事件,所以需要我们自己去码

其中ie,chorme,safri中事件为mouseWheel,火狐为DOMMouseScroll,判断滚动方向也不一样,前4者为wheelDelta,后者为detail.detail与wheelDelta只各取两个 值,detail只取±3,wheelDelta只取±120。

2.perspective

当为元素定义 perspective 属性时,其子元素会获得透视效果,而不是元素本身。

perspective属性设置镜头到元素平面的距离。所有元素都是放置在z=0的平面上。比如perspective(300px)表示,镜头距离元素表面的位置是300像素。值越小,用户与3D空间Z平面距离越近,视觉效果更令人印象深刻;反之,值越大,用户与3D空间Z平面距离越远,视觉效果就很小。

3.rotateY

rotateX()、rotateY()和rotateZ()分别为沿X,Y,Z方向旋转。

css3+js打造炫酷图片展示的更多相关文章

  1. GJM :JS + CSS3 打造炫酷3D相册 [转载]

    感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...

  2. 9种CSS3炫酷图片展开预览展示动画特效

    详细内容请点击 在线预览立即下载 这是一组共9款CSS3炫酷图片预览展示动画特效插件.css的新特性可以让我们制作出各种炫酷的动画效果.该图片预览展示动画特效就是一个很好的例子,该效果开始时图片堆叠在 ...

  3. JS打造的跟随鼠标移动的酷炫拓扑图案

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. JParticles 2.0 发布,打造炫酷的粒子特效

    JParticles 2.0 发布,打造炫酷的粒子特效.不好意思哈,在这么繁花似锦的世界里,标题不得不取得吸引眼球一点哈,不然...还是不啰嗦了,我们进入正题吧 简单介绍一下 JParticles 2 ...

  5. 你要是还学不会,请提刀来见 Typora+PicGo+Gitee + node.js 打造个人高效稳定优雅图床

    你要是还学不会,请提刀来见 Typora+PicGo+Gitee + node.js 打造个人高效稳定优雅图床 经过前面两弹的介绍,相信大家对图床都不陌生了吧, 但是小魔童觉得这样做法还是不方便,使用 ...

  6. Android ViewPager 打造炫酷欢迎页

    Android ViewPager 打造炫酷欢迎页 ViewPager是Android扩展v4包中的类,这个类可以让用户切换当前的View.对于这个类的应用场景,稍加修改就可以应用到多个环境下.比如: ...

  7. 7款纯CSS3实现的炫酷动画应用|慕课网只学有用的!

    关于我们 | 时尚廊 ♦ 时尚廊,中国大陆地区首家以"Lounge"为概念的艺文空间 ♦  7款纯CSS3实现的炫酷动画应用|慕课网只学有用的! 7款纯CSS3实现的炫酷动画应用

  8. Android 教你打造炫酷的ViewPagerIndicator 不仅仅是高仿MIUI

    1.概述 哈,今天给大家带来一个ViewPagerIndicator的制作,相信大家在做tabIndicator的时候,大多数人都用过 TabPageIndicator,并且很多知名APP都使用过这个 ...

  9. java+js实现完整的图片展示本地目录demo

    java+js实现完整的图片展示本地目录demo 最近的项目满足需要,实现通过一个前端button点击事件,流行音乐浏览下的全部图片: 思路: - 获取到所需展示图片的本地目录内全部图片的文件绝对路径 ...

随机推荐

  1. php支付宝接口用法

    现在流行的网站支持平台,支付宝当仁不让的老大了,现在我们就来告诉你如何使用支付宝api来做第三方支付,把支付宝放到自己网站来, alipay_config.php配置程序如下: <?php */ ...

  2. MVC中Action 过滤

    总结Action过滤器实用功能,常用的分为以下两个方面: 1.Action过滤器主要功能就是针对客服端请求过来的对象行为进行过滤,类似于门卫或者保安的职能,通过Action过滤能够避免一些非必要的深层 ...

  3. DES加密算法实现

    好久没写博客了,正好趁着实现网络工程与安全的DES算法的功夫,把代码发上来. DES的介绍可见:DES加密 原理不赘述了..实在太多,其实就是一个形式化算法,按部就班的实现就可以,只不过有些繁琐,我写 ...

  4. Linux LVM全面实践

    1.磁盘分区 [root@ol6-121-rac1 ~]# fdisk /dev/sdb Device contains neither a valid DOS partition table, no ...

  5. Auto Layout

    Auto Layout XCode5+ Auto Layout Concepts 核心的概念是约束. Constraint Basics Constant value Relation Priorit ...

  6. AgileEAS.NET SOA 中间件平台5.2版本下载、配置学习(二):配置WinClient分布式运行环境

    一.前言 AgileEAS.NET SOA 中间件平台是一款基于基于敏捷并行开发思想和Microsoft .Net构件(组件)开发技术而构建的一个快速开发应用平台.用于帮助中小型软件企业建立一条适合市 ...

  7. 信号量进程同步,王明学learn

    信号量进程同步 一组并发进程进行互相合作.互相等待,使得各进程按一定的顺序执行的过程称为进程间的同步. 信号量在进程同步时初始值为:0 信号量在进程互斥时初始值为:大于0的 本章节主要使用信号量,使的 ...

  8. Codeforces Beta Round #77 (Div. 1 Only) C. Volleyball (最短路)

    题目链接:http://codeforces.com/contest/95/problem/C 思路:首先dijkstra预处理出每个顶点到其他顶点的最短距离,然后如果该出租车到某个顶点的距离小于等于 ...

  9. 智能车学习(十)——MMA8451加速度计的使用

    一.驱动说明: 就是使用I2C的通信方式驱动这款加速度计就行了,代码的话选择使用51单片机的代码进行移植. 二.代码分享: 1.头文件: #ifndef MMA8451_H #define MMA84 ...

  10. 转载 linux内核 asmlinkage宏

    转载http://blog.chinaunix.net/uid-7390305-id-2057287.html 看一下/usr/include/asm/linkage.h里面的定义:#define a ...