- 型パラメータ:
E
- このリストの要素の型
- すべての実装されたインタフェース:
ImageObserver
,MenuContainer
,Serializable
,Accessible
,Scrollable
ListModel
が、リストの内容を保持します。
読取り専用のListModel
のインスタンスを自動生成するJList
コンストラクタを使用すれば、オブジェクトの配列またはVectorを簡単に表示できます。
// Create a JList that displays strings from an array
String[] data = {"one", "two", "three", "four"};
JList<String> myList = new JList<String>(data);
// Create a JList that displays the superclasses of JList.class, by
// creating it with a Vector populated with this data
Vector<Class<?>> superClasses = new Vector<Class<?>>();
Class<JList> rootClass = javax.swing.JList.class;
for(Class<?> cls = rootClass; cls != null; cls = cls.getSuperclass()) {
superClasses.addElement(cls);
}
JList<Class<?>> myList = new JList<Class<?>>(superClasses);
// The automatically created model is stored in JList's "model"
// property, which you can retrieve
ListModel<Class<?>> model = myList.getModel();
for(int i = 0; i < model.getSize(); i++) {
System.out.println(model.getElementAt(i));
}
コンストラクタまたはsetModel
メソッドを使用して、ListModel
をJList
に直接指定できます。 コンテンツがstaticである必要はありません。項目数や項目の値は、時間の経過とともに変化してもかまいません。 ListModel
が正しく実装されていれば、変更が発生するたびに、追加されたjavax.swing.event.ListDataListener
のセットに通知が送られます。 これらの変更は、修正、追加または削除されたリスト・インデックスの範囲を識別するjavax.swing.event.ListDataEvent
によって記述されます。 JList
のListUI
は、モデルの変更を待機することによって、視覚表現が常に最新の状態になるようにします。
単純な動的コンテンツのJList
アプリケーションは、DefaultListModel
クラスを使用してリスト要素を管理できます。 このクラスは、ListModel
インタフェースを実装し、java.util.Vector
と同様のAPIも提供します。 一方、カスタムListModel
実装を必要とするアプリケーションは、リスナーの管理および通知に関する基本機能を提供するAbstractListModel
のサブクラスとすることができます。 たとえば、AbstractListModel
の読取り専用実装の場合、次のようになります。
// This list model has about 2^16 elements. Enjoy scrolling.
ListModel<String> bigData = new AbstractListModel<String>() {
public int getSize() { return Short.MAX_VALUE; }
public String getElementAt(int index) { return "Index " + index; }
};
JList
の選択状態は、ListSelectionModel
のインスタンスである別のモデルによって管理されます。 JList
は、構築時に選択モデルによって初期化され、また、この選択モデルの照会や設定を行う各メソッドを含んでいます。 JList
は、選択を簡単に管理できる便利なメソッドも提供します。 たとえばsetSelectedIndex
、getSelectedValue
などのカバー・メソッドでは、選択モデルとのやりとりの詳細を管理できます。 デフォルトでは、JList
の選択モデルは、任意の項目の組み合わせを一度に選択できるように設定されます(MULTIPLE_INTERVAL_SELECTION
選択モード)。 選択モードは、選択モデル上で直接変更するか、JList
のカバー・メソッドを使って変更します。 ユーザーのジェスチャに応じて選択モデルを更新する処理は、リストのListUI
によって行われます。
ListSelectionModel
が正しく実装されていれば、選択が変更されるたびに追加されたjavax.swing.event.ListSelectionListener
のセットに通知が送られます。 これらの変更は、選択範囲の変更を識別するjavax.swing.event.ListSelectionEvent
によって記述されます。
リスト選択の変更をリスンする方法としては、JList
に直接ListSelectionListener
を追加することをお勧めします。 JList
は、選択モデルをリッスンし、リスナーに変更を通知します。
リストの視覚表現を常に最新の状態にしておくため、選択の変更を待機する処理は、リストのListUI
によって行われます。
JList
内のセルのペイントは、リスト上にcellRenderer
プロパティとしてインストールされた、セル・レンダラと呼ばれる委譲によって処理されます。 このレンダラは、「ゴムスタンプ」のように使用してセルをペイントできるjava.awt.Component
を提供します。 セルをペイントする必要が生じるたびに、リストのListUI
はセル・レンダラにコンポーネントを要求し、それを適切な位置に移動した後、paint
メソッドを使用してセルのコンテンツをペイントします。 JLabel
コンポーネントを使用してレンダリングを行うデフォルトのセル・レンダラは、リストのListUI
によってインストールされます。 次のようなコードにより、独自のレンダラを使用することもできます。
// Display an icon and a string for each object in the list.
class MyCellRenderer extends JLabel implements ListCellRenderer<Object> {
static final ImageIcon longIcon = new ImageIcon("long.gif");
static final ImageIcon shortIcon = new ImageIcon("short.gif");
// This is the only method defined by ListCellRenderer.
// We just reconfigure the JLabel each time we're called.
public Component getListCellRendererComponent(
JList<?> list, // the list
Object value, // value to display
int index, // cell index
boolean isSelected, // is the cell selected
boolean cellHasFocus) // does the cell have focus
{
String s = value.toString();
setText(s);
setIcon((s.length() > 10) ? longIcon : shortIcon);
if (isSelected) {
setBackground(list.getSelectionBackground());
setForeground(list.getSelectionForeground());
} else {
setBackground(list.getBackground());
setForeground(list.getForeground());
}
setEnabled(list.isEnabled());
setFont(list.getFont());
setOpaque(true);
return this;
}
}
myList.setCellRenderer(new MyCellRenderer());
セル・レンダリングの別のジョブは、リストのサイズ情報の特定にも役立ちます。 デフォルトでは、リストのListUI
がセル・レンダリングに各リスト項目の推奨サイズを問い合わせることによって、セルのサイズを決定します。 リストの項目数が多い場合、この処理は負荷が大きくなります。 これらの計算を回避するには、リスト上にfixedCellWidth
とfixedCellHeight
を設定するか、これらの値が単一のプロトタイプ値に基づいて自動計算されるように設定します。
JList<String> bigDataList = new JList<String>(bigData);
// We don't want the JList implementation to compute the width
// or height of all of the list cells, so we give it a string
// that's as big as we'll need for any cell. It uses this to
// compute values for the fixedCellWidth and fixedCellHeight
// properties.
bigDataList.setPrototypeCellValue("Index 1234567890");
JList
はスクロールを直接実装していません。 スクロール・リストを作成するには、これをJScrollPane
のビューポート・ビューとして設定します。 たとえば:
JScrollPane scrollPane = new JScrollPane(myList); // Or in two steps: JScrollPane scrollPane = new JScrollPane(); scrollPane.getViewport().setView(myList);
JList
は、ダブルクリックやトリプル・クリック(またはそれ以上の回数のクリック)のような特別な処理は行いませんが、これらのイベントの発生時にアクションを実行したい場合は、MouseListener
を簡単に追加できます。 クリックされたセルを調べるには、locationToIndex
メソッドを使用します。 たとえば:
MouseListener mouseListener = new MouseAdapter() { public void mouseClicked(MouseEvent e) { if (e.getClickCount() == 2) { int index = list.locationToIndex(e.getPoint()); System.out.println("Double clicked on Item " + index); } } }; list.addMouseListener(mouseListener);
警告: Swingはスレッドに対して安全ではありません。 詳細は、「Swing's Threading Policy」を参照してください。
警告: このクラスの直列化されたオブジェクトは、今後のSwingリリースと互換ではなくなる予定です。 現在の直列化のサポートは、短期間の格納や、同じバージョンのSwingを実行するアプリケーション間のRMIに適しています。 1.4では、すべてのJavaBeansの長期ストレージのサポートがjava.beans
パッケージに追加されました。 XMLEncoder
を参照してください。
詳細は、「The Java Tutorial」の「How to Use Lists」を参照してください。
- 導入されたバージョン:
- 1.2
- 関連項目:
-
ネストされたクラスのサマリー
修飾子と型クラス説明protected class
このクラスはJList
クラスのアクセシビリティ・サポートを実装しています。static final class
TransferHandler.DropLocation
のサブクラスであり、JList
のドロップ位置を表します。クラス javax.swing.JComponentで宣言されたネストされたクラス/インタフェース
JComponent.AccessibleJComponent
クラス java.awt.Containerで宣言されたネストされたクラス/インタフェース
Container.AccessibleAWTContainer
クラス java.awt.Componentで宣言されたネストされたクラス/インタフェース
Component.AccessibleAWTComponent, Component.BaselineResizeBehavior, Component.BltBufferStrategy, Component.FlipBufferStrategy
-
フィールドのサマリー
修飾子と型フィールド説明static final int
セルが水平方向の次に垂直方向の順で並ぶ「ニュースペーパー・スタイル」レイアウトを示します。static final int
セルを垂直方向に1列に並べたレイアウト(デフォルト)を示します。static final int
セルが垂直方向の次に水平方向の順で並ぶ「ニュースペーパー・スタイル」レイアウトを示します。クラス javax.swing.JComponentで宣言されたフィールド
listenerList, TOOL_TIP_TEXT_KEY, ui, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW
クラス java.awt.Componentで宣言されたフィールド
accessibleContext, BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT
インタフェース java.awt.image.ImageObserverで宣言されたフィールド
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH
-
コンストラクタのサマリー
-
メソッドのサマリー
修飾子と型メソッド説明void
選択が変更されるたびに通知されるリストにリスナーを追加します。選択状態の変更を待機する方法としてお勧めです。void
addSelectionInterval
(int anchor, int lead) 指定された区間を現在の選択に加えます。void
選択をクリアします。このメソッドを呼び出したあとは、isSelectionEmpty
はtrue
を返します。protected ListSelectionModel
リストの選択モデル・プロパティを初期化するため、構築中に呼び出されるDefaultListSelectionModel
のインスタンスを返します。void
ensureIndexIsVisible
(int index) 囲み側のビュー・ポート内のリストをスクロールし、指定されたセルを完全に可視にします。protected void
fireSelectionValueChanged
(int firstIndex, int lastIndex, boolean isAdjusting) 選択のリストに直接追加されたListSelectionListener
に、選択モデルに変更が加えられたことを通知します。このJList
に関連付けられているAccessibleContext
を取得します。int
アンカー選択インデックスを返します。getCellBounds
(int index0, int index1) 2つのインデックスで指定されたセルの範囲を示す、リストの座標系内の境界の矩形を返します。ListCellRenderer<? super E>
リスト項目をペイントするオブジェクトを返します。boolean
自動ドラッグ処理が有効であるかどうかを返します。final JList.DropLocation
このコンポーネントがコンポーネントのドラッグ・アンド・ドロップ時にドロップ位置として視覚的に示す位置を返します。現在位置が表示されていない場合はnull
を返します。final DropMode
このコンポーネントのドロップ・モードを返します。int
現在表示されている最小のリスト・インデックスを返します。int
fixedCellHeight
プロパティの値を返します。int
fixedCellWidth
プロパティの値を返します。int
現在表示されている最大のリスト・インデックスを返します。int
リストのレイアウト方向のプロパティを返します。レイアウトがセルの単一の列の場合はVERTICAL
、コンテンツが垂直方向の次に水平方向の順に並ぶ「ニュースペーパー・スタイル」の場合はVERTICAL_WRAP
、コンテンツが水平方向の次に垂直方向の順に並ぶ「ニュースペーパー・スタイル」の場合はHORIZONTAL_WRAP
を返します。int
選択範囲のリード・インデックスを返します。addListSelectionListener
を使用してこのJList
に追加されたすべてのListSelectionListener
の配列を返します。int
選択されているセルの最大インデックスを返すか、選択範囲が空の場合は-1
を返します。int
選択されているセルの最小インデックスを返すか、選択範囲が空の場合は-1
を返します。getModel()
JList
コンポーネントによって表示される項目のリストを保持するデータ・モデルを返します。int
getNextMatch
(String prefix, int startIndex, Position.Bias bias) 指定された接頭辞で始まる、toString
値を持つ次のリスト要素を返します。visibleRowCount
行を表示するために必要なビュー・ポートのサイズを計算します。セルの固定幅と固定の高さを計算するために使用する値、「プロトタイプ」セル値を返します。int
getScrollableBlockIncrement
(Rectangle visibleRect, int orientation, int direction) 次または前のブロックを表示するためにスクロールする距離を返します。boolean
このJList
がJViewport
内に表示され、ビュー・ポートの幅がリストの適切な高さよりも高い場合、またはレイアウト方向がVERTICAL_WRAP
でvisibleRowCount <= 0
である場合はtrue
を返します。それ以外の場合はfalse
を返します。boolean
このJList
がJViewport
内に表示され、ビュー・ポートの幅がリストの適切な幅よりも広い場合、またはレイアウト方向がHORIZONTAL_WRAP
でvisibleRowCount <= 0
である場合はtrue
を返します。それ以外の場合はfalse
を返します。int
getScrollableUnitIncrement
(Rectangle visibleRect, int orientation, int direction) 次または前の行(垂直スクロール)または列(水平スクロール)を表示するためにスクロールする距離を返します。int
選択されているセルの最小インデックスを返します。リスト内の項目が1つだけ選択されている場合は「選択値」。int[]
選択されているすべてのインデックスの昇順配列を返します。選択されているセルの最小インデックスの値を返します。リスト内の項目が1つだけ選択されている場合は「選択値」Object[]
非推奨。選択されているすべての項目を、リスト内のインデックスに基づいて昇順のリストにして返します。選択された項目のバックグラウンドの描画に使用する色を返します。選択された項目のフォアグラウンドの描画に使用する色を返します。int
リストの現在の選択モードを返します。現在の選択モデルを返します。getToolTipText
(MouseEvent event) 指定されたイベントで使用されるツールヒント・テキストを返します。getUI()
このコンポーネントをレンダリングするルック・アンド・フィールオブジェクトのListUI
を返します。このコンポーネントのルック・アンド・フィールを定義するjavax.swing.plaf.ListUI
クラスの名前を検索するために使用するUIDefaults
キー、"ListUI"
を返します。boolean
選択モデルのisAdjusting
プロパティの値を返します。int
visibleRowCount
プロパティの値を返します。indexToLocation
(int index) リストの座標系内の指定された項目の原点を返します。boolean
isSelectedIndex
(int index) 指定のインデックスが選択されている場合はtrue
を返し、それ以外の場合はfalse
を返します。boolean
何も選択されていない場合はtrue
を返し、それ以外の場合はfalse
を返します。int
locationToIndex
(Point location) リストの座標系内の指定された位置にもっとも近いセル・インデックスを返します。protected String
このJList
のString
表現を返します。void
リストから選択リスナーを削除します。void
removeSelectionInterval
(int index0, int index1) 選択範囲を、指定された区間と現在の選択範囲との差集合に設定します。void
setCellRenderer
(ListCellRenderer<? super E> cellRenderer) リスト内の各セルをペイントするために使用される委譲を設定します。void
setDragEnabled
(boolean b) 自動ドラッグ処理をオンまたはオフにします。final void
setDropMode
(DropMode dropMode) このコンポーネントのドロップ・モードを設定します。void
setFixedCellHeight
(int height) リストに含まれるすべてのセルの高さとして使用する固定値を設定します。void
setFixedCellWidth
(int width) リストに含まれるすべてのセルの幅として使用する固定値を設定します。void
setLayoutOrientation
(int layoutOrientation) リスト・セルのレイアウト方法を定義します。void
setListData
(E[] listData) 項目の配列から読取り専用ListModel
を構築し、このモデルを使ってsetModel
を呼び出します。void
setListData
(Vector<? extends E> listData) Vector
から読取り専用ListModel
を構築し、このモデルを使ってsetModel
を呼び出します。void
リストの内容または「値」を表すモデルを設定し、プロパティ変更リスナーに通知して、リストの選択をクリアします。void
setPrototypeCellValue
(E prototypeCellValue) prototypeCellValue
プロパティを設定し、新しい値がnon-null
である場合は、セル・レンダリング・コンポーネントにセル・レンダラからの指定の値(およびインデックス0)を要求し、このコンポーネントの推奨サイズを使用して、fixedCellWidth
プロパティとfixedCellHeight
プロパティを計算します。void
setSelectedIndex
(int index) 単一セルを選択します。void
setSelectedIndices
(int[] indices) 選択を、指定の配列によって示される一連のインデックスに変更します。void
setSelectedValue
(Object anObject, boolean shouldScroll) 指定されたオブジェクトをリストから選択します。void
setSelectionBackground
(Color selectionBackground) 選択された項目のバックグラウンドのレンダリングに使用する色(セル・レンダリングが選択したセルの塗りつぶしに使用できる色)を設定します。void
setSelectionForeground
(Color selectionForeground) 選択された項目のフォアグラウンドのレンダリングに使用する色(セル・レンダリングがテキストとグラフィックスのレンダリングに使用できる色)を設定します。void
setSelectionInterval
(int anchor, int lead) 指定された区間を選択します。void
setSelectionMode
(int selectionMode) リストの選択モードを設定します。void
setSelectionModel
(ListSelectionModel selectionModel) リストのselectionModel
をnull
ではないListSelectionModel
実装に設定します。void
このコンポーネントをレンダリングするルック・アンド・フィールオブジェクトのListUI
を設定します。void
setValueIsAdjusting
(boolean b) 選択モデルのvalueIsAdjusting
プロパティを設定します。void
setVisibleRowCount
(int visibleRowCount) visibleRowCount
プロパティ(レイアウト方向によって意味が異なる)を設定します。レイアウト方向がVERTICAL
の場合、スクロールしないで表示できる適切な行数が設定されます。これ以外の方向の場合、セルの折返しに影響があります。void
updateUI()
ListUI
プロパティに現在のルック・アンド・フィールが提供する値を設定することにより、このプロパティをリセットします。クラス javax.swing.JComponentで宣言されたメソッド
addAncestorListener, addNotify, addVetoableChangeListener, computeVisibleRect, contains, createToolTip, disable, enable, firePropertyChange, firePropertyChange, fireVetoableChange, getActionForKeyStroke, getActionMap, getAlignmentX, getAlignmentY, getAncestorListeners, getAutoscrolls, getBaseline, getBaselineResizeBehavior, getBorder, getBounds, getClientProperty, getComponentGraphics, getComponentPopupMenu, getConditionForKeyStroke, getDebugGraphicsOptions, getDefaultLocale, getFontMetrics, getGraphics, getHeight, getInheritsPopupMenu, getInputMap, getInputMap, getInputVerifier, getInsets, getInsets, getListeners, getLocation, getMaximumSize, getMinimumSize, getNextFocusableComponent, getPopupLocation, getPreferredSize, getRegisteredKeyStrokes, getRootPane, getSize, getToolTipLocation, getToolTipText, getTopLevelAncestor, getTransferHandler, getVerifyInputWhenFocusTarget, getVetoableChangeListeners, getVisibleRect, getWidth, getX, getY, grabFocus, hide, isDoubleBuffered, isLightweightComponent, isManagingFocus, isOpaque, isOptimizedDrawingEnabled, isPaintingForPrint, isPaintingOrigin, isPaintingTile, isRequestFocusEnabled, isValidateRoot, paint, paintBorder, paintChildren, paintComponent, paintImmediately, paintImmediately, print, printAll, printBorder, printChildren, printComponent, processComponentKeyEvent, processKeyBinding, processKeyEvent, processMouseEvent, processMouseMotionEvent, putClientProperty, registerKeyboardAction, registerKeyboardAction, removeAncestorListener, removeNotify, removeVetoableChangeListener, repaint, repaint, requestDefaultFocus, requestFocus, requestFocus, requestFocusInWindow, requestFocusInWindow, resetKeyboardActions, reshape, revalidate, scrollRectToVisible, setActionMap, setAlignmentX, setAlignmentY, setAutoscrolls, setBackground, setBorder, setComponentPopupMenu, setDebugGraphicsOptions, setDefaultLocale, setDoubleBuffered, setEnabled, setFocusTraversalKeys, setFont, setForeground, setInheritsPopupMenu, setInputMap, setInputVerifier, setMaximumSize, setMinimumSize, setNextFocusableComponent, setOpaque, setPreferredSize, setRequestFocusEnabled, setToolTipText, setTransferHandler, setUI, setVerifyInputWhenFocusTarget, setVisible, unregisterKeyboardAction, update
クラス java.awt.Containerで宣言されたメソッド
add, add, add, add, add, addContainerListener, addImpl, addPropertyChangeListener, addPropertyChangeListener, applyComponentOrientation, areFocusTraversalKeysSet, countComponents, deliverEvent, doLayout, findComponentAt, findComponentAt, getComponent, getComponentAt, getComponentAt, getComponentCount, getComponents, getComponentZOrder, getContainerListeners, getFocusTraversalKeys, getFocusTraversalPolicy, getLayout, getMousePosition, insets, invalidate, isAncestorOf, isFocusCycleRoot, isFocusCycleRoot, isFocusTraversalPolicyProvider, isFocusTraversalPolicySet, layout, list, list, locate, minimumSize, paintComponents, preferredSize, printComponents, processContainerEvent, processEvent, remove, remove, removeAll, removeContainerListener, setComponentZOrder, setFocusCycleRoot, setFocusTraversalPolicy, setFocusTraversalPolicyProvider, setLayout, transferFocusDownCycle, validate, validateTree
クラス java.awt.Componentで宣言されたメソッド
action, add, addComponentListener, addFocusListener, addHierarchyBoundsListener, addHierarchyListener, addInputMethodListener, addKeyListener, addMouseListener, addMouseMotionListener, addMouseWheelListener, bounds, checkImage, checkImage, coalesceEvents, contains, createImage, createImage, createVolatileImage, createVolatileImage, disableEvents, dispatchEvent, enable, enableEvents, enableInputMethods, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, getBackground, getBounds, getColorModel, getComponentListeners, getComponentOrientation, getCursor, getDropTarget, getFocusCycleRootAncestor, getFocusListeners, getFocusTraversalKeysEnabled, getFont, getForeground, getGraphicsConfiguration, getHierarchyBoundsListeners, getHierarchyListeners, getIgnoreRepaint, getInputContext, getInputMethodListeners, getInputMethodRequests, getKeyListeners, getLocale, getLocation, getLocationOnScreen, getMouseListeners, getMouseMotionListeners, getMousePosition, getMouseWheelListeners, getName, getParent, getPropertyChangeListeners, getPropertyChangeListeners, getSize, getToolkit, getTreeLock, gotFocus, handleEvent, hasFocus, imageUpdate, inside, isBackgroundSet, isCursorSet, isDisplayable, isEnabled, isFocusable, isFocusOwner, isFocusTraversable, isFontSet, isForegroundSet, isLightweight, isMaximumSizeSet, isMinimumSizeSet, isPreferredSizeSet, isShowing, isValid, isVisible, keyDown, keyUp, list, list, list, location, lostFocus, mouseDown, mouseDrag, mouseEnter, mouseExit, mouseMove, mouseUp, move, nextFocus, paintAll, postEvent, prepareImage, prepareImage, processComponentEvent, processFocusEvent, processHierarchyBoundsEvent, processHierarchyEvent, processInputMethodEvent, processMouseWheelEvent, remove, removeComponentListener, removeFocusListener, removeHierarchyBoundsListener, removeHierarchyListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeMouseWheelListener, removePropertyChangeListener, removePropertyChangeListener, repaint, repaint, repaint, requestFocus, requestFocus, requestFocusInWindow, resize, resize, setBounds, setBounds, setComponentOrientation, setCursor, setDropTarget, setFocusable, setFocusTraversalKeysEnabled, setIgnoreRepaint, setLocale, setLocation, setLocation, setMixingCutoutShape, setName, setSize, setSize, show, show, size, toString, transferFocus, transferFocusBackward, transferFocusUpCycle
-
フィールド詳細
-
VERTICAL
public static final int VERTICALセルを垂直方向に1列に並べたレイアウト(デフォルト)を示します。- 導入されたバージョン:
- 1.4
- 関連項目:
-
VERTICAL_WRAP
public static final int VERTICAL_WRAPセルが垂直方向の次に水平方向の順で並ぶ「ニュースペーパー・スタイル」レイアウトを示します。- 導入されたバージョン:
- 1.4
- 関連項目:
-
HORIZONTAL_WRAP
public static final int HORIZONTAL_WRAPセルが水平方向の次に垂直方向の順で並ぶ「ニュースペーパー・スタイル」レイアウトを示します。- 導入されたバージョン:
- 1.4
- 関連項目:
-
-
コンストラクタの詳細
-
JList
指定されたnull以外
のモデルの要素を表示するJList
を構築します。 すべてのJList
コンストラクタは、このオブジェクトに委譲します。このコンストラクタは、
ToolTipManager
にリストを登録することにより、セル・レンダリングのツールヒントが提供されるようにします。- パラメータ:
dataModel
- リストのモデル- 例外:
IllegalArgumentException
- モデルがnull
の場合
-
JList
public JList(E[] listData) 指定された配列の要素を表示するJList
を構築します。 このコンストラクタは、指定された配列の読取り専用モデルを作成し、ListModel
をとるコンストラクタに委譲します。このメソッドに
null
値を渡そうとすると未定義の動作が発生し、さらに多くの場合は例外が発生します。 作成されたモデルは、指定された配列を直接参照します。 リストの作成後に配列を変更しようとすると、不確定な動作が生じます。- パラメータ:
listData
- データ・モデルにロードされるObjectの配列(null以外
)
-
JList
指定されたVector
の要素を表示するJList
を構築します。 このコンストラクタは、指定されたVector
の読取り専用モデルを作成し、ListModel
をとるコンストラクタに委譲します。このメソッドに
null
値を渡そうとすると未定義の動作が発生し、さらに多くの場合は例外が発生します。 作成されたモデルは、指定されたVector
を直接参照します。 リストの作成後にVector
を変更しようとすると、不確定な動作が生じます。- パラメータ:
listData
- データ・モデルにロードされるVector
。non-null
-
JList
public JList()空の読取り専用モデルでJList
を構築します。
-
-
メソッドの詳細
-
getUI
public ListUI getUI()このコンポーネントをレンダリングするルック・アンド・フィールオブジェクトのListUI
を返します。- オーバーライド:
- クラス
JComponent
のgetUI
- 戻り値:
- このコンポーネントをレンダリングする
ListUI
オブジェクト
-
setUI
@BeanProperty(hidden=true, visualUpdate=true, description="The UI object that implements the Component\'s LookAndFeel.") public void setUI(ListUI ui) このコンポーネントをレンダリングするルック・アンド・フィールオブジェクトのListUI
を設定します。- パラメータ:
ui
-ListUI
オブジェクト- 関連項目:
-
updateUI
public void updateUI()ListUI
プロパティに現在のルック・アンド・フィールが提供する値を設定することにより、このプロパティをリセットします。 現在のセル・レンダリングがルック・アンド・フィールによってではなく開発者によってインストールされたものである場合、この処理を実行すると、SwingUtilities.updateComponentTreeUI
が呼び出されて、セル・レンダリングとその子が更新されます。- オーバーライド:
updateUI
、クラスJComponent
- 関連項目:
-
getUIClassID
@BeanProperty(bound=false) public String getUIClassID()このコンポーネントのルック・アンド・フィールを定義するjavax.swing.plaf.ListUI
クラスの名前を検索するために使用するUIDefaults
キー、"ListUI"
を返します。- オーバーライド:
getUIClassID
、クラスJComponent
- 戻り値:
- 文字列「ListUI」
- 関連項目:
-
getPrototypeCellValue
public E getPrototypeCellValue()セルの固定幅と固定の高さを計算するために使用する値、「プロトタイプ」セル値を返します。 このような値が存在しない場合は、null
が返される可能性があります。- 戻り値:
prototypeCellValue
プロパティの値- 関連項目:
-
setPrototypeCellValue
@BeanProperty(visualUpdate=true, description="The cell prototype value, used to compute cell width and height.") public void setPrototypeCellValue(E prototypeCellValue) prototypeCellValue
プロパティを設定し、新しい値がnon-null
である場合は、セル・レンダリング・コンポーネントにセル・レンダラからの指定の値(およびインデックス0)を要求し、このコンポーネントの推奨サイズを使用して、fixedCellWidth
プロパティとfixedCellHeight
プロパティを計算します。リストが長すぎて
ListUI
が各セルの幅と高さを計算できず、ほかのセルと同じスペースを占有することがわかっているセル値(プロトタイプ)がある場合には、このメソッドが便利です。prototypeCellValue
、fixedCellHeight
、fixedCellWidth
の3つのプロパティはすべてこのメソッドで変更できますが、PropertyChangeEvent
通知が送信されるのは、prototypeCellValue
プロパティが変更された場合にかぎられます。このプロパティの設定例を参照するには、上記のクラスの説明を参照してください。
このプロパティのデフォルト値は
null
です。これはJavaBeansバウンド・プロパティです。
- パラメータ:
prototypeCellValue
-fixedCellWidth
およびfixedCellHeight
のベースとなる値- 関連項目:
-
getFixedCellWidth
public int getFixedCellWidth()fixedCellWidth
プロパティの値を返します。- 戻り値:
- 固定セル幅
- 関連項目:
-
setFixedCellWidth
@BeanProperty(visualUpdate=true, description="Defines a fixed cell width when greater than zero.") public void setFixedCellWidth(int width) リストに含まれるすべてのセルの幅として使用する固定値を設定します。width
が -1の場合、リストの各要素のセル・レンダリング・コンポーネントにgetPreferredSize
を適用することにより、ListUI
でセルの幅が計算されます。このプロパティのデフォルト値は
-1
です。これはJavaBeansバウンド・プロパティです。
- パラメータ:
width
- リスト内のすべてのセルの幅- 関連項目:
-
getFixedCellHeight
public int getFixedCellHeight()fixedCellHeight
プロパティの値を返します。- 戻り値:
- 固定セル高
- 関連項目:
-
setFixedCellHeight
@BeanProperty(visualUpdate=true, description="Defines a fixed cell height when greater than zero.") public void setFixedCellHeight(int height) リストに含まれるすべてのセルの高さとして使用する固定値を設定します。height
が -1の場合、リストの各要素のセル・レンダリング・コンポーネントにgetPreferredSize
を適用することにより、ListUI
でセルの高さが計算されます。このプロパティのデフォルト値は
-1
です。これはJavaBeansバウンド・プロパティです。
- パラメータ:
height
- リスト内のすべてのセルに使用される高さ- 関連項目:
-
getCellRenderer
public ListCellRenderer<? super E> getCellRenderer()リスト項目をペイントするオブジェクトを返します。- 戻り値:
cellRenderer
プロパティの値- 関連項目:
-
setCellRenderer
@BeanProperty(visualUpdate=true, description="The component used to draw the cells.") public void setCellRenderer(ListCellRenderer<? super E> cellRenderer) リスト内の各セルをペイントするために使用される委譲を設定します。 セル・レンダリングのジョブについては、クラス・レベルのドキュメントで詳しく説明します。prototypeCellValue
プロパティがnon-null
である場合は、セル・レンダリングを設定すると、fixedCellWidth
プロパティとfixedCellHeight
プロパティが再計算されます。 しかし、cellRenderer
プロパティに対してはPropertyChangeEvent
は1つだけ生成されます。このプロパティのデフォルト値は
ListUI
委譲(ルック・アンド・フィールの実装)によって提供されます。これはJavaBeansバウンド・プロパティです。
- パラメータ:
cellRenderer
- リストのセルをペイントするListCellRenderer
- 関連項目:
-
getSelectionForeground
public Color getSelectionForeground()選択された項目のフォアグラウンドの描画に使用する色を返します。 大多数のListUI
実装によってインストールされたレンダリングと同様に、DefaultListCellRenderer
は、この色を使って、選択されている項目のフォアグラウンドをレンダリングします。- 戻り値:
- 選択された項目のフォアグラウンドを描画する色
- 関連項目:
-
setSelectionForeground
@BeanProperty(visualUpdate=true, description="The foreground color of selected cells.") public void setSelectionForeground(Color selectionForeground) 選択された項目のフォアグラウンドのレンダリングに使用する色(セル・レンダリングがテキストとグラフィックスのレンダリングに使用できる色)を設定します。 大多数のListUI
実装によってインストールされたレンダリングと同様に、DefaultListCellRenderer
は、この色を使って、選択されている項目のフォアグラウンドをレンダリングします。このプロパティのデフォルト値は、ルック・アンド・フィールの実装によって定義されます。
これはJavaBeansバウンド・プロパティです。
- パラメータ:
selectionForeground
- 選択されたリスト項目のフォアグラウンドで使用するColor
- 関連項目:
-
getSelectionBackground
public Color getSelectionBackground()選択された項目のバックグラウンドの描画に使用する色を返します。 大多数のListUI
実装によってインストールされたレンダリングと同様に、DefaultListCellRenderer
は、この色を使って、選択されている項目のバックグラウンドをレンダリングします。- 戻り値:
- 選択された項目のバックグラウンドを描画する色
- 関連項目:
-
setSelectionBackground
@BeanProperty(visualUpdate=true, description="The background color of selected cells.") public void setSelectionBackground(Color selectionBackground) 選択された項目のバックグラウンドのレンダリングに使用する色(セル・レンダリングが選択したセルの塗りつぶしに使用できる色)を設定します。 大多数のListUI
実装によってインストールされたレンダリングと同様に、DefaultListCellRenderer
は、この色を使って、選択されている項目のバックグラウンドを塗りつぶします。このプロパティのデフォルト値は、ルック・アンド・フィールの実装によって定義されます。
これはJavaBeansバウンド・プロパティです。
- パラメータ:
selectionBackground
- 選択されたセルのバックグラウンドで使用するColor
- 関連項目:
-
getVisibleRowCount
public int getVisibleRowCount()visibleRowCount
プロパティの値を返します。 この値の解釈方法の詳細については、setVisibleRowCount(int)
のドキュメントを参照してください。- 戻り値:
visibleRowCount
プロパティの値。- 関連項目:
-
setVisibleRowCount
@BeanProperty(visualUpdate=true, description="The preferred number of rows to display without requiring scrolling") public void setVisibleRowCount(int visibleRowCount) visibleRowCount
プロパティ(レイアウト方向によって意味が異なる)を設定します。レイアウト方向がVERTICAL
の場合、スクロールしないで表示できる適切な行数が設定されます。これ以外の方向の場合、セルの折返しに影響があります。VERTICAL
方向の場合:
このプロパティを設定すると、囲み側のビュー・ポートの推奨サイズの計算に使用される、getPreferredScrollableViewportSize()
メソッドの戻り値に影響があります。 詳細は、該当メソッドのドキュメントを参照してください。HORIZONTAL_WRAP
方向またはVERTICAL_WRAP
方向の場合:
セルの折返しの方法に影響があります。 詳細は、setLayoutOrientation(int)
のドキュメントを参照してください。このプロパティのデフォルト値は
8
です。負の値を指定してこのメソッドを呼び出した場合、プロパティが
0
に設定されます。これはJavaBeansバウンド・プロパティです。
- パラメータ:
visibleRowCount
- スクロールしないで表示できる適切な行数を指定する整数- 関連項目:
-
getLayoutOrientation
public int getLayoutOrientation()リストのレイアウト方向のプロパティを返します。レイアウトがセルの単一の列の場合はVERTICAL
、コンテンツが垂直方向の次に水平方向の順に並ぶ「ニュースペーパー・スタイル」の場合はVERTICAL_WRAP
、コンテンツが水平方向の次に垂直方向の順に並ぶ「ニュースペーパー・スタイル」の場合はHORIZONTAL_WRAP
を返します。- 戻り値:
layoutOrientation
プロパティの値- 導入されたバージョン:
- 1.4
- 関連項目:
-
setLayoutOrientation
@BeanProperty(visualUpdate=true, enumerationValues={"JList.VERTICAL","JList.HORIZONTAL_WRAP","JList.VERTICAL_WRAP"}, description="Defines the way list cells are laid out.") public void setLayoutOrientation(int layoutOrientation) リスト・セルのレイアウト方法を定義します。 5つのセルから成るJList
があるとします。 セルは、次のいずれかの方法で配置できます:VERTICAL: 0 1 2 3 4 HORIZONTAL_WRAP: 0 1 2 3 4 VERTICAL_WRAP: 0 3 1 4 2
これらのレイアウトの説明は、次のとおりです。
VERTICAL、HORIZONTAL_WRAP、およびVERTICAL_WRAPのレイアウトについて説明 値 説明 VERTICAL
セルは1つの列に垂直に配置されます。 HORIZONTAL_WRAP
セルは水平に配置され、必要に応じて新しい行に折り返されます。 visibleRowCount
プロパティの値がゼロ以下である場合、折返しはリストの幅によって決定されます。それ以外の場合は、リスト内にvisibleRowCount
行が確保されるように折返しが行われます。VERTICAL_WRAP
セルは垂直に配置され、必要に応じて新しい列に折り返されます。 visibleRowCount
プロパティの値がゼロ以下である場合、折返しはリストの高さによって決定されます。それ以外の場合は、visibleRowCount
行で折返しが行われます。VERTICAL
です。- パラメータ:
layoutOrientation
- 新しいレイアウト方向。VERTICAL
、HORIZONTAL_WRAP
、またはVERTICAL_WRAP
のどれか- 例外:
IllegalArgumentException
-layoutOrientation
が許容値のどれでもない場合- 導入されたバージョン:
- 1.4
- 関連項目:
-
getFirstVisibleIndex
@BeanProperty(bound=false) public int getFirstVisibleIndex()現在表示されている最小のリスト・インデックスを返します。componentOrientation
が左から右である場合、最初の可視セルはリストの左上隅にもっとも近い位置に見つかります。 右から左である場合、最初の可視セルはリストの右上隅にもっとも近い位置に見つかります。 どのセルも可視ではない場合やリストが空である場合には-1
を返します。 返されたセルは部分的に可視でもかまいません。- 戻り値:
- 最初の可視セルのインデックス
- 関連項目:
-
getLastVisibleIndex
@BeanProperty(bound=false) public int getLastVisibleIndex()現在表示されている最大のリスト・インデックスを返します。 どのセルも可視ではない場合やリストが空である場合には-1
を返します。 返されたセルは部分的に可視でもかまいません。- 戻り値:
- 最後の可視セルのインデックス
- 関連項目:
-
ensureIndexIsVisible
public void ensureIndexIsVisible(int index) 囲み側のビュー・ポート内のリストをスクロールし、指定されたセルを完全に可視にします。 これは、指定されたセルの境界を引数にして、scrollRectToVisible
を呼びます。 このメソッドが動作するには、JList
がJViewport
内に存在する必要があります。指定されたインデックスがリストのセルの範囲外にある場合、このメソッドは何も行いません。
- パラメータ:
index
- 可視にするセルのインデックス- 関連項目:
-
setDragEnabled
@BeanProperty(bound=false, description="determines whether automatic drag handling is enabled") public void setDragEnabled(boolean b) 自動ドラッグ処理をオンまたはオフにします。 自動ドラッグ処理を有効にするには、このプロパティの値をtrue
に設定し、リストのTransferHandler
の値をnon-null
にしてください。dragEnabled
プロパティのデフォルト値はfalse
です。このプロパティを受け入れ、ユーザーのドラッグ・ジェスチャを認識する処理は、ルック・アンド・フィール実装(特にリストの
ListUI
)によって行われます。 自動ドラッグ処理が有効である場合、ほとんどのルック・アンド・フィール (BasicLookAndFeel
のサブクラスのルック・アンド・フィールを含む)は、ユーザーが項目の上でマウス・ボタンを押し、マウスを数ピクセル移動すると、ドラッグ・アンド・ドロップ操作を開始します。 したがって、このプロパティをtrue
に設定すると、選択の動作に微妙に影響する場合があります。このプロパティを無視するようなルック・アンド・フィールを使用している場合も、リストの
TransferHandler
上でexportAsDrag
を呼び出すことにより、ドラッグ・アンド・ドロップ操作を開始できます。- パラメータ:
b
- 自動ドラッグ処理を有効にするかどうか- 例外:
HeadlessException
-b
がtrue
で、GraphicsEnvironment.isHeadless()
がtrue
を返す場合- 導入されたバージョン:
- 1.4
- 関連項目:
-
getDragEnabled
public boolean getDragEnabled()自動ドラッグ処理が有効であるかどうかを返します。- 戻り値:
dragEnabled
プロパティの値- 導入されたバージョン:
- 1.4
- 関連項目:
-
setDropMode
public final void setDropMode(DropMode dropMode) このコンポーネントのドロップ・モードを設定します。 下位互換性を確保するため、このプロパティのデフォルト値はDropMode.USE_SELECTION
になっています。 ただし、ユーザー側の操作を改善する場合は、ほかのモードを使用することをお勧めします。 たとえば、DropMode.ON
は、リスト内の実際の選択内容に影響を及ぼすことなく、選択されたように項目を表示する動作と似た動作を提供します。JList
は次のドロップ・モードをサポートしています。DropMode.USE_SELECTION
DropMode.ON
DropMode.INSERT
DropMode.ON_OR_INSERT
TransferHandler
を持っていなければ、ドロップ・モードの効果はありません。- パラメータ:
dropMode
- 使用するドロップ・モード- 例外:
IllegalArgumentException
- ドロップ・モードがサポートされていないかnull
の場合- 導入されたバージョン:
- 1.6
- 関連項目:
-
getDropMode
public final DropMode getDropMode()このコンポーネントのドロップ・モードを返します。- 戻り値:
- このコンポーネントのドロップ・モード
- 導入されたバージョン:
- 1.6
- 関連項目:
-
getDropLocation
@BeanProperty(bound=false) public final JList.DropLocation getDropLocation()このコンポーネントがコンポーネントのドラッグ・アンド・ドロップ時にドロップ位置として視覚的に示す位置を返します。現在位置が表示されていない場合はnull
を返します。このメソッドは、
TransferHandler
からドロップ位置を照会する手段にはなりません。ドロップ位置は、TransferHandler
のcanImport
が返され、ドロップ位置を表示する準備ができてから設定されるためです。このプロパティが変更されると、コンポーネントにより、プロパティ変更イベントdropLocationがトリガーされます。
デフォルトでは、このプロパティに対する変更を待機し、ドロップ位置を視覚的に示す処理は、リストの
ListUI
が行います。これは、ドロップ位置を直接ペイントするか、セル・レンダラをインストールしてこの処理を行わせるか、またはその両方の処理を行う可能性があります。 カスタム・ドロップ位置のペイントを実装するか、デフォルトのセル・レンダラを置き換えるか、またはその両方の処理を行う開発者は、このプロパティを考慮する必要がある場合があります。- 戻り値:
- ドロップ位置
- 導入されたバージョン:
- 1.6
- 関連項目:
-
getNextMatch
public int getNextMatch(String prefix, int startIndex, Position.Bias bias) 指定された接頭辞で始まる、toString
値を持つ次のリスト要素を返します。- パラメータ:
prefix
- 一致をテストする文字列startIndex
- 検索を開始するインデックスbias
- 検索方向。Position.Bias.Forward、またはPosition.Bias.Backward。- 戻り値:
- 接頭辞で始まる、次のリスト要素のインデックス。そうでない場合は
-1
- 例外:
IllegalArgumentException
- 接頭辞がnull
またはstartIndexが範囲外にある場合- 導入されたバージョン:
- 1.4
-
getToolTipText
public String getToolTipText(MouseEvent event) 指定されたイベントで使用されるツールヒント・テキストを返します。 これは、JComponent
のgetToolTipText
をオーバーライドして、まずイベントが発生したセルのセル・レンダリング・コンポーネントをチェックし、ツールヒント・テキストがあれば、それを返します。 この実装では、セル・レンダリング・コンポーネントに対してsetToolTipText
を使用することにより、セル・レベルでツールヒント・テキストを指定できます。ノート:
JList
がこの方法でレンダラのツールヒントを適切に表示するためには、JList
がToolTipManager
に登録済のコンポーネントである必要があります。 この登録は、コンストラクタで自動的に行われます。 ただし、その後setToolTipText(null)
の呼出しによりJList
の登録が解除された場合、レンダリングからのヒントは表示されなくなります。- オーバーライド:
getToolTipText
、クラスJComponent
- パラメータ:
event
- ツールヒント・テキストを取得するMouseEvent
- 戻り値:
- ツール・ヒントを含む文字列
- 関連項目:
-
locationToIndex
public int locationToIndex(Point location) リストの座標系内の指定された位置にもっとも近いセル・インデックスを返します。 セルが実際にその指定された位置を含むかどうかを判定するには、その点と、getCellBounds
で提供されるセルの境界とを比較します。 このメソッドは、モデルが空の場合、-1
を返しますこれは、リストの
ListUI
内の同じ名前のメソッドに委譲するカバー・メソッドです。 リストにListUI
がない場合、-1
を返します。- パラメータ:
location
- 点の座標- 戻り値:
- 指定された位置にもっとも近いセル・インデックス、または
-1
-
indexToLocation
public Point indexToLocation(int index) リストの座標系内の指定された項目の原点を返します。 このメソッドは、インデックスが有効でない場合にnull
を返します。これは、リストの
ListUI
内の同じ名前のメソッドに委譲するカバー・メソッドです。 リストにListUI
がない場合、null
を返します。- パラメータ:
index
- セルのインデックス- 戻り値:
- セルの原点、または
null
-
getCellBounds
public Rectangle getCellBounds(int index0, int index1) 2つのインデックスで指定されたセルの範囲を示す、リストの座標系内の境界の矩形を返します。 これらのインデックスは、任意の順序で指定できます。小さいほうのインデックスがリストのセルの範囲外にある場合、このメソッドは
null
を返します。 小さいほうのインデックスが有効であっても、大きいほうのインデックスがリストの範囲外にある場合、最初のインデックスの境界だけが返されます。 そうでない場合、有効な範囲の境界が返されます。これは、リストの
ListUI
内の同じ名前のメソッドに委譲するカバー・メソッドです。 リストにListUI
がない場合、null
を返します。- パラメータ:
index0
- 範囲の1番目のインデックスindex1
- 範囲の2番目のインデックス- 戻り値:
- セルの範囲を示す境界の矩形、または
null
-
getModel
JList
コンポーネントによって表示される項目のリストを保持するデータ・モデルを返します。- 戻り値:
- 表示された項目のリストを提供する
ListModel
- 関連項目:
-
setModel
@BeanProperty(visualUpdate=true, description="The object that contains the data to be drawn by this JList.") public void setModel(ListModel<E> model) リストの内容または「値」を表すモデルを設定し、プロパティ変更リスナーに通知して、リストの選択をクリアします。これはJavaBeansバウンド・プロパティです。
- パラメータ:
model
- 表示される項目のリストを提供するListModel
- 例外:
IllegalArgumentException
-model
がnull
である場合- 関連項目:
-
setListData
public void setListData(E[] listData) 項目の配列から読取り専用ListModel
を構築し、このモデルを使ってsetModel
を呼び出します。このメソッドに
null
値を渡そうとすると未定義の動作が発生し、さらに多くの場合は例外が発生します。 作成されたモデルは、指定された配列を直接参照します。 このメソッドの呼出し後に配列を変更しようとすると、不確定な動作が生じます。- パラメータ:
listData
- リストに表示する項目を保持するE
の配列- 関連項目:
-
setListData
Vector
から読取り専用ListModel
を構築し、このモデルを使ってsetModel
を呼び出します。このメソッドに
null
値を渡そうとすると未定義の動作が発生し、さらに多くの場合は例外が発生します。 作成されたモデルは、指定されたVector
を直接参照します。 このメソッドの呼出し後にVector
を変更しようとすると、不確定な動作が生じます。- パラメータ:
listData
- リストに表示する項目を保持するVector
- 関連項目:
-
createSelectionModel
protected ListSelectionModel createSelectionModel()リストの選択モデル・プロパティを初期化するため、構築中に呼び出されるDefaultListSelectionModel
のインスタンスを返します。- 戻り値:
- 構築中にリストの選択モデル・プロパティを初期化するために使用する
DefaultListSelecitonModel
- 関連項目:
-
getSelectionModel
public ListSelectionModel getSelectionModel()現在の選択モデルを返します。 選択モデルは、リストの選択状態を保持します。 詳細は、クラス・レベルのドキュメントを参照してください。- 戻り値:
- リストの選択を保持する
ListSelectionModel
- 関連項目:
-
fireSelectionValueChanged
protected void fireSelectionValueChanged(int firstIndex, int lastIndex, boolean isAdjusting) 選択のリストに直接追加されたListSelectionListener
に、選択モデルに変更が加えられたことを通知します。JList
は、選択モデル内の選択に対する変更を待機し、このメソッドを呼び出すことにより、リストに直接追加されたリスナーに通知を送ります。このメソッドは、このリストをソースとし、指定の引数を使って、
ListSelectionEvent
を構築します。さらに、それを登録済みのListSelectionListeners
に送信します。- パラメータ:
firstIndex
- 範囲内の最初のインデックス、<= lastIndex
lastIndex
- 範囲内の最後のインデックス、>= firstIndex
isAdjusting
- このイベントが変更中の一連のイベントに含まれているかどうか- 関連項目:
-
addListSelectionListener
public void addListSelectionListener(ListSelectionListener listener) 選択が変更されるたびに通知されるリストにリスナーを追加します。選択状態の変更を待機する方法としてお勧めです。JList
は、選択モデルの選択状態の変更を待機し、指定されたリスナーに個々の変更を通知します。 リスナーに送信されたListSelectionEvent
により、source
プロパティがこのリストに設定されます。- パラメータ:
listener
- 追加するListSelectionListener
- 関連項目:
-
removeListSelectionListener
public void removeListSelectionListener(ListSelectionListener listener) リストから選択リスナーを削除します。- パラメータ:
listener
- 削除するListSelectionListener
- 関連項目:
-
getListSelectionListeners
@BeanProperty(bound=false) public ListSelectionListener[] getListSelectionListeners()addListSelectionListener
を使用してこのJList
に追加されたすべてのListSelectionListener
の配列を返します。- 戻り値:
- このリスト上のすべての
ListSelectionListener
。追加されたリスナーがない場合は空の配列 - 導入されたバージョン:
- 1.4
- 関連項目:
-
setSelectionModel
@BeanProperty(description="The selection model, recording which cells are selected.") public void setSelectionModel(ListSelectionModel selectionModel) リストのselectionModel
をnull
ではないListSelectionModel
実装に設定します。 選択モデルは、単一選択、隣接した範囲の選択、および非隣接選択を作成するタスクを処理します。これはJavaBeansバウンド・プロパティです。
- パラメータ:
selectionModel
- 選択を実装するListSelectionModel
- 例外:
IllegalArgumentException
-selectionModel
がnull
である場合- 関連項目:
-
setSelectionMode
@BeanProperty(bound=false, enumerationValues={"ListSelectionModel.SINGLE_SELECTION","ListSelectionModel.SINGLE_INTERVAL_SELECTION","ListSelectionModel.MULTIPLE_INTERVAL_SELECTION"}, description="The selection mode.") public void setSelectionMode(int selectionMode) リストの選択モードを設定します。 これは、選択モデル上で直接選択モードを設定するカバー・メソッドです。使用可能な選択モードは、次のリストのとおりです。
ListSelectionModel.SINGLE_SELECTION
- 1回に1つのリスト・インデックスのみを選択できます。 このモードでは、setSelectionInterval
メソッドとaddSelectionInterval
メソッドは同等であり、どちらも現在の選択を、2番目の引数で表されるインデックス(「リード・インデックス」)で置き換えます。ListSelectionModel.SINGLE_INTERVAL_SELECTION
- 1回に1つの連続区間のみを選択できます。 このモードでは、addSelectionInterval
は、指定された間隔が既存の選択範囲に隣接していたりオーバーラップしていたりしないかぎりsetSelectionInterval
と同様に動作するため(現在の選択を置き換える)、選択範囲を拡張する目的で使用できます。ListSelectionModel.MULTIPLE_INTERVAL_SELECTION
- このモードでは、選択対象に制限はありません。 このモードがデフォルトです。
- パラメータ:
selectionMode
- 選択モード- 例外:
IllegalArgumentException
- 許可された選択モードでない場合- 関連項目:
-
getSelectionMode
public int getSelectionMode()リストの現在の選択モードを返します。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。- 戻り値:
- 現在の選択モード
- 関連項目:
-
getAnchorSelectionIndex
@BeanProperty(bound=false) public int getAnchorSelectionIndex()アンカー選択インデックスを返します。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。- 戻り値:
- アンカー選択インデックス
- 関連項目:
-
getLeadSelectionIndex
@BeanProperty(bound=false, description="The lead selection index.") public int getLeadSelectionIndex()選択範囲のリード・インデックスを返します。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。- 戻り値:
- リード選択インデックス
- 関連項目:
-
getMinSelectionIndex
@BeanProperty(bound=false) public int getMinSelectionIndex()選択されているセルの最小インデックスを返すか、選択範囲が空の場合は-1
を返します。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。- 戻り値:
- 選択されているセルの最小インデックス、または
-1
- 関連項目:
-
getMaxSelectionIndex
@BeanProperty(bound=false) public int getMaxSelectionIndex()選択されているセルの最大インデックスを返すか、選択範囲が空の場合は-1
を返します。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。- 戻り値:
- 選択されているセルの最大インデックス
- 関連項目:
-
isSelectedIndex
public boolean isSelectedIndex(int index) 指定のインデックスが選択されている場合はtrue
を返し、それ以外の場合はfalse
を返します。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。- パラメータ:
index
- 選択状態が照会されるインデックス- 戻り値:
- 指定のインデックスが選択されている場合は
true
、それ以外の場合はfalse
- 関連項目:
-
isSelectionEmpty
@BeanProperty(bound=false) public boolean isSelectionEmpty()何も選択されていない場合はtrue
を返し、それ以外の場合はfalse
を返します。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。- 戻り値:
- 何も選択されていない場合は
true
、それ以外の場合はfalse
- 関連項目:
-
clearSelection
public void clearSelection()選択をクリアします。このメソッドを呼び出したあとは、isSelectionEmpty
はtrue
を返します。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。- 関連項目:
-
setSelectionInterval
public void setSelectionInterval(int anchor, int lead) 指定された区間を選択します。anchor
とlead
の両方のインデックスが含まれます。anchor
はlead
以下でなくてもかまいません。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。0
より小さい値の処理方法については、使用する選択モデル・クラスのドキュメントを参照してください。- パラメータ:
anchor
- 選択する最初のインデックスlead
- 選択する最後のインデックス- 関連項目:
-
addSelectionInterval
public void addSelectionInterval(int anchor, int lead) 指定された区間を現在の選択に加えます。anchor
とlead
の両方のインデックスが含まれます。anchor
はlead
以下でなくてもかまいません。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。0
より小さい値の処理方法については、使用する選択モデル・クラスのドキュメントを参照してください。- パラメータ:
anchor
- 選択に追加する最初のインデックスlead
- 選択に追加する最後のインデックス- 関連項目:
-
removeSelectionInterval
public void removeSelectionInterval(int index0, int index1) 選択範囲を、指定された区間と現在の選択範囲との差集合に設定します。index0
とindex1
の両方のインデックスが削除されます。index0
はindex1
以下でなくてもかまいません。 これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。0
より小さい値の処理方法については、使用する選択モデル・クラスのドキュメントを参照してください。- パラメータ:
index0
- 選択から削除する最初のインデックスindex1
- 選択から削除する最後のインデックス- 関連項目:
-
setValueIsAdjusting
public void setValueIsAdjusting(boolean b) 選択モデルのvalueIsAdjusting
プロパティを設定します。true
の場合、選択モデルに対する複数の変更は、1つの変更の一部であると見なされるはずです。 このプロパティは内部で使用され、開発者は通常、このメソッドを呼び出す必要はありません。 たとえば、ユーザーのドラッグに応じてモデルが更新される場合、プロパティの値は、ドラッグの開始時にはtrue
、終了時にはfalse
に設定されます。 このため、中間値をすべて処理するのではなく、変更がファイナライズされた場合にだけリスナーを更新できます。一連の変更を1回の変更の一部と見なす必要がある場合は、これを直接使用できます。
これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。 詳細は、
ListSelectionModel.setValueIsAdjusting(boolean)
のドキュメントを参照してください。- パラメータ:
b
- プロパティの変更後の値- 関連項目:
-
getValueIsAdjusting
public boolean getValueIsAdjusting()選択モデルのisAdjusting
プロパティの値を返します。これは、リストの選択モデル上の同じ名前のメソッドに委譲するカバー・メソッドです。
- 戻り値:
- 選択モデルの
isAdjusting
プロパティの値。 - 関連項目:
-
getSelectedIndices
public int[] getSelectedIndices()選択されているすべてのインデックスの昇順配列を返します。- 戻り値:
- 選択されているすべてのインデックス(昇順)、または何も選択されていない場合は空の配列
- 関連項目:
-
setSelectedIndex
@BeanProperty(bound=false, description="The index of the selected cell.") public void setSelectedIndex(int index) 単一セルを選択します。 指定されたインデックスがモデル・サイズ以上である場合は、何も行いません。 これは、選択モデル上でsetSelectionInterval
を使用する簡易メソッドです。0
より小さい値の処理方法については、使用する選択モデル・クラスのドキュメントを参照してください。- パラメータ:
index
- 選択するセルのインデックス- 関連項目:
-
setSelectedIndices
public void setSelectedIndices(int[] indices) 選択を、指定の配列によって示される一連のインデックスに変更します。 モデル・サイズ以上のインデックスは無視されます。 これは、選択をクリアし、選択モデル上でaddSelectionInterval
を使ってインデックスを追加する簡易メソッドです。0
より小さい値の処理方法については、使用する選択モデル・クラスのドキュメントを参照してください。- パラメータ:
indices
- 選択するセルのインデックスの配列、null以外
- 例外:
NullPointerException
- 指定された配列がnull
である場合- 関連項目:
-
getSelectedValues
@Deprecated @BeanProperty(bound=false) public Object[] getSelectedValues()非推奨。JDK 1.7以降は、getSelectedValuesList()
に置き換えられています選択されているすべての値を、リスト内のインデックスに基づいて昇順の配列にして返します。- 戻り値:
- 選択された値。何も選択されていない場合は空の配列
- 関連項目:
-
getSelectedValuesList
@BeanProperty(bound=false) public List<E> getSelectedValuesList()選択されているすべての項目を、リスト内のインデックスに基づいて昇順のリストにして返します。- 戻り値:
- 選択された項目。何も選択されていない場合は空のリスト
- 導入されたバージョン:
- 1.7
- 関連項目:
-
getSelectedIndex
public int getSelectedIndex()選択されているセルの最小インデックスを返します。リスト内の項目が1つだけ選択されている場合は「選択値」。 複数の項目が選択されている場合は、単純に選択されている最小インデックスになります。 何も選択されていない場合は-1
を返します。このメソッドは、
getMinSelectionIndex
に委譲するカバー・メソッドです。- 戻り値:
- 選択されているセルの最小インデックス
- 関連項目:
-
getSelectedValue
@BeanProperty(bound=false) public E getSelectedValue()選択されているセルの最小インデックスの値を返します。リスト内の項目が1つだけ選択されている場合は「選択値」 複数の項目が選択されている場合は、単純に選択されている最小インデックスの値になります。 何も選択されていない場合はnull
を返します。これは、単純に
getMinSelectionIndex
のモデル値を返す簡易メソッドです。- 戻り値:
- 最初に選択された値
- 関連項目:
-
setSelectedValue
public void setSelectedValue(Object anObject, boolean shouldScroll) 指定されたオブジェクトをリストから選択します。 渡されたオブジェクトがnull
の場合は、選択がクリアされます。- パラメータ:
anObject
- 選択するオブジェクトshouldScroll
- オブジェクトが存在し、選択したオブジェクトを表示するためにリストをスクロールするべきである場合はtrue
。そうでない場合はfalse
-
getPreferredScrollableViewportSize
@BeanProperty(bound=false) public Dimension getPreferredScrollableViewportSize()visibleRowCount
行を表示するために必要なビュー・ポートのサイズを計算します。 このメソッドの戻り値は、レイアウト方向によって異なります。VERTICAL
:
fixedCellWidth
とfixedCellHeight
の両方が設定されている場合(明示的に設定される場合と、セルのプロトタイプ値を指定して設定される場合がある)、この値は明らかです。 幅は、単純にfixedCellWidth
にリストの水平のイン・セットを足し合わせた値になります。 高さは、fixedCellHeight
にvisibleRowCount
を掛けて、リストの垂直のイン・セットを足し合わせた値になります。fixedCellWidth
とfixedCellHeight
のどちらかが指定されていない場合、ヒューリスティックな方法が使用されます。 モデルが空であり、幅が0
より大きいか、またはハードコードされた値256
である場合、幅はfixedCellWidth
になります。fixedCellHeight
が0
より大きい場合、高さはfixedCellHeight
にvisibleRowCount
を掛けた値になります。そうでない場合は、ハードコードされた値16
にvisibleRowCount
を掛けた値になります。モデルが空でなければ、幅は推奨サイズの幅(通常、もっとも幅の広いリスト要素の幅)になります。 高さは、インデックス0に
visibleRowCount
を乗算したセルの高さとリストの垂直枠を掛けたものです。VERTICAL_WRAP
またはHORIZONTAL_WRAP
:
このメソッドは、単純にgetPreferredSize
から値を返します。 リストのListUI
は、getPreferredSize
をオーバーライドして、適切な値を返す必要があります。- 定義:
getPreferredScrollableViewportSize
、インタフェースScrollable
- 戻り値:
visibleRowCount
行の表示に必要なビュー・ポートのサイズを含む寸法- 関連項目:
-
getScrollableUnitIncrement
public int getScrollableUnitIncrement(Rectangle visibleRect, int orientation, int direction) 次または前の行(垂直スクロール)または列(水平スクロール)を表示するためにスクロールする距離を返します。水平方向のスクロールでは、レイアウトの方向が
VERTICAL
である場合、リストのフォント・サイズ(フォントがnull
の場合は1
)が返されます。- 定義:
getScrollableUnitIncrement
、インタフェースScrollable
- パラメータ:
visibleRect
- ビュー・ポート内の可視のビュー領域orientation
-SwingConstants.HORIZONTAL
またはSwingConstants.VERTICAL
direction
- 上または左にスクロールする場合は0以下、下または右にスクロールする場合は0より大きい- 戻り値:
- 指定された方向にスクロールするための「ユニット」増分値。常に正の値
- 例外:
IllegalArgumentException
-visibleRect
がnull
、またはorientation
がSwingConstants.VERTICAL
またはSwingConstants.HORIZONTAL
のいずれでもない場合。- 関連項目:
-
getScrollableBlockIncrement
public int getScrollableBlockIncrement(Rectangle visibleRect, int orientation, int direction) 次または前のブロックを表示するためにスクロールする距離を返します。垂直方向のスクロールには、次のルールが適用されます。
- 下にスクロールする場合、最後の可視要素が最初の完全な可視要素になるように、スクロールする距離を返す
- 上にスクロールする場合、最初の可視要素が最後の完全な可視要素になるように、スクロールする距離を返す
- リストが空の場合は、
visibleRect.height
を返す
水平方向のスクロールで、レイアウト方向が
VERTICAL_WRAP
またはHORIZONTAL_WRAP
である場合、次のルールが適用されます。- 右にスクロールする場合、最後の可視要素が最初の完全な可視要素になるように、スクロールする距離を返す
- 左にスクロールする場合、最初の可視要素が最後の完全な可視要素になるように、スクロールする距離を返す
- リストが空の場合は、
visibleRect.width
を返す
水平方向のスクロールで、レイアウト方向が
VERTICAL
である場合、visibleRect.width
を返します。visibleRect
の値は、this.getVisibleRect()
と同じである必要があります。- 定義:
getScrollableBlockIncrement
、インタフェースScrollable
- パラメータ:
visibleRect
- ビュー・ポート内の可視のビュー領域orientation
-SwingConstants.HORIZONTAL
またはSwingConstants.VERTICAL
direction
- 上または左にスクロールする場合は0以下、下または右にスクロールする場合は0より大きい- 戻り値:
- 指定された方向にスクロールするための「ブロック」増分値。常に正の値
- 例外:
IllegalArgumentException
-visibleRect
がnull
、またはorientation
がSwingConstants.VERTICAL
またはSwingConstants.HORIZONTAL
のいずれでもない場合。- 関連項目:
-
getScrollableTracksViewportWidth
@BeanProperty(bound=false) public boolean getScrollableTracksViewportWidth()このJList
がJViewport
内に表示され、ビュー・ポートの幅がリストの適切な幅よりも広い場合、またはレイアウト方向がHORIZONTAL_WRAP
でvisibleRowCount <= 0
である場合はtrue
を返します。それ以外の場合はfalse
を返します。false
の場合、ビュー・ポートの幅を追跡しません。 これにより、JViewport
自体がJScrollPane
に組み込まれている場合、水平スクロールができるようになります。- 定義:
getScrollableTracksViewportWidth
、インタフェースScrollable
- 戻り値:
- 囲み側のビュー・ポートがリストの幅をそれ自体の幅に強制的に一致させるかどうか
- 関連項目:
-
getScrollableTracksViewportHeight
@BeanProperty(bound=false) public boolean getScrollableTracksViewportHeight()このJList
がJViewport
内に表示され、ビュー・ポートの幅がリストの適切な高さよりも高い場合、またはレイアウト方向がVERTICAL_WRAP
でvisibleRowCount <= 0
である場合はtrue
を返します。それ以外の場合はfalse
を返します。false
の場合、ビュー・ポートの高さを追跡しません。 これにより、JViewport
自体がJScrollPane
に組み込まれている場合、垂直スクロールができるようになります。- 定義:
getScrollableTracksViewportHeight
、インタフェースScrollable
- 戻り値:
- 囲み側のビュー・ポートがリストの高さを自体の高さに強制的に一致させるかどうか
- 関連項目:
-
paramString
protected String paramString()このJList
のString
表現を返します。 このメソッドはデバッグ専用であり、返されるString
の内容および形式は実装によって異なります。 返されるString
は空の場合がありますが、null
にはなりません。- オーバーライド:
paramString
、クラスJComponent
- 戻り値:
- この
JList
のString
表現。
-
getAccessibleContext
@BeanProperty(bound=false) public AccessibleContext getAccessibleContext()このJList
に関連付けられているAccessibleContext
を取得します。JList
の場合、AccessibleContext
はAccessibleJList
の形式を取ります。必要に応じて、新しい
AccessibleJList
インスタンスが作成されます。- 定義:
getAccessibleContext
、インタフェースAccessible
- オーバーライド:
getAccessibleContext
、クラスComponent
- 戻り値:
- この
JList
のAccessibleContext
として機能するAccessibleJList
-
getSelectedValuesList()
に置き換えられています