Swing/JumpToClickedPositionSlider のバックアップソース(No.6)
- バックアップ一覧
- 差分 を表示
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- バックアップ を表示
- Swing/JumpToClickedPositionSlider へ行く。
- 1 (2009-07-27 (月) 11:47:16)
- 2 (2009-07-27 (月) 16:09:39)
- 3 (2009-08-03 (月) 20:23:07)
- 4 (2013-01-08 (火) 18:41:52)
- 5 (2014-09-13 (土) 03:30:00)
- 6 (2014-10-04 (土) 03:36:43)
- 7 (2014-12-02 (火) 01:41:08)
- 8 (2015-07-08 (水) 16:56:43)
- 9 (2015-10-30 (金) 19:29:56)
- 10 (2017-04-07 (金) 13:51:51)
- 11 (2017-04-14 (金) 14:18:55)
- 12 (2017-04-14 (金) 15:39:22)
- 13 (2018-02-24 (土) 19:51:30)
- 14 (2018-04-03 (火) 15:09:58)
- 15 (2019-07-01 (月) 15:32:45)
- 16 (2021-03-11 (木) 19:51:44)
--- title: JSliderでクリックした位置にノブをスライド tags: [JSlider, MouseMotionListener, MouseListener] author: aterai pubdate: 2009-07-27T11:47:16+09:00 --- * 概要 [#n7414230] `JSlider`をマウスでクリックした場合、その位置にノブをスライド、続けてドラッグ可能にします。 #download(https://lh6.googleusercontent.com/_9Z4BYR88imo/TQTOt05WV7I/AAAAAAAAAc0/Eobj6KIAQzk/s800/JumpToClickedPositionSlider.png) * サンプルコード [#o79573fb] #code(link){{ slider.setUI(new MetalSliderUI() { protected TrackListener createTrackListener(JSlider slider) { return new TrackListener() { @Override public void mousePressed(MouseEvent e) { JSlider slider = (JSlider)e.getSource(); switch (slider.getOrientation()) { case JSlider.VERTICAL: slider.setValue(valueForYPosition(e.getY())); break; case JSlider.HORIZONTAL: slider.setValue(valueForXPosition(e.getX())); break; } super.mousePressed(e); //isDragging = true; super.mouseDragged(e); } @Override public boolean shouldScroll(int direction) { return false; } }; } }); }} * 解説 [#bd0e40a6] - 縦の左、横の上 -- デフォルトの動作 -- ノブをクリックすると、ドラッグ可能 -- ノブ以外の場所をクリックすると、タイマーでノブの幅ずつその方向に移動 - 縦の右、横の下 -- クリックした位置までスライドし、続けてドラッグ可能 --- 目盛の間隔が広い場合、ノブがスナップされてマウスカーソルからはずれてしまい、続けてドラッグできない場合がある -- メディアプレイヤー風? * 参考リンク [#w99369c4] - [http://stackoverflow.com/questions/518471/jslider-question-position-after-leftclick JSlider question: Position after leftclick - Stack Overflow] * コメント [#o91edc64] #comment #comment