Polaroid_Gallery是一款效果非常酷的可交互的jQuery和CSS3图片墙特效插件。该照片墙插件可以使用圆点导航按钮将相应的图片旋转居中显示,当点击居中的图片时,图片会翻转到反面,显示图片的信息。
使用方法
使用该签名插件要引入jQuery文件。
HTML结构
下面是该图片墙特效的基本HTML结构:
{{desc}}
在你的图片文件夹中放置你自己的图片,然后在该文件夹下创建一个data.js
文件。该文件用于描述图片的数据,代码如下:
var data = []; var dataStr = "1.DeathNote
\
\ Japanese Cartoon
\
\
\ 2.FateUBW
\
\ Japanese Cartoon
\
\
\ 3.FateZero
\
\ Japanese Cartoon
\ " var d = dataStr.split("
"); for(var i = 0; i
"); data.push({ img: c[0]+ ".jpg", caption: c[0].split(".")[1], desc: c[1] }); }
CSS样式
该照片墙的基本CSS样式如下:
.wrap { width: 100%; height: 600px; position: absolute; top: 50%; margin-top: -300px; background-color: #333; overflow: hidden; -webkit-perspective: 800px; -moz-perspective: 800px; } .photo { width: 260px; height: 320px; position: absolute; z-index: 1; box-shadow: 0 0 1px rgba(0,0,0,.01); -webkit-transition: all 0.6s; -moz-transition: all 0.6s; left: 50%; top: 50%; margin: -160px 0 0 -130px; } .photo .side { width: 100%; height: 100%; background-color: #eee; position: absolute; top: 0; right: 0; padding: 20px; box-sizing: border-box; } .photo .side-front { /*display: none;*/ } .photo .side-front .image { width: 100%; height: 250px; line-height: 250px; overflow: hidden; } .photo .side-front .image img { width: 100%; } .photo .side-front .caption { text-align: center; font-size: 16px; line-height: 50px; } .photo .side-back { } .photo .side-back .desc { color: #666; font-size: 14px; line-height: 1.5em; } .photo_center { left: 50%; top: 50%; margin: -160px 0 0 -130px; z-index: 999; } .photo-wrap { position: absolute; width: 100%; height: 100%; -webkit-transform-style: preserve-3d; -webkit-transition: all 0.6s; -moz-transform-style: preserve-3d; -moz-transition: all 0.6s; } .photo-wrap .side-front { -webkit-transform: rotateY(0deg); -moz-transform: rotateY(0deg); } .photo-wrap .side-back { -webkit-transform: rotateY(180deg); -moz-transform: rotateY(180deg); } .photo-wrap .side { -webkit-backface-visibility: hidden; -moz-backface-visibility: hidden; } .photo_front .photo-wrap { -webkit-transform: rotateY(0deg); -moz-transform: rotateY(0deg); } .photo_back .photo-wrap { -webkit-transform: rotateY(180deg); -moz-transform: rotateY(180deg); }
下面是圆点导航按钮的CSS样式。
.nav { width: 80%; height: 30px; line-height: 30px; position: absolute; left: 10%; bottom: 20px; z-index: 999; text-align: center; } .nav .i { width: 30px; height: 30px; display: inline-block; cursor: pointer; background-color: #aaa; text-align: center; border-radius: 90%; -webkit-transform: scale(0.5); -webkit-transition: all 0.5s; -moz-transform: scale(0.5); -moz-transition: all 0.5s; } .nav .i_current { -webkit-transform: scale(0.8); -moz-transform: scale(0.8); } .nav .i_back { -webkit-transform: rotateY(-180deg) scale(0.8); -moz-transform: rotateY(-180deg) scale(0.8); background-color: #555; }
初始化插件
在页面加载完成之后使用下面的代码来初始化该图片墙特效插件。
$(document).ready(function(){ addPhotos(); }); function select(selector) { var method = selector.substr(0,1) == '.' ? 'getElementsByClassName' : 'getElementById'; return document[method](selector.substr(1)); } function range() { var range = {left : {x : [], y : []}, right : {x : [], y : []}}; var wrap = { w : select("#wrap").clientWidth, h : select("#wrap").clientHeight } var photo = { w : select(".photo")[0].clientWidth, h : select(".photo")[0].clientHeight } range.wrap = wrap; range.photo = photo; range.left.x = [0, wrap.w/2 - photo.w/2]; range.left.y = [0, wrap.h - photo.w/2]; range.right.x = [wrap.w/2 + photo.w/2, wrap.w]; range.right.y = [0, wrap.h - photo.w/2]; return range; } function sort(n) { var _photo = select('.photo'); var photos = []; for(i=0; i<_photo.length i _photo photo_front scale photos.push var photo_center="select('#photo_'" n photo_center.classname photos_left="photos.splice(0," math.ceil photos_right="photos;" ranges="range();" for random navs="select('.i');" select i_current function max="Math.max(range[0]," range min="Math.min(range[0]," diff="max" number="Math.floor(Math.random()" return data="data;" addphotos template="select('#wrap').innerHTML;" html="[];" nav="[];" _html="template.replace('{{index}}'," .replace html.push nav.push id="nav_'+i+'" class="i" onclick="turn(select(\'#photo_'+i+'\'))"> '); } html.push(''); select('#wrap').innerHTML = html.join(''); sort(random([0, data.length])); } function turn(elem) { var cls = elem.className; var n = elem.id.split("_")[1]; if(! /photo_center/.test(cls)) { return sort(n); } if(/photo_front/.test(cls)) { cls = cls.replace(/photo_front/, 'photo_back'); select('#nav_' + n).className += ' i_back '; } else { cls = cls.replace(/photo_back/, 'photo_front'); select('#nav_' + n).className = select('#nav_' + n).className.replace(/\s*i_back\s*/, ' '); } return elem.className = cls; }
版权声明
版权说明: 仅限用于学习和研究目的;不得将上述内容用于商业和非法用途!否则一切后果自负。我们非常重视版权问题,如有侵权请邮件至(171373236#qq.com)与我们联系处理,敬请谅解!