jQuery:创建一个圆形滑块

时间:2008-12-08 23:55:55

标签: javascript jquery jquery-ui slider draggable

您之前可能已经看过JavaScript滑块:

http://dev.jquery.com/view/tags/ui/1.5b2/demos/ui.slider.html

我想象的是一个圆形滑块。它将包含圆圈上一个点上的可拖动按钮 - 该按钮可以沿着环的任何位置拖动。该值取决于按钮的位置(想想时钟)。

4 个答案:

答案 0 :(得分:3)

定义中心点c 当前鼠标点在m

在鼠标拖动事件处理程序中,你有

var dx = m.x-c.x;
var dy = m.y-c.y;

var scale = radius/Math.sqrt(dx*dx+dy*dy);

slider.x = dx*scale + c.x;
slider.y = dy*scale + c.y;

半径是滑块的某个预设值,

答案 1 :(得分:1)

答案 2 :(得分:0)

我写了jQuery plugin,支持完整/半圆滑块。

Demo Page& Documentation

答案 3 :(得分:0)

从这里http://roundsliderui.com/检查jQuery roundSlider插件。这正是你想要的。

这个滑翔机有类似jQuery ui滑块的选项。它支持默认,最小范围和范围滑块类型。不仅圆形滑块还支持各种circle shapes,例如四分之一一半饼形圆形状。

有关详细信息,请查看demosdocumentation页。

请从jsFiddle查看演示。

相关回答: https://stackoverflow.com/a/31367164/1845801https://stackoverflow.com/a/31369265/1845801

<强>截图:

jquery circular sliders - different circle shapes