1
|
1 |
// @name The Fade Anything Technique
|
|
2 |
// @namespace http://www.axentric.com/aside/fat/
|
|
3 |
// @version 1.0-RC1
|
|
4 |
// @author Adam Michela
|
|
5 |
|
|
6 |
var Fat = {
|
|
7 |
make_hex : function (r,g,b)
|
|
8 |
{
|
|
9 |
r = r.toString(16); if (r.length == 1) r = '0' + r;
|
|
10 |
g = g.toString(16); if (g.length == 1) g = '0' + g;
|
|
11 |
b = b.toString(16); if (b.length == 1) b = '0' + b;
|
|
12 |
return "#" + r + g + b;
|
|
13 |
},
|
|
14 |
fade_all : function ()
|
|
15 |
{
|
|
16 |
var a = document.getElementsByTagName("*");
|
|
17 |
for (var i = 0; i < a.length; i++)
|
|
18 |
{
|
|
19 |
var o = a[i];
|
|
20 |
var r = /fade-?(\w{3,6})?/.exec(o.className);
|
|
21 |
if (r)
|
|
22 |
{
|
|
23 |
if (!r[1]) r[1] = "";
|
|
24 |
if (!o.id) o.id = 'autofat_'+Math.floor(Math.random() * 100000);
|
|
25 |
if (o.id) Fat.fade_element(o.id,null,null,"#"+r[1]);
|
|
26 |
}
|
|
27 |
}
|
|
28 |
},
|
|
29 |
fade_element : function (id, fps, duration, from, to)
|
|
30 |
{
|
|
31 |
if (!fps) fps = 30;
|
|
32 |
if (!duration) duration = 3000;
|
|
33 |
if (!from || from=="#") from = "#FFFF33";
|
|
34 |
if (!to) to = this.get_bgcolor(id);
|
|
35 |
|
|
36 |
var frames = Math.round(fps * (duration / 1000));
|
|
37 |
var interval = duration / frames;
|
|
38 |
var delay = interval;
|
|
39 |
var frame = 0;
|
|
40 |
|
|
41 |
if (from.length < 7) from += from.substr(1,3);
|
|
42 |
if (to.length < 7) to += to.substr(1,3);
|
|
43 |
|
|
44 |
var rf = parseInt(from.substr(1,2),16);
|
|
45 |
var gf = parseInt(from.substr(3,2),16);
|
|
46 |
var bf = parseInt(from.substr(5,2),16);
|
|
47 |
var rt = parseInt(to.substr(1,2),16);
|
|
48 |
var gt = parseInt(to.substr(3,2),16);
|
|
49 |
var bt = parseInt(to.substr(5,2),16);
|
|
50 |
|
|
51 |
var r,g,b,h;
|
|
52 |
while (frame < frames)
|
|
53 |
{
|
|
54 |
r = Math.floor(rf * ((frames-frame)/frames) + rt * (frame/frames));
|
|
55 |
g = Math.floor(gf * ((frames-frame)/frames) + gt * (frame/frames));
|
|
56 |
b = Math.floor(bf * ((frames-frame)/frames) + bt * (frame/frames));
|
|
57 |
h = this.make_hex(r,g,b);
|
|
58 |
|
|
59 |
setTimeout("Fat.set_bgcolor('"+id+"','"+h+"')", delay);
|
|
60 |
|
|
61 |
frame++;
|
|
62 |
delay = interval * frame;
|
|
63 |
}
|
|
64 |
setTimeout("Fat.set_bgcolor('"+id+"','"+to+"')", delay);
|
|
65 |
},
|
|
66 |
set_bgcolor : function (id, c)
|
|
67 |
{
|
|
68 |
var o = document.getElementById(id);
|
|
69 |
if(!o) return;
|
|
70 |
o.style.backgroundColor = c;
|
|
71 |
},
|
|
72 |
get_bgcolor : function (id)
|
|
73 |
{
|
|
74 |
var o = document.getElementById(id);
|
|
75 |
while(o)
|
|
76 |
{
|
|
77 |
var c;
|
|
78 |
if (window.getComputedStyle) c = window.getComputedStyle(o,null).getPropertyValue("background-color");
|
|
79 |
if (o.currentStyle) c = o.currentStyle.backgroundColor;
|
|
80 |
if ((c != "" && c != "transparent") || o.tagName == "BODY") { break; }
|
|
81 |
o = o.parentNode;
|
|
82 |
}
|
|
83 |
if (c == undefined || c == "" || c == "transparent") c = "#FFFFFF";
|
|
84 |
var rgb = c.match(/rgb\s*\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*\)/);
|
|
85 |
if (rgb) c = this.make_hex(parseInt(rgb[1]),parseInt(rgb[2]),parseInt(rgb[3]));
|
|
86 |
return c;
|
|
87 |
}
|
|
88 |
}
|
|
89 |
|
|
90 |
window.onload = function ()
|
|
91 |
{
|
|
92 |
Fat.fade_all();
|
|
93 |
} |