JFace

JFace is defined by the Eclipse project as "a UI toolkit that provides helper classes for developing UI features that can be tedious to implement."[1] The Standard Widget Toolkit (SWT) is an open source widget toolkit for Java designed to provide efficient, portable access to the user-interface facilities of the operating systems on which it is implemented.

JFace
The Eclipse IDE, a JFace-based application
Developer(s)Eclipse Foundation
Stable release
3.9.1 / July 25, 2013 (2013-07-25)
Operating systemCross-platform
Available inMultilingual
Typewidget toolkit for the Java platform
LicenseEclipse Public License
Websitewiki.eclipse.org/index.php/JFace

Structure

It is a layer that sits on top of the raw widget system, and provides classes for handling common UI programming tasks. It brings model view controller programming to the Standard Widget Toolkit.

  1. Provides Viewer classes that handle the tedious tasks of populating, sorting, filtering, and updating widgets
  2. Provides Actions to allow users to define their own behavior and to assign that behavior to specific components, e.g. menu items, tool items, push buttons, etc.
  3. Provides registries that hold Images and Fonts
  4. Defines standard dialogs and wizards, and defines a framework for building complex interactions with the user
  5. Its primary goal is to free the developer up, letting the developer focus on the implementation of his or her specific application without having to be concerned with the underlying widget system or solving problems that are common in almost all UI applications.
  6. A primary concern of the Eclipse group when developing JFace was that under no circumstances did they want to hide the SWT component implementation from the programmer. JFace is completely dependent on SWT, but SWT is not dependent on JFace. Furthermore, the Eclipse Workbench is built on both JFace and SWT; in some instances, it bypasses JFace and accesses SWT directly.

Example

The following is a basic Hello World program using JFace.

import org.eclipse.jface.window.ApplicationWindow;
import org.eclipse.swt.SWT;
import org.eclipse.swt.widgets.*;

public class HelloWorld extends ApplicationWindow {
    public static void main(String[] args) {
        new HelloWorld().run();
    }
    public HelloWorld() {
        super(null);
    }
    public void run() {
        setBlockOnOpen(true);
        open();
        Display.getCurrent().dispose();
    }
    protected Control createContents(Composite parent) {
        Label label = new Label(parent, SWT.CENTER);
        label.setText("Hello, World");
        return label;
    }
}
gollark: Buying some sort of very cheap computer which can still run MacOS and running something saner on your main one might be viable.
gollark: How Apple of Apple.
gollark: There are, IIRC, ways to make VMs which most stuff won't detect as virtual, but then you lose performance a lot.
gollark: Really? If so, that's very Apple.
gollark: I like the new logo, it has a nice color.

See also

References

Bibliography

  • Scarpino, Matthew; Holder, Stephen; Ng, Stanford; Mihalkovic, Laurent (November 28, 2004), SWT/JFace in Action: GUI Design with Eclipse 3.0 (1st ed.), Manning Publications, p. 496, ISBN 1-932394-27-3
  • Li Guojie, Jackwind (February 11, 2005), Professional Java Native Interfaces with SWT/JFace (1st ed.), Wrox Press, p. 528, ISBN 0-470-09459-1
  • Harris, Robert; Warner, Rob (June 21, 2004), The Definitive Guide to SWT and JFACE (1st ed.), Apress, p. 684, ISBN 1-59059-325-1, archived from the original on July 31, 2009, retrieved July 21, 2009
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.