站内搜索: 请输入搜索关键词
当前页面: 在线文档首页 > JavaTM 2 Platform Standard Edition 5.0 API 规范中文版

JList (Java 2 Platform SE 5.0) - JavaTM 2 Platform Standard Edition 5.0 API 规范中文版

JavaTM 2 Platform
Standard Ed. 5.0

javax.swing
类 JList

java.lang.Object
  继承者 java.awt.Component
      继承者 java.awt.Container
          继承者 javax.swing.JComponent
              继承者 javax.swing.JList
所有已实现的接口:
ImageObserver, MenuContainer, Serializable, Accessible, Scrollable

public class JList
extends JComponent
implements Scrollable, Accessible

该组件允许用户从列表中选择一个或多个对象。单独的模型 ListModel 表示列表的内容。使用构建 ListModel 实例的 JList 构造方法,可以方便地显示对象的数组或向量:

 // Create a JList that displays the strings in data[]

 String[] data = {"one", "two", "three", "four"};
 JList dataList = new JList(data);
 
 // The value of the JList model property is an object that provides
 // a read-only view of the data.  It was constructed automatically.

 for(int i = 0; i < dataList.getModel().getSize(); i++) {
     System.out.println(dataList.getModel().getElementAt(i));
 }

 // Create a JList that displays the superclass of JList.class.
 // We store the superclasses in a java.util.Vector.

 Vector superClasses = new Vector();
 Class rootClass = javax.swing.JList.class;
 for(Class cls = rootClass; cls != null; cls = cls.getSuperclass()) {
     superClasses.addElement(cls);
 }
 JList classList = new JList(superClasses);
 

JList 不支持直接滚动。要创建滚动列表,需要让 JList 作为 JScrollPane 的视口视图。例如:

 JScrollPane scrollPane = new JScrollPane(dataList);
 // Or in two steps:
 JScrollPane scrollPane = new JScrollPane();
 scrollPane.getViewport().setView(dataList);
 

默认情况下,JList 选择模型允许使用常量 MULTIPLE_INTERVAL_SELECTION 一次选择任何项的组合。选择状态由单独的委托对象(即 ListSelectionModel 的实例)实际管理。不过,JList 提供了便捷的属性,可用于管理选择。

 String[] data = {"one", "two", "three", "four"};
 JList dataList = new JList(data);

 dataList.setSelectedIndex(1);  // select "two"
 dataList.getSelectedValue();   // returns "two"
 

JList 的内容可以是动态的,换句话说,在创建 JList 之后,列表元素可以改变值,列表的大小也可以改变。JList 利用 swing.event.ListDataListener 实现在其模型中观察更改。正确实现的 ListModel 在每次发生更改时向其侦听器发出通知。更改的特征由标识已修改、已添加或已移除的列表索引范围的 swing.event.ListDataEvent 来描述。简单动态内容 JList 应用程序可以使用 DefaultListModel 类存储列表元素。此类实现 ListModel 接口,同时提供 java.util.Vector API。需要提供自定义 ListModel 实现的应用程序可以为提供基本 ListDataListener 支持的 AbstractListModel 创建子类。例如:

 // This list model has about 2^16 elements.  Enjoy scrolling.

 
 ListModel bigData = new AbstractListModel() {
     public int getSize() { return Short.MAX_VALUE; }
     public Object getElementAt(int index) { return "Index " + index; }
 };

 JList bigDataList = new JList(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 使用 java.awt.Component(由名为 cellRendererer 的委派提供)在列表中绘制可见单元。单元渲染器组件类似于“橡皮图章”,用于绘制每个可见行。每当 JList 需要绘制单元时,它就要求单元渲染器提供组件,使用 setBounds() 将其移动到位,然后通过调用其绘制方法来绘制。默认的单元渲染器使用 JLabel 组件呈现每个组件的字符串值。用户还可以使用如下代码替代自己的单元渲染器:

  // Display an icon and a string for each object in the list.

 
 class MyCellRenderer extends JLabel implements ListCellRenderer {
     final static ImageIcon longIcon = new ImageIcon("long.gif");
     final static 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,
       Object value,            // value to display
       int index,               // cell index
       boolean isSelected,      // is the cell selected
       boolean cellHasFocus)    // the list and the cell have the 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;
     }
 }

 String[] data = {"one", "two", "three", "four"};
 JList dataList = new JList(data);
 dataList.setCellRenderer(new MyCellRenderer());
 

JList 没有对处理两次或三次(或 N 次)鼠标单击提供特殊支持,不过可以使用 MouseListener 方便地处理这些操作。使用 JList 方法 locationToIndex() 确定单击的是哪一个单元。例如:

 final JList list = new JList(dataModel);
 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);
 
注意,在此例中,dataListfinal,因为它由匿名 MouseListener 类引用。

警告:此类的序列化对象将与以后的 Swing 版本不兼容。当前的序列化支持适用于短期存储或运行相同 Swing 版本的应用程序之间的 RMI。从 1.4 版本开始,已在 java.beans 包中添加了支持所有 JavaBeansTM 长期存储的功能。请参见 XMLEncoder

请参见《The Java Tutorial》中的 How to Use Lists 以获取更多文档。另请参见 The Swing Connection 中的文章 Advanced JList Programming

另请参见:
ListModel, AbstractListModel, DefaultListModel, ListSelectionModel, DefaultListSelectionModel, ListCellRenderer

嵌套类摘要
protected  class JList.AccessibleJList
          此类实现 JList 类的可访问性支持。
 
从类 javax.swing.JComponent 继承的嵌套类/接口
JComponent.AccessibleJComponent
 
从类 java.awt.Container 继承的嵌套类/接口
Container.AccessibleAWTContainer
 
从类 java.awt.Component 继承的嵌套类/接口
Component.AccessibleAWTComponent, Component.BltBufferStrategy, Component.FlipBufferStrategy
 
字段摘要
static int HORIZONTAL_WRAP
          指示“报纸样式”,单元按先横向后纵向流动。
static int VERTICAL
          指示默认布局:一列单元。
static int VERTICAL_WRAP
          指示“报纸样式”布局,单元按先纵向后横向流动。
 
