Swing/SpinnerButtonLayout のバックアップの現在との差分(No.2)
- バックアップ一覧
- 差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- バックアップ を表示
- Swing/SpinnerButtonLayout へ行く。
- 追加された行はこの色です。
- 削除された行はこの色です。
TITLE:JSpinnerのボタンを左右に配置する #navi(../) #tags() RIGHT:Posted by &author(aterai); at 2011-01-24 *JSpinnerのボタンを左右に配置する [#le03b7c8] JSpinnerのレイアウトを変更して、矢印ボタンを左右に配置します。 --- 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 --- * 概要 [#summary] `JSpinner`のレイアウトを変更して、矢印ボタンを左右に配置します。 -&jnlp; -&jar; -&zip; #download(https://lh5.googleusercontent.com/_9Z4BYR88imo/TT0IT-0k7EI/AAAAAAAAAzA/8LBM7qgDVvw/s800/SpinnerButtonLayout.png) //#screenshot #ref(http://lh5.ggpht.com/_9Z4BYR88imo/TT0IT-0k7EI/AAAAAAAAAzA/8LBM7qgDVvw/s800/SpinnerButtonLayout.png) **サンプルコード [#nc3f3cd5] * サンプルコード [#sourcecode] #code(link){{ class SpinnerLayout extends BorderLayout { @Override public void addLayoutComponent(Component comp, Object constraints) { String str = ""; if("Editor".equals(constraints)) { str = "Center"; } else if("Next".equals(constraints)) { str = "East"; } else if("Previous".equals(constraints)) { str = "West"; 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, str); super.addLayoutComponent(comp, cons); } } }} **解説 [#c473abc6] -Default * 解説 [#explanation] - `Default` -- デフォルト -RIGHT_TO_LEFT -- JSpinner#setComponentOrientation(ComponentOrientation.RIGHT_TO_LEFT)で、ボタンを左側に配置 -L(Prev), R(Next): 1 -- BorderLayout#addLayoutComponent(...)をオーバーライドして、EditorをCenter、NextをEast、PrevをWestに配置するレイアウトマネージャを作成して使用 -- 右端に増加ボタン、減少ボタンを配置 - `RIGHT_TO_LEFT` -- `JSpinner#setComponentOrientation(ComponentOrientation.RIGHT_TO_LEFT)`で各ボタンを左側に配置 - `L(Prev), R(Next): 1` -- `BorderLayout#addLayoutComponent(...)`をオーバーライドして`Editor`を`Center`、`Next`を`East`、`Prev`を`West`に配置するレイアウトマネージャーを作成 #code{{ 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(...)メソッドをオーバーライドして設定 - `L(Prev), R(Next): 2` -- `L(Prev), R(Next): 1`と同じレイアウトマネージャーを`JSpinner#setLayout(...)`メソッドをオーバーライドして設定 #code{{ JSpinner spinner = new JSpinner(model) { @Override public void setLayout(LayoutManager mgr) { super.setLayout(new SpinnerLayout()); } }; }} //**参考リンク **コメント [#ea28402e] * 参考リンク [#reference] - [https://docs.oracle.com/javase/jp/8/docs/api/javax/swing/plaf/basic/BasicSpinnerUI.html#createLayout-- BasicSpinnerUI#createLayout() (Java Platform SE 8)] * コメント [#comment] #comment #comment