/*****************************************************************************
日期资料
*****************************************************************************/

var lunarInfo=new Array(
0x04bd8,0x04ae0,0x0a570,0x054d5,0x0d260,0x0d950,0x16554,0x056a0,0x09ad0,0x055d2,
0x04ae0,0x0a5b6,0x0a4d0,0x0d250,0x1d255,0x0b540,0x0d6a0,0x0ada2,0x095b0,0x14977,
0x04970,0x0a4b0,0x0b4b5,0x06a50,0x06d40,0x1ab54,0x02b60,0x09570,0x052f2,0x04970,
0x06566,0x0d4a0,0x0ea50,0x06e95,0x05ad0,0x02b60,0x186e3,0x092e0,0x1c8d7,0x0c950,
0x0d4a0,0x1d8a6,0x0b550,0x056a0,0x1a5b4,0x025d0,0x092d0,0x0d2b2,0x0a950,0x0b557,
0x06ca0,0x0b550,0x15355,0x04da0,0x0a5d0,0x14573,0x052d0,0x0a9a8,0x0e950,0x06aa0,
0x0aea6,0x0ab50,0x04b60,0x0aae4,0x0a570,0x05260,0x0f263,0x0d950,0x05b57,0x056a0,
0x096d0,0x04dd5,0x04ad0,0x0a4d0,0x0d4d4,0x0d250,0x0d558,0x0b540,0x0b5a0,0x195a6,
0x095b0,0x049b0,0x0a974,0x0a4b0,0x0b27a,0x06a50,0x06d40,0x0af46,0x0ab60,0x09570,
0x04af5,0x04970,0x064b0,0x074a3,0x0ea50,0x06b58,0x055c0,0x0ab60,0x096d5,0x092e0,
0x0c960,0x0d954,0x0d4a0,0x0da50,0x07552,0x056a0,0x0abb7,0x025d0,0x092d0,0x0cab5,
0x0a950,0x0b4a0,0x0baa4,0x0ad50,0x055d9,0x04ba0,0x0a5b0,0x15176,0x052b0,0x0a930,
0x07954,0x06aa0,0x0ad50,0x05b52,0x04b60,0x0a6e6,0x0a4e0,0x0d260,0x0ea65,0x0d530,
0x05aa0,0x076a3,0x096d0,0x04bd7,0x04ad0,0x0a4d0,0x1d0b6,0x0d250,0x0d520,0x0dd45,
0x0b5a0,0x056d0,0x055b2,0x049b0,0x0a577,0x0a4b0,0x0aa50,0x1b255,0x06d20,0x0ada0)

var solarMonth=new Array(31,28,31,30,31,30,31,31,30,31,30,31);
var Gan=new Array("甲","乙","丙","丁","戊","己","庚","辛","壬","癸");
var Zhi=new Array("子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥");
var Animals=new Array("鼠","牛","虎","兔","龙","蛇","马","羊","猴","鸡","狗","猪");
var solarTerm = new Array("小寒","大寒","立春","雨水","惊蛰","春分","清明","谷雨","立夏","小满","芒种","夏至","小暑","大暑","立秋","处暑","白露","秋分","寒露","霜降","立冬","小雪","大雪","冬至")
var sTermInfo = new Array(0,21208,42467,63836,85337,107014,128867,150921,173149,195551,218072,240693,263343,285989,308563,331033,353350,375494,397447,419210,440795,462224,483532,504758)
var nStr1 = new Array('日','一','二','三','四','五','六','七','八','九','十')
var nStr2 = new Array('初','十','廿','卅','　')
var monthName = new Array("1 月","2 月","3 月","4 月","5 月","6 月","7 月","8 月","9 月","10 月","11 月","12 月");

//国历节日 *表示放假日
var sFtv = new Array(
)

//农历节日 *表示放假日
var lFtv = new Array(
)

//某月的第几个星期几
var wFtv = new Array(
"0520 母亲节")

/*****************************************************************************
日期计算
*****************************************************************************/

//====================================== 传回农历 y年的总天数
function lYearDays(y){
var i, sum = 348
for(i=0x8000; i>0x8; i>>=1) sum += (lunarInfo[y-1900] & i)? 1: 0
return(sum+leapDays(y))
}

//====================================== 传回农历 y年闰月的天数
function leapDays(y){
if(leapMonth(y))  return((lunarInfo[y-1900] & 0x10000)? 30: 29)
else return(0)
}

