Eclipse WindowBuilder. This tutorial describes the usage of WindowBuilder for creating user interfaces.
1. Using the SWT Designer (WindowBuilder) for visual UI design
1.1. Overview of the SWT Designer
SWT Designer is a visual editor used to create graphical user interfaces. It is a two way parser, e.g., you can edit the source code or use a graphical editor to modify the user interface. SWT Designer synchronizes between both representations.
SWT Designer is part of the WindowBuilder project. WindowBuilder provides the foundation and SWT Designer adds the support for working with SWT based applications.
1.2. Using SWT Designer
SWT Designer provides a special editor. This editor can work with Eclipse 4 parts, SWT and JFace dialogs, JFace wizards, etc.
The following screenshot demonstrates what the editor looks like.
data:image/s3,"s3://crabby-images/e5fbf/e5fbfbc7b2bc34aed10005f539837cdca8ba03a3" alt="Showing SWT Designer main perspective"
SWT Designer allows you to drag-and-drop SWT components into an existing layout. You can configure layout settings and create event handlers for your widgets.
SWT Designer contributes additional SWT and JFace templates to the Eclipse IDE.
For example, you can use it to create Composites
and add these to the Eclipse user interface.
To create a new Composite
select .
data:image/s3,"s3://crabby-images/a39a1/a39a1021414c995ffb5460a1dbacce414b8987f9" alt="SWT Designer in Action"
SWT Designer has support to establish data binding via the JFace Data Binding framework.
2. Install SWT Designer
To install SWT Designer use the https://download.eclipse.org/windowbuilder/latest/
menu entry and enter the following update site to use it.data:image/s3,"s3://crabby-images/86a28/86a28016b38b3aec3ece9548b2304775ecabf495" alt="Install SWT Designer"
WindowBuilder downloads lists the available SWT designer releases. Typical, the latest release is the best to use. |
3. Optional Exercise: Getting started with SWT Designer
3.1. Building a user interface
Add a new view to your application using a model fragmet.
The implementations class of this view should be WindowBuilderPlaygroundPart
.
The following exercise assumes that you have SWT Designer already installed. |
Right-click on your WindowBuilderPlaygroundPart
class and select .
WindowBuilder uses the |
package com.vogella.tasks.ui.parts;
import jakarta.annotation.PostConstruct;
import org.eclipse.swt.widgets.Composite;
public class WindowBuilderPlaygroundPart {
// the WindowBuilder / SWTDesigner tooling
// uses the @PostConstruct method to figure out
// that the class is an Eclipse 4 part
// one method must be annotated with @PostConstruct and
// must receive at least a SWT Composite
@PostConstruct
public void createControls(Composite parent) {
System.out.println(this.getClass().getSimpleName()
+ " @PostConstruct method called.");
}
}
Switch to the Design tab in the WindowBuilder editor. This selection is highlighted in the following screenshot.
data:image/s3,"s3://crabby-images/a2bc2/a2bc27112c61513a18b52d1afde16b99e1df27c8" alt="Switch to design tab in the SWT Designer"
Use the SWT Designer to change the layout of the Composite
of the part to a GridLayout
.
data:image/s3,"s3://crabby-images/47568/4756859d800dd2b1d1b0e8f7ce4862240cb4ada8" alt="Changing the layout with WB"
Click in the Palette on Button and add a few buttons to your user interface.
data:image/s3,"s3://crabby-images/09544/095446622e0049abfc2e11423448ad7619c53e8f" alt="Adding buttons"
Add a Label
and a Text
field.
data:image/s3,"s3://crabby-images/d845b/d845bdc86cb3f727c9999a9e166b4ddd6da3f5ec" alt="Adding label and text"
3.2. Add a SelectionListener to your button
Assign an SelectionListener (event handler) to one of your buttons for the widgetSelected
.
You can do this via a right-click on the button.
Select .
data:image/s3,"s3://crabby-images/45e3b/45e3be80289f46f751a4cd9ce3d55938820d0c89" alt="Assign an EventHandler to your Button"
3.3. Review the generated code
Switch to the Source tab and review the code generated by the SWT Designer.
4. Learn more and get support
This tutorial continues on Eclipse RCP online training or Eclipse IDE extensions with lots of video material, additional exercises and much more content.
5. Links and Literature
Nothing listed.
5.1. vogella Java example code
endifdef::printrun[]
If you need more assistance we offer Online Training and Onsite training as well as consulting