Swing/SnapToTicksDrag のバックアップ(No.3)
- バックアップ一覧
- 差分 を表示
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- Swing/SnapToTicksDrag へ行く。
- 1 (2009-12-21 (月) 11:01:51)
- 2 (2009-12-21 (月) 16:43:54)
- 3 (2010-09-14 (火) 12:09:26)
- 4 (2010-10-26 (火) 15:30:26)
- 5 (2010-10-26 (火) 19:14:48)
- 6 (2012-01-01 (日) 14:52:57)
- 7 (2012-08-17 (金) 18:39:12)
- 8 (2013-01-03 (木) 14:14:03)
- 9 (2013-06-22 (土) 13:39:59)
- 10 (2014-12-02 (火) 01:42:42)
- 11 (2015-07-08 (水) 16:59:44)
- 12 (2016-06-01 (水) 21:48:40)
- 13 (2017-09-12 (火) 14:26:27)
- 14 (2017-11-14 (火) 17:25:07)
- 15 (2018-02-24 (土) 19:51:30)
- 16 (2019-05-30 (木) 18:36:47)
- 17 (2021-02-20 (土) 09:51:26)
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