//====================================== 传回农历 y年闰哪个月 1-12 , 没闰传回 0
function leapMonth(y){
return(lunarInfo[y-1900] & 0xf)
}

//====================================== 传回农历 y年m月的总天数
function monthDays(y,m){
return( (lunarInfo[y-1900] & (0x10000>>m))? 30: 29 )
}

//====================================== 算出农历, 传入日期物件, 传回农历日期物件
//                                       该物件属性有 .year .month .day .isLeap .yearCyl .dayCyl .monCyl
function Lunar(objDate){

var i, leap=0, temp=0
var baseDate = new Date(1900,0,31)
var offset   = (objDate - baseDate)/86400000

this.dayCyl = offset + 40
this.monCyl = 14

for(i=1900; i<2050 && offset>0; i++){
temp = lYearDays(i)
offset -= temp
this.monCyl += 12
}

if(offset<0){
offset += temp;
i--;
this.monCyl -= 12
}

this.year = i
this.yearCyl = i-1864

leap = leapMonth(i) //闰哪个月
this.isLeap = false

for(i=1; i<13 && offset>0; i++){
//闰月
if(leap>0 && i==(leap+1) && this.isLeap==false)
{--i; this.isLeap = true; temp = leapDays(this.year);}
else
{temp = monthDays(this.year, i);}

//解除闰月
if(this.isLeap==true && i==(leap+1)) this.isLeap = false

offset -= temp
if(this.isLeap == false) this.monCyl ++
}

if(offset==0 && leap>0 && i==leap+1)
if(this.isLeap)
{this.isLeap = false;}
else
{this.isLeap = true; --i; --this.monCyl;}

if(offset<0){offset += temp; --i; --this.monCyl;}

this.month = i
this.day = offset + 1
}

//==============================传回国历 y年某m+1月的天数
function solarDays(y,m){
if(m==1)
return(((y%4 == 0) && (y%100 != 0) || (y%400 == 0))? 29: 28)
else
return(solarMonth[m])
}
//============================== 传入 offset 传回干支, 0=甲子
function cyclical(num){
return(Gan[num%10]+Zhi[num%12])
}

//============================== 月历属性
function calElement(sYear,sMonth,sDay,week,lYear,lMonth,lDay,isLeap,cYear,cMonth,cDay){

this.isToday    = false;
//国历
this.sYear      = sYear;
this.sMonth     = sMonth;
this.sDay       = sDay;
this.week       = week;
//农历
this.lYear      = lYear;
this.lMonth     = lMonth;
this.lDay       = lDay;
this.isLeap     = isLeap;
//干支
this.cYear      = cYear;
this.cMonth     = cMonth;
this.cDay       = cDay;

this.color      = '';

this.lunarFestival = ''; //农历节日
this.solarFestival = ''; //国历节日
this.solarTerms    = ''; //节气

}

//===== 某年的第n个节气为几日(从0小寒起算)
function sTerm(y,n){
var offDate = new Date( ( 31556925974.7*(y-1900) + sTermInfo[n]*60000  ) + Date.UTC(1900,0,6,2,5) )
return(offDate.getUTCDate())
}