从类 javax.swing.JComponent 继承的字段
accessibleContext, listenerList, TOOL_TIP_TEXT_KEY, ui, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW
 
从类 java.awt.Component 继承的字段
BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT
 
从接口 java.awt.image.ImageObserver 继承的字段
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH
 
构造方法摘要
JList()
          构造一个使用空模型的 JList
JList(ListModel dataModel)
          构造一个 JList,使其使用指定的非 null 模型显示元素。
JList(Object[] listData)
          构造一个 JList,使其显示指定数组中的元素。
JList(Vector<?> listData)
          构造一个 JList,使其显示指定 Vector 中的元素。
 
方法摘要
 void addListSelectionListener(ListSelectionListener listener)
          为每次选择发生更改时要通知的列表添加侦听器。
 void addSelectionInterval(int anchor, int lead)
          将选择设置为指定间隔与当前选择的并集。
 void clearSelection()
          清除选择,调用此方法后,isSelectionEmpty 将返回 true。
protected  ListSelectionModel createSelectionModel()
          返回 DefaultListSelectionModel 实例。
 void ensureIndexIsVisible(int index)
          滚动视口,使指定单元完全可见。
protected  void fireSelectionValueChanged(int firstIndex, int lastIndex, boolean isAdjusting)
          通知 JList ListSelectionListener 选择模型已改变。
 AccessibleContext getAccessibleContext()
          获取与此 JList 关联的 AccessibleContext。
 int getAnchorSelectionIndex()
          返回最近一次 addSelectionModelsetSelectionInterval 调用中的第一个 index 参数。
 Rectangle getCellBounds(int index0, int index1)
          返回 JList 坐标中项的指定范围的边界。
 ListCellRenderer getCellRenderer()
          返回呈现列表项的对象。
 boolean getDragEnabled()
          获取 dragEnabled 属性。
 int getFirstVisibleIndex()
          返回第一个可见单元的索引。
 int getFixedCellHeight()
          返回固定单元高度值,该值通过设置 fixedCellHeight 属性指定,而不是根据列表元素计算。
 int getFixedCellWidth()
          返回固定单元宽度值,该值通过设置 fixedCellWidth 属性指定,而不是根据列表元素计算。
 int getLastVisibleIndex()
          返回最后一个可见单元的索引。
 int getLayoutOrientation()
          如果布局是单列单元,则返回 JList.VERTICAL;如果布局是“报纸样式”并且内容按先纵向后横向流动,则返回 JList.VERTICAL_WRAP;如果布局是“报纸样式”并且内容按先横向后纵向流动,则返回 JList.HORIZONTAL_WRAP
 int getLeadSelectionIndex()
          返回最近一次 addSelectionIntervalsetSelectionInterval 调用中的第二个 index 参数。
 ListSelectionListener[] getListSelectionListeners()
          返回使用 addListSelectionListener() 添加到此 JList 中的所有 ListSelectionListener 组成的数组。
 int getMaxSelectionIndex()
          返回选择的最大单元索引。
 int getMinSelectionIndex()
          返回选择的最小单元索引。
 ListModel getModel()
          返回保存由 JList 组件显示的项列表的数据模型。
 int getNextMatch(String prefix, int startIndex, Position.Bias bias)
          返回以某一前缀开头的下一个列表元素。
 Dimension getPreferredScrollableViewportSize()
          计算显示 visibleRowCount 行所需的视口的大小。
 Object getPrototypeCellValue()
          返回“原型单元”的单元宽度,原型单元是一个用于计算单元宽度的单元,因为它与所有其他列表项具有相同的值。
 int getScrollableBlockIncrement(Rectangle visibleRect, int orientation, int direction)
          返回为显露上一个或下一个块而滚动的距离。
 boolean getScrollableTracksViewportHeight()
          如果此 JListJViewport 中显示并且视口的高度大于 JList 的首选高度,或者布局方向为 VERTICAL_WRAP 但可见行数 <= 0,则返回 true;否则返回 false。
 boolean getScrollableTracksViewportWidth()
          如果此 JListJViewport 中显示并且视口的宽度大于 JList 的首选宽度,或者布局方向为 HORIZONTAL_WRAP 但可见行数 <= 0,则返回 true;否则返回 false。
 int getScrollableUnitIncrement(Rectangle visibleRect, int orientation, int direction)
          返回为显露上一个或下一个行(纵向滚动)或列(横向滚动)而滚动的距离。
 int getSelectedIndex()
          返回所选的第一个索引;如果没有选择项,则返回 -1。
 int[] getSelectedIndices()
          返回所选的全部索引的数组(按升序排列)。
 Object getSelectedValue()
          返回所选的第一个值,如果选择为空,则返回 null
 Object[] getSelectedValues()
          返回所选单元的一组值。
 Color getSelectionBackground()
          返回所选单元的背景色。
 Color getSelectionForeground()
          返回选择的前景色。
 int getSelectionMode()
          返回允许单项选择还是多项选择。
 ListSelectionModel getSelectionModel()
          返回当前选择模型的值。
 String getToolTipText(MouseEvent event)
          重写 JComponentgetToolTipText 方法,从而允许使用渲染器的提示(如果设置了文本)。
 ListUI getUI()
          返回呈现此组件的外观 (L&F) 对象。
 String getUIClassID()
          返回用于构造呈现此组件时使用的外观 (L&F) 类名称的后缀。
 boolean getValueIsAdjusting()
          返回数据模型的 isAdjusting 属性的值。
 int getVisibleRowCount()
          返回首选可见行数。
 Point indexToLocation(int index)
          返回 JList 坐标中指定项的原点。
 boolean isSelectedIndex(int index)
          如果选择了指定的索引,则返回 true。
 boolean isSelectionEmpty()
          如果什么也没有选择,则返回 true。
 int locationToIndex(Point location)
          将 JList 坐标中的点转换为该处单元最接近的索引。
