颜色代码生成器


脚本说明:
第一步:把如下代码加入<head>区域中:
<script language=JavaScript1.2>
<!--
var bName=navigator.appName;
var bVer=parseInt(navigator.appVersion);
var NS4=(bName=="Netscape" && bVer >= 4);
var IE4=(bName=="Microsoft Internet Explorer" && bVer >= 4);
var fstr_r;
var fstr_g;
var fstr_b;
var sItem="S";

function display(id, str){
  if(NS4 || IE4){
    if(NS4){
      with (document[id].document){
        open(); write(str); close();
      }
    }else document.all[id].innerHTML=str;
  }else{
    document.fsample2.startcolor.value=document.GradForm.start.value;
    document.fsample2.endcolor.value=document.GradForm.end.value;
  }
}

function makeArray(){
  for(i = 0; i<makeArray.arguments.length; i++)
    this[i] = makeArray.arguments[i];
}

var convert = new makeArray('0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z');

function returnBase(number,base) {
  eval("var output=parseInt(number)");
  if(isNum(number,base)){
    if(number < base) output = convert[output];
    else{
      var MSD = '' + Math.floor(number / base);
      var LSD = number - MSD*base;
      if(MSD > base) output = returnBase(MSD,base) + convert[LSD];
      else output = convert[MSD] + convert[LSD];
    }
  }else{
    output=0;
  }
  return output;
}

function isNum(no, base){
  var cmp="0123456789";
  var chkStr=no;
  var chkChar;
  var rc=true;
  var nLen;

  if(base == 16){
    cmp+="ABCDEFabcdef";
  }else if(base == 10){
    eval("chkStr=''+parseInt(chkStr)");
  }
  nLen=chkStr.length;

  for(var i=0; i<nLen; i++){
     chkChar=chkStr.substring(i,i+1)
     if(i==0 && chkChar == "#" && base == 16){
     }else if(cmp.indexOf(chkChar)<0){
       rc=false;
     }
     if(rc == false) i=nLen;
  }
  return rc;
}

function chkNum(obj,base){
  var form=document.GradForm;
  var rc=true;

  if(base==10){
    eval("rc=form."+obj+".value <= 255");
  }

  if(rc){
    eval("rc=isNum(form."+obj+".value,"+base+")");
    if(!rc){
      alert("输入的数值不正确!");
      eval("form."+obj+".focus()");
    }
  }else{
    alert("输入的数值大于255!");
    eval("form."+obj+".focus()");
  }
  return rc;
}

function twobyte(no){
  var str=no;

  if(isNum(no,16)){
    str="0"+str;
    str=str.substring((str.length-3)+1);
  }else{
    str="00";
  }
  return str;
}

function CstrLen(cStr){
  var sLen=cStr.length;
  var j=0;
  for(var i=0;i<sLen;i++){
     str=cStr.charAt(i);
     if(NS4 && str.charCodeAt(0)<1){
       i++;
     }
     j++;
  }
  return j;
}