//============================== 传回月历物件 (y年,m+1月)
function calendar(y,m){

var sDObj, lDObj, lY, lM, lD=1, lL, lX=0, tmp1, tmp2
var lDPOS = new Array(3)
var n = 0
var firstLM = 0

sDObj = new Date(y,m,1)            //当月一日日期

this.length    = solarDays(y,m)    //国历当月天数
this.firstWeek = sDObj.getDay()    //国历当月1日星期几


for(var i=0;i<this.length;i++){

if(lD>lX){
sDObj = new Date(y,m,i+1)    //当月一日日期
lDObj = new Lunar(sDObj)     //农历
lY    = lDObj.year           //农历年
lM    = lDObj.month          //农历月
lD    = lDObj.day            //农历日
lL    = lDObj.isLeap         //农历是否闰月
lX    = lL? leapDays(lY): monthDays(lY,lM) //农历当月最後一天

if(n==0) firstLM = lM
lDPOS[n++] = i-lD+1
}

//sYear,sMonth,sDay,week,
//lYear,lMonth,lDay,isLeap,
//cYear,cMonth,cDay
this[i] = new calElement(y, m+1, i+1, nStr1[(i+this.firstWeek)%7],
lY, lM, lD++, lL,
cyclical(lDObj.yearCyl) ,cyclical(lDObj.monCyl), cyclical(lDObj.dayCyl++) )


if((i+this.firstWeek)%7==0)   this[i].color = 'red'  //周日颜色
if((i+this.firstWeek)%14==13) this[i].color = 'red'  //周休二日颜色
}

//节气
tmp1=sTerm(y,m*2  )-1
tmp2=sTerm(y,m*2+1)-1
//this[tmp1].solarTerms = solarTerm[m*2]
//this[tmp2].solarTerms = solarTerm[m*2+1]
if(m==3) this[tmp1].color = 'red' //清明颜色

//国历节日
for(i = 0; i <sFtv.length; i ++)
if(sFtv[i].match(/^(\d{2})(\d{2})([\s\*])(.+)$/))

if(Number(RegExp.$1)==(m+1)){
this[Number(RegExp.$2)-1].solarFestival += RegExp.$4 + ' '
if(RegExp.$3=='*') this[Number(RegExp.$2)-1].color = 'red'
}

//月周节日
for(i = 0; i < wFtv.length; i ++)
if(wFtv[i].match(/^(\d{2})(\d)(\d)([\s\*])(.+)$/))
if(Number(RegExp.$1)==(m+1)){
tmp1=Number(RegExp.$2)
tmp2=Number(RegExp.$3)
this[((this.firstWeek>tmp2)?7:0) + 7*(tmp1-1) + tmp2 - this.firstWeek].solarFestival += RegExp.$5 + ' '
}

//农历节日
for(i = 0; i < lFtv.length; i ++)
if(lFtv[i].match(/^(\d{2})(.{2})([\s\*])(.+)$/)){
tmp1=Number(RegExp.$1)-firstLM

if(tmp1==-11) tmp1=1
if(tmp1 >=0 && tmp1<n){
tmp2 = lDPOS[tmp1] + Number(RegExp.$2) -1
if( tmp2 >= 0 && tmp2<this.length){
this[tmp2].lunarFestival += RegExp.$4 + ' '
if(RegExp.$3=='*') this[tmp2].color = 'red'
}
}
}

//黑色星期五
if((this.firstWeek+12)%7==5)
this[12].solarFestival += '黑色星期五 '

//今日
if(y==tY && m==tM) this[tD-1].isToday = true;

}

//====================== 中文日期
function cDay(d){
var s;

switch (d){
case 10:
s = '初十'; break;
case 20:
s = '二十'; break;
break;
case 30:
s = '三十'; break;
break;
default :
s = nStr2[Math.floor(d/10)];
s += nStr1[d%10];
}
return(s);
}

///////////////////////////////////////////////////////////////////////////////

var cld;

function drawCld(SY,SM){
var i,sD,s,size;
cld = new calendar(SY,SM);

if(SY>1874 && SY<1909) yDisplay = '光绪' + (((SY-1874)==1)?'元':SY-1874)+'年'
if(SY>1908 && SY<1912) yDisplay = '宣统' + (((SY-1908)==1)?'元':SY-1908)+'年'
if(SY>1911 && SY<1950) yDisplay = '民国' + (((SY-1911)==1)?'元':SY-1911)+'年'
if(SY>1949) yDisplay = ' '



GZ.innerHTML = yDisplay +' 农历' + cyclical(SY-1900+36) + '年 &nbsp;&nbsp;【'+Animals[(SY-4)%12]+'】';

YMBG.innerHTML = "&nbsp;" + SY + "<BR>&nbsp;" + monthName[SM];


for(i=0;i<42;i++){

sObj=eval('SD'+ i);
lObj=eval('LD'+ i);

sObj.className = '';

sD = i - cld.firstWeek;

if(sD>-1 && sD<cld.length){//日期内
sObj.innerHTML = sD+1;

if(cld[sD].isToday) sObj.className = 'todyaColor'; //今日颜色

sObj.style.color = cld[sD].color; //国定假日颜色

if(cld[sD].lDay==1) //显示农历月
lObj.innerHTML = '<b>'+(cld[sD].isLeap?'闰':'') + cld[sD].lMonth + '月' + (monthDays(cld[sD].lYear,cld[sD].lMonth)==29?'小':'大')+'</b>';
else //显示农历日
lObj.innerHTML = cDay(cld[sD].lDay);

s=cld[sD].lunarFestival;
if(s.length>0){//农历节日
if(s.length>6) s = s.substr(0, 4)+'…';
s = s.fontcolor('red');
}
else{//国历节日
s=cld[sD].solarFestival;
if(s.length>0){
size = (s.charCodeAt(0)>0 && s.charCodeAt(0)<128)?8:4;
if(s.length>size+2) s = s.substr(0, size)+'…';
s = s.fontcolor('blue');
}
else{//廿四节气
s=cld[sD].solarTerms;
if(s.length>0) s = s.fontcolor('limegreen');
}
}
if(s.length>0) lObj.innerHTML = s;

}
else{//非日期
sObj.innerHTML = '';
lObj.innerHTML = '';
}
}
}


