javascript - Java颜色整数到JavaScript中的RGB字符串

标签 javascript java colors rgb

我正在尝试在 Javascript 中使用数据库中的一些 Java Color int 值。使用Javascript将Java颜色int(如-2147473665)转换为RGB字符串(如'#ffff00')的正确方法是什么?

现在我正在取数字,将其翻转为负数,将其转换为十六进制,并添加一个标签,但这给了我错误的颜色。 (子字符串是为了说明 alpha channel )

function getClients() {
  var query = new Parse.Query(Client);

  query.each(function(client) {
    var clientName = client.get("clientName");
    var borderColor = '#' + (-client.get("borderColor")).toString(16);
    var fillColor = '#' + (-client.get("fillColor")).toString(16).substr(2);
    var outline = client.get("outline");

    console.log(client.get("borderColor"));
    console.log(client.get("borderColor").toString(16));
    console.log(hexToRGB(client.get("borderColor")));

    var clientPoly = new google.maps.Polygon({
      paths: outline,
      strokeColor: borderColor,
      strokeOpacity: 1,
      strokeWeight: 2,
      fillColor: fillColor,
      fillOpacity: 0.5
    });

    clientPoly.setMap(mMap);
  });
}

例如,int -16767233 应该是海军蓝,但它显示为黄色。

-16731137 应该是浅蓝色的,但它是红色的

-1218518 应该是橙色的,但它是蓝色的

正确的颜色:
Correct colors

这就是我用当前代码在 JS 中得到的
This is what I get in JS with my current code

这里发生了什么??我知道它应该是 RGB,而不是 HSV,所以不是这样......

最佳答案

您需要处理有符号整数。见 How to convert decimal to hex in JavaScript?

console.log(getHexColor(-16731137)); // light blue
console.log(getHexColor(-1218518)); // orange

function getHexColor(number){
    return "#"+((number)>>>0).toString(16).slice(-6);
}

关于javascript - Java颜色整数到JavaScript中的RGB字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37795241/

相关文章:

javascript - 为什么我的 Canvas 在一段时间后性能会下降?

java - 使 ReflectionToStringBuilder 跳过具有空值的字段

java - 该字符串中的哪些字符会抛出错误 invalid character constant?

java - JzAzBz java实现精度

java - 在Java中创建随机颜色?

javascript - 更改文本框输入的背景颜色在为空时不起作用

javascript - 我可以在函数数组中放入一行指令吗?

javascript - 在 Javascript 中使用 Google 文字转语音

javascript - 模态不会关闭并防止在没有点击时默认,并且不会在点击时执行 func

Java:在网站上查找JAR文件的主类