在JavaScript中将float转换为32位十六进制字符串

时间:2017-11-07 18:06:21

标签: javascript floating-point hex

我有一个表示gps坐标的浮点值,我喜欢将其转换为32位十六进制字符串。

我尝试了here所描述的每个解决方案,但每一次,结果都不是我所期待的。

例如,大多数'ToHex'功能:

var lat = 45.839152;
console.log(ToHex(lat));

给我'2d.56d0b30b5aa8'

但是我期待'{42}转换

的结果为'42355b43'

你知道如何在JavaScript中获得'42355b43'吗?

谢谢!

2 个答案:

答案 0 :(得分:3)

您可以使用TypedArrayArrayBuffer获取DataView个对象。

然后将值设置为float 32,并将值视为无符号整数8位。

const getHex = i => ('00' + i.toString(16)).slice(-2);

var view = new DataView(new ArrayBuffer(4)),
    result;

view.setFloat32(0, 45.839152);

result = Array
    .apply(null, { length: 4 })
    .map((_, i) => getHex(view.getUint8(i)))
    .join('');

console.log(result);

答案 1 :(得分:0)

我最终决定编写自己的函数。我在这里发布它可以帮助人们:

function ToHex(d) {

    var sign = "0";

    if(d<0.0){
        sign = "1";
        d = -d;
    }

    var mantissa = parseFloat(d).toString(2);

    var exponent = 0;

    if(mantissa.substr(0,1) === "0"){
        exponent = mantissa.indexOf('.') - mantissa.indexOf('1') + 127;
    }
    else{
        exponent = mantissa.indexOf('.') - 1 + 127;
    }

    mantissa = mantissa.replace(".", "");
    mantissa = mantissa.substr(mantissa.indexOf('1')+1);

    if(mantissa.length>23){
        mantissa = mantissa.substr(0,23);
    }
    else{
        while(mantissa.length<23){
            mantissa = mantissa +"0";
        }
    }

    var exp = parseFloat(exponent).toString(2);

    while(exp.length<8){
        exp = "0" + exp;
    }

    var numberFull = sign + exp + mantissa;

    return parseInt(numberFull, 2).toString(16);
}