Package xal.extension.application
Class XalWindow
java.lang.Object
java.awt.Component
java.awt.Container
java.awt.Window
java.awt.Frame
javax.swing.JFrame
xal.extension.application.XalWindow
- All Implemented Interfaces:
ImageObserver
,MenuContainer
,Serializable
,Accessible
,RootPaneContainer
,WindowConstants
,XalDocumentListener
,XalDocumentView
- Direct Known Subclasses:
AcceleratorWindow
,DefaultXalWindow
The base class for custom windows that are the main windows for documents.
Subclasses need to define their custom views.
- Author:
- t6p
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class javax.swing.JFrame
JFrame.AccessibleJFrame
Nested classes/interfaces inherited from class java.awt.Frame
Frame.AccessibleAWTFrame
Nested classes/interfaces inherited from class java.awt.Window
Window.AccessibleAWTWindow, Window.Type
Nested classes/interfaces inherited from class java.awt.Container
Container.AccessibleAWTContainer
Nested classes/interfaces inherited from class java.awt.Component
Component.AccessibleAWTComponent, Component.BaselineResizeBehavior, Component.BltBufferStrategy, Component.FlipBufferStrategy
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected XalDocument
The document corresponding to this main windowstatic final int
static final int
Fields inherited from class javax.swing.JFrame
accessibleContext, rootPane, rootPaneCheckingEnabled
Fields inherited from class java.awt.Frame
CROSSHAIR_CURSOR, DEFAULT_CURSOR, E_RESIZE_CURSOR, HAND_CURSOR, ICONIFIED, MAXIMIZED_BOTH, MAXIMIZED_HORIZ, MAXIMIZED_VERT, MOVE_CURSOR, N_RESIZE_CURSOR, NE_RESIZE_CURSOR, NORMAL, NW_RESIZE_CURSOR, S_RESIZE_CURSOR, SE_RESIZE_CURSOR, SW_RESIZE_CURSOR, TEXT_CURSOR, W_RESIZE_CURSOR, WAIT_CURSOR
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
Fields inherited from interface javax.swing.WindowConstants
DISPOSE_ON_CLOSE, DO_NOTHING_ON_CLOSE, EXIT_ON_CLOSE, HIDE_ON_CLOSE
-
Constructor Summary
ConstructorsModifierConstructorDescriptionprotected
XalWindow
(XalDocument aDocument) Creates a new instance of WindowAdaptorprotected
XalWindow
(XalDocument aDocument, boolean displayToolbar) -
Method Summary
Modifier and TypeMethodDescriptionvoid
Capture the window content as a PNG.void
Close this window.void
customizeCommands
(Commander commander) Override this method to register custom commands.int
displayConfirmDialog
(String title, String message) Display a confirmation dialog with a title and messagevoid
displayError
(Exception exception) Display an error dialog box with information about the exception and provide an audible alert.void
displayError
(String aTitle, String message) Display an error dialog box and provide an audible alert.void
displayError
(String aTitle, String prefix, Exception exception) Display an error dialog box with information about the exception and provide an audible alert.void
displayWarning
(Exception exception) Display a warning dialog box showing information about an exception that has been thrown and provide an audible alert.void
displayWarning
(String aTitle, String message) Display a warning dialog box and provide an audible alert.void
displayWarning
(String aTitle, String prefix, Exception exception) Display a warning dialog box with information about the exception and provide an audible alert.void
documentHasClosed
(XalDocument document) Implement XalDocumentListener.void
documentWillClose
(XalDocument document) Implement XalDocumentListener.void
Dispose of custom window resources.void
Generate the title on the title bar to reflect the document state.Get the toolbar associated with this window.void
hasChangesChanged
(XalDocument document, boolean newHasChangesStatus) Implement XalDocumentListener.void
Iconify this window.Subclasses should override this method to provide a custom Commander.void
Make the frame and populate the menubar and toolbar.Create a new window listener.void
Register the event handlersfinal void
Dispose of this window and remove its association with the document.void
Show this window.final void
titleChanged
(XalDocument document, String documentTitle) Implement XalDocumentListener and handle the event where the title has changed.boolean
Query the user to see if it is okay to close the document given that unsaved changes exist.boolean
Subclasses may override this method to not create the toolbar.Methods inherited from class javax.swing.JFrame
addImpl, createRootPane, frameInit, getAccessibleContext, getContentPane, getDefaultCloseOperation, getGlassPane, getGraphics, getJMenuBar, getLayeredPane, getRootPane, getTransferHandler, isDefaultLookAndFeelDecorated, isRootPaneCheckingEnabled, paramString, processWindowEvent, remove, repaint, setContentPane, setDefaultCloseOperation, setDefaultLookAndFeelDecorated, setGlassPane, setIconImage, setJMenuBar, setLayeredPane, setLayout, setRootPane, setRootPaneCheckingEnabled, setTransferHandler, update
Methods inherited from class java.awt.Frame
addNotify, getCursorType, getExtendedState, getFrames, getIconImage, getMaximizedBounds, getMenuBar, getState, getTitle, isResizable, isUndecorated, remove, removeNotify, setBackground, setCursor, setExtendedState, setMaximizedBounds, setMenuBar, setOpacity, setResizable, setShape, setState, setTitle, setUndecorated
Methods inherited from class java.awt.Window
addPropertyChangeListener, addPropertyChangeListener, addWindowFocusListener, addWindowListener, addWindowStateListener, applyResourceBundle, applyResourceBundle, createBufferStrategy, createBufferStrategy, dispose, getBackground, getBufferStrategy, getFocusableWindowState, getFocusCycleRootAncestor, getFocusOwner, getFocusTraversalKeys, getIconImages, getInputContext, getListeners, getLocale, getModalExclusionType, getMostRecentFocusOwner, getOpacity, getOwnedWindows, getOwner, getOwnerlessWindows, getShape, getToolkit, getType, getWarningString, getWindowFocusListeners, getWindowListeners, getWindows, getWindowStateListeners, hide, isActive, isAlwaysOnTop, isAlwaysOnTopSupported, isAutoRequestFocus, isFocusableWindow, isFocusCycleRoot, isFocused, isLocationByPlatform, isOpaque, isShowing, isValidateRoot, pack, paint, postEvent, processEvent, processWindowFocusEvent, processWindowStateEvent, removeWindowFocusListener, removeWindowListener, removeWindowStateListener, reshape, setAlwaysOnTop, setAutoRequestFocus, setBounds, setBounds, setCursor, setFocusableWindowState, setFocusCycleRoot, setIconImages, setLocation, setLocation, setLocationByPlatform, setLocationRelativeTo, setMinimumSize, setModalExclusionType, setSize, setSize, setType, setVisible, show, toBack, toFront
Methods inherited from class java.awt.Container
add, add, add, add, add, addContainerListener, applyComponentOrientation, areFocusTraversalKeysSet, countComponents, deliverEvent, doLayout, findComponentAt, findComponentAt, getAlignmentX, getAlignmentY, getComponent, getComponentAt, getComponentAt, getComponentCount, getComponents, getComponentZOrder, getContainerListeners, getFocusTraversalPolicy, getInsets, getLayout, getMaximumSize, getMinimumSize, getMousePosition, getPreferredSize, insets, invalidate, isAncestorOf, isFocusCycleRoot, isFocusTraversalPolicyProvider, isFocusTraversalPolicySet, layout, list, list, locate, minimumSize, paintComponents, preferredSize, print, printComponents, processContainerEvent, remove, removeAll, removeContainerListener, setComponentZOrder, setFocusTraversalKeys, setFocusTraversalPolicy, setFocusTraversalPolicyProvider, setFont, 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, contains, createImage, createImage, createVolatileImage, createVolatileImage, disable, disableEvents, dispatchEvent, enable, enable, enableEvents, enableInputMethods, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, getBaseline, getBaselineResizeBehavior, getBounds, getBounds, getColorModel, getComponentListeners, getComponentOrientation, getCursor, getDropTarget, getFocusListeners, getFocusTraversalKeysEnabled, getFont, getFontMetrics, getForeground, getGraphicsConfiguration, getHeight, getHierarchyBoundsListeners, getHierarchyListeners, getIgnoreRepaint, getInputMethodListeners, getInputMethodRequests, getKeyListeners, getLocation, getLocation, getLocationOnScreen, getMouseListeners, getMouseMotionListeners, getMousePosition, getMouseWheelListeners, getName, getParent, getPropertyChangeListeners, getPropertyChangeListeners, getSize, getSize, getTreeLock, getWidth, getX, getY, gotFocus, handleEvent, hasFocus, imageUpdate, inside, isBackgroundSet, isCursorSet, isDisplayable, isDoubleBuffered, isEnabled, isFocusable, isFocusOwner, isFocusTraversable, isFontSet, isForegroundSet, isLightweight, isMaximumSizeSet, isMinimumSizeSet, isPreferredSizeSet, isValid, isVisible, keyDown, keyUp, list, list, list, location, lostFocus, mouseDown, mouseDrag, mouseEnter, mouseExit, mouseMove, mouseUp, move, nextFocus, paintAll, prepareImage, prepareImage, printAll, processComponentEvent, processFocusEvent, processHierarchyBoundsEvent, processHierarchyEvent, processInputMethodEvent, processKeyEvent, processMouseEvent, processMouseMotionEvent, processMouseWheelEvent, removeComponentListener, removeFocusListener, removeHierarchyBoundsListener, removeHierarchyListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeMouseWheelListener, removePropertyChangeListener, removePropertyChangeListener, repaint, repaint, repaint, requestFocus, requestFocus, requestFocus, requestFocus, requestFocusInWindow, requestFocusInWindow, requestFocusInWindow, resize, resize, revalidate, setComponentOrientation, setDropTarget, setEnabled, setFocusable, setFocusTraversalKeysEnabled, setForeground, setIgnoreRepaint, setLocale, setMaximumSize, setMixingCutoutShape, setName, setPreferredSize, show, size, toString, transferFocus, transferFocusBackward, transferFocusUpCycle
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface java.awt.MenuContainer
getFont, postEvent
Methods inherited from interface javax.swing.RootPaneContainer
getContentPane, getGlassPane, getLayeredPane, getRootPane, setContentPane, setGlassPane, setLayeredPane
Methods inherited from interface xal.extension.application.XalDocumentView
getJMenuBar, getLocation, getLocationOnScreen, isVisible, setJMenuBar, setLocation, setVisible
-
Field Details
-
YES_OPTION
public static final int YES_OPTION- See Also:
-
NO_OPTION
public static final int NO_OPTION- See Also:
-
document
The document corresponding to this main window
-
-
Constructor Details
-
XalWindow
Creates a new instance of WindowAdaptor -
XalWindow
-
-
Method Details
-
registerEvents
public void registerEvents()Register the event handlers -
makeFrame
public void makeFrame()Make the frame and populate the menubar and toolbar. -
makeCommander
Subclasses should override this method to provide a custom Commander. -
getToolBar
Get the toolbar associated with this window.- Specified by:
getToolBar
in interfaceXalDocumentView
- Returns:
- This window's toolbar or null if none was added.
-
customizeCommands
Override this method to register custom commands. -
closeWindow
public void closeWindow()Close this window. Check to see if the document has unsaved changes and if so warn the user and allow them to cancel the close operation. -
captureAsImage
public void captureAsImage()Capture the window content as a PNG. Present the user with a save dialog box so the image can be saved to a file.- Specified by:
captureAsImage
in interfaceXalDocumentView
-
newWindowHandler
Create a new window listener. -
showWindow
public void showWindow()Show this window. Make it visible (de-iconify if necessary) and bring it to the front.- Specified by:
showWindow
in interfaceXalDocumentView
-
hideWindow
public void hideWindow()Iconify this window.- Specified by:
hideWindow
in interfaceXalDocumentView
-
userPermitsCloseWithUnsavedChanges
public boolean userPermitsCloseWithUnsavedChanges()Query the user to see if it is okay to close the document given that unsaved changes exist.- Returns:
- If the user allows the document to be closed.
-
releaseWindow
public final void releaseWindow()Dispose of this window and remove its association with the document. -
freeCustomResources
public void freeCustomResources()Dispose of custom window resources. Subclasses should override this method to provide custom disposal of resources. The default implementation does nothing. -
generateWindowTitle
public void generateWindowTitle()Generate the title on the title bar to reflect the document state. The title displays the application name, the document title if any and an asterisk if the document has unsaved changes. -
titleChanged
Implement XalDocumentListener and handle the event where the title has changed. Update the title on the title bar to reflect the new document title.- Specified by:
titleChanged
in interfaceXalDocumentListener
- Parameters:
document
- The document initiating the title changed event.documentTitle
- The new document title.
-
hasChangesChanged
Implement XalDocumentListener. Update the title on the title bar to reflect whether the document has changes that need saving.- Specified by:
hasChangesChanged
in interfaceXalDocumentListener
- Parameters:
document
- The document initiating the event.newHasChangesStatus
- The new status identifying whether the document has changes to be saved- See Also:
-
documentWillClose
Implement XalDocumentListener. Event indicating that the document will close. Closes the window in response.- Specified by:
documentWillClose
in interfaceXalDocumentListener
- Parameters:
document
- The document that will close.
-
documentHasClosed
Implement XalDocumentListener. Does nothing.- Specified by:
documentHasClosed
in interfaceXalDocumentListener
- Parameters:
document
- The document that has closed.
-
usesToolbar
public boolean usesToolbar()Subclasses may override this method to not create the toolbar. -
displayConfirmDialog
Display a confirmation dialog with a title and message- Specified by:
displayConfirmDialog
in interfaceXalDocumentView
- Parameters:
title
- The title of the dialogmessage
- The message to display- Returns:
- YES_OPTION or NO_OPTION
-
displayWarning
Display a warning dialog box and provide an audible alert.- Specified by:
displayWarning
in interfaceXalDocumentView
- Parameters:
aTitle
- Title of the warning dialog box.message
- The warning message to appear in the warning dialog box.
-
displayWarning
Display a warning dialog box showing information about an exception that has been thrown and provide an audible alert.- Specified by:
displayWarning
in interfaceXalDocumentView
- Parameters:
exception
- The exception whose description is being displayed.
-
displayWarning
Display a warning dialog box with information about the exception and provide an audible alert. This method allows clarification about the consequences of the exception (e.g. "Save Failed:").- Specified by:
displayWarning
in interfaceXalDocumentView
- Parameters:
aTitle
- Title of the warning dialog box.prefix
- Text that should appear in the dialog box before the exception message.exception
- The exception about which the warning dialog is displayed.
-
displayError
Display an error dialog box and provide an audible alert.- Specified by:
displayError
in interfaceXalDocumentView
- Parameters:
aTitle
- Title of the warning dialog box.message
- The warning message to appear in the warning dialog box.
-
displayError
Display an error dialog box with information about the exception and provide an audible alert.- Specified by:
displayError
in interfaceXalDocumentView
- Parameters:
exception
- The exception about which the warning dialog is displayed.
-
displayError
Display an error dialog box with information about the exception and provide an audible alert. This method allows clarification about the consequences of the exception (e.g. "Save Failed:").- Specified by:
displayError
in interfaceXalDocumentView
- Parameters:
aTitle
- Title of the warning dialog box.prefix
- Text that should appear in the dialog box before the exception messasge.exception
- The exception about which the warning dialog is displayed.
-