対数スライダーに使用するこの jQuery UI コードを使用しています。
var minVal = 10;
var maxVal = 100;
$("#slider").slider({
range: true,
min: minVal,
max: maxVal / 2,
values: [minVal, maxVal],
slide: function(event, ui) {
$("#amount_min").val(Number(expon(ui.values[0], minVal, maxVal)).toFixed(0));
$("#amount_max").val(Number(expon(ui.values[1], minVal, maxVal)).toFixed(0));
}
});
expon
機能は次のとおりです。
function expon(val, min,max) {
var minv = Math.log(min);
var maxv = Math.log(max);
max = max / 2;
// calculate adjustment factor
var scale = (maxv - minv) / (max - min);
return Math.exp(minv + scale * (val - min));
}
#amount_min
および#amount_max
HTML 入力要素です。上記のコードは、スライダーから値を取得して入力要素に配置するのに問題なく機能します。
しかし、今は逆の機能が必要ですexpon()
— 入力の値を変更するときにスライダーを変更します。誰でもこれで私を助けることができますか?