protected  String paramString()
          返回此 JList 的字符串表示形式。
 void removeListSelectionListener(ListSelectionListener listener)
          从每次选择发生更改时要通知的列表中移除侦听器。
 void removeSelectionInterval(int index0, int index1)
          将选择设置为指定间隔和当前选择的差集。
 void setCellRenderer(ListCellRenderer cellRenderer)
          设置用于绘制列表中每个单元的委托。
 void setDragEnabled(boolean b)
          设置 dragEnabled 属性,该属性必须为 true 才能启用对此组件的自动拖动处理(拖放操作的第一部分)。
 void setFixedCellHeight(int height)
          设置列表中每个单元的高度。
 void setFixedCellWidth(int width)
          设置列表中每个单元的宽度。
 void setLayoutOrientation(int layoutOrientation)
          定义布置列表单元的方式。
 void setListData(Object[] listData)
          根据一个 object 数组构造 ListModel,然后对其应用 setModel
 void setListData(Vector<?> listData)
          根据 Vector 构造 ListModel,然后对其应用 setModel
 void setModel(ListModel model)
          设置表示列表内容或“值”的模型,并在通知 PropertyChangeListener 之后清除列表选择。
 void setPrototypeCellValue(Object prototypeCellValue)
          计算 fixedCellWidthfixedCellHeight 属性,方法是针对指定值将 cellRenderer 配置为索引等于零,然后计算渲染器组件的首选大小。
 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 设置为非 nullListSelectionModel 实现。
 void setUI(ListUI ui)
          设置呈现此组件的外观 (L&F) 对象。
 void setValueIsAdjusting(boolean b)
          将数据模型的 isAdjusting 属性设置为 true,这样完成所有选择事件时就会生成单个事件(例如,在选择模式的列表上拖动鼠标时)。
 void setVisibleRowCount(int visibleRowCount)
          设置不使用滚动条可以在列表中显示的首选行数,这一点由最近的 JViewport 祖先(如果有)确定。
 void updateUI()
          根据当前外观的值重置 UI 属性。
 
从类 javax.swing.JComponent 继承的方法
addAncestorListener, addNotify, addVetoableChangeListener, computeVisibleRect, contains, createToolTip, disable, enable, firePropertyChange, firePropertyChange, firePropertyChange, fireVetoableChange, getActionForKeyStroke, getActionMap, getAlignmentX, getAlignmentY, getAncestorListeners, getAutoscrolls, 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, isDoubleBuffered, isLightweightComponent, isManagingFocus, isOpaque, isOptimizedDrawingEnabled, 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, transferFocusBackward, 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, 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, getPeer, getPropertyChangeListeners, getPropertyChangeListeners, getSize, getToolkit, getTreeLock, gotFocus, handleEvent, hasFocus, hide, 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, resize, resize, setBounds, setBounds, setComponentOrientation, setCursor, setDropTarget, setFocusable, setFocusTraversalKeysEnabled, setIgnoreRepaint, setLocale, setLocation, setLocation, setName, setSize, setSize, show, show, size, toString, transferFocus, transferFocusUpCycle
 
从类 java.lang.Object 继承的方法
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 

字段详细信息

VERTICAL

public static final int VERTICAL
指示默认布局:一列单元。

从以下版本开始:
1.4
另请参见:
setLayoutOrientation(int), 常量字段值

VERTICAL_WRAP

public static final int VERTICAL_WRAP
指示“报纸样式”布局,单元按先纵向后横向流动。

从以下版本开始:
1.4
另请参见:
setLayoutOrientation(int), 常量字段值

HORIZONTAL_WRAP

public static final int HORIZONTAL_WRAP
指示“报纸样式”,单元按先横向后纵向流动。

从以下版本开始:
1.4
另请参见:
setLayoutOrientation(int), 常量字段值
构造方法详细信息

JList

public JList(ListModel dataModel)
构造一个 JList,使其使用指定的非 null 模型显示元素。所有 JList 构造方法都委派给此方法。

参数:
dataModel - 此列表的数据模型
抛出:
IllegalArgumentException - 如果 dataModelnull

JList

public JList(Object[] listData)
构造一个 JList,使其显示指定数组中的元素。此构造方法仅委派给 ListModel 构造方法。

参数:
listData - 要加载到数据模型中的 Object 的数组

JList

public JList(Vector<?> listData)
构造一个 JList,使其显示指定 Vector 中的元素。此构造方法仅委派给 ListModel 构造方法。

参数:
listData - 要加载到数据模型中的 Vector

JList

public JList()
构造一个使用空模型的 JList

方法详细信息

getUI

public ListUI getUI()
返回呈现此组件的外观 (L&F) 对象。

返回:
呈现此组件的 ListUI 对象

setUI

public void setUI(ListUI ui)
设置呈现此组件的外观 (L&F) 对象。

参数:
ui - ListUI L&F 对象
另请参见:
UIDefaults.getUI(javax.swing.JComponent)

updateUI

public void updateUI()
根据当前外观的值重置 UI 属性。

覆盖:
JComponent 中的 updateUI
另请参见:
UIManager.getUI(javax.swing.JComponent)

getUIClassID

public String getUIClassID()
返回用于构造呈现此组件时使用的外观 (L&F) 类名称的后缀。

覆盖:
JComponent 中的 getUIClassID
返回:
字符串 "ListUI"
另请参见:
JComponent.getUIClassID(), UIDefaults.getUI(javax.swing.JComponent)

getPrototypeCellValue

public Object getPrototypeCellValue()
返回“原型单元”的单元宽度,原型单元是一个用于计算单元宽度的单元,因为它与所有其他列表项具有相同的值。

返回:
prototypeCellValue 属性的值
另请参见:
setPrototypeCellValue(java.lang.Object)

setPrototypeCellValue

public void setPrototypeCellValue(Object prototypeCellValue)
计算 fixedCellWidthfixedCellHeight 属性,方法是针对指定值将 cellRenderer 配置为索引等于零,然后计算渲染器组件的首选大小。当由于列表过长而不允许 JList 计算每个单元的宽度/高度,并且已知某个单元值所占用的空间与任何其他单元一样多时,这些属性非常有用。

注意,我们在此确实设置了 fixedCellWidthfixedCellHeight 属性,但是仅激发了一个 prototypeCellValue PropertyChangeEvent

