JSliderでマウスドラッグによる値の変更が可能な範囲を制限する
Total: 3890
, Today: 3
, Yesterday: 1
Posted by aterai at
Last-modified:
概要
JSlider
の最小・最大値とは別に、マウスドラッグによる値の変更可能範囲を制限します。
Screenshot
Advertisement
サンプルコード
class MetalDragLimitedSliderUI extends MetalSliderUI {
@Override protected TrackListener createTrackListener(JSlider slider) {
return new TrackListener() {
@Override public void mouseDragged(MouseEvent e) {
// case HORIZONTAL:
int halfThumbWidth = thumbRect.width / 2;
int thumbLeft = e.getX() - offset;
int maxPos = xPositionForValue(MAXI) - halfThumbWidth;
if (thumbLeft > maxPos) {
e.translatePoint(maxPos + offset - e.getX(), 0);
}
super.mouseDragged(e);
}
};
}
}
View in GitHub: Java, Kotlin解説
上記のサンプルでは、最小値0
、最大値100
の目盛りを持つJSlider
を作成し、その目盛りの範囲とは別に取りうる値を制限するためのリスナーを設定しています。
ChangeListener
JSlider
のBoundedRangeModel
にChangeListener
を追加し、80
以上の値を指定できないように設定- マウスドラッグで
100
まで移動するとリリースした時点で80
の位置まで戻る
TrackListener
- 上の
ChangeListener
に加えてMetalSliderUI#createTrackListener(...)
をオーバーライドした独自のTrackListener
を設定しマウスドラッグで80
以上に移動できないように制限 TrackListener
はMouseMotionListener
を実装しているのでmouseDragged(...)
メソッドをオーバーライドして80
以上へのMouseEvent
をtranslatePoint(...)
メソッドで座標変換して無効化consume()
メソッドで消費して無効化
- 上の