javascript - 如何计算较暗的十六进制颜色

标签 javascript

使用this solution我正在尝试计算一种颜色的较暗范围,但输出看起来不像正确的十六进制值(缺少一个值)。

> #84079

我做错了什么?

function LightenDarkenColor(col, amt) {
  
    var usePound = false;
  
    if (col[0] == "#") {
        col = col.slice(1);
        usePound = true;
    }
 
    var num = parseInt(col,16);
 
    var r = (num >> 16) + amt;
 
    if (r > 255) r = 255;
    else if  (r < 0) r = 0;
 
    var b = ((num >> 8) & 0x00FF) + amt;
 
    if (b > 255) b = 255;
    else if  (b < 0) b = 0;
 
    var g = (num & 0x0000FF) + amt;
 
    if (g > 255) g = 255;
    else if (g < 0) g = 0;
 
    return (usePound?"#":"") + (g | (b << 8) | (r << 16)).toString(16);
  
}
var firstColor = LightenDarkenColor("#3068A1", -20); 
var NewColor = LightenDarkenColor(firstColor, -20); 

console.log(NewColor);

最佳答案

更改此:

(usePound?"#":"") + (g | (b << 8) | (r << 16)).toString(16);

到此

(usePound?"#":"") + ('00000'+(b | (g << 8) | (r << 16)).toString(16)).slice(-6);

这将确保有 6 位数字,并修复了原始文章中关闭的绿色和蓝色位置。

  • (r << 16)将红色移动到位 32 到 47
  • (g << 8)将绿色移动到位 16 到 31
  • b将蓝色保留在 0-15 位中。

更新

正如所指出的那样 bg变量也读取错误的值。因此您还需要执行以下操作:

var g = ((num >> 8) & 0x00FF) + amt;

var b = (num & 0x0000FF) + amt;

交换bg获取他们的值。

如果您不想交换它们,请将我原来的行更改为:

(usePound?"#":"") + ('00000'+(g | (b << 8) | (r << 16)).toString(16)).slice(-6);

关于javascript - 如何计算较暗的十六进制颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48195882/

相关文章:

javascript - 为什么是 {} || 3 Javascript中的语法错误?

javascript - 在 AngularJs 中创建 'widgets' 的建议方法是什么?

javascript - Alfresco 自定义 UI 控件 - 关联

javascript - Vuejs 动态访问数据值

javascript - 我的 HTML 正在自行重新排列,这是怎么发生的?

javascript - 移动后使可移动图像按钮静止

javascript - 我必须单击显示按钮两次才能将数据呈现到屏幕上?

javascript - 如何在 html 或 javascript 中自动左对齐图像

javascript - 我如何使用 getOptions 检索 Jcrop 中的 truesize 数组值?

javascript - 如何更改Javascript音频对象src?