Summary

JSliderの数値テキストラベルの値を変更した場合、その位置やサイズが正しく描画されるように更新を行うメソッドを実行します。

Source Code Examples

JSlider slider = new JSlider(0, 10000);
slider.putClientProperty("Slider.paintThumbArrowShape", Boolean.TRUE);
slider.setMajorTickSpacing(2500);
slider.setMinorTickSpacing(500);
slider.setPaintLabels(true);
slider.setPaintTicks(true);
slider.setSnapToTicks(true);
// slider.setBorder(BorderFactory.createLineBorder(Color.WHITE, 10));
Dictionary<?, ?> labelTable = slider.getLabelTable();
Collections.list(labelTable.keys()).stream()
    .filter(Integer.class::isInstance)
    .map(Integer.class::cast)
    .forEach(i -> {
      JLabel label = (JLabel) labelTable.get(i);
      label.setText(Objects.toString(i / 100));
    });
slider.setLabelTable(labelTable);
View in GitHub: Java, Kotlin

Explanation

  • Default
    • 最小0、最大10000で作成したJSliderのラベルをその1/100で表示
    • 各ラベルの文字数が変更されてもその幅が更新されないので目盛り中央に数字(文字列)が配置されない
    • NimbusLookAndFeelなどで最大値の100が見切れて10までしか表示されない
  • JSlider#updateLabelUIs()
    • 1/100に変更後、JSlider#updateLabelUIs()を実行してラベルを更新する
    • JSlider#updateLabelUIs()protectedなので内部でこれを呼び出しているJSlider#setLabelTable(...)を実行する
    • JSlider#updateUI()内でもJSlider#updateLabelUIs()を呼び出しているので、代わりにSwingUtilities.updateComponentTreeUI(slider);を実行しても可

Reference

Comment