要查看设置此属性的示例,请参见上述类描述

此属性的默认值为 null

这是一个 JavaBeans bound 属性。

参数:
prototypeCellValue - 作为 fixedCellWidthfixedCellHeight 的基础的值
另请参见:
getPrototypeCellValue(), setFixedCellWidth(int), setFixedCellHeight(int), Container.addPropertyChangeListener(java.beans.PropertyChangeListener)

getFixedCellWidth

public int getFixedCellWidth()
返回固定单元宽度值,该值通过设置 fixedCellWidth 属性指定,而不是根据列表元素计算。

返回:
固定单元宽度
另请参见:
setFixedCellWidth(int)

setFixedCellWidth

public void setFixedCellWidth(int width)
设置列表中每个单元的宽度。如果 width 为 -1,则可以通过将 getPreferredSize 应用到 cellRenderer 组件为每个列表元素计算单元宽度。

此属性的默认值为 -1。

这是一个 JavaBeans bound 属性。

参数:
width - 此列表中所有单元的宽度(以像素表示)
另请参见:
getPrototypeCellValue(), setFixedCellWidth(int), Container.addPropertyChangeListener(java.beans.PropertyChangeListener)

getFixedCellHeight

public int getFixedCellHeight()
返回固定单元高度值,该值通过设置 fixedCellHeight 属性指定,而不是根据列表元素计算。

返回:
固定单元高度(以像素表示)
另请参见:
setFixedCellHeight(int)

setFixedCellHeight

public void setFixedCellHeight(int height)
设置列表中每个单元的高度。如果 height 为 -1,则可以通过将 getPreferredSize 应用到 cellRenderer 组件为每个列表元素计算单元高度。

此属性的默认值为 -1。

这是一个 JavaBeans bound 属性。

参数:
height - 给出此列表中所有单元高度的整数(以像素表示)
另请参见:
getPrototypeCellValue(), setFixedCellWidth(int), Container.addPropertyChangeListener(java.beans.PropertyChangeListener)

getCellRenderer

public ListCellRenderer getCellRenderer()
返回呈现列表项的对象。

返回:
ListCellRenderer
另请参见:
setCellRenderer(javax.swing.ListCellRenderer)

setCellRenderer

public void setCellRenderer(ListCellRenderer cellRenderer)
设置用于绘制列表中每个单元的委托。如果设置了 prototypeCellValue,则同时设置了 fixedCellWidthfixedCellHeight 属性。但是仅对 cellRenderer 属性生成一个 PropertyChangeEvent

此属性的默认值由 ListUI 委托(即外观实现)提供。

要查看设置单元渲染器的示例,请参见上述类描述

这是一个 JavaBeans bound 属性。

参数:
cellRenderer - 绘制列表单元的 ListCellRenderer
另请参见:
getCellRenderer()

getSelectionForeground

public Color getSelectionForeground()
返回选择的前景色。

返回:
前景属性的 Color 对象
另请参见:
setSelectionForeground(java.awt.Color), setSelectionBackground(java.awt.Color)

setSelectionForeground

public void setSelectionForeground(Color selectionForeground)
设置所选单元的前景色。单元渲染器可以使用此颜色呈现所选单元的文本和图形。

此属性的默认值由外观实现定义。

这是一个 JavaBeans bound 属性。

参数:
selectionForeground - 在所选列表项的前景中使用的 Color
另请参见:
getSelectionForeground(), setSelectionBackground(java.awt.Color), JComponent.setForeground(java.awt.Color), JComponent.setBackground(java.awt.Color), JComponent.setFont(java.awt.Font)

getSelectionBackground

public Color getSelectionBackground()
返回所选单元的背景色。

返回:
用于所选列表项的背景的 Color
另请参见:
setSelectionBackground(java.awt.Color), setSelectionForeground(java.awt.Color)

setSelectionBackground

public void setSelectionBackground(Color selectionBackground)
设置所选单元的背景色。单元渲染器可以使用此颜色填充所选单元。

此属性的默认值由外观实现定义。

这是一个 JavaBeans bound 属性。

参数:
selectionBackground - 用于所选单元的背景的 Color
另请参见:
getSelectionBackground(), setSelectionForeground(java.awt.Color), JComponent.setForeground(java.awt.Color), JComponent.setBackground(java.awt.Color), JComponent.setFont(java.awt.Font)

getVisibleRowCount

public int getVisibleRowCount()
返回首选可见行数。

返回:
一个整数,该整数指示无需使用滚动条显示的首选行数
另请参见:
setVisibleRowCount(int)

setVisibleRowCount

public void setVisibleRowCount(int visibleRowCount)
设置不使用滚动条可以在列表中显示的首选行数,这一点由最近的 JViewport 祖先(如果有)确定。此属性的值仅对 JListpreferredScrollableViewportSize 的值有影响。

此属性的默认值为 8。

这是一个 JavaBeans bound 属性。

参数:
visibleRowCount - 指定首选可见行数的整数
另请参见:
getVisibleRowCount(), JComponent.getVisibleRect(), JViewport

getLayoutOrientation

public int getLayoutOrientation()
如果布局是单列单元,则返回 JList.VERTICAL;如果布局是“报纸样式”并且内容按先纵向后横向流动,则返回 JList.VERTICAL_WRAP;如果布局是“报纸样式”并且内容按先横向后纵向流动,则返回 JList.HORIZONTAL_WRAP

返回:
layoutOrientation 属性的值
从以下版本开始:
1.4
另请参见:
setLayoutOrientation(int)

setLayoutOrientation

public void setLayoutOrientation(int layoutOrientation)
定义布置列表单元的方式。考虑一个具有四个单元的 JList,它的布局可以采用以下方式之一:
   0
   1
   2
   3
 
   0  1
   2  3
 
   0  2
   1  3
 

它们与以下值相对应:

描述

JList.VERTICAL 应该在一个列中纵向布置单元。
JList.HORIZONTAL_WRAP 应该横向布置单元,需要时将单元包装到新行中。要使用的行数或者由 getVisibleRowCount 定义(如果大于 0)或者由 JList 的宽度确定。
JList.VERTICAL_WRAP 应该纵向布置单元,需要时将单元包装到新列中。要使用的行数或者由 getVisibleRowCount 定义(如果大于 0)或者由 JList 的高度确定。
此属性的默认值为 JList.VERTICAL