function changeCld(){
var y,m;
y=CLD.SY.selectedIndex+1900;
m=CLD.SM.selectedIndex;
drawCld(y,m);
}

function pushBtm(K){
switch (K){
case 'YU' :
if(CLD.SY.selectedIndex>0) CLD.SY.selectedIndex--;
break;
case 'YD' :
if(CLD.SY.selectedIndex<149) CLD.SY.selectedIndex++;
break;
case 'MU' :
if(CLD.SM.selectedIndex>0){
CLD.SM.selectedIndex--;
}
else{
CLD.SM.selectedIndex=11;
if(CLD.SY.selectedIndex>0) CLD.SY.selectedIndex--;
}
break;
case 'MD' :
if(CLD.SM.selectedIndex<11){
CLD.SM.selectedIndex++;
}
else{
CLD.SM.selectedIndex=0;
if(CLD.SY.selectedIndex<149) CLD.SY.selectedIndex++;
}
break;
default :
CLD.SY.selectedIndex=tY-1900;
CLD.SM.selectedIndex=tM;
}
changeCld();
}



var Today = new Date();
var tY = Today.getFullYear();
var tM = Today.getMonth();
var tD = Today.getDate();
//////////////////////////////////////////////////////////////////////////////

var width = "130";
var offsetx = 2;
var offsety = 16;

var x = 135;
var y = 260;
var snow = 0;
var sw = 0;
var cnt = 0;

var dStyle;
//document.onmousemove = mEvn;

//显示详细日期资料
function mOvr(v){
var s,festival;
var sObj=eval('SD'+ v);
var d=sObj.innerHTML-1;

//sYear,sMonth,sDay,week,
//lYear,lMonth,lDay,isLeap,
//cYear,cMonth,cDay

if(sObj.innerHTML!=''){

//sObj.style.cursor = 's-resize';   //s-resize

if(cld[d].solarTerms == '' && cld[d].solarFestival == '' && cld[d].lunarFestival == '')
festival = '';
else
festival = '<TABLE WIDTH=100% BORDER=0 CELLPADDING=2 CELLSPACING=0 BGCOLOR="#CCFFCC"><TR><TD>'+
'<FONT COLOR="#000000" STYLE="font-size:9pt;">'+cld[d].solarTerms + ' ' + cld[d].solarFestival + ' ' + cld[d].lunarFestival+'</FONT></TD>'+
'</TR></TABLE>';

s= '<TABLE WIDTH="130" BORDER=0 CELLPADDING="2" CELLSPACING=0 BGCOLOR="#000066"><TR><TD>' +
'<TABLE WIDTH=100% BORDER=0 CELLPADDING=0 CELLSPACING=0><TR><TD ALIGN="right"><FONT COLOR="#ffffff" STYLE="font-size:9pt;">'+
cld[d].sYear+' 年 '+cld[d].sMonth+' 月 '+cld[d].sDay+' 日<br>星期'+cld[d].week+'<br>'+
'<font color="violet">农历'+(cld[d].isLeap?'闰 ':' ')+cld[d].lMonth+' 月 '+cld[d].lDay+' 日</font><br>'+
'<font color="yellow">'+cld[d].cYear+'年 '+cld[d].cMonth+'月 '+cld[d].cDay + '日</font>'+
'</FONT></TD></TR></TABLE>'+ festival +'</TD></TR></TABLE>';


document.all["detail"].innerHTML = s;

	if (snow == 0){
dStyle.left = x+offsetx-(width/2);
dStyle.top = y+offsety;
		dStyle.visibility = "visible";
		snow = 1;
	}
	}
}

//清除详细日期资料
function mOut(){}

//取得位置
function mEvn(){
x=event.x;
y=event.y;
	if (document.body.scrollLeft)
	{x=event.x+document.body.scrollLeft; y=event.y+document.body.scrollTop;}
	if (snow){
dStyle.left = x+offsetx-(width/2)
dStyle.top = y+offsety
	}
}

