4

下の画像のように丸みを帯びたスライダーを作成したいと思います。jQueryはこれを行うことができますか?

まっすぐなスライダーがどのように機能するかは知っていますが、HTML5の丸いスライダーを作成したいと思います。これが私がオンラインで見つけたものです http://jsfiddle.net/XdvNg/1/-しかし、ユーザーが手放すスライダー値を取得する方法がわかりません ここに画像の説明を入力してください

4

3 に答える 3

10

これが私が思いついたものです:

jsBinデモ

$(function () {
    var $circle = $('#circle'),
        $handler = $('#handler'),
        $p = $('#test'),
        handlerW2 = $handler.width()/2,
        rad = $circle.width()/2,
        offs = $circle.offset(),
        elPos = {x:offs.left, y:offs.top},
        mHold = 0,
        PI2 = Math.PI/180;
    $handler.mousedown(function() { mHold = 1; });
    $(document).mousemove(function(e) {
        if (mHold) {
            var mPos = {x:e.pageX-elPos.x, y:e.pageY-elPos.y},
                atan = Math.atan2(mPos.x-rad, mPos.y-rad),
                deg  = -atan/PI2+180,
                perc = (deg*100/360)|0,
                X = Math.round(rad*  Math.sin(deg*PI2)),    
                Y = Math.round(rad* -Math.cos(deg*PI2));
            $handler.css({left:X+rad-handlerW2, top:Y+rad-handlerW2, transform:'rotate('+deg+'deg)'});
        }
    }).mouseup(function() { mHold = 0; });
});
于 2012-04-20T14:17:07.373 に答える
4

これがRokoのスクリプトの少し改良されたバージョンです: jsFiddleデモ

マウスの位置を計算するには、イベントオフセット(Firefoxの修正はほとんどありません)を使用し、イベントターゲットが#rotationSliderContainerでない場合に修正しました。90度の倍数にも魅力を加えています。

$(function(){
    var $container = $('#rotationSliderContainer');
    var $slider = $('#rotationSlider');
    var $degrees = $('#rotationSliderDegrees');

    var sliderWidth = $slider.width();
    var sliderHeight = $slider.height();
    var radius = $container.width()/2;
    var deg = 0;    

    X = Math.round(radius* Math.sin(deg*Math.PI/180));
    Y = Math.round(radius*  -Math.cos(deg*Math.PI/180));
    $slider.css({ left: X+radius-sliderWidth/2, top: Y+radius-sliderHeight/2 });

    var mdown = false;
    $container
    .mousedown(function (e) { mdown = true; e.originalEvent.preventDefault(); })
    .mouseup(function (e) { mdown = false; })
    .mousemove(function (e) {
        if(mdown)
        {

            // firefox compatibility
            if(typeof e.offsetX === "undefined" || typeof e.offsetY === "undefined") {
               var targetOffset = $(e.target).offset();
               e.offsetX = e.pageX - targetOffset.left;
               e.offsetY = e.pageY - targetOffset.top;
            }

            if($(e.target).is('#rotationSliderContainer'))
                var mPos = {x: e.offsetX, y: e.offsetY};
            else
                var mPos = {x: e.target.offsetLeft + e.offsetX, y: e.target.offsetTop + e.offsetY};

            var atan = Math.atan2(mPos.x-radius, mPos.y-radius);
            deg = -atan/(Math.PI/180) + 180; // final (0-360 positive) degrees from mouse position 


            // for attraction to multiples of 90 degrees
            var distance = Math.abs( deg - ( Math.round(deg / 90) * 90 ) );

            if( distance <= 5 )
                deg = Math.round(deg / 90) * 90;

            if(deg == 360)
                deg = 0;

            X = Math.round(radius* Math.sin(deg*Math.PI/180));
            Y = Math.round(radius*  -Math.cos(deg*Math.PI/180));

            $slider.css({ left: X+radius-sliderWidth/2, top: Y+radius-sliderHeight/2 });              

            var roundDeg = Math.round(deg);

            $degrees.html(roundDeg + '&deg;');
            $('#imageRotateDegrees').val(roundDeg);

        }
    });
});
于 2012-09-13T09:46:24.677 に答える
1

これが要件に合ったjQueryroundSliderプラグインです。モバイルデバイスやタッチデバイスでも正常に機能します。

このラウンドスライダーには、jQueryuiスライダーと同様のオプションがあります。デフォルト、最小範囲、範囲スライダータイプをサポートします。丸型スライダーだけでなく、四分円、半円、パイ円などのさまざまな円形状にも対応しています。

詳細については、デモドキュメントのページを確認してください。

からのデモを確認してくださいjsFiddle

出力のスクリーンショット:

モバイルラウンドスライダー-jQueryプラグイン

要件に応じて外観をカスタマイズできます。カスタムの外観については、こちらを確認してください。

于 2015-07-13T18:24:26.857 に答える