如果 layoutOrientation 不为 JList.HORIZONTAL_WRAPJList.VERTICALJList.VERTICAL_WRAP 之一,则此操作抛出 IllegalArgumentException

参数:
layoutOrientation - 新方向,JList.HORIZONTAL_WRAPJList.VERTICALJList.VERTICAL_WRAP 之一。
从以下版本开始:
1.4
另请参见:
getLayoutOrientation(), setVisibleRowCount(int), getScrollableTracksViewportHeight()

getFirstVisibleIndex

public int getFirstVisibleIndex()
返回第一个可见单元的索引。哪一个单元被当作“第一个”取决于列表的 componentOrientation 属性。如果方向为横向从左到右,则第一个可见单元位于列表的左上角。如果方向为横向从右到左,则第一个可见单元位于列表的右上角。如果任何单元都不可见或者列表为空,则返回 -1。注意,可返回仅部分可见的单元。

返回:
第一个可见单元的索引
另请参见:
getLastVisibleIndex(), JComponent.getVisibleRect()

getLastVisibleIndex

public int getLastVisibleIndex()
返回最后一个可见单元的索引。哪一个单元被当作“最后一个”取决于列表的 componentOrientation 属性。如果方向为横向从左到右,则最后一个可见单元位于 JList 的右下角。如果方向为横向从右到左,则最后一个可见单元位于 JList 的左下角。如果任何单元都不可见或者列表为空,则返回 -1。注意,可返回仅部分可见的单元。

返回:
最后一个可见单元的索引
另请参见:
getFirstVisibleIndex(), JComponent.getVisibleRect()

ensureIndexIsVisible

public void ensureIndexIsVisible(int index)
滚动视口,使指定单元完全可见。注意,要让此方法生效,JList 必须在 JViewport 中显示。

参数:
index - 要变得可见的单元的索引
另请参见:
JComponent.scrollRectToVisible(java.awt.Rectangle), JComponent.getVisibleRect()

setDragEnabled

public void setDragEnabled(boolean b)
设置 dragEnabled 属性,该属性必须为 true 才能启用对此组件的自动拖动处理(拖放操作的第一部分)。必须将 transferHandler 属性设置为非 null 值,拖动才有效。dragEnabled 属性的默认值为 false

启用自动拖动处理时,只要用户在选择上按下鼠标按键,然后将鼠标移动几个像素,大多数外观就开始拖放操作了。因此,将此属性设置为 true 可以对选择的行为方式产生微妙的影响。

有些外观可能不支持自动拖放;它们将忽略此属性。对于这些外观,可通过修改组件以直接调用 TransferHandlerexportAsDrag 方法来处理该问题。

参数:
b - 作为 dragEnabled 属性设置目标的值
抛出:
HeadlessException - 如果 btrue 并且 GraphicsEnvironment.isHeadless() 返回 true
从以下版本开始:
1.4
另请参见:
GraphicsEnvironment.isHeadless(), getDragEnabled(), JComponent.setTransferHandler(javax.swing.TransferHandler), TransferHandler

getDragEnabled

public boolean getDragEnabled()
获取 dragEnabled 属性。

返回:
dragEnabled 属性的值
从以下版本开始:
1.4
另请参见:
setDragEnabled(boolean)

getNextMatch

public int getNextMatch(String prefix,
                        int startIndex,
                        Position.Bias bias)
返回以某一前缀开头的下一个列表元素。

参数:
prefix - 要测试是否匹配的字符串
startIndex - 开始搜索的索引
bias - 搜索方向,Position.Bias.Forward 或 Position.Bias.Backward。
返回:
以 prefix 开头的下一个列表元素的索引;否则返回 -1
抛出:
IllegalArgumentException - 如果 prefix 为 null 或者 startIndex 超出范围
从以下版本开始:
1.4

getToolTipText

public String getToolTipText(MouseEvent event)
重写 JComponentgetToolTipText 方法,从而允许使用渲染器的提示(如果设置了文本)。

注:为了让 JList 正确显示渲染器的工具提示,JList 必须是 ToolTipManager 中的注册组件。此操作可以在构造方法中自动完成,但是如果之后在 JList 上调用了 setToolTipText(null),则这是一个注销的列表组件,渲染器的提示将不再显示。

覆盖:
JComponent 中的 getToolTipText
另请参见:
JComponent.getToolTipText()

locationToIndex

public int locationToIndex(Point location)
JList 坐标中的点转换为该处单元最接近的索引。要确定单元是否实际包含指定的位置,需要配合使用此方法与 getCellBounds。如果模型为空,则返回 -1。

参数:
location - 相对于 JList 的单元坐标
返回:
一个整数,即位于给定位置的单元的索引,或者返回 -1。

indexToLocation

public Point indexToLocation(int index)
返回 JList 坐标中指定项的原点。如果 index 无效,则返回 null

参数:
index - JList 单元的索引
返回:
返回索引处单元的原点

getCellBounds

public Rectangle getCellBounds(int index0,
                               int index1)
返回 JList 坐标中项的指定范围的边界。如果索引无效,则返回 null

参数:
index0 - 该范围中第一个 JList 单元的索引
index1 - 该范围中最后一个 JList 单元的索引
返回:
索引单元的边界(以像素形式)

getModel

public ListModel getModel()
返回保存由 JList 组件显示的项列表的数据模型。

返回:
提供显示的项列表的 ListModel
另请参见:
setModel(javax.swing.ListModel)

setModel

public void setModel(ListModel model)
设置表示列表内容或“值”的模型,并在通知 PropertyChangeListener 之后清除列表选择。

这是一个 JavaBeans bound 属性。

参数:
model - 提供要显示的项列表的 ListModel
抛出:
IllegalArgumentException - 如果 modelnull
另请参见:
getModel()

setListData

public void setListData(Object[] listData)
根据一个 object 数组构造 ListModel,然后对其应用 setModel

