js rgb颜色阶梯渐变效果实现

Posted asia9847

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js rgb颜色阶梯渐变效果实现相关的知识,希望对你有一定的参考价值。

核心代码

function gradientColor(startColor, endColor, step) 
    
    var startRGB = this.colorRgb(startColor);//转换为rgb数组模式
    var startR = startRGB[0];
    var startG = startRGB[1];
    var startB = startRGB[2];
    var endRGB = this.colorRgb(endColor);
    var endR = endRGB[0];
    var endG = endRGB[1];
    var endB = endRGB[2];
    var sR = (endR - startR) / step;//总差值
    var sG = (endG - startG) / step;
    var 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;
    

export 
    gradientColor

调用

let colors = new gradientColor(this.getColor(),'#FFFFFF',10)

以上是关于js rgb颜色阶梯渐变效果实现的主要内容,如果未能解决你的问题,请参考以下文章

Shader Forge 实现颜色渐变、透明度渐变效果

Android颜色渐变动画效果的实现

Android颜色渐变动画效果的实现

如何CSS实现网页背景三种颜色渐变效果?

android imageview 颜色渐变实现三维效果怎么弄

JS实现背景渐变轮换(已有背景轮换代码,只要一个轮换效果就可以)