综合

img LuckyJan

鼠标下浮动的文字和时钟(转帖修改)

发表于2004/10/8 10:24:00  1251人阅读

<!--  动态鼠标开始  -->
<script language="JavaScript"><!--
var Dy,Dx,DY,DX,i,x,y,X,Y,ie,ns,D,H,M,S,n,a;

var dCol='009900';//date colour.
var fCol='FF6666';//face colour.
var sCol='0000ff';//seconds colour.
var mCol='000000';//minutes colour.
var hCol='FF0000';//hours colour.
var ClockHeight=40;
var ClockWidth=40;
var ClockFromMouseY=-30;
var ClockFromMouseX=60;
var ymouse=0;
var xmouse=0;
var scrll=0;
var font='Arial';
var size=2;
var speed=0.5;
var TodaysDate="☆健康是福☆有爱是缘";
var Face='1 2 3 4 5 6 7 8 9 10 11 12';
D=TodaysDate.split('');
Face=Face.split(' ');
H='....';
H=H.split('');
M='.....';
M=M.split('');
S='......';
S=S.split('');
ns=(document.layers);
ie=(document.all);
n=Face.length;
a=size*10;
var props="<font face="+font+" size="+size+" color="+fCol+"><B>";
var props2="<font face="+font+" size="+size+" color="+dCol+">";
var Split=360/n;
var Dsplit=360/D.length;
var HandHeight=ClockHeight/5.5
var HandWidth=ClockWidth/5.5
var HandY=-7;
var HandX=-2.5;
var step=0.06;
var currStep=0;
y=new Array();x=new Array();Y=new Array();X=new Array();
for (i=0; i < n; i++){y[i]=0;x[i]=0;Y[i]=0;X[i]=0}
Dy=new Array();Dx=new Array();DY=new Array();DX=new Array();
for (i=0; i < D.length; i++){Dy[i]=0;Dx[i]=0;DY[i]=0;DX[i]=0}
if (ns){
for (i=0; i < D.length; i++)
document.write('<layer name="nsDate'+i+'" top=0 left=0 height='+a+' width='+a+'><center>'+props2+D[i]+'</font></center></layer>');
for (i=0; i < n; i++)
document.write('<layer name="nsFace'+i+'" top=0 left=0 height='+a+' width='+a+'><center>'+props+Face[i]+'</font></center></layer>');
for (i=0; i < S.length; i++)
document.write('<layer name=nsSeconds'+i+' top=0 left=0 width=15 height=15><font face=Arial size=3 color='+sCol+'><center><b>'+S[i]+'</b></center></font></layer>');
for (i=0; i < M.length; i++)
document.write('<layer name=nsMinutes'+i+' top=0 left=0 width=15 height=15><font face=Arial size=3 color='+mCol+'><center><b>'+M[i]+'</b></center></font></layer>');
for (i=0; i < H.length; i++)
document.write('<layer name=nsHours'+i+' top=0 left=0 width=15 height=15><font face=Arial size=3 color='+hCol+'><center><b>'+H[i]+'</b></center></font></layer>');
}
if (ie){
document.write('<div id="Od" style="position:absolute;top:0px;left:0px"><div style="position:relative">');
for (i=0; i < D.length; i++)
document.write('<div id="ieDate" style="position:absolute;top:0px;left:0;height:'+a+';width:'+a+';text-align:center">'+props2+D[i]+'</font></div>');
document.write('</div></div>');
document.write('<div id="Of" style="position:absolute;top:0px;left:0px"><div style="position:relative">');
for (i=0; i < n; i++)
document.write('<div id="ieFace" style="position:absolute;top:0px;left:0;height:'+a+';width:'+a+';text-align:center">'+props+Face[i]+'</B></font></div>');
document.write('</div></div>');
document.write('<div id="Oh" style="position:absolute;top:0px;left:0px"><div style="position:relative">');
for (i=0; i < H.length; i++)
document.write('<div id="ieHours" style="position:absolute;width:16px;height:16px;font-family:Arial;font-size:16px;color:'+hCol+';text-align:center;font-weight:bold">'+H[i]+'</div>');
document.write('</div></div>');
document.write('<div id="Om" style="position:absolute;top:0px;left:0px"><div style="position:relative">');
for (i=0; i < M.length; i++)
document.write('<div id="ieMinutes" style="position:absolute;width:16px;height:16px;font-family:Arial;font-size:16px;color:'+mCol+';text-align:center;font-weight:bold">'+M[i]+'</div>');
document.write('</div></div>')
document.write('<div id="Os" style="position:absolute;top:0px;left:0px"><div style="position:relative">');
for (i=0; i < S.length; i++)
document.write('<div id="ieSeconds" style="position:absolute;width:16px;height:16px;font-family:Arial;font-size:16px;color:'+sCol+';text-align:center;font-weight:bold">'+S[i]+'</div>');
document.write('</div></div>')
}
(ns)?window.captureEvents(Event.MOUSEMOVE):0;
function Mouse(evnt){
ymouse = (ns)?evnt.pageY+ClockFromMouseY-(window.pageYOffset):event.y+ClockFromMouseY;
xmouse = (ns)?evnt.pageX+ClockFromMouseX:event.x+ClockFromMouseX;
}
(ns)?window.onMouseMove=Mouse:document.onmousemove=Mouse;

