java.lang.Object java.awt.Component java.awt.Container javax.swing.JComponent com.realtime.crossfire.jxclient.gui.gui.GUIElement com.realtime.crossfire.jxclient.gui.gui.ActivatableGUIElement com.realtime.crossfire.jxclient.gui.list.GUIList
public abstract class GUIList
A GUIElement
that displays a list of entries.
Nested Class Summary |
---|
Nested classes/interfaces inherited from class javax.swing.JComponent |
---|
javax.swing.JComponent.AccessibleJComponent |
Nested classes/interfaces inherited from class java.awt.Container |
---|
java.awt.Container.AccessibleAWTContainer |
Nested classes/interfaces inherited from class java.awt.Component |
---|
java.awt.Component.AccessibleAWTComponent, java.awt.Component.BaselineResizeBehavior, java.awt.Component.BltBufferStrategy, java.awt.Component.FlipBufferStrategy |
Field Summary | |
---|---|
private int |
cellHeight
The height of a list cell in pixels. |
private CommandList |
doubleClickCommandList
The CommandList to execute on double-clicks or null
to ignore double-clicks. |
private javax.swing.JList |
list
The list used to display the cells. |
private GUIListCellRenderer |
listCellRenderer
The GUIListCellRenderer for the list . |
private javax.swing.event.ListSelectionListener |
listSelectionListener
The ListSelectionListener attached to list . |
private javax.swing.DefaultListModel |
model
The list model of list . |
private javax.swing.JScrollPane |
scrollPane
The scroll pane instance used to display the list. |
private static long |
serialVersionUID
The serial version UID. |
private int |
tooltipIndex
The index of the currently shown tooltip. |
private java.awt.Rectangle |
tooltipRectangle
The location of the tooltip. |
private GUIListViewport |
viewport
The viewport used by scrollPane . |
Fields inherited from class com.realtime.crossfire.jxclient.gui.gui.GUIElement |
---|
bufferedImageSync |
Fields inherited from class javax.swing.JComponent |
---|
accessibleContext, listenerList, TOOL_TIP_TEXT_KEY, ui, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW |
Fields inherited from class java.awt.Component |
---|
BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT |
Fields inherited from interface java.awt.image.ImageObserver |
---|
ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH |
Constructor Summary | |
---|---|
protected |
GUIList(TooltipManager tooltipManager,
GUIElementListener elementListener,
java.lang.String name,
Extent extent,
int cellWidth,
int cellHeight,
GUIListCellRenderer listCellRenderer,
CommandList doubleClickCommandList)
Creates a new instance. |
Method Summary | |
---|---|
protected void |
addElement(GUIElement element)
Adds an GUIElement to the list. |
boolean |
canMoveSelection(int diffLines,
int diffElements)
Returns whether the selection can be moved. |
boolean |
canScroll(int distance)
Returns whether the list can be scrolled. |
void |
dispose()
Releases all allocated resources. |
private void |
doSelect(java.awt.event.MouseEvent e)
Selects the list entry corresponding to a MouseEvent instance. |
private void |
doTooltip(java.awt.event.MouseEvent e)
Updates the tooltip text corresponding to a MouseEvent instance. |
GUIElement |
getElement(int index)
Returns the GUIElement for a given index. |
protected java.lang.Object |
getSelectedObject()
Returns the selected list object. |
void |
mouseClicked(java.awt.event.MouseEvent e)
Will be called when the user has clicked (pressed+released) this element. |
void |
mouseDragged(java.awt.event.MouseEvent e)
Will be called when the mouse moves within this component while the button is pressed. |
void |
mouseEntered(java.awt.event.MouseEvent e)
Will be called when the mouse has entered the bounding box of this element. |
void |
mouseExited(java.awt.event.MouseEvent e)
Will be called when the mouse has left the bounding box of this element. |
void |
mouseMoved(java.awt.event.MouseEvent e)
Will be called when the mouse moves within this component. |
void |
mousePressed(java.awt.event.MouseEvent e)
Will be called when the user has pressed the mouse inside this element. |
void |
moveSelection(int diffLines,
int diffElements)
Moves the selection. |
protected void |
render(java.awt.Graphics2D g2)
Paints the element's contents into the passed graphics. |
void |
resetScroll()
Resets the scroll index to the default value. |
protected int |
resizeElements(int newSize)
Changes the number of list elements. |
void |
scroll(int distance)
Moves the list. |
protected void |
selectionChanged()
Called whenever the selected list entry has changed. |
protected abstract void |
selectionChanged(int selectedIndex)
Called whenever the selected list entry has changed. |
void |
setChanged()
Records that GUIElement.bufferedImage has changed and must be repainted. |
protected void |
setLayoutOrientation(int layoutOrientation,
int visibleRowCount)
Sets the layout orientation. |
protected void |
setSelectedIndex(int newIndex)
Update the selected list entry. |
void |
updateResolution(int screenWidth,
int screenHeight)
Updates the location and size to a new screen resolution. |
private void |
updateTooltip()
Updates the current tooltip text. |
protected abstract void |
updateTooltip(int index,
int x,
int y,
int w,
int h)
Updates the tooltip text. |
Methods inherited from class com.realtime.crossfire.jxclient.gui.gui.ActivatableGUIElement |
---|
activeChanged, isActive, setActive |
Methods inherited from class com.realtime.crossfire.jxclient.gui.gui.GUIElement |
---|
createBufferGraphics, getElementX, getElementY, getGui, getName, getTooltipText, hasBufferedImage, isChanged, isDefault, isElementAtPoint, isElementVisible, isIgnore, mouseReleased, paintComponent, resetChanged, setChangedListener, setChangedNoListeners, setDefault, setElementLocation, setElementSize, setElementVisible, setGui, setIgnore, setTooltipText, setTooltipText, toString, updateResolutionConstant |
Methods inherited from class javax.swing.JComponent |
---|
addAncestorListener, addNotify, addVetoableChangeListener, computeVisibleRect, contains, createToolTip, disable, enable, firePropertyChange, firePropertyChange, firePropertyChange, fireVetoableChange, getAccessibleContext, 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, getToolTipText, getTopLevelAncestor, getTransferHandler, getUIClassID, getVerifyInputWhenFocusTarget, getVetoableChangeListeners, getVisibleRect, getWidth, getX, getY, grabFocus, isDoubleBuffered, isLightweightComponent, isManagingFocus, isOpaque, isOptimizedDrawingEnabled, isPaintingForPrint, isPaintingTile, isRequestFocusEnabled, isValidateRoot, paint, paintBorder, paintChildren, paintImmediately, paintImmediately, paramString, 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, updateUI |
Methods inherited from class 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 |
Methods inherited from class 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, 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, transferFocus, transferFocusBackward, transferFocusUpCycle |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
---|
private final int cellHeight
@Nullable private final CommandList doubleClickCommandList
CommandList
to execute on double-clicks or null
to ignore double-clicks.
@NotNull private final javax.swing.JList list
@NotNull private final GUIListCellRenderer listCellRenderer
GUIListCellRenderer
for the list
.
@NotNull private final javax.swing.event.ListSelectionListener listSelectionListener
ListSelectionListener
attached to list
.
@NotNull private final javax.swing.DefaultListModel model
list
.
@NotNull private final javax.swing.JScrollPane scrollPane
private static final long serialVersionUID
private int tooltipIndex
-1
if no
tooltip is shown.
@Nullable private java.awt.Rectangle tooltipRectangle
null
if no tooltip is
shown.
@NotNull private final GUIListViewport viewport
scrollPane
.
Constructor Detail |
---|
protected GUIList(@NotNull TooltipManager tooltipManager, @NotNull GUIElementListener elementListener, @NotNull java.lang.String name, @NotNull Extent extent, int cellWidth, int cellHeight, @NotNull GUIListCellRenderer listCellRenderer, @Nullable CommandList doubleClickCommandList)
tooltipManager
- the tooltip manager to updateelementListener
- the element listener to notifyname
- the name of this elementextent
- the extent of this elementcellWidth
- the width of each cellcellHeight
- the height of each celllistCellRenderer
- the renderer for the listdoubleClickCommandList
- the command list to execute on double-click
or null
to ignore double-clicksMethod Detail |
---|
protected void addElement(@NotNull GUIElement element)
GUIElement
to the list.
element
- the element to addpublic boolean canMoveSelection(int diffLines, int diffElements)
diffLines
- the distance in lines to movediffElements
- the distance in elements to move
public boolean canScroll(int distance)
canScroll
in interface GUIScrollable
distance
- the distance to scroll
public void dispose()
dispose
in class GUIElement
private void doSelect(@NotNull java.awt.event.MouseEvent e)
MouseEvent
instance.
e
- the mouse event instanceprivate void doTooltip(@NotNull java.awt.event.MouseEvent e)
MouseEvent
instance.
e
- the mouse event instance@NotNull public GUIElement getElement(int index)
GUIElement
for a given index.
index
- the index
@NotNull protected java.lang.Object getSelectedObject()
null
if none is selectedpublic void mouseClicked(@NotNull java.awt.event.MouseEvent e)
GUIElement.mouseReleased(MouseEvent)
.
mouseClicked
in class GUIElement
e
- the mouse event relative to this elementpublic void mouseDragged(@NotNull java.awt.event.MouseEvent e)
GUIElement.mouseMoved(MouseEvent)
.
Note: if the mouse leaves this element's bounding box while the mouse
button is still pressed, further mouseDragged
(but no
mouseMoved
) events will be generated.
mouseDragged
in class GUIElement
e
- the mouse event relative to this elementpublic void mouseEntered(@NotNull java.awt.event.MouseEvent e)
mouseEntered
in class GUIElement
e
- the mouse event relative to this elementpublic void mouseExited(@NotNull java.awt.event.MouseEvent e)
GUIElement.mouseEntered(MouseEvent)
has been called before.
mouseExited
in class GUIElement
e
- the mouse event relative to this elementpublic void mouseMoved(@NotNull java.awt.event.MouseEvent e)
mouseMoved
in class GUIElement
e
- the mouse event relative to this elementpublic void mousePressed(@NotNull java.awt.event.MouseEvent e)
mousePressed
in class ActivatableGUIElement
e
- the mouse event relative to this elementpublic void moveSelection(int diffLines, int diffElements)
diffLines
- the distance in lines to movediffElements
- the distance in elements to moveprotected void render(@NotNull java.awt.Graphics2D g2)
render
in class GUIElement
g2
- the graphics to paint topublic void resetScroll()
resetScroll
in interface GUIScrollable
protected int resizeElements(int newSize)
addElement(GUIElement)
.
newSize
- the new element count
public void scroll(int distance)
scroll
in interface GUIScrollable
distance
- the distance to scrollprotected void selectionChanged()
protected abstract void selectionChanged(int selectedIndex)
selectedIndex
- the selected list entrypublic void setChanged()
GUIElement.bufferedImage
has changed and must be repainted.
setChanged
in class GUIElement
protected void setLayoutOrientation(int layoutOrientation, int visibleRowCount)
JList.setLayoutOrientation(int)
and JList.setVisibleRowCount(int)
.
layoutOrientation
- the layout orientationvisibleRowCount
- the number of visible rowsprotected void setSelectedIndex(int newIndex)
newIndex
- the new selected list entrypublic void updateResolution(int screenWidth, int screenHeight)
updateResolution
in class GUIElement
screenWidth
- the new screen widthscreenHeight
- the new screen heightprivate void updateTooltip()
protected abstract void updateTooltip(int index, int x, int y, int w, int h)
index
- the index to usex
- the x coordinate of the celly
- the y coordinate of the cellw
- the width of the cellh
- the height of the cell