欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

js实现颜色阶梯渐变效果(Gradient算法)

程序员文章站 2022-04-07 09:51:09
html中颜色可以使用rgb和hex方式来表示。 在色彩中,色相、明度、纯度也都可以产生渐变效果,并会表现出具有丰富层次的美感。本文主要讲述两种颜色rgb数值的梯级渐变算...

html中颜色可以使用rgb和hex方式来表示。

在色彩中,色相、明度、纯度也都可以产生渐变效果,并会表现出具有丰富层次的美感。本文主要讲述两种颜色rgb数值的梯级渐变算法。

其中如如16进制颜色如#336600分别表示rgb模式中r的值为16进制33(即),g的值为16进制的66,和b为16进制的00,转换后用rgb完整表述为:rgb(51,102,0)。

其中使用16进制进行加减乘除不方便,尤其还使用了rgb的16进制颜色组合(#336600)。因此我们可以将16进制转换为rgb单个进行梯级运算在进行组合。

已知:rstart=50,rend=200,rstart、rend之间平均分成3份(step=3),求每份的数值(stepn)分别是多少。

公式:gradient = rstart+ (rend-rstart) / step * n (第n步的颜色rgb中r的值)

实现方法非常简单,只是需要将颜色从rgb到hex的互转。

实现代码:

<script type="text/javascript">
 /*
 // 作者 yanue
 // 参数:
 // startcolor:开始颜色hex
 // endcolor:结束颜色hex
 // step:几个阶级(几步)
 */
 function gradientcolor(startcolor,endcolor,step){
  startrgb = this.colorrgb(startcolor);//转换为rgb数组模式
  startr = startrgb[0];
  startg = startrgb[1];
  startb = startrgb[2];
  endrgb = this.colorrgb(endcolor);
  endr = endrgb[0];
  endg = endrgb[1];
  endb = endrgb[2];
  sr = (endr-startr)/step;//总差值
  sg = (endg-startg)/step;
  sb = (endb-startb)/step;
  var colorarr = [];
  for(var i=0;i<step;i++){
  //计算每一步的hex值 
   var hex = this.colorhex('rgb('+parseint((sr*i+startr))+','+parseint((sg*i+startg))+','+parseint((sb*i+startb))+')');
   colorarr.push(hex);
  }
  return colorarr;
 }
 // 将hex表示方式转换为rgb表示方式(这里返回rgb数组模式)
 gradientcolor.prototype.colorrgb = function(scolor){
  var reg = /^#([0-9a-fa-f]{3}|[0-9a-fa-f]{6})$/;
  var scolor = scolor.tolowercase();
  if(scolor && reg.test(scolor)){
   if(scolor.length === 4){
    var scolornew = "#";
    for(var i=1; i<4; i+=1){
     scolornew += scolor.slice(i,i+1).concat(scolor.slice(i,i+1));
    }
    scolor = scolornew;
   }
   //处理六位的颜色值
   var scolorchange = [];
   for(var i=1; i<7; i+=2){
    scolorchange.push(parseint("0x"+scolor.slice(i,i+2)));
   }
   return scolorchange;
  }else{
   return scolor;
  }
 };
 // 将rgb表示方式转换为hex表示方式
 gradientcolor.prototype.colorhex = function(rgb){
  var _this = rgb;
  var reg = /^#([0-9a-fa-f]{3}|[0-9a-fa-f]{6})$/;
  if(/^(rgb|rgb)/.test(_this)){
   var acolor = _this.replace(/(?:(|)|rgb|rgb)*/g,"").split(",");
   var strhex = "#";
   for(var i=0; i<acolor.length; i++){
    var hex = number(acolor[i]).tostring(16);
    hex = hex<10 ? 0+''+hex :hex;// 保证每个rgb的值为2位
    if(hex === "0"){
     hex += hex;
    }
    strhex += hex;
   }
   if(strhex.length !== 7){
    strhex = _this;
   }
   return strhex;
  }else if(reg.test(_this)){
   var anum = _this.replace(/#/,"").split("");
   if(anum.length === 6){
    return _this;
   }else if(anum.length === 3){
    var numhex = "#";
    for(var i=0; i<anum.length; i+=1){
     numhex += (anum[i]+anum[i]);
    }
    return numhex;
   }
  }else{
   return _this;
  }
 }
 var gradient = new gradientcolor('#013548','#554851',10);
 console.log(gradient);//控制台输出
 alert(gradient);
</script>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!