function ClockAndAssign(){
 var time = new Date ();
 var secs = time.getSeconds();
 var sec = -1.57 + Math.PI * secs/30;
 var mins = time.getMinutes();
 var min = -1.57 + Math.PI * mins/30;
 var hr = time.getHours();
 var hrs = -1.575 + Math.PI * hr/6+Math.PI*parseInt(time.getMinutes())/360;
 if (ie){
  Od.style.top=window.document.body.scrollTop;
  Of.style.top=window.document.body.scrollTop;
  Oh.style.top=window.document.body.scrollTop;
  Om.style.top=window.document.body.scrollTop;
  Os.style.top=window.document.body.scrollTop;
 }
 for (i=0; i < n; i++){
  var F=(ns)?document.layers['nsFace'+i]:ieFace[i].style;
  F.top=y[i] + ClockHeight*Math.sin(-1.0471 + i*Split*Math.PI/180)+scrll;
  F.left=x[i] + ClockWidth*Math.cos(-1.0471 + i*Split*Math.PI/180);
 }
 for (i=0; i < H.length; i++){
  var HL=(ns)?document.layers['nsHours'+i]:ieHours[i].style;
  HL.top=y[i]+HandY+(i*HandHeight)*Math.sin(hrs)+scrll;
  HL.left=x[i]+HandX+(i*HandWidth)*Math.cos(hrs);
 }
 for (i=0; i < M.length; i++){
  var ML=(ns)?document.layers['nsMinutes'+i]:ieMinutes[i].style;
  ML.top=y[i]+HandY+(i*HandHeight)*Math.sin(min)+scrll;
  ML.left=x[i]+HandX+(i*HandWidth)*Math.cos(min);
 }
 for (i=0; i < S.length; i++){
  var SL=(ns)?document.layers['nsSeconds'+i]:ieSeconds[i].style;
  SL.top=y[i]+HandY+(i*HandHeight)*Math.sin(sec)+scrll;
  SL.left=x[i]+HandX+(i*HandWidth)*Math.cos(sec);
 }
 for (i=0; i < D.length; i++){
  var DL=(ns)?document.layers['nsDate'+i]:ieDate[i].style;
  DL.top=Dy[i] + ClockHeight*1.3*Math.sin(currStep+i*Dsplit*Math.PI/180)+scrll;
  DL.left=Dx[i] + ClockWidth*1.3*Math.cos(currStep+i*Dsplit*Math.PI/180);
 }
 currStep-=step;
}
function Delay(){
 scrll=(ns)?window.pageYOffset:0;
 Dy[0]=Math.round(DY[0]+=((ymouse)-DY[0])*speed);
 Dx[0]=Math.round(DX[0]+=((xmouse)-DX[0])*speed);
 for (i=1; i < D.length; i++){
  Dy[i]=Math.round(DY[i]+=(Dy[i-1]-DY[i])*speed);
  Dx[i]=Math.round(DX[i]+=(Dx[i-1]-DX[i])*speed);
 }
 y[0]=Math.round(Y[0]+=((ymouse)-Y[0])*speed);
 x[0]=Math.round(X[0]+=((xmouse)-X[0])*speed);
 for (i=1; i < n; i++){
  y[i]=Math.round(Y[i]+=(y[i-1]-Y[i])*speed);
  x[i]=Math.round(X[i]+=(x[i-1]-X[i])*speed);
 }

 ClockAndAssign();
 setTimeout('Delay()',40);
}

if (ns||ie) Delay();//if (ns||ie)window.onload=Delay();
// --></script>
<!--  动态鼠标结束  -->

阅读全文
0 0

相关文章推荐

img
取 消
img