///////////////////////////////////////////////////////////////////////////

function changeTZ(){
CITY.innerHTML = CLD.TZ.value.substr(6)
setCookie("TZ",CLD.TZ.selectedIndex)
}

function tick(){
var today
today = new Date()
Clock.innerHTML = today.toLocaleString().replace(/(年|月)/g, "/").replace(/日/, "");
Clock.innerHTML = TimeAdd(today.toGMTString(), CLD.TZ.value)
window.setTimeout("tick()", 1000);
}

function setCookie(name, value){
	var today = new Date()
	var expires = new Date()
	expires.setTime(today.getTime() + 1000*60*60*24*365)
	document.cookie = name + "=" + escape(value)	+ "; expires=" + expires.toGMTString()
}

function getCookie(Name){
var search = Name + "="
if(document.cookie.length > 0){
offset = document.cookie.indexOf(search)
if(offset != -1){
offset += search.length
end = document.cookie.indexOf(";", offset)
if(end == -1) end = document.cookie.length
return unescape(document.cookie.substring(offset, end))
}
else return ""
}
}

/////////////////////////////////////////////////////////

function initial(){
dStyle = detail.style;
CLD.SY.selectedIndex=tY-1900;
CLD.SM.selectedIndex=tM;
drawCld(tY,tM);

CLD.TZ.selectedIndex=getCookie("TZ");
changeTZ();
tick();
}

//农历日历效果

var bsYear; 
var bsDate; 
var bsWeek; 
var arrLen=8; //数组长度 
var svalue=0; //当年的秒数 
var dayiy=0; //当年第几天 
var miy=0; //月份的下标 
var iyear=0; //年份标记 
var dayim=0; //当月第几天 
var spd=86400; //每天的秒数 

var year1999="30;29;29;30;29;29;30;29;30;30;30;29"; //354 
var year2000="30;30;29;29;30;29;29;30;29;30;30;29"; //354 
var year2001="30;30;29;30;29;30;29;29;30;29;30;29;30"; //384 
var year2002="30;30;29;30;29;30;29;29;30;29;30;29"; //354 
var year2003="30;30;29;30;30;29;30;29;29;30;29;30"; //355 
var year2004="29;30;29;30;30;29;30;29;30;29;30;29;30"; //384 
var year2005="29;30;29;30;29;30;30;29;30;29;30;29"; //354 
var year2006="30;29;30;29;30;30;29;29;30;30;29;29;30"; 

var month1999="正月;二月;三月;四月;五月;六月;七月;八月;九月;十月;十一月;十二月" 
var month2001="正月;二月;三月;四月;闰四月;五月;六月;七月;八月;九月;十月;十一月;十二月" 
var month2004="正月;二月;闰二月;三月;四月;五月;六月;七月;八月;九月;十月;十一月;十二月" 
var month2006="正月;二月;三月;四月;五月;六月;七月;闰七月;八月;九月;十月;十一月;十二月" 
var Dn="初一;初二;初三;初四;初五;初六;初七;初八;初九;初十;十一;十二;十三;十四;十五;十六;十七;十八;十九;二十;廿一;廿二;廿三;廿四;廿五;廿六;廿七;廿八;廿九;三十"; 

var Ys=new Array(arrLen); 
Ys[0]=919094400;Ys[1]=949680000;Ys[2]=980265600; 
Ys[3]=1013443200;Ys[4]=1044028800;Ys[5]=1074700800; 
Ys[6]=1107878400;Ys[7]=1138464000; 

var Yn=new Array(arrLen); //农历年的名称 
Yn[0]="己卯年";Yn[1]="庚辰年";Yn[2]="辛巳年"; 
Yn[3]="壬午年";Yn[4]="癸未年";Yn[5]="甲申年"; 
Yn[6]="乙酉年";Yn[7]="丙戌年"; 
var D=new Date(); 
var yy=D.getYear(); 
var mm=D.getMonth()+1; 
var dd=D.getDate(); 
var ww=D.getDay(); 
if (ww==0) ww="<font color=RED>星期日"; 
if (ww==1) ww="星期一"; 
if (ww==2) ww="星期二"; 
if (ww==3) ww="星期三"; 
if (ww==4) ww="星期四"; 
if (ww==5) ww="星期五"; 
if (ww==6) ww="<font color=RED>星期六"; 
ww=ww; 
var ss=parseInt(D.getTime() / 1000); 
if (yy<100) yy="19"+yy; 