function GradientText(form, color1, color2, color3, gStr, gType){
  var redStep, greenStep, BlueStep;
  var str_r, str_g, str_b, str;

  var gStep=CstrLen(gStr);

  var b1 = color1 % 0x100; if(isNaN(b1)) b1=0;
  var g1 = parseInt(color1 / 0x100) % 0x100; if(isNaN(g1)) g1=0;
  var r1 = parseInt(color1 / 0x10000) % 0x100; if(isNaN(r1)) r1=0;

  var b2 = color2 % 0x100; if(isNaN(b2)) b2=0;
  var g2 = parseInt(color2 / 0x100) % 0x100; if(isNaN(g2)) g2=0;
  var r2 = parseInt(color2 / 0x10000) % 0x100; if(isNaN(r2)) r2=0;

  var cStepAdd = parseInt(256 / gStep);

  if(g1 > g2){
    greenStep = 0;
  }else if(g2 > g1){
    greenStep = 1;
  }else{
    greenStep = 2;
  }

  if(r1 > r2){
    redStep = 0;
  }else if(r2 > r1){
    redStep = 1;
  }else{
    redStep = 2;
  }

  if(b1 > b2){
    BlueStep = 0;
  }else if(b2 > b1){
    BlueStep = 1;
  }else{
    BlueStep = 2;
  }

  var GradStr="";
  if(gType == 'S'){
    GradStr+='<TABLE WIDTH="100%" BORDER=0 CELLSPACING=0 CELLPADDING=0><TR><TD ALIGN=CENTER BGCOLOR="'+color3+'"><br>';
  }

  for(var i=0; i<gStr.length; i++){
     str_r=twobyte(returnBase(r1,16));
     str_g=twobyte(returnBase(g1,16));
     str_b=twobyte(returnBase(b1,16));

     str=gStr.charAt(i);
     if(NS4 && str.charCodeAt(0)<1){
       str=str+gStr.charAt(i+1);
       i++;
     }

     GradStr+='<font color="#'+str_r+str_g+str_b+'">'+str+'</font>';

     if(redStep==1){
       r1 = r1 + cStepAdd;
       if(r1 > r2) r1 = r2;
     }else if(redStep==0){
       r1 = r1 - cStepAdd;
       if(r1 < r2) r1 = r2;
     }
        
     if(greenStep==1){
       g1 = g1 + cStepAdd;
       if(g1 > g2) g1 = g2;
     }else if(greenStep==0){
       g1 = g1 - cStepAdd;
       if(g1 < g2) g1 = g2;
     }

     if(BlueStep==1){
       b1 = b1 + cStepAdd;
       if(b1 > b2) b1 = b2;
     }else if(BlueStep==0){
       b1 = b1 - cStepAdd;
       if(b1 < b2) b1 = b2;
     }
  }

  if(gType == 'S'){
    GradStr+='<br> </TD></TR></TABLE>';
  }

  return GradStr;
}

function GenTag(form){
  var ss,ee,bb;

  if(!isNum(form.start.value,16)){
    alert("请检查起始颜色数值");
  }else if(!isNum(form.end.value,16)){
    alert("请检查结束颜色数值");
  }else if(!isNum(form.bg.value,16)){
    alert("请检查背景颜色数值");
  }else{
    eval("ss=0x"+form.start.value.substring(1)+";");
    eval("ee=0x"+form.end.value.substring(1)+";");
    eval("bb=form.bg.value");
    form.code.value=GradientText(form,ss,ee,bb,form.showstr.value,"C");
  }
}

function newRGB(type, field2){
  var form=document.GradForm;
  var chkOK=true;
  var vNo;

  if(field2==""){
    if(sItem=="S"){
      chkOK=chkNum('start',16);
    }else if(sItem=="E"){
      chkOK=chkNum('end',16);
    }else if(sItem=="B"){
      chkOK=chkNum('bg',16);
    }
  }

  if(chkOK){
    if(type==0){
      if(field2 != "") eval("chkOK=isNum(form.rgb_"+field2+".value,10)");
      if(chkOK){
        if(field2 != "") eval("chkOK=chkNum('rgb_"+field2+"',10)");
        if(chkOK){
          fstr_r=twobyte(returnBase(form.rgb_r.value,16));
          fstr_g=twobyte(returnBase(form.rgb_g.value,16));
          fstr_b=twobyte(returnBase(form.rgb_b.value,16));
          if(sItem=="S"){
            form.start.value="#"+fstr_r+fstr_g+fstr_b;
          }else if(sItem=="E"){
            form.end.value="#"+fstr_r+fstr_g+fstr_b;
          }else if(sItem=="B"){
            form.bg.value="#"+fstr_r+fstr_g+fstr_b;
          }
        }
      }else{
        alert("输入的颜色数值不正确。");
        eval("form.rgb_"+field2+"s.focus()");
      }
    }else{
      if(sItem=="S"){
        fstr_r=form.start.value.substring(1,3);
        fstr_g=form.start.value.substring(3,5);
        fstr_b=form.start.value.substring(5,7);
      }else if(sItem=="E"){
        fstr_r=form.end.value.substring(1,3);
        fstr_g=form.end.value.substring(3,5);
        fstr_b=form.end.value.substring(5,7);
      }else if(sItem=="B"){
        fstr_r=form.bg.value.substring(1,3);
        fstr_g=form.bg.value.substring(3,5);
        fstr_b=form.bg.value.substring(5,7);
      }
      form.rgb_r.value=parseInt(fstr_r,16);
      form.rgb_g.value=parseInt(fstr_g,16);
      form.rgb_b.value=parseInt(fstr_b,16);
    }
    if(chkOK) AddText();
  }
}

