• category: swing folder: SpinnerButtonLayout title: JSpinnerのボタンを左右に配置する tags: [JSpinner, ArrowButton, LayoutManager] author: aterai pubdate: 2011-01-24T14:15:43+09:00 description: JSpinnerのレイアウトを変更して、矢印ボタンを左右に配置します。 image: https://lh5.googleusercontent.com/_9Z4BYR88imo/TT0IT-0k7EI/AAAAAAAAAzA/8LBM7qgDVvw/s800/SpinnerButtonLayout.png

概要

JSpinnerのレイアウトを変更して、矢印ボタンを左右に配置します。

サンプルコード

class SpinnerLayout extends BorderLayout {
  @Override public void addLayoutComponent(Component comp, Object constraints) {
    Object cons = constraints;
    if ("Editor".equals(constraints)) {
      cons = "Center";
    } else if ("Next".equals(constraints)) {
      cons = "East";
    } else if ("Previous".equals(constraints)) {
      cons = "West";
    }
    super.addLayoutComponent(comp, cons);
  }
}
View in GitHub: Java, Kotlin

解説

  • Default
    • デフォルト
    • 右端に2つのボタンが配置される
    • 右端に増加ボタン、減少ボタンを配置
  • RIGHT_TO_LEFT
    • JSpinner#setComponentOrientation(ComponentOrientation.RIGHT_TO_LEFT)で、ボタンを左側に配置
    • JSpinner#setComponentOrientation(ComponentOrientation.RIGHT_TO_LEFT)で各ボタンを左側に配置
  • L(Prev), R(Next): 1
    • BorderLayout#addLayoutComponent(...)をオーバーライドして、EditorCenterNextEastPrevWestに配置するレイアウトマネージャーを作成して使用
    • BorderLayout#addLayoutComponent(...)をオーバーライドしてEditorCenterNextEastPrevWestに配置するレイアウトマネージャーを作成
      JSpinner spinner = new JSpinner(model) {
        @Override public void updateUI() {
          super.updateUI();
          setUI(new BasicSpinnerUI() {
            @Override protected LayoutManager createLayout() {
              return new SpinnerLayout();
            }
          });
        }
      };
      
  • L(Prev), R(Next): 2
    • L(Prev), R(Next): 1と同じレイアウトマネージャーをJSpinner#setLayout(...)メソッドをオーバーライドして設定
      JSpinner spinner = new JSpinner(model) {
        @Override public void setLayout(LayoutManager mgr) {
          super.setLayout(new SpinnerLayout());
        }
      };
      

参考リンク

コメント