TITLE:JSliderのSnapToTicksをマウスのドラッグでも適用する

Posted by terai at 2009-12-14

JSliderのSnapToTicksをマウスのドラッグでも適用する

JSliderのSnapToTicksをマウスでのドラッグ中にも適用されるように設定します。

  • &jnlp;
  • &jar;
  • &zip;

#screenshot

サンプルコード

slider.setUI(new MetalSliderUI() {
  protected TrackListener createTrackListener(final JSlider slider) {
    return new TrackListener() {
      public void mouseDragged(MouseEvent e) {
        //case JSlider.HORIZONTAL:
        int halfThumbWidth    = thumbRect.width / 2;
        int trackLength = trackRect.width;
        int trackLeft   = trackRect.x - halfThumbWidth;
        int trackRight  = trackRect.x + (trackRect.width - 1) + halfThumbWidth;
        int xPos = e.getX();
        int snappedPos = xPos;
        if(xPos <= trackLeft) {
          snappedPos = trackLeft;
        }else if(xPos >= trackRight) {
          snappedPos = trackRight;
        }else{
          int tickSpacing = slider.getMajorTickSpacing();
          float temp = trackLength * tickSpacing / (float)slider.getMaximum();
          xPos -= trackLeft;
          snappedPos = (int)((Math.round(xPos/temp) * temp) + 0.5) + trackLeft;
          offset = 0;
          //System.out.println(snappedPos);
        }
        MouseEvent me = new MouseEvent(
          e.getComponent(), e.getID(), e.getWhen(), e.getModifiers(),
          snappedPos, e.getY(),
          e.getXOnScreen(), e.getYOnScreen(),
          e.getClickCount(), e.isPopupTrigger(), e.getButton());
        super.mouseDragged(me);
      }
    };
  }
});

解説

  • 上:デフォルト
    • slider.setSnapToTicks(true);としているので、マウスをリリースした時点で、ノブを置いた位置にもっとも近い目盛にスナップされる
  • 下:
    • TrackListener#mouseDraggedをオーバーライドして、マウスでドラッグ中でもカーソルからもっとも近い目盛にスナップされる

コメント

  • JSlider.HORIZONTAL にしか対応していません。 -- terai