function AddText(){
  var form=document.GradForm;
  var ss,ee,bb;

  eval("ss=0x"+form.start.value.substring(1)+";");
  eval("ee=0x"+form.end.value.substring(1)+";");
  eval("bb=form.bg.value");

  str=GradientText(form,ss,ee,bb,form.showstr.value,"S");
  display("fsample", str);
}

function setRGB(id,no){
  var form=document.GradForm;
  var nid="rgb_"+id;

  if(id){
    var tmp=eval("parseInt(form."+nid+".value)+parseInt("+no+")");
    if(tmp<0) tmp=255;
    else if(tmp>255) tmp=0;

    eval("form."+nid+".value="+tmp);
  }

  fstr_r=twobyte(returnBase(form.rgb_r.value,16));
  fstr_g=twobyte(returnBase(form.rgb_g.value,16));
  fstr_b=twobyte(returnBase(form.rgb_b.value,16));

  if(sItem=="S"){
    form.start.value="#"+fstr_r+fstr_g+fstr_b;
  }else if(sItem=="E"){
    form.end.value="#"+fstr_r+fstr_g+fstr_b;
  }else if(sItem=="B"){
    form.bg.value="#"+fstr_r+fstr_g+fstr_b;
  }

  AddText();
}

function SetColor(clr){
  if(sItem=="S"){
    document.GradForm.start.value="#"+clr;
  }else if(sItem=="E"){
    document.GradForm.end.value="#"+clr;
  }else if(sItem=="B"){
    document.GradForm.bg.value="#"+clr;
  }

  ResetValue();
  AddText();
}

function set(swtch){
  if(swtch == 1) sItem="S";
  else if (swtch == 2) sItem="E";
  else if (swtch == 0) sItem="B";
  ResetValue();
}

function ResetValue(){
  var form=document.GradForm;
  var str_r, str_g, str_b;

  if(sItem=="S"){
    str_r=form.start.value.substring(1,3);
    str_g=form.start.value.substring(3,5);
    str_b=form.start.value.substring(5,7);
  }else if(sItem=="E"){
    str_r=form.end.value.substring(1,3);
    str_g=form.end.value.substring(3,5);
    str_b=form.end.value.substring(5,7);
  }else if(sItem=="B"){
    str_r=form.bg.value.substring(1,3);
    str_g=form.bg.value.substring(3,5);
    str_b=form.bg.value.substring(5,7);
  }
  form.rgb_r.value=parseInt(str_r,16);
  form.rgb_g.value=parseInt(str_g,16);
  form.rgb_b.value=parseInt(str_b,16);
}

function nomsg(){
  self.status="";
}

function myReset(){
  AddText();
}

//-->
</script>




第二步:把如下代码加入<body>区域中:
<form name=GradForm>
<table border=1><tr><td>
 <INPUT type=radio name=setitem value="bg" onClick="set(0)">背景色<input type=text name="bg" size=6 value="#FFFFFF" onChange="newRGB(1,'')">
<INPUT type=radio name=setitem value="start" onClick="set(1)" checked>起始色<input type=text name="start" size=6 value="#FF0000" onChange="newRGB(1,'')">
 <INPUT type=radio name=setitem value="end" onClick="set(2)">结束色<input type=text name="end" size=6 value="#0000FF" onChange="newRGB(1,'')">
</td></tr>

<tr><td>
<font color="#FF0000">红</font> <input type="Button" value="+" onClick="setRGB('r',1)"><INPUT type=text name=rgb_r size=3 value=0 onChange="newRGB(0,'r')"><input type="Button" value="-" onClick="setRGB('r',-1)">
<font color="#009900">绿</font> <input type="Button" value="+" onClick="setRGB('g',1)"><INPUT type=text name=rgb_g size=3 value=0 onChange="newRGB(0,'g')"><input type="Button" value="-" onClick="setRGB('g',-1)">
<font color="#0000FF">蓝</font> <input type="Button" value="+" onClick="setRGB('b',1)"><INPUT type=text name=rgb_b size=3 value=255 onChange="newRGB(0,'b')"><input type="Button" value="-" onClick="setRGB('b',-1)">

</td></tr>

