-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjquery.spify.js
88 lines (68 loc) · 2.35 KB
/
jquery.spify.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
(function( $ ){
$.fn.spify = function( options ) {
var settings = $.extend( {
'count' : 1,
'url' : '',
'duration' : 300,
'size' : [100, 100],
'durations' : {},
'vector' : 'vertical'
}, options);
return this.each(function() {
var size = settings.size;
var url = settings.url;
var count = settings.count;
var duration = settings.duration;
var durations = settings.durations;
var vector = settings.vector;
var dataSize = $(this).attr('data-size');
var dataCount = $(this).attr('data-count');
var dataUrl = $(this).attr('data-url');
var dataDuration = $(this).attr('data-duration');
var dataDurations = $(this).attr('data-durations');
var dataVector = $(this).attr('data-vector');
var _tmp, _i, _d;
if (dataSize) {
size = dataSize.split(',');
size[0] = parseInt(size[0]);
size[1] = parseInt(size[1]);
}
if (dataCount) { count = parseInt(dataCount); }
if (dataUrl) { url = dataUrl; }
if (dataDuration) { duration = parseInt(dataDuration); }
if (dataVector) { vector = dataVector }
if (dataDurations) {
durations = {};
_tmp = dataDurations.split(',');
for (i in _tmp) {
_d = _tmp[i].split(':');
durations[parseInt(_d[0])] = parseInt(_d[1]);
}
}
var el = $(this);
var currentIndex = 0;
var bgPos;
function circle () {
currentIndex += 1;
if (currentIndex >= count) { currentIndex = 0; }
if (vector == 'vertical') {
bgPos = size[1] * currentIndex;
bgPos = '0px ' + -bgPos + 'px';
} else {
bgPos = -size[0] * currentIndex + 'px 0px';
}
el.css('background-position', bgPos );
if ((_d = durations[currentIndex + 1]) === undefined) {
_d = duration;
}
setTimeout(circle, _d);
}
$(this).css({
width: size[0],
height: size[1],
background: 'url(' + url + ')'
});
setTimeout(circle, duration);
});
};
})( jQuery );