参数:
listData - 包含要在列表中显示的项的 Object 数组
另请参见:
setModel(javax.swing.ListModel)

setListData

public void setListData(Vector<?> listData)
根据 Vector 构造 ListModel,然后对其应用 setModel

参数:
listData - 包含要在列表中显示的项的 Vector
另请参见:
setModel(javax.swing.ListModel)

createSelectionModel

protected ListSelectionModel createSelectionModel()
返回 DefaultListSelectionModel 实例。此方法供构造方法使用,用来初始化 selectionModel 属性。

返回:
由此 JList 所使用的 ListSelectionModel
另请参见:
setSelectionModel(javax.swing.ListSelectionModel), DefaultListSelectionModel

getSelectionModel

public ListSelectionModel getSelectionModel()
返回当前选择模型的值。选择模型可以完成单个选择、连续范围选择和非连续范围选择等任务。

返回:
实现列表选择的 ListSelectionModel
另请参见:
setSelectionModel(javax.swing.ListSelectionModel), ListSelectionModel

fireSelectionValueChanged

protected void fireSelectionValueChanged(int firstIndex,
                                         int lastIndex,
                                         boolean isAdjusting)
通知 JList ListSelectionListener 选择模型已改变。用于将 ListSelectionEventselectionModel 转发到直接添加到 JListListSelectionListener

参数:
firstIndex - 选择的第一个索引
lastIndex - 选择的最后一个索引
isAdjusting - 如果要进行多处更改则为 true
另请参见:
addListSelectionListener(javax.swing.event.ListSelectionListener), removeListSelectionListener(javax.swing.event.ListSelectionListener), EventListenerList

addListSelectionListener

public void addListSelectionListener(ListSelectionListener listener)
为每次选择发生更改时要通知的列表添加侦听器。直接添加到 JList 的侦听器将满足:ListSelectionEvent.getSource() == this JList(而 ListSelectionModel)。

参数:
listener - 要添加的 ListSelectionListener
另请参见:
getSelectionModel(), getListSelectionListeners()

removeListSelectionListener

public void removeListSelectionListener(ListSelectionListener listener)
从每次选择发生更改时要通知的列表中移除侦听器。

参数:
listener - 要移除的 ListSelectionListener
另请参见:
getSelectionModel(), getListSelectionListeners()

getListSelectionListeners

public ListSelectionListener[] getListSelectionListeners()
返回使用 addListSelectionListener() 添加到此 JList 中的所有 ListSelectionListener 组成的数组。

返回:
添加的所有 ListSelectionListener;如果没有添加任何侦听器,则返回空数组
从以下版本开始:
1.4
另请参见:
addListSelectionListener(javax.swing.event.ListSelectionListener)

setSelectionModel

public void setSelectionModel(ListSelectionModel selectionModel)
将列表的 selectionModel 设置为非 nullListSelectionModel 实现。选择模型可以完成单个选择、连续范围选择和非连续范围选择等任务。

这是一个 JavaBeans bound 属性。

参数:
selectionModel - 实现选择的 ListSelectionModel
抛出:
IllegalArgumentException - 如果 selectionModelnull
另请参见:
getSelectionModel()

setSelectionMode

public void setSelectionMode(int selectionMode)
确定允许单项选择还是多项选择。允许以下 selectionMode 值:
  • ListSelectionModel.SINGLE_SELECTION 一次只能选择一个列表索引。在此模式中,setSelectionInterval 方法等价于只使用第二个 index 参数的 addSelectionInterval 方法。
  • ListSelectionModel.SINGLE_INTERVAL_SELECTION 一次可以选择一个连续的索引间隔。在此模式中,setSelectionInterval 等价于 addSelectionInterval
  • ListSelectionModel.MULTIPLE_INTERVAL_SELECTION 在此模式中,不存在对选择的限制。这是默认设置。

参数:
selectionMode - 指定可能的选择类型的整数
另请参见:
getSelectionMode()

getSelectionMode

public int getSelectionMode()
返回允许单项选择还是多项选择。

返回:
selectionMode 属性的值
另请参见:
setSelectionMode(int)

getAnchorSelectionIndex

public int getAnchorSelectionIndex()
返回最近一次 addSelectionModelsetSelectionInterval 调用中的第一个 index 参数。这是一个仅委托给 selectionModel 的便捷方法。

返回:
最近定位间隔选择的索引
另请参见:
ListSelectionModel.getAnchorSelectionIndex(), addSelectionInterval(int, int), setSelectionInterval(int, int), addListSelectionListener(javax.swing.event.ListSelectionListener)

getLeadSelectionIndex

public int getLeadSelectionIndex()
返回最近一次 addSelectionIntervalsetSelectionInterval 调用中的第二个 index 参数。这是一个仅委托给 selectionModel 的便捷方法。

返回:
最近结束间隔选择的索引
另请参见:
ListSelectionModel.getLeadSelectionIndex(), addSelectionInterval(int, int), setSelectionInterval(int, int), addListSelectionListener(javax.swing.event.ListSelectionListener)

getMinSelectionIndex

public int getMinSelectionIndex()
返回选择的最小单元索引。这是一个仅委托给 selectionModel 的便捷方法。

返回:
选择的最小单元索引
另请参见:
ListSelectionModel.getMinSelectionIndex(), addListSelectionListener(javax.swing.event.ListSelectionListener)

getMaxSelectionIndex

public int getMaxSelectionIndex()
返回选择的最大单元索引。这是一个仅委托给 selectionModel 的便捷方法。

返回:
选择的最大单元索引
另请参见:
ListSelectionModel.getMaxSelectionIndex(), addListSelectionListener(javax.swing.event.ListSelectionListener)

isSelectedIndex

public boolean isSelectedIndex(int index)
如果选择了指定的索引,则返回 true。这是一个仅委托给 selectionModel 的便捷方法。

参数:
index - 要查询其选择状态的索引
返回:
如果选择了指定的索引,则返回 true
另请参见:
ListSelectionModel.isSelectedIndex(int), setSelectedIndex(int), addListSelectionListener(javax.swing.event.ListSelectionListener)

isSelectionEmpty

