Swing/SnapToTicksDrag のバックアップ差分(No.7)
- バックアップ一覧
- 現在との差分 を表示
- 現在との差分 - 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をマウスのドラッグでも適用する #navi(../) RIGHT:Posted by [[aterai]] at 2009-12-14 RIGHT:Posted by &author(aterai); at 2009-12-14 *JSliderのSnapToTicksをマウスのドラッグでも適用する [#ec2028a2] JSliderのSnapToTicksをマウスでのドラッグ中にも適用されるように設定します。 -&jnlp; -&jar; -&zip; //#screenshot #ref(http://lh6.ggpht.com/_9Z4BYR88imo/TQTTU-ruijI/AAAAAAAAAkM/p3Mze4pjyEk/s800/SnapToTicksDrag.png) **サンプルコード [#hccb5c20] #code{{ #code(link){{ slider.setUI(new MetalSliderUI() { protected TrackListener createTrackListener(final JSlider slider) { @Override protected TrackListener createTrackListener(final JSlider slider) { return new TrackListener() { public void mouseDragged(MouseEvent e) { @Override public void mouseDragged(MouseEvent e) { if(!slider.getSnapToTicks() || slider.getMajorTickSpacing()==0) { super.mouseDragged(e); return; } //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 actualPixelsForOneTick = trackLength * tickSpacing // / (float)slider.getMaximum(); // a problem if you choose to set a negative MINIMUM for // the JSlider; the calculated drag-positions are wrong. // Fixed by bobndrew: int possibleTickPositions=slider.getMaximum()-slider.getMinimum(); int tickSpacing = (slider.getMinorTickSpacing()==0) ? slider.getMajorTickSpacing() : slider.getMinorTickSpacing(); float actualPixelsForOneTick = trackLength * tickSpacing / (float)possibleTickPositions; xPos -= trackLeft; snappedPos=(int)((Math.round( xPos/actualPixelsForOneTick)*actualPixelsForOneTick)+0.5)+trackLeft; offset = 0; } 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); } }; } }); }} **解説 [#idd12036] -上:デフォルト --slider.setSnapToTicks(true);としているので、マウスをリリースした時点で、ノブを置いた位置にもっとも近い目盛にスナップされる -下: --TrackListener#mouseDraggedをオーバーライドして、マウスでドラッグ中でもカーソルからもっとも近い目盛にスナップされる //**参考リンク **コメント [#h246efdc] - JSlider.HORIZONTAL にしか対応していません。 -- [[aterai]] &new{2009-12-21 (月) 11:01:51}; - bobndrewさんからの指摘で、ミニマムにマイナスの値を入れるとおかしくなるバグ修正と、MinorTickSpacingに対応。 -- [[aterai]] &new{2010-10-26 (火) 15:32:11}; #comment