| 
 | Eclipse Platform Release 3.4 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||
java.lang.Objectjava.util.EventObject
org.eclipse.swt.internal.SWTEventObject
org.eclipse.swt.events.TypedEvent
org.eclipse.swt.browser.WindowEvent
A WindowEvent is sent by a Browser when
 a new window needs to be created or when an existing window needs to be
 closed. This notification occurs when a javascript command such as
 window.open or window.close gets executed by
 a Browser.
 
 The following example shows how WindowEvent's are typically
 handled.
 
 
	public static void main(String[] args) {
		Display display = new Display();
		Shell shell = new Shell(display);
		shell.setText("Main Window");
		shell.setLayout(new FillLayout());
		Browser browser = new Browser(shell, SWT.NONE);
		initialize(display, browser);
		shell.open();
		browser.setUrl("http://www.eclipse.org");
		while (!shell.isDisposed()) {
			if (!display.readAndDispatch())
				display.sleep();
		}
		display.dispose();
	}
	static void initialize(final Display display, Browser browser) {
		browser.addOpenWindowListener(new OpenWindowListener() {
			public void open(WindowEvent event) {
				// Certain platforms can provide a default full browser.
				// simply return in that case if the application prefers
				// the default full browser to the embedded one set below.
				if (!event.required) return;
				// Embed the new window
				Shell shell = new Shell(display);
				shell.setText("New Window");
				shell.setLayout(new FillLayout());
				Browser browser = new Browser(shell, SWT.NONE);
				initialize(display, browser);
				event.browser = browser;
			}
		});
		browser.addVisibilityWindowListener(new VisibilityWindowListener() {
			public void hide(WindowEvent event) {
				Browser browser = (Browser)event.widget;
				Shell shell = browser.getShell();
				shell.setVisible(false);
			}
			public void show(WindowEvent event) {
				Browser browser = (Browser)event.widget;
				Shell shell = browser.getShell();
				if (event.location != null) shell.setLocation(event.location);
				if (event.size != null) {
					Point size = event.size;
					shell.setSize(shell.computeSize(size.x, size.y));
				}
				if (event.addressBar || event.menuBar || event.statusBar || event.toolBar) {
					// Create widgets for the address bar, menu bar, status bar and/or tool bar
					// leave enough space in the Shell to accommodate a Browser of the size
					// given by event.size
				}
				shell.open();
			}
		});
		browser.addCloseWindowListener(new CloseWindowListener() {
			public void close(WindowEvent event) {
				Browser browser = (Browser)event.widget;
				Shell shell = browser.getShell();
				shell.close();
			}
		});
	}
 
Main Browser
Second Browser
CloseWindowListener, 
OpenWindowListener, 
VisibilityWindowListener, 
Sample code and further information, 
Serialized Form| Field Summary | |
|  boolean | addressBarSpecifies whether the Shellhosting theBrowsershould
 display an address bar. | 
|  Browser | browserBrowserprovided by the application. | 
|  Point | locationRequested location for the Shellhosting theBrowser. | 
|  boolean | menuBarSpecifies whether the Shellhosting theBrowsershould
 display a menu bar. | 
|  boolean | requiredSpecifies whether the platform requires the user to provide a Browserto handle the new window. | 
|  Point | sizeRequested Browsersize. | 
|  boolean | statusBarSpecifies whether the Shellhosting theBrowsershould
 display a status bar. | 
|  boolean | toolBarSpecifies whether the Shellhosting theBrowsershould
 display a tool bar. | 
| Fields inherited from class org.eclipse.swt.events.TypedEvent | 
| data, display, time, widget | 
| Fields inherited from class java.util.EventObject | 
| source | 
| Method Summary | |
|  String | toString()Returns a string containing a concise, human-readable description of the receiver. | 
| Methods inherited from class java.util.EventObject | 
| getSource | 
| Methods inherited from class java.lang.Object | 
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Field Detail | 
public boolean required
Browser to handle the new window.
public Browser browser
Browser provided by the application.
public Point location
Shell hosting the Browser.
 It is null if no location has been requested.
public Point size
Browser size. The client area of the Shell 
 hosting the Browser should be large enough to accommodate that size. 
 It is null if no size has been requested.
public boolean addressBar
Shell hosting the Browser should
 display an address bar.
public boolean menuBar
Shell hosting the Browser should
 display a menu bar.
public boolean statusBar
Shell hosting the Browser should
 display a status bar.
public boolean toolBar
Shell hosting the Browser should
 display a tool bar.
| Method Detail | 
public String toString()
toString in class TypedEvent| 
 | Eclipse Platform Release 3.4 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||
Guidelines for using Eclipse APIs.
Copyright (c) Eclipse contributors and others 2000, 2008. All rights reserved.