<tr><td>
<TABLE BORDER=1 CELLSPACING=-1 CELLPADDING=1>
<TR>
<TD BGCOLOR="#FFFFFF"><a href="#" onClick="SetColor('FFFFFF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FFFF00"><a href="#" onClick="SetColor('FFFF00');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FFE000"><a href="#" onClick="SetColor('FFE000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FFC000"><a href="#" onClick="SetColor('FFC000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FFA000"><a href="#" onClick="SetColor('FFA000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FF8000"><a href="#" onClick="SetColor('FF8000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FF6000"><a href="#" onClick="SetColor('FF6000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FF4000"><a href="#" onClick="SetColor('FF4000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FF0000"><a href="#" onClick="SetColor('FF0000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#E00000"><a href="#" onClick="SetColor('E00000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#C00000"><a href="#" onClick="SetColor('C00000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FFC0FF"><a href="#" onClick="SetColor('FFC0FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FFA0FF"><a href="#" onClick="SetColor('FFA0FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FF80FF"><a href="#" onClick="SetColor('FF80FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FF60FF"><a href="#" onClick="SetColor('FF60FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#FF00FF"><a href="#" onClick="SetColor('FF00FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#E000FF"><a href="#" onClick="SetColor('E000FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#C000FF"><a href="#" onClick="SetColor('C000FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#A000FF"><a href="#" onClick="SetColor('A000FF');return false" onMouseOver="nomsg();return true">  </a></TD>
</tr><tr>
<TD BGCOLOR="#8000FF"><a href="#" onClick="SetColor('8000FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#00FFFF"><a href="#" onClick="SetColor('00FFFF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#00E0FF"><a href="#" onClick="SetColor('00E0FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#00C0FF"><a href="#" onClick="SetColor('00C0FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#00A0FF"><a href="#" onClick="SetColor('00A0FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#0080FF"><a href="#" onClick="SetColor('0080FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#0060FF"><a href="#" onClick="SetColor('0060FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#0000FF"><a href="#" onClick="SetColor('0000FF');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#0000E0"><a href="#" onClick="SetColor('0000E0');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#0000C0"><a href="#" onClick="SetColor('0000C0');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#D0FF00"><a href="#" onClick="SetColor('D0FF00');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#A0FF00"><a href="#" onClick="SetColor('A0FF00');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#80FF00"><a href="#" onClick="SetColor('80FF00');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#00FF00"><a href="#" onClick="SetColor('00FF00');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#00E000"><a href="#" onClick="SetColor('00E000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#00C000"><a href="#" onClick="SetColor('00C000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#00A000"><a href="#" onClick="SetColor('00A000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#008000"><a href="#" onClick="SetColor('008000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#00A0A0"><a href="#" onClick="SetColor('00A0A0');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#A0A000"><a href="#" onClick="SetColor('A0A000');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#A0A0A0"><a href="#" onClick="SetColor('A0A0A0');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#A0A0E0"><a href="#" onClick="SetColor('A0A0E0');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#E0A0A0"><a href="#" onClick="SetColor('E0A0A0');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#A0E0A0"><a href="#" onClick="SetColor('A0E0A0');return false" onMouseOver="nomsg();return true">  </a></TD>
<TD BGCOLOR="#000000"><a href="#" onClick="SetColor('000000');return false" onMouseOver="nomsg();return true">  </a></TD>
</TR>
</TABLE>
</td></tr>

<tr><td>
显示文字:<input type=text name="showstr" value="南京有线电视台" onChange="AddText()">
</td></tr>

<tr><td>
<input type=hidden name="tempVal" value="">
代码如下:<br>
<TEXTAREA wrap=soft name=code COLS=62 ROWS=6"></TEXTAREA>
</td></tr><tr><td>
<INPUT TYPE="button" VALUE="生成代码" onClick='GenTag(this.form)'>
<INPUT TYPE="button" VALUE="预览效果" onClick='AddText()'>
<INPUT TYPE="reset" VALUE="全部清除">
</td></tr></table>
</form>
</CENTER>
<SPAN ID="fsample" STYLE="position: absolute;left:280;top:460; color: black; font-weight: normal; font-size: 9pt">
<form name="fsample2">
起始颜色<input type=text name="startcolor" size=8 onfocus="this.blur()">
结束颜色<input type=text name="endcolor" size=8 onfocus="this.blur()">
</form>
</SPAN>

<SCRIPT LANGUAGE="JavaScript">
<!--
onload = myReset;
//-->
</SCRIPT>