|
org.openide.windows 6.16 | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES All Classes | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectjava.awt.Component
java.awt.Container
javax.swing.JComponent
org.openide.windows.TopComponent
public class TopComponent
Embeddable visual component to be displayed in NetBeans. This is the basic unit of display--windows should not be created directly, but rather use this class. A top component may correspond to a single window, but may also be a tab (e.g.) in a window. It may be docked or undocked, have selected nodes, supply actions, etc. Important serialization note: Serialization of this TopComponent is designed in a way that it's not desired to override writeReplace method. If you would like to resolve to something, please implement readResolve() method directly on your top component.
Nested Class Summary | |
---|---|
static interface |
TopComponent.Cloneable
Each top component that wishes to be cloned should implement this interface, so CloneAction can check it and call the cloneComponent method. |
static class |
TopComponent.NodeName
Deprecated. Please do not use. This support class does nothing much useful. If you need to synchronize display name of your TopComponent with some Node's display name, we recommend you to do it manually in your client's code. |
static interface |
TopComponent.Registry
Registry of all top components. |
Nested classes/interfaces inherited from class javax.swing.JComponent |
---|
JComponent.AccessibleJComponent |
Nested classes/interfaces inherited from class java.awt.Container |
---|
Container.AccessibleAWTContainer |
Nested classes/interfaces inherited from class java.awt.Component |
---|
Component.AccessibleAWTComponent, Component.BltBufferStrategy, Component.FlipBufferStrategy |
Field Summary | |
---|---|
static int |
CLOSE_EACH
Deprecated. Do not use. It is redundant since workspaces are not supported anymore. |
static int |
CLOSE_LAST
Deprecated. Do not use. It is redundant since workspaces are not supported anymore. |
static int |
PERSISTENCE_ALWAYS
Persistence type of TopComponent instance. |
static int |
PERSISTENCE_NEVER
Persistence type of TopComponent instance. |
static int |
PERSISTENCE_ONLY_OPENED
Persistence type of TopComponent instance. |
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 | |
---|---|
TopComponent()
Create a top component. |
|
TopComponent(Lookup lookup)
Creates a top component for a provided lookup that will delegate take and synchronize activated nodes and ActionMap from a provided lookup. |
Method Summary | |
---|---|
protected void |
associateLookup(Lookup lookup)
Associates the provided lookup with the component. |
List<Mode> |
availableModes(List<Mode> modes)
Allows top component to specify list of modes into which can be docked by end user. |
void |
cancelRequestAttention()
Cause this TopComponent's tab to stop flashing if it was flashing. |
boolean |
canClose()
This method is called when this TopComponent is about to close. |
boolean |
canClose(Workspace workspace,
boolean last)
Deprecated. Do not use anymore. Use canClose() instead.
Both parameters are redundant since workspaces are not supported anymore. |
boolean |
close()
Closes this TopComponent . |
boolean |
close(Workspace workspace)
Deprecated. Use close() instead. |
protected void |
closeNotify()
Deprecated. Use componentClosed() instead. |
protected void |
componentActivated()
Called when this component is activated. |
protected void |
componentClosed()
Called only when top component was closed so that now it is closed on all workspaces in the system. |
protected void |
componentDeactivated()
Called when this component is deactivated. |
protected void |
componentHidden()
Called when TopComponent was hidden. |
protected void |
componentOpened()
Called only when top component was closed on all workspaces before and now is opened for the first time on some workspace. |
protected void |
componentShowing()
Called when TopComponent is about to be shown. |
AccessibleContext |
getAccessibleContext()
|
Action[] |
getActions()
Gets the actions which will appear in the popup menu of this component. |
Node[] |
getActivatedNodes()
Get the set of activated nodes in this component. |
int |
getCloseOperation()
Deprecated. Do not use. It is redundant since workspaces are not supported anymore. |
String |
getDisplayName()
Gets localized display name of this TopComponent . |
HelpCtx |
getHelpCtx()
Get the help context for this component. |
String |
getHtmlDisplayName()
Gets localized display name of this TopComponent with added
html tags for text coloring and/or font style. |
Image |
getIcon()
|
Lookup |
getLookup()
Gets lookup which represents context of this component. |
int |
getPersistenceType()
Overwrite when you want to change default persistence type. |
static TopComponent.Registry |
getRegistry()
Getter for class that allows obtaining of information about components. |
SystemAction[] |
getSystemActions()
Deprecated. Use getActions() instead. |
int |
getTabPosition()
Gives position index of opened TopComponent in the mode. |
UndoRedo |
getUndoRedo()
Get the undo/redo support for this component. |
boolean |
isOpened()
Indicates whether this TopComponent is opened. |
boolean |
isOpened(Workspace workspace)
Deprecated. Use isOpened() instead. |
void |
open()
Shows this TopComponent . |
void |
open(Workspace workspace)
Deprecated. Use open() instead. |
void |
openAtTabPosition(int position)
Opens TopComponent at given position in the mode. |
protected void |
openNotify()
Deprecated. Use componentOpened() instead. |
protected String |
preferredID()
Subclasses are encouraged to override this method to provide preferred value for unique TopComponent ID returned by WindowManager.findTopComponentID(org.openide.windows.TopComponent) . |
protected boolean |
processKeyBinding(KeyStroke ks,
KeyEvent e,
int condition,
boolean pressed)
Overrides superclass method, adds possible additional handling of global keystrokes in case this TopComoponent is ancestor of focused component. |
void |
readExternal(ObjectInput in)
Deserialize this top component. |
void |
requestActive()
Activates this TopComponent |
void |
requestAttention(boolean brief)
Cause this TopComponent's tab to flash or otherwise draw attention to itself. |
void |
requestFocus()
Deprecated. Use requestActive() instead to make TopComponent active
in window system not only focused. This method should have been preserved
for focus management only but not activation of TopComponent inside
window system. The default implementation does nothing, and does not call
super.requestFocus(). |
boolean |
requestFocusInWindow()
Deprecated. Use requestActive() instead to make TopComponent active
in window system not only focused. This method should have been preserved
for focus management only but not activation of TopComponent inside
window system. The default implementation does nothing, and does not call
super.requestFocusInWindow(). |
void |
requestVisible()
Selects this TopComponent , if it is opened, but does not activate it
unless it is in active mode already. |
void |
setActivatedNodes(Node[] activatedNodes)
Set the set of activated nodes in this component. |
void |
setCloseOperation(int closeOperation)
Deprecated. Do not use. It is redundant since workspaces are not supported anymore. |
void |
setDisplayName(String displayName)
Sets localized display name of this TopComponent . |
void |
setHtmlDisplayName(String htmlDisplayName)
Sets localized html display name of this TopComponent . |
void |
setIcon(Image icon)
Set the icon of this top component. |
void |
setName(String name)
Set the name of this top component. |
void |
setToolTipText(String toolTip)
Sets toolTip for this TopComponent , adds notification
about the change to its WindowManager.TopComponentManager . |
void |
toFront()
Attempts to bring the parent Window or Frame
of this TopComponent |
void |
writeExternal(ObjectOutput out)
Serialize this top component. |
protected Object |
writeReplace()
Delegates instance of replacer class to be serialized instead of top component itself. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
---|
@Deprecated public static final int CLOSE_EACH
close()
is called.
This is appropriate for top components such as Editor panes which
the user expects to really close (and prompt to save) when closed
in any
@Deprecated public static final int CLOSE_LAST
close()
.
Appropriate for components containing no user data, for which closing
the component is only likely to result from the user's wanting to remove
it from active view (on the current workspace).
public static final int PERSISTENCE_ALWAYS
public static final int PERSISTENCE_ONLY_OPENED
public static final int PERSISTENCE_NEVER
Constructor Detail |
---|
public TopComponent()
public TopComponent(Lookup lookup)
getLookup()
method,
if not overriden.
lookup
- the lookup to associate withMethod Detail |
---|
public static final TopComponent.Registry getRegistry()
public final Node[] getActivatedNodes()
null
, null
means such component does not change TopComponent.Registry.getActivatedNodes()
just
TopComponent.Registry.getCurrentNodes()
when this component gets activatedpublic final void setActivatedNodes(Node[] activatedNodes)
activatedNodes
- activated nodes for this componentpublic int getPersistenceType()
public UndoRedo getUndoRedo()
public void open()
TopComponent
.
Note: This method only makes it visible, but does not
activates it.
requestActive()
@Deprecated public void open(Workspace workspace)
open()
instead.
TopComponent
in current workspace.
Node: Currently workspaces are not supported. The method has the same effect
like open()
.
public final void openAtTabPosition(int position)
position
- Index of the requested position.public final int getTabPosition()
public final boolean isOpened()
TopComponent
is opened.
@Deprecated public final boolean isOpened(Workspace workspace)
isOpened()
instead.
TopComponent
is opened in current workspace.
Node: Currently workspaces are not supported. The method has the same effect
like isOpened()
.
public final boolean close()
TopComponent
.
@Deprecated public final boolean close(Workspace workspace)
close()
instead.
TopComponent
in current workspace.
Node: Currently workspaces are not supported. The method has the same effect
like close()
.
public boolean canClose()
TopComponent
is about to close.
Allows subclasses to decide if TopComponent
is ready to close.
@Deprecated public boolean canClose(Workspace workspace, boolean last)
canClose()
instead.
Both parameters are redundant since workspaces are not supported anymore.
workspace
- the workspace on which we are about to close or
null which means that component will be closed
on all workspaces where it is opened (CLOSE_EACH mode)last
- true if this is last workspace where top component is
opened, false otherwise. If close operation is set to
CLOSE_EACH, then this param is always true
@Deprecated protected void openNotify()
componentOpened()
instead.
@Deprecated protected void closeNotify()
componentClosed()
instead.
@Deprecated public SystemAction[] getSystemActions()
getActions()
instead.
public Action[] getActions()
Subclasses are encouraged to override this method to specify their own sets of actions.
Remember to call the super method when overriding and add your actions to the superclass' ones (in some order), because the default implementation provides support for standard component actions like save, close, and clone.
@Deprecated public final void setCloseOperation(int closeOperation)
closeOperation
- one of CLOSE_EACH
or CLOSE_LAST
IllegalArgumentException
- if an unrecognized close mode was suppliedclose()
@Deprecated public final int getCloseOperation()
CLOSE_EACH
or CLOSE_LAST
protected String preferredID()
WindowManager.findTopComponentID(org.openide.windows.TopComponent)
.
Returned value should be a String, preferably describing semantics of
TopComponent subclass, such as "PieChartViewer" or "HtmlEditor" etc.
Value is then used by window system as prefix value for creating unique
TopComponent ID.
Returned String value should be preferably unique, but need not be.
protected void componentOpened()
protected void componentClosed()
protected void componentShowing()
TopComponent
is about to be shown.
Shown here means the component is selected or resides in it own cell
in container in its Mode
. The container is visible and not minimized.
Note: component is considered to be shown, even its container window is overlapped by another window.
protected void componentHidden()
TopComponent
was hidden. Nore:
Note: Beside typical situations when component is hidden,
it is considered to be hidden even in that case
the component is in Mode
container hierarchy,
the cointainer is visible, not minimized,
but the component is neither selected nor in its own cell,
i.e. it has it's own tab, but is not the selected one.
protected void componentActivated()
protected void componentDeactivated()
@Deprecated public void requestFocus()
requestActive()
instead to make TopComponent active
in window system not only focused. This method should have been preserved
for focus management only but not activation of TopComponent
inside
window system. The default implementation does nothing, and does not call
super.requestFocus().
opened
first
if it is not already.
Subclasses should override this method to transfer focus to desired
focusable component. TopComponent
itself is not focusable.
See for example text.CloneableEditor
.
requestFocus
in class JComponent
@Deprecated public boolean requestFocusInWindow()
requestActive()
instead to make TopComponent active
in window system not only focused. This method should have been preserved
for focus management only but not activation of TopComponent
inside
window system. The default implementation does nothing, and does not call
super.requestFocusInWindow().
opened
first
if it is not already.
Subclasses should override this method to transfer focus to desired
focusable component. TopComponent
itself is not focusable.
See for example text.CloneableEditor
.
requestFocusInWindow
in class JComponent
public void requestActive()
TopComponent if it is opened.
- Since:
- 4.13
toFront
public void toFront()
- Attempts to bring the parent
Window
or Frame
of this TopComponent to front of other windows.
- Since:
- 5.8
requestVisible
public void requestVisible()
- Selects this
TopComponent
, if it is opened, but does not activate it
unless it is in active mode already.
requestAttention
public final void requestAttention(boolean brief)
- Cause this TopComponent's tab to flash or otherwise draw attention to
itself. This method is thread-safe.
It will remain flashing until either cancelRequestAttention
is called, the component becomes selected or its activated state changes,
unless the brief
argument is true, in which case it will stop
after a few second.
- Parameters:
brief
- True if the tab should blink a few times and stop- Since:
- 5.1
cancelRequestAttention
public final void cancelRequestAttention()
- Cause this TopComponent's tab to stop flashing if it was flashing.
- Since:
- 5.1
setName
public void setName(String name)
- Set the name of this top component.
The default implementation just notifies the window manager.
-
- Parameters:
name
- the new display name
setDisplayName
public void setDisplayName(String displayName)
- Sets localized display name of this
TopComponent
.
- Parameters:
displayName
- localized display name which is set- Since:
- 4.13
getDisplayName
public String getDisplayName()
- Gets localized display name of this
TopComponent
.
- Returns:
- localized display name or
null
if there is none - Since:
- 4.13
setHtmlDisplayName
public void setHtmlDisplayName(String htmlDisplayName)
- Sets localized html display name of this
TopComponent
.
Hmtl name usually contains basic html tags for text coloring and style.
Html name may be null if not needed.
Must apparently begin with <html>
.
- Parameters:
htmlDisplayName
- localized html display name which is set- Since:
- 6.4
getHtmlDisplayName
public String getHtmlDisplayName()
- Gets localized display name of this
TopComponent
with added
html tags for text coloring and/or font style. May return null.
Must apparently begin with <html>
.
- Returns:
- localized html display name or
null
if there is none - Since:
- 6.4
setToolTipText
public void setToolTipText(String toolTip)
- Sets toolTip for this
TopComponent
, adds notification
about the change to its WindowManager.TopComponentManager
.
- Overrides:
setToolTipText
in class JComponent
setIcon
public void setIcon(Image icon)
- Set the icon of this top component.
The icon will be used for
the component's representation on the screen, e.g. in a multiwindow's tab.
The default implementation just notifies the window manager.
- Parameters:
icon
- New components' icon.
getIcon
public Image getIcon()
- Returns:
- The icon of the top component
getHelpCtx
public HelpCtx getHelpCtx()
- Get the help context for this component.
Subclasses should generally override this to return specific help.
- Specified by:
getHelpCtx
in interface HelpCtx.Provider
- Returns:
- the help context
availableModes
public List<Mode> availableModes(List<Mode> modes)
- Allows top component to specify list of modes into which can be docked
by end user. Subclasses should override this method if they want to
alter docking policy of top component.
So for example, by returning empty list, top component refuses
to be docked anywhere.
Default implementation allows docking anywhere by returning
input list unchanged.
- Parameters:
modes
- list of Mode
which represent all modes of current
workspace, can contain nulls. Items are structured in logical groups
separated by null entries.
Input array also contains special constant modes for docking
into newly created frames. Their names are "SingleNewMode",
"MultiNewMode", "SplitNewMode", can be used for their
recognition. Please note that names and existence of special modes
can change in future releases.
- Returns:
- list of
Mode
which are available for dock, can contain nulls - Since:
- 2.14
processKeyBinding
protected boolean processKeyBinding(KeyStroke ks,
KeyEvent e,
int condition,
boolean pressed)
- Overrides superclass method, adds possible additional handling of global keystrokes
in case this
TopComoponent
is ancestor of focused component.
- Overrides:
processKeyBinding
in class JComponent
writeExternal
public void writeExternal(ObjectOutput out)
throws IOException
- Serialize this top component.
Subclasses wishing to store state must call the super method, then write to the stream.
- Specified by:
writeExternal
in interface Externalizable
- Parameters:
out
- the stream to serialize to
- Throws:
IOException
readExternal
public void readExternal(ObjectInput in)
throws IOException,
ClassNotFoundException
- Deserialize this top component.
Subclasses wishing to store state must call the super method, then read from the stream.
- Specified by:
readExternal
in interface Externalizable
- Parameters:
in
- the stream to deserialize from
- Throws:
IOException
ClassNotFoundException
writeReplace
protected Object writeReplace()
throws ObjectStreamException
- Delegates instance of replacer class to be serialized instead
of top component itself. Replacer class calls writeExternal and
constructor, readExternal and readResolve methods properly, so
8 any top component can behave like any other externalizable object.
Subclasses can override this method to perform their
serialization differentrly
- Throws:
ObjectStreamException
getAccessibleContext
public AccessibleContext getAccessibleContext()
- Specified by:
getAccessibleContext
in interface Accessible
- Overrides:
getAccessibleContext
in class JComponent
getLookup
public Lookup getLookup()
- Gets lookup which represents context of this component. By default
the lookup delegates to result of
getActivatedNodes
method and result of this component ActionMap
delegate.
- Specified by:
getLookup
in interface Lookup.Provider
- Returns:
- a lookup with designates context of this component
- Since:
- 3.29
- See Also:
ContextAwareAction
,
Utilities.actionsToPopup(Action[], Lookup)
associateLookup
protected final void associateLookup(Lookup lookup)
- Associates the provided lookup with the component. So it will
be returned from
getLookup()
method.
- Parameters:
lookup
- the lookup to associate
- Throws:
IllegalStateException
- if there already is a lookup registered
with this component- Since:
- 4.23
Overview
Package
Class
Use
Tree
Deprecated
Index
Help
org.openide.windows 6.16
PREV CLASS
NEXT CLASS
FRAMES
NO FRAMES
All Classes
SUMMARY: NESTED | FIELD | CONSTR | METHOD
DETAIL: FIELD | CONSTR | METHOD
Built on May 28 2007. | Portions Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.