for (i=0;i<arrLen;i++) 
if (ss>=Ys[i]){ 
iyear=i; 
svalue=ss-Ys[i]; //当年的秒数 
} 
dayiy=parseInt(svalue/spd)+1; //当年的天数 

var dpm=year1999; 
if (iyear==1) dpm=year2000; 
if (iyear==2) dpm=year2001; 
if (iyear==3) dpm=year2002; 
if (iyear==4) dpm=year2003; 
if (iyear==5) dpm=year2004; 
if (iyear==6) dpm=year2005; 
if (iyear==7) dpm=year2006; 
dpm=dpm.split(";"); 

var Mn=month1999; 
if (iyear==2) Mn=month2001; 
if (iyear==5) Mn=month2004; 
if (iyear==7) Mn=month2006; 
Mn=Mn.split(";"); 

var Dn="初一;初二;初三;初四;初五;初六;初七;初八;初九;初十;十一;十二;十三;十四;十五;十六;十七;十八;十九;二十;廿一;廿二;廿三;廿四;廿五;廿六;廿七;廿八;廿九;三十"; 
Dn=Dn.split(";"); 

dayim=dayiy; 

var total=new Array(13); 
total[0]=parseInt(dpm[0]); 
for (i=1;i<dpm.length-1;i++) total[i]=parseInt(dpm[i])+total[i-1]; 
for (i=dpm.length-1;i>0;i--) 
if (dayim>total[i-1]){ 
dayim=dayim-total[i-1]; 
miy=i; 
} 
bsWeek=ww; 
bsDate=yy+"年"+mm+"月"; 
bsDate2=dd; 
var ctMonth=new Array("正月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月");
var ctDay=new Array("初一","初二","初三","初四","初五","初六","初七","初八","初九","初十","十一","十二","十三","十四","十五","十六","十七","十八","十九","二十","廿一","廿二","廿三","廿四","廿五","廿六","廿七","廿八","廿九","三十");

//当天的日期转成农历
cld = new calendar(yy,mm-1);
lm=cld[dd-1].lMonth;
ld=cld[dd-1].lDay;
	  
//农历年
bsYear=cyclical(yy-1900+36)+"年"; 
//农历月日
if(cld[dd-1].isLeap){
bsYear2="闰"+ctMonth[lm-1]+ctDay[ld-1]; 
}else{
bsYear2=ctMonth[lm-1]+ctDay[ld-1]; 
}

function CAL(){ 
document.write("<table width='98' border='0' cellspacing='0' cellpadding='0'>");
document.write("<tr><td align='center' height='2'></td></tr>");
document.write("<tr><td align='center'><img src='images/timer_top.jpg' width='98' height='12' /></td></tr>");  
document.write("<tr><td align='center' background='images/timer_bg.jpg' height='6'></td></tr>");
document.write("<tr><td align='center' background='images/timer_bg.jpg'><strong>" + bsDate +"</strong></td></tr>");
document.write("<tr><td align='center' background='images/timer_bg.jpg' height='6'></td></tr>");
document.write("<tr><td align='center' background='images/timer_bg.jpg' height='25' class='font_red19b'>"+bsDate2+"</td></tr>"); 
document.write("<tr><td align='center' background='images/timer_bg.jpg' height='3'></td></tr>");
document.write("<tr><td align='center' background='images/timer_bg.jpg'>" + bsWeek +"</td></tr>"); 
document.write("<tr><td align='center' background='images/timer_bg.jpg' height='2'></td></tr>");
document.write("<tr><td align='center' background='images/timer_bg.jpg' class='font_black12'>" + bsYear+bsYear2+"</td></tr>"); 
document.write("<tr><td align='center'><img src='images/timer_bott.jpg' width='98' height='8'/></td></tr>"); 
document.write("</table>");
} 

