gpt4 book ai didi

javascript - 对数 slider

转载 作者:IT王子 更新时间:2023-10-29 02:50:43 28 4
gpt4 key购买 nike

我有一个数值范围为 0 到 100 的 slider 。

我想将它们映射到 100 到 10,000,000 的范围内。

我在网上看到过一些函数,但它们都是用 C++ 编写的。我需要它在 Javascript 中。

有什么想法吗?

最佳答案

您可以使用这样的函数:

function logslider(position) {
// position will be between 0 and 100
var minp = 0;
var maxp = 100;

// The result should be between 100 an 10000000
var minv = Math.log(100);
var maxv = Math.log(10000000);

// calculate adjustment factor
var scale = (maxv-minv) / (maxp-minp);

return Math.exp(minv + scale*(position-minp));
}

结果值匹配对数刻度:

js> logslider(0);
100.00000000000004
js> logslider(10);
316.22776601683825
js> logslider(20);
1000.0000000000007
js> logslider(40);
10000.00000000001
js> logslider(60);
100000.0000000002
js> logslider(100);
10000000.000000006

反向函数将与 minpmaxpminvmaxv 具有相同的定义code>scale,从这样的值计算 slider 位置:

function logposition(value) {
// set minv, ... like above
// ...
return (Math.log(value)-minv) / scale + minp;
}


全部一起包装在一个类中并作为功能代码片段,它看起来像这样:

// Generic class:

function LogSlider(options) {
options = options || {};
this.minpos = options.minpos || 0;
this.maxpos = options.maxpos || 100;
this.minlval = Math.log(options.minval || 1);
this.maxlval = Math.log(options.maxval || 100000);

this.scale = (this.maxlval - this.minlval) / (this.maxpos - this.minpos);
}

LogSlider.prototype = {
// Calculate value from a slider position
value: function(position) {
return Math.exp((position - this.minpos) * this.scale + this.minlval);
},
// Calculate slider position from a value
position: function(value) {
return this.minpos + (Math.log(value) - this.minlval) / this.scale;
}
};


// Usage:

var logsl = new LogSlider({maxpos: 20, minval: 100, maxval: 10000000});

$('#slider').on('change', function() {
var val = logsl.value(+$(this).val());
$('#value').val(val.toFixed(0));
});

$('#value').on('keyup', function() {
var pos = logsl.position(+$(this).val());
$('#slider').val(pos);
});

$('#value').val("1000").trigger("keyup");
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

Input value or use slider:
<input id="value" />
<input id="slider" type="range" min="0" max="20" />

关于javascript - 对数 slider ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/846221/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com