fade-color-pictogram
Version:
一个简单的渐变色象形图
92 lines (85 loc) • 2.67 kB
JavaScript
// 将hex表示方式转换为rgb表示方式(这里返回rgb数组模式)
function colorToRgb(sColorVal) {
const reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/
let sColor = sColorVal.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 (let i = 1; i < 7; i += 2) {
sColorChange.push(parseInt('0x' + sColor.slice(i, i + 2)))
}
return sColorChange
} else {
return sColor
}
};
// 将rgb表示方式转换为hex表示方式
function colorToHex(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 (let i = 0; i < aNum.length; i += 1) {
numHex += (aNum[i] + aNum[i])
}
return numHex
}
} else {
return _this
}
}
export default {
/**
*
* @param {string} startColor 开始颜色hex
* @param {string} endColor 结束颜色hex
* @param {string} step 几个阶级(几步)
* @returns 返回hex类型的色值集合
*/
gradientColor(startColor, endColor, step) {
const startRGB = colorToRgb(startColor)// 转换为rgb数组模式
const startR = startRGB[0]
const startG = startRGB[1]
const startB = startRGB[2]
const endRGB = colorToRgb(endColor)
const endR = endRGB[0]
const endG = endRGB[1]
const endB = endRGB[2]
const sR = (endR - startR) / step// 总差值
const sG = (endG - startG) / step
const sB = (endB - startB) / step
var colorArr = []
for (var i = 0; i < step; i++) {
// 计算每一步的hex值
var hex = colorToHex('rgb(' + parseInt((sR * i + startR)) + ',' + parseInt((sG * i + startG)) + ',' + parseInt((sB * i + startB)) + ')')
colorArr.push(hex)
}
return colorArr
}
}