/*年月日历样式*/
function getTime() {
// 初始化时间
var now = new Date()
var hour = now.getHours()
var minute = now.getMinutes()
now = null
var ampm = "" 
// 时间检测，并设置上下午AM和PM
if (hour >= 12) {
hour -= 12
ampm = "PM"
} else
ampm = "AM"
hour = (hour == 0) ? 12 : hour
// add zero digit to a one digit minute
if (minute < 10)
minute = "0" + minute // do not parse this number!
// return time string
return hour + ":" + minute + " " + ampm
}
function leapYear(year) {
if (year % 4 == 0) // basic rule
return true // is leap year
/* else */ // else not needed when statement is "return"
return false // is not leap year
}
function getDays(month, year) {
// 设定每月的天数数组
var ar = new Array(12)
ar[0] = 31 // January
ar[1] = (leapYear(year)) ? 29 : 28 // February
ar[2] = 31 // March
ar[3] = 30 // April
ar[4] = 31 // May
ar[5] = 30 // June
ar[6] = 31 // July
ar[7] = 31 // August
ar[8] = 30 // September
ar[9] = 31 // October
ar[10] = 30 // November
ar[11] = 31 // December

return ar[month]
}
function getMonthName(month) {
// 为月份名称设定数组
var ar = new Array(12)
ar[0] = "1月"
ar[1] = "2月"
ar[2] = "3月"
ar[3] = "4月"
ar[4] = "5月"
ar[5] = "6月"
ar[6] = "7月"
ar[7] = "8月"
ar[8] = "9月"
ar[9] = "10月"
ar[10] = "11月"
ar[11] = "12月"

return ar[month]
}
function setCal() {

var now = new Date()
var year = now.getYear()
var month = now.getMonth()
var monthName = getMonthName(month)
var date = now.getDate()
now = null

var firstDayInstance = new Date(year, month, 1)
var firstDay = firstDayInstance.getDay()
firstDayInstance = null

var days = getDays(month, year)
// 呼叫函数画日历
drawCal(firstDay + 1, days, date, monthName, year)
}
function drawCal(firstDay, lastDate, date, monthName, year) {
// 以下设定表格的属性，这些参数可以自己改变，只是注意相互匹配。
var headerHeight = 15 // height of the table's header cell
var border = 0 // 3D height of table's border
var cellspacing = 0 // width of table's border
var headerColor = "#000000" // color of table's header
var headerSize = "4" // size of tables header font
var colWidth = 30 // width of columns in table
var dayCellHeight = 9 // height of cells containing days of the week
var dayColor = "#FF6600" // color of font representing week days
var cellHeight = 7 // height of cells representing dates in the calendar
var todayColor = "white" // color specifying today's date in the calendar
var timeColor = "black" // color of font representing current time
// create basic table structure
var text = "" // initialize accumulative variable to empty string
text += '<CENTER>'
text += '<TABLE BORDER=' + border + ' CELLSPACING=' + cellspacing + ' width=97%><tr><td>'
text += '<TABLE BORDER=' + border + ' CELLSPACING=' + cellspacing + ' width=100%  background=images/timetab_bg.gif>' // table settings
// variables to hold constant settings
var openCol = '<TD  WIDTH=' + colWidth + ' HEIGHT=' + dayCellHeight + '>'
openCol += '<FONT COLOR="' + dayColor + '"><b>'
var closeCol = '</b></FONT></TD>'
// create array of abbreviated day names
var weekDay = new Array(7)
weekDay[0] = "日"
weekDay[1] = "一"
weekDay[2] = "二"
weekDay[3] = "三"
weekDay[4] = "四"
weekDay[5] = "五"
weekDay[6] = "六"

// create first row of table to set column width and specify week day
text += '<TR ALIGN="center" VALIGN="center">'
for (var dayNum = 0; dayNum < 7; ++dayNum) {
text += openCol + weekDay[dayNum] + closeCol 
}
text += '</TR>'

var digit = 1
var curCell = 1
var displaydiv=document.getElementById("groupMenu");

for (var row = 1; row <= Math.ceil((lastDate + firstDay - 1) / 7); ++row) {
	text += '<TR ALIGN="center" VALIGN="top">'
	for (var col = 1; col <= 7; ++col) {
		if (digit > lastDate)
			break
			
		if (curCell < firstDay) {
			text += '<TD></TD>';
			curCell++
		} else {
			var message=getHoliday(yy,mm,digit);
			//显示当天
			if (digit == date) {
				//当天是节日
			   if(message.length>0){
					text += '<TD HEIGHT=' + cellHeight + ' class="timer_happyday"><a onmouseover="showMenu(\''+message+'\');" onmouseout="hideMenu();">'
					text += '<FONT COLOR="' + timeColor + '">'
					text += digit
					text += '</FONT></a><BR>'
					text += '</TD>'
			   }else{
					text += '<TD HEIGHT=' + cellHeight + ' class="timer_now" >'
					text += '<FONT COLOR="' + todayColor + '">'
					text += digit
					text += '</FONT><BR>'
					text += '</TD>'
			   }
			}else if(message.length>0){
				text += '<TD HEIGHT=' + cellHeight + ' class="timer_happyday"><a onmouseover="showMenu(\''+message+'\');" onmouseout="hideMenu();">'
				text += digit
				text += '</a><BR>'
				text += '</TD>'
			} else{
				text += '<TD HEIGHT=' + cellHeight + '>' + digit + '</TD>'
			}
			digit++
		}
	}
	text += '</TR>'
}
text += '</TABLE>'
text += '</td></tr></TABLE>'
text += '</CENTER>'
document.write(text) 
}

// -- End Hiding Here -->
function getPosition(obj) {
	l = obj.offsetLeft;
	t = obj.offsetTop;
	while (obj = obj.offsetParent) {
		l += obj.offsetLeft;
		t += obj.offsetTop;
	}
	return {x:l, y:t};
}

function setMenuPosition() {
	var groupTextObj = document.getElementById("groupText");
	var groupMenuObj = document.getElementById("groupMenu");
	var textPostion = getPosition(groupTextObj);
	var x = textPostion.x;
	var y = textPostion.y;
	
	groupMenuObj.style.left = textPostion.x + "px";
	groupMenuObj.style.top = (textPostion.y + groupTextObj.offsetHeight) + "px";
}

function showMenu(message) {
	var groupMenuObj = document.getElementById("groupMenu");
	groupMenuObj.style.display = "block";
	groupMenuObj.innerHTML=message;
}

function hideMenu() {
	var groupMenuObj = document.getElementById("groupMenu");
	groupMenuObj.style.display = "none";
}
//国历节日 
var sFtv = new Array(
"0101 元旦",
"0214 情人节",
"0308 妇女节",
"0312 植树节",
"0315 消费者权益日",
"0401 愚人节",
"0501 劳动节",
"0504 青年节",
"0601 儿童节",
"0701 建党节",
"0801 建军节",
"0910 教师节",
"1001 国庆节",
"1225 圣诞节"
)

//农历节日 
var lFtv = new Array(
"0101 农历春节",
"0115 元宵节",
"0505 端午节",
"0707 七夕情人节",
"0815 中秋节",
"0909 重阳节",
"1208 腊八节",
"1224 小年",
"0100 除夕")

//获得当前日期的节日，公历年月日
function getHoliday(yy,mm,dd){

	  //取得农历的月日
	  cld = new calendar(yy,mm-1);
	  lm=cld[dd-1].lMonth;
	  ld=cld[dd-1].lDay;
	  
      if(mm<10) t_mm="0"+mm; else t_mm=mm;
	  if(dd<10)  t_dd="0"+dd;  else t_dd=dd;
	  if(lm<10) t_miy="0"+lm; else t_miy=lm;
	  if(ld<10) t_dayim="0"+ld; else t_dayim=ld;

	  var result="";

	 //公历节日
     for(i = 0; i < sFtv.length; i ++){
         var tsFtv=sFtv[i].split(" ");
		 if((String(t_mm)+String(t_dd))==tsFtv[0]){
			result=tsFtv[1];
		 }
	 }
	
	 //农历节日
     for(i = 0; i < lFtv.length; i ++){
         var tlFtv=lFtv[i].split(" ");
		 if((String(t_miy)+String(t_dayim))==tlFtv[0]){
			 if(result!=""){
			    result+=","+tlFtv[1];
			}else{
                result=tlFtv[1];
			}
		 }
	 }
	 //清明节
	 var solarTermId=6;
	 var offDate = new Date( ( 31556925974.7*(yy-1900) + sTermInfo[solarTermId]*60000  ) + Date.UTC(1900,0,6,2,5) );
	 if(offDate.getUTCMonth()==(mm-1)&&offDate.getUTCDate()==dd){
		if(result!=""){
			result+=","+solarTerm[solarTermId];
		}else{
		    result=solarTerm[solarTermId];
		}
	 }

	 return result;
}
//取得指定的年月日是什么节气
function getSolarTerm(yy,mm,dd){
    var result="";
	for(i = 0; i < solarTerm.length; i ++){
		var offDate = new Date( ( 31556925974.7*(yy-1900) + sTermInfo[i]*60000  ) + Date.UTC(1900,0,6,2,5) );
		if(offDate.getUTCMonth()==(mm-1)&&offDate.getUTCDate()==dd){
			result=solarTerm[i];
			break;
		}
	}
	
	return result;
}


