html5+css3实现3D图片(附源码)
(function( $ ) {
$.fn.jigsaw = function(options)
{
var settings = $.extend( {}, $.fn.jigsaw.defaults, options );
$.fn.jigsaw.defaults = settings;
//image value in defaults
$.fn.jigsaw.defaults.image = this.children("img").attr("src");
this.append(‘<div class="jigsaw_panel_"></div>‘);
$.fn.jigsaw.defaults.width = this.children("img").attr("width");
$.fn.jigsaw.defaults.height = this.children("img").attr("height");
obj = this.children(".jigsaw_panel_");
obj.css("width",parseInt($.fn.jigsaw.defaults.width) + parseInt($.fn.jigsaw.defaults.x*$.fn.jigsaw.defaults.margin*2) +parseInt($.fn.jigsaw.defaults.error) +"px").css("height",parseInt($.fn.jigsaw.defaults.height) + parseInt($.fn.jigsaw.defaults.y*$.fn.jigsaw.defaults.margin*2) +"px");
w = Math.floor($.fn.jigsaw.defaults.width/$.fn.jigsaw.defaults.x);
h = Math.floor($.fn.jigsaw.defaults.height/$.fn.jigsaw.defaults.y);
for(i=0;i<$.fn.jigsaw.defaults.x;i++)
{
for(j=0;j<$.fn.jigsaw.defaults.y;j++)
{
pos = "block" +i +j;
obj.append("<div pos=‘" +pos +"‘></div>");
obj.children("div[pos=‘" +pos +"‘]").css("background-position","-" +(j*w) +"px -" +(i*h) +"px").css("width",w +"px").css("height",h+"px").css("background-image","url("+$.fn.jigsaw.defaults.image+")").css("display","inline-block").css("margin",$.fn.jigsaw.defaults.margin);
//background-position: -10px -10px;
}
obj.append("<div class=‘clearfix‘></div>");
}
this.children("img").hide();
obj.fadeIn();
animate(this);
}
$.fn.jigsaw.defaults = {
width: 100,
height: 200,
x : 4,
y : 4,
margin : 3,
error : 16,
freq :2000,
image: ""
}
function animate(obj)
{
w = Math.floor($.fn.jigsaw.defaults.width/$.fn.jigsaw.defaults.x);
h = Math.floor($.fn.jigsaw.defaults.height/$.fn.jigsaw.defaults.y);
var len = obj.children(".jigsaw_panel_").children("div").length;
for(i=0;i<len;i++)
{
var randI = Math.floor((Math.random()*3)+0);
var randJ = Math.floor((Math.random()*3)+0);
var bp = "-" +(randI*w) +"px -" +(randJ*h) +"px";
obj.children(".jigsaw_panel_").children("div:eq(" +i +")").css("background-position",bp);
}
if(Math.floor((Math.random()*5)+0) == 2)
{
t = setTimeout(function(){rearrange(obj)},$.fn.jigsaw.defaults.freq);
}
else
t = setTimeout(function(){animate(obj);},$.fn.jigsaw.defaults.freq);
}
function rearrange(obj)
{
w = Math.floor($.fn.jigsaw.defaults.width/$.fn.jigsaw.defaults.x);
h = Math.floor($.fn.jigsaw.defaults.height/$.fn.jigsaw.defaults.y);
for(i=0;i<$.fn.jigsaw.defaults.x;i++)
{
for(j=0;j<$.fn.jigsaw.defaults.y;j++)
{
pos = "block" +i +j;
obj.children(".jigsaw_panel_").children("div[pos=‘" +pos +"‘]").css("background-position","-" +(j*w) +"px -" +(i*h) +"px").css("width",w +"px").css("height",h+"px").css("background-image","url("+$.fn.jigsaw.defaults.image+")");
}
}
t = setTimeout(function(){animate(obj)},$.fn.jigsaw.defaults.freq);
}
}( jQuery ));
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。