public boolean isSelectionEmpty()
如果什么也没有选择,则返回 true。这是一个仅委托给 selectionModel 的便捷方法。

返回:
如果什么也没有选择,则返回 true
另请参见:
ListSelectionModel.isSelectionEmpty(), clearSelection(), addListSelectionListener(javax.swing.event.ListSelectionListener)

clearSelection

public void clearSelection()
清除选择,调用此方法后,isSelectionEmpty 将返回 true。这是一个仅委托给 selectionModel 的便捷方法。

另请参见:
ListSelectionModel.clearSelection(), isSelectionEmpty(), addListSelectionListener(javax.swing.event.ListSelectionListener)

setSelectionInterval

public void setSelectionInterval(int anchor,
                                 int lead)
选择指定的间隔。包括 anchorlead 两个索引。没有必要让 anchor 小于 lead。这是一个仅委托给 selectionModel 的便捷方法。如果 anchorlead 为 -1,则 DefaultListSelectionModel 实现不执行任何操作。如果 anchorlead 小于 -1,则抛出 IndexOutOfBoundsException

参数:
anchor - 要选择的第一个索引
lead - 要选择的最后一个索引
抛出:
IndexOutOfBoundsException - 如果 anchorlead 小于 -1
另请参见:
ListSelectionModel.setSelectionInterval(int, int), addSelectionInterval(int, int), removeSelectionInterval(int, int), addListSelectionListener(javax.swing.event.ListSelectionListener)

addSelectionInterval

public void addSelectionInterval(int anchor,
                                 int lead)
将选择设置为指定间隔与当前选择的并集。包括 anchor 和 lead 两个索引。没有必要让 anchor 小于 lead。这是一个仅委托给 selectionModel 的便捷方法。如果 anchorlead 为 -1,则 DefaultListSelectionModel 实现不执行任何操作。如果 anchorlead 小于 -1,则抛出 IndexOutOfBoundsException

参数:
anchor - 要添加到选择的第一个索引
lead - 要添加到选择的最后一个索引
抛出:
IndexOutOfBoundsException - 如果 anchorlead 小于 -1
另请参见:
ListSelectionModel.addSelectionInterval(int, int), setSelectionInterval(int, int), removeSelectionInterval(int, int), addListSelectionListener(javax.swing.event.ListSelectionListener)

removeSelectionInterval

public void removeSelectionInterval(int index0,
                                    int index1)
将选择设置为指定间隔和当前选择的差集。两个索引 index0index1 都要移除。没有必要让 index0 小于 index1。这是一个仅委托给 selectionModel 的便捷方法。如果 index0index1 为 -1,则 DefaultListSelectionModel 实现不执行任何操作。如果 index0index1 小于 -1,则抛出 IndexOutOfBoundsException

参数:
index0 - 要从选择移除的第一个索引
index1 - 要从选择移除的最后一个索引
抛出:
IndexOutOfBoundsException - 如果 index0index1 小于 -1
另请参见:
ListSelectionModel.removeSelectionInterval(int, int), setSelectionInterval(int, int), addSelectionInterval(int, int), addListSelectionListener(javax.swing.event.ListSelectionListener)

setValueIsAdjusting

public void setValueIsAdjusting(boolean b)
将数据模型的 isAdjusting 属性设置为 true,这样完成所有选择事件时就会生成单个事件(例如,在选择模式的列表上拖动鼠标时)。

参数:
b - 属性值的 boolean 值
另请参见:
ListSelectionModel.setValueIsAdjusting(boolean)

getValueIsAdjusting

public boolean getValueIsAdjusting()
返回数据模型的 isAdjusting 属性的值。如果进行了多处更改,则此值为 true。

返回:
如果在列表上拖动鼠标时发生多处选择更改,则返回 true
另请参见:
ListSelectionModel.getValueIsAdjusting()

getSelectedIndices

public int[] getSelectedIndices()
返回所选的全部索引的数组(按升序排列)。

返回:
所选的全部索引(按升序排列)
另请参见:
removeSelectionInterval(int, int), addListSelectionListener(javax.swing.event.ListSelectionListener)

setSelectedIndex

public void setSelectedIndex(int index)
选择单个单元。

参数:
index - 要选择的一个单元的索引
另请参见:
ListSelectionModel.setSelectionInterval(int, int), isSelectedIndex(int), addListSelectionListener(javax.swing.event.ListSelectionListener)

setSelectedIndices

public void setSelectedIndices(int[] indices)
选择一组单元。

参数:
indices - 要选择的单元的索引数组
另请参见:
ListSelectionModel.addSelectionInterval(int, int), isSelectedIndex(int), addListSelectionListener(javax.swing.event.ListSelectionListener)

getSelectedValues

public Object[] getSelectedValues()
返回所选单元的一组值。返回值以递增的索引顺序存储。

返回:
所选值;如果什么也没有选择,则返回空列表
另请参见:
isSelectedIndex(int), getModel(), addListSelectionListener(javax.swing.event.ListSelectionListener)

getSelectedIndex

public int getSelectedIndex()
返回所选的第一个索引;如果没有选择项,则返回 -1。

返回:
getMinSelectionIndex 的值
另请参见:
getMinSelectionIndex(), addListSelectionListener(javax.swing.event.ListSelectionListener)

getSelectedValue

public Object getSelectedValue()
返回所选的第一个值,如果选择为空,则返回 null

返回:
所选的第一个值
另请参见:
getMinSelectionIndex(), getModel(), addListSelectionListener(javax.swing.event.ListSelectionListener)

setSelectedValue

public void setSelectedValue(Object anObject,
                             boolean shouldScroll)
从列表中选择指定的对象。

参数:
anObject - 要选择的对象
shouldScroll - 如果所选对象存在,但列表需要滚动才能显示,则为 true;否则为 false

getPreferredScrollableViewportSize

public Dimension getPreferredScrollableViewportSize()
计算显示 visibleRowCount 行所需的视口的大小。如果指定了 fixedCellWidthfixedCellHeight,则此操作无足轻重。注意,可以使用 prototypeCellValue 属性隐式指定它们。如果未指定 fixedCellWidth,则通过查找最宽的列表元素来计算。如果未指定 fixedCellHeight,则我们采取直观推断:
  • 如果模型不为空,则我们仅将第一行的高度乘以 visibleRowCount 即可。
  • 如果模型为空(JList.getModel().getSize() == 0),则为每个可见行分配 16 个像素,为其宽度分配 256 个像素(除非设置了 fixedCellWidth),即可获取最佳效果。
如果布局方向不为 VERTICAL,则此操作将返回 getPreferredSize 的返回值。当前的 ListUI 需要重写 getPreferredSize 才能返回适当的值。

指定者:
接口 Scrollable 中的 getPreferredScrollableViewportSize
返回:
包含显示 visibleRowCount 行所需视口大小的 dimension
另请参见:
getPreferredScrollableViewportSize(), setPrototypeCellValue(java.lang.Object)

getScrollableUnitIncrement

public int getScrollableUnitIncrement(Rectangle visibleRect,
                                      int orientation,
                                      int direction)
返回为显露上一个或下一个行(纵向滚动)或列(横向滚动)而滚动的距离。

对于横向滚动,如果列表是纵向布置的(即 orientation 为 VERTICAL),则返回列表字体大小或 1(如果使用了为 null 的字体)。

注意,visibleRect 的值必须等于 this.getVisibleRect()

指定者:
接口 Scrollable 中的 getScrollableUnitIncrement
参数:
visibleRect - 可见矩形
orientation - HORIZONTAL 或 VERTICAL
direction - 如果 <= 0,则向上滚动;如果 > 0,则向下滚动
返回:
为显露下一个或上一个单元而滚动的距离(以像素表示)
抛出:
IllegalArgumentException - 如果 visibleRect 为 null 或者 orientation 不为 SwingConstants.VERTICAL 或 SwingConstants.HORIZONTAL 之一。
另请参见:
Scrollable.getScrollableUnitIncrement(java.awt.Rectangle, int, int)

getScrollableBlockIncrement

public int getScrollableBlockIncrement(Rectangle visibleRect,
                                       int orientation,
                                       int direction)
返回为显露上一个或下一个块而滚动的距离。对于纵向滚动,使用以下规则:
  • 如果向下滚动(direction 大于 0),则最后一个可见元素应该成为第一个完全可见元素
  • 如果向上滚动,则第一个可见元素应该成为最后一个完全可见元素
  • visibleRect.height,如果列表为空

对于横向滚动,如果列表是横向布置的(orientation 为 VERTICAL_WRAPHORIZONTAL_WRAP):

  • 如果向右滚动(direction 大于 0),则最后一个可见元素应该成为第一个完全可见元素
  • 如果向左滚动,则第一个可见元素应该成为最后一个完全可见元素
  • visibleRect.width,如果列表为空

    如果纵向布置列表,则返回 visibleRect.width。

    注意,visibleRect 的值必须等于 this.getVisibleRect()

    指定者:
    接口 Scrollable 中的 getScrollableBlockIncrement
    参数:
    visibleRect - 可见矩形
    orientation - HORIZONTAL 或 VERTICAL
    direction - 如果 <= 0,则向上滚动;如果 > 0,则向下滚动
    返回:
    块增量。
    抛出:
    IllegalArgumentException - 如果 visibleRect 为 null 或者 orientation 不为 SwingConstants.VERTICAL 或 SwingConstants.HORIZONTAL 之一。
    另请参见:
    Scrollable.getScrollableUnitIncrement(java.awt.Rectangle, int, int)

  • getScrollableTracksViewportWidth

    public boolean getScrollableTracksViewportWidth()
    如果此 JListJViewport 中显示并且视口的宽度大于 JList 的首选宽度,或者布局方向为 HORIZONTAL_WRAP 但可见行数 <= 0,则返回 true;否则返回 false。如果返回 false,则不跟踪视口宽度。如果 JViewport 本身嵌入在 JScrollPane 中,则此操作允许横向滚动。

    指定者:
    接口 Scrollable 中的 getScrollableTracksViewportWidth
    返回:
    如果视口的宽度大于 JList 的首选宽度,则返回 true;否则返回 false
    另请参见:
    Scrollable.getScrollableTracksViewportWidth()

    getScrollableTracksViewportHeight

    public boolean getScrollableTracksViewportHeight()
    如果此 JListJViewport 中显示并且视口的高度大于 JList 的首选高度,或者布局方向为 VERTICAL_WRAP 但可见行数 <= 0,则返回 true;否则返回 false。如果返回 false,则不跟踪视口高度。如果 JViewport 本身嵌入在 JScrollPane 中,则此操作允许纵向滚动。

    指定者:
    接口 Scrollable 中的 getScrollableTracksViewportHeight
    返回:
    如果视口的高度大于 Jlist 的首选高度,则返回 true;否则返回 false
    另请参见:
    Scrollable.getScrollableTracksViewportHeight()

    paramString

    protected String paramString()
    返回此 JList 的字符串表示形式。此方法仅在进行调试的时候使用,对于各个实现,所返回字符串的内容和格式可能有所不同。返回的字符串可能为空,但不可能为 null

    覆盖:
    JComponent 中的 paramString
    返回:
    JList 的字符串表示形式。

    getAccessibleContext

    public AccessibleContext getAccessibleContext()
    获取与此 JList 关联的 AccessibleContext。对于 JList,AccessibleContext 采取 AccessibleJList 的形式。必要时要创建新的 AccessibleJList 实例。

    指定者:
    接口 Accessible 中的 getAccessibleContext
    覆盖:
    JComponent 中的 getAccessibleContext
    返回:
    用作此 JList 的 AccessibleContext 的 AccessibleJList

    JavaTM 2 Platform
    Standard Ed. 5.0

    提交错误或意见
    有关更多的 API 参考资料和开发人员文档,请参阅 Java 2 SDK SE 开发人员文档。该文档包含更详细的、面向开发人员的描述,以及总体概述、术语定义、使用技巧和工作代码示例。

    版权所有 2004 Sun Microsystems, Inc. 保留所有权利。 请遵守许可证条款。另请参阅文档重新分发政策