js 怎么把一个16进制颜色转成相近的颜色
时间: 2023-10-26 15:17:05 浏览: 64
颜色获取工具 直接转换成16进制
4星 · 用户满意度95%
可以使用以下的算法将16进制颜色转成相近的颜色:
1. 将16进制颜色分解成红、绿、蓝三个分量。
2. 对于每一个分量,计算出其离相邻颜色的距离,然后找出颜色距离最小的相邻颜色。
3. 用新的相邻颜色替代原来的颜色,得到新的颜色。
下面是一个实现相似颜色算法的Javascript代码片段:
```javascript
function approximateColor(hexColor) {
// 将16进制颜色转换成RGB颜色值
var r = parseInt(hexColor.slice(1,3), 16);
var g = parseInt(hexColor.slice(3,5), 16);
var b = parseInt(hexColor.slice(5,7), 16);
// 原始颜色到相近颜色的映射表
var colorMap = {
'0': '0',
'1': '1',
'2': '2',
'3': '3',
'4': '4',
'5': '5',
'6': '6',
'7': '7',
'8': '8',
'9': '9',
'a': 'a',
'b': 'b',
'c': 'c',
'd': 'd',
'e': 'e',
'f': 'f'
};
// 颜色分量的相邻颜色列表
var colors = {
r: ['00', '33', '66', '99', 'cc', 'ff'],
g: ['00', '33', '66', '99', 'cc', 'ff'],
b: ['00', '33', '66', '99', 'cc', 'ff']
};
// 计算颜色距离最小的相邻颜色
function findNearestColor(c, type) {
var minDistance = -1; // 最小距离初始化为-1
for (var i = 0; i < colors[type].length; i++) {
var distance = Math.abs(parseInt(colors[type][i], 16) - c);
if (minDistance === -1 || distance < minDistance) {
minDistance = distance;
var nearestColor = colors[type][i];
}
}
return nearestColor;
}
// 计算新的颜色值
var newR = colorMap[findNearestColor(r, 'r')];
var newG = colorMap[findNearestColor(g, 'g')];
var newB = colorMap[findNearestColor(b, 'b')];
// 返回新的颜色值
return '#' + newR + newG + newB;
}
```
调用示例:
```javascript
var hexColor = '#ff8c00'; // 这是一个16进制颜色值
var approxColor = approximateColor(hexColor); // 这是相近的颜色值
console.log(approxColor);
```
阅读全文