TCP2201
Object-oriented Analysis and Design
• At the end of this lecture you should
• Learn more details about GUI application programming
• Learn about Java’s GUI libraries
• Learn about event handling to enable interactivity with GUI
elements
• Learn about the difference between Android apps and normal
Java applications.
• Java graphical applications make use of the operating system
capabilities to provide WIMP (windows, icons, menus and pointer)
features
• Basic GUI elements are provided by the AWT library
• The AWT library is widely supported but has since been mostly
superseded by Swing
• Abstract window toolkit was the original GUI for Java upto v1.02
• Requires java.awt.* package
• GUI elements are platform dependent and considered
heavyweight – you need to implement many things yourself
• The following slide shows how the same Java code implementing
an AWT interface looks different on 5 different platforms (2 for
Windows)
http://www.eclipse.org/swt/
• Swing starts in JDK1.2 onwards (known as Java v2)
• Needs plugins to work
• Not all features available / backward compatible with earlier JDK
releases
• Swing is built upon AWT – enhances AWT
• GUI elements are platform independent / lightweight –
components are pure java and less reliant on operating system
components
• Provides more functionality compared to AWT but slower
• Basic functionality is often built-in (you'll learn more about this
later) compared to AWT
• The following slide shows several Swing interface ‘skins’
For reasons of deprecation and support, you should
focus more on the Swing library and JavaFX instead
of AWT.
• GUI with AWT uses many packages but the main ones are
• java.awt has GUI (button, textfield, label), container (frame,
panel, dialog, scroll), layout manager (flow, border, grid)
graphics (graphics, color font) elements
• java.event has event classes (actionevent, mouseevent,k
eyevent) listener interfaces (mouselistener, keylistener,
windowlistener) and adapters (mouseadapter, keyadapter)
• Swing replaces AWT in newer versions of Java
• Requires the javax.swing.* package but can work
alongside java.awt and java.event
• Java GUI has two types of elements – components and containers
• Graphical applications will use containers and components
• Command line applications do not use any
• Components
• elementary GUI objects like button, textfield etc.
• components can only exist inside containers use the add()
method of a container
• Containers
• holds components in a specific layout
• can hold other containers/components
• divided into 2: top-level and secondary-level containers
• Top-level containers – frame and dialog are most
common (equivalent JFrame and JDialog)
• Secondary-level containers – placed INSIDE top level
containers or another secondary container. Most common
are Panel and ScrollPane (equivalent JPanel,
JScrollpane)
• Extends javax.Swing.* and java.event.*
• Makes use of a container class – components are placed inside
the container based on a layout.
• With the container, GUI applications are standalone programs
that, by default, has a window (with size, border, location etc),
titlebar, control section, menu/tool bar (optional) , content area
and statusbar
• Typical containers and components are shown below (AWT
versions)
• Provides main standalone window for a Java GUI application
• Because it is an application, a JFrame needs the main() in your
code to run (same with JDialog)
• Has title bar with controls, optional menu bar and content area
• Needs a size!
• Common JFrame constructors
public JFrame()
public JFrame(String title)
public JFrame(GraphicsConfiguration gc)
public JFrame(String,GraphicsConfiguration)
• JFrame objects are ALWAYS invisible during declaration. To show
on screen use the setVisible method.
Ref: http://docs.oracle.com/javase/7/docs/api/java/awt/Frame.html
https://docs.oracle.com/javase/tutorial/uiswing/components/frame.html
import javax.swing.*;
public class TestFrame{
public static void main(String[] args) {
JFrame f = new JFrame("This is a frame");
f.setSize(250,100);
f.setVisible(true);
f.setDefaultCloseOperation
(JFrame.EXIT_ON_CLOSE);
}
}
import javax.swing.*;
public class Test extends JFrame{
public Test(){
super("This is a frame");
setSize(300,300);
setVisible(true);
setDefaultCloseOperation
(JFrame.EXIT_ON_CLOSE);
}
public static void main(String args[]){
Test m = new Test();
}
}
• This time the whole application class inherits and becomes a
subclass of Frame
• Provides additional pop-up windows – used as warning or prompt
for user to take notice or perform I/O operation
• Has minimal controls for window manipulation (e.g. no maximize)
import javax.swing.*; Note how JFrame still exists as
import java.awt.*; inheritance superclass.
public class Test extends JFrame{ Dialogs cannot exist on their own
JDialog d1; – they usually popup from
public Test(){ somewhere – in this case Frame is
d1=new JDialog(this);
d1.setTitle("which one?"); not “displayed”.
d1.setSize(380,200);
d1.getContentPane().setBackground(Color.red);
d1.setLocationRelativeTo(null);
d1.setVisible(true);
d1.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
// Note this program does not end correctly!!
}
public static void main(String args[]){
new Test();
}
}
JFrame has full titlebar control
JDialog only has close
• AWT containers are fairly similar to their Swing counterparts
• JFrame is Frame, JDialog is Dialog etc.
• Main difference with AWT containers - no functionality exists and
the programmer has to write every single action
• E.g. using similar code from slide 17 but with AWT
import java.awt.*;
public class TestFrame{
public static void main(String[] args) {
Frame f = new Frame("This is a frame");
f.setSize(250,100);
f.setVisible(true);
}
}
• The Frame object window does not do anything... it cannot even
CLOSE!! (use ctrl-c in your command window to terminate the
program)
AWT requires you to write event
handlers for everything
Swing has autoclose!!
But you still need to END your
program!
• Placed INSIDE top level containers or another secondary
container - to control layout or to place components in an area
using a specific layout style
• Most common are JPanel and JScrollPane
• Panel constructors : JPanel() and JPanel(Layout layout)
• ScrollPane constructors : JScrollPane() and
JScrollPane(int)
• AWT has similar containers but called Panel and ScrollPane
instead
• Code example
JPanel npl = new JPanel(); // create the Panel
npl.add(cbox); // Add components into Panel
this.add(npl); // Add panel onto this Frame
Ref: http://docs.oracle.com/javase/7/docs/api/javax/swing/JPanel.html
http://docs.oracle.com/javase/7/docs/api/javax/swing/JScrollPane.html
• Classes of ready made and reusable GUI components
• AWT includes Button, TextField, Label, CheckBox,
CheckBoxGroup(radio), List and Choice these are the ones
you need to know and are most common anyways
• All components shown below need the java.awt.* package
• Majority of AWT components have equivalent Swing versions that
have all the same functionality but have added features
• Used to display single line of formatted text
• Three AWT Label constructors provided
public Label(String, int alignment);
public Label(String);
public Label();
• Six JLabel constructors available (3 same as above but JLabel)
public JLabel(Icon image);
public JLabel(Icon image, int alignment);
public JLabel(String, Icon image, int align);
• Syntax example
JLabel lbl1=new JLabel ("This is a label");
lbl1.setText("Change the text of the label");
Ref: http://docs.oracle.com/javase/7/docs/api/java/awt/Label.html
http://docs.oracle.com/javase/7/docs/api/javax/swing/JLabel.html
• This class creates a labeled button which triggers an action
depending on state –normal (non-pushed), highlighted and
pushed.
• Requires ActionEvent to capture event that occurs towards the
button – else the button does nothing and is for show only
• Two constructors for Button
public Button(String btnlbl);
public Button();
• JButton has additional constructors, e.g.
public JButton(Icon icn);
public JButton(String btnlbl, Icon icn);
• Syntax example
JButton aButton = new JButton("Push me");
Ref: http://docs.oracle.com/javase/7/docs/api/java/awt/Button.html
http://docs.oracle.com/javase/7/docs/api/javax/swing/JButton.html
import javax.swing.*;
public class Test extends JFrame{
public Test(){
super("This is a frame");
JButton aB = new JButton ("Push me");
this.add(aB);
setSize(300,300);
setVisible(true);
setDefaultCloseOperation
(JFrame.EXIT_ON_CLOSE);
}
public static void main(String args[]){
Test m = new Test();
}
}
• Note how the button fills the whole frame.
• Without any layout managers, components
will always try to fill the entire container
and overlap each other based on order of
declaration
• Text fields look like labels but act differently (it can actually
replace a label if necessary) – it allows for I/O of text data making
it useful for data entry fields
• Four constructors for AWT
public TextField(String strText, int columns);
public TextField(String strText);
public TextField(int columns);
public TextField();
• Swing has additional
public JTextField
(Document doc, String strText, int columns);
• Syntax example
JTextField txtName = new JTextField();
Ref: http://docs.oracle.com/javase/7/docs/api/java/awt/TextField.html
http://docs.oracle.com/javase/7/docs/api/javax/swing/JTextField.html
JTextField tf1, tf2, tf3, tf4;
// a blank text field
tf1 = new JTextField();
// blank field of 20 columns
tf2 = new JTextField("", 20);
// predefined text displayed
tf3 = new JTextField("Hello!");
// predefined text in 30 columns
tf4 = new JTextField("Hello", 30);
this.add(tf1);
this.add(tf2);
......
• Checkboxes are use to provide users with preset options of which
the user can choose and select.
• User can select multiple options – good for question fields with
multiple answers
• AWT Checkboxes are convertible into radio buttons with grouping
• Checkbox constructors
public Checkbox()
public Checkbox(String label)
public Checkbox(String, Boolean state)
• JCheckBoxes (note case of letter B) are similar but have
additional constructors to include images
Ref: http://docs.oracle.com/javase/7/docs/api/java/awt/Checkbox.html
http://docs.oracle.com/javase/7/docs/api/javax/swing/JCheckBox.html
add(new JCheckBox("one", true));
add(new JCheckBox("two"));
add(new JCheckBox("three"));
setSize(300,150);
setVisible(true);
• Note: Inline declaration used in this example where no instance
identifiers are declared for the checkboxes
• If not comfortable with this declaration, then use normal
JCheckBox cbOne = new JCheckBox("one",true)
this.add(cbOne);
• Alternative method of declaring multiple checkboxes (or any
component)
for (int i=0;i<2;i++){
JCheckBox cbox = new JCheckBox("Check "+i);
add(cbox);
}
• Note: event handling will be different for components declared in
loops because they share the same identifier (in this case all the
checkboxes are called cbox)
• Radio buttons allow user to select pre-determined options –
similar to checkboxes – but only allow for single selection or one-
choice options only.
• Good for questions with multiple pre-determined answers that only
require one choice (e.g. Sex of user)
• Radio buttons makes use of multiple Checkbox objects AND the
CheckboxGroup (note the case of the letter ‘b’)
• With the CheckboxGroup, the checkboxes are converted into
radio buttons and automatically allow only one selection.
• Checkbox constructor
public Checkbox(String, Boolean, CheckboxGroup)
public Checkbox(String, CheckboxGroup, Boolean)
• Must be used together with CheckboxGroup
public CheckboxGroup()
Ref:http://docs.oracle.com/javase/7/docs/api/java/awt/CheckboxGroup.html
for (int i=0;i<2;i++){
CheckboxGroup cbg = new CheckboxGroup()
Checkbox cbox = new Checkbox("Check "+i,cbg,false);
add(cbox);
}
for (int i=0;i<2;i++){
Checkbox cbox = new Checkbox("Check "+i);
add(cbox);
}
• Swing does not have CheckboxGroup but instead implements a
new component called JRadioButton as a replacement
• To ‘group’ multiple radio buttons together, the ButtonGroup
component is used– you do not need to “add” ButtonGroup
JRadioButton b1 = new JRadioButton("A");
add(b1);
JRadioButton b2 = new JRadioButton("B");
add(b2);
JRadioButton b3 = new JRadioButton("C");
add(b3);
ButtonGroup bg = new ButtonGroup();
bg.add(b1); bg.add(b2); bg.add(b3);
Ref:https://docs.oracle.com/javase/7/docs/api/javax/swing/JRadioButton.html
• Alternative to radio buttons is to use choice - allows for selection
of a single option but saves space compared to radio buttons.
• Choice constructor
public Choice()
• Syntax example
Choice colorOption = new Choice();
colorOption.add("Blue"); // accepts String only
• Swing replaces choice with JComboBox
• Syntax example
String[] petStrings = { "Bird", "Cat", "Dog"};
JComboBox pList = new JComboBox(petStrings);
Ref: http://docs.oracle.com/javase/7/docs/api/java/awt/Choice.html
http://docs.oracle.com/javase/7/docs/api/javax/swing/JComboBox.html
Choice nc = new Choice();
nc.add("Blue");
nc.add("Red");
nc.add("Green");
add(nc);
Choice nc = new Choice();
for (int i=0;i<10;i++)
nc.add(Integer.toString(i+1));
add(nc);
DefaultComboBoxModel fruitsName = new DefaultComboBoxModel();
fruitsName.addElement("Apple");
fruitsName.addElement("Grapes");
fruitsName.addElement("Mango");
fruitsName.addElement("Pear");
JComboBox fruitCombo = new JComboBox(fruitsName);
fruitCombo.setSelectedIndex(0);
• TextArea is fairly similar to the TextField but can span multiple
lines
• TextArea has additional options to set size and scroll bar options
• TextArea common constructors
public TextArea()
public TextArea(int,int)
public TextArea(String)
public TextArea(String, int row, int col)
• Syntax example
TextArea nt = new TextArea(“Hello”,5,40);
• The Swing equivalent has the same constructors (using
JTextArea instead of TextArea) but also adds
public JTextArea(Document)
Ref: http://docs.oracle.com/javase/7/docs/api/java/awt/TextArea.html
String sample = new String("Lorem ipsum dolor sit amet.....");
TextArea ta = new TextArea(sample, 4,30);
add(ta);
By default, a text area does not
auto “wrap” text so any text string
longer than the area creates scroll
bars
String sample = new String("Lorem ipsum dolor sit amet.....");
TextArea ta = new TextArea(sample,
4,30,TextArea.SCROLLBARS_VERTICAL_ONLY);
add(ta);
Note: In this example, no layout
managers are used so the
components fill the container and
ignore the size parameters
• Other useful components but not covered here
• Scrollbar/Jscrollbar adds scrollbar(s) to a container
• JFileChooser built-in file open/save dialog (Swing only)
• JColorChooser color palette (Swing only)
• MDI multiple document interface (i.e. window in window)
• JOptionPane alternative to JDialog
• JEditorPane text editor with support for HTML elements
• AWT has many layout managers, you need to know 3
• FlowLayout, GridLayout, BorderLayout,
GridBagLayout, BoxLayout, CardLayout, GroupLayout,
SpringLayout
• Each container usually has its default layout if you do not specify
(content pane is border, panel is flow, etc. see javadocs)
• FlowLayout – arranges components in order they are declared
left-to-right top-to-bottom
• GridLayout – arranges components in order they are declared
based on available grid cells (increased when necessary)
• BorderLayout – arranges components based on relativity to
compass direction (NORTH, SOUTH, WEST. EAST, CENTER)
• The following examples show how Flow, Grid and Border layout
managers will handle different components on a Frame.
setLayout(new FlowLayout());
If application is resized, FlowLayout manager re-flows items accordingly
Notice how TextArea now follows the
size declaration no matter the
application size
setLayout(new GridLayout(3,1));
(rows,columns)
setLayout(new GridLayout(1,3));
setLayout(new GridLayout(0,5));
When both the number of rows and the number of columns have been set to
non-zero values, either by a constructor or by the setRows and setColumns
methods, the number of columns specified is ignored.
Instead, the number of columns is determined from the specified number of
rows and the total number of components in the layout.
setLayout(new BorderLayout());
add(new Button("North"), BorderLayout.NORTH);
add(new Button("South"), BorderLayout.SOUTH);
add(new Button("East"), BorderLayout.EAST);
add(new Button("West"), BorderLayout.WEST);
add(new Button("Center"), BorderLayout.CENTER);
If the window is enlarged, the
center area gets as much of the
available space as possible.
• Note that this method is deprecated but still supported.
• Latest versions of Java recommend PAGE_START,
LINE_START, CENTER, LINE_END and PAGE_END to replace
North, West, Center, East and South.
• Everything that occurs in a GUI is an event
• To handle user interactions you need to add in triggers (event
source), targets (event listener) and types (event object)
• Two general groups in AWT: component events and I/O events
• component events handle interactions with GUI components
(e.g. button is clicked, text area is filled, checkbox is
unchecked etc)
• I/O events handle input and output events from users through
mouse and keyboard (or touch) --> "implements
MouseListener,KeyListener"
• Event handling requires you to overwrite ALL functions from the
implemented class
• Represents events that occur from mouse and keyboard trigger
(touch is not included in AWT)
• Event handling is provided by interface classes – divided into
MouseEvents. MouseListener and KeyEvents
• Because they are interface classes, they must be implements
into program code
• Mouse events have two interface classes because one tracks for
movement whilst the other tracks for button presses
• Implements the listener you want to use in your program class
• Create and add your component you want to track
• Add the listener to that component
• Add the event handler which triggers when the listener ‘hears’
something and sends an event message
• Complete the event handler code to handle the event that was
triggered.
• MouseListener
public void mouseClicked(MouseEvent evt)
public void mouseExited(MouseEvent evt)
public void mouseReleased(MouseEvent evt)
public void mousePressed(MouseEvent evt)
public void mouseEntered(MouseEvent evt)
• MouseMotionListener
public void mouseDragged(MouseEvent e)
public void mouseMoved(MouseEvent e)
• Basic code (example using AWT) with no event handling
import java.awt.*;
public class FrameDemo extends Frame{
public FrameDemo(){
super("This is a frame");
setSize(300,150);
setVisible(true);
}
public static void main(String args[]){
FrameDemo m = new FrameDemo();
}
}
• Add in listener we want (this example tracks mouse movement)
AND event handling package
import java.awt.*;
import java.event.*;
public class FrameDemo extends Frame implements
MouseListener{
public FrameDemo(){
super("This is a frame");
setSize(300,150);
setVisible(true);
}
public static void main(String args[]){
FrameDemo m = new FrameDemo();
}
}
• Override all abstract methods from interface class (add them all in!)
import java.awt.*;
import java.awt.event.*;
public class FrameDemo extends Frame implements MouseListener{
public FrameDemo(){
super("This is a frame");
setSize(300,150);
setVisible(true);
}
public static void main(String args[]){
FrameDemo m = new FrameDemo();
}
public void mouseClicked(MouseEvent evt){};
public void mouseExited(MouseEvent evt){};
public void mouseReleased(MouseEvent evt){};
public void mousePressed(MouseEvent evt){};
public void mouseEntered(MouseEvent evt){};
}
• Override the abstract methods we want to use
import java.awt.*;
import java.awt.event.*;
public class FrameDemo extends Frame implements MouseListener{
public FrameDemo(){
super("This is a frame");
setSize(300,150);
setVisible(true);
}
public static void main(String args[]){
FrameDemo m = new FrameDemo();
}
public void mouseClicked(MouseEvent evt){};
public void mouseExited(MouseEvent evt){
setBackground(Color.white);};
public void mouseReleased(MouseEvent evt){};
public void mousePressed(MouseEvent evt){};
public void mouseEntered(MouseEvent evt){
setBackground(Color.red);};
}
• Add the trigger to the component
import java.awt.*;
import java.awt.event.*;
public class FrameDemo extends Frame implements MouseListener{
public FrameDemo(){
super("This is a frame");
setSize(300,150);
setVisible(true);
addMouseListener(this);
}
public static void main(String args[]){
FrameDemo m = new FrameDemo();
}
public void mouseClicked(MouseEvent evt){};
public void mouseExited(MouseEvent evt){
setBackground(Color.white);};
public void mouseReleased(MouseEvent evt){};
public void mousePressed(MouseEvent evt){};
public void mouseEntered(MouseEvent evt){
setBackground(Color.red);};
}
public class FrameDemo extends Frame implements MouseListener{
Label nl = new Label("This is a label");
public FrameDemo(){
setLayout(new FlowLayout());
add(nl);
setSize(300,150);
setVisible(true);
addMouseListener(this);
}
public static void main(String args[]){
FrameDemo m = new FrameDemo();
}
public void mouseClicked(MouseEvent evt){
int x = evt.getX();
int y = evt.getY();
nl.setText("Clicked: " + x + "," +y);
};
public void mouseExited(MouseEvent evt){};
public void mouseReleased(MouseEvent evt){};
public void mousePressed(MouseEvent evt){};
public void mouseEntered(MouseEvent evt){};
}
• Keyboards cannot move so they only have one interface class for
events
• Keyboard events are triggered whenever the keyboard is used
(does not have to be within a component like a text field)
• Useful for handling events in applications with no discrete
components for keyboard to interact with (e.g. games)
• KeyEvents
public void keyPressed(KeyEvent e){};
public void keyReleased(KeyEvent e){};
public void keyTyped(KeyEvent e){};
import java.awt.*;
import java.awt.event.*;
public class FrameDemo extends Frame implements KeyListener{
Label nl = new Label("This is a label");
public FrameDemo(){
super("This is a frame");
setLayout(new FlowLayout());
add(nl);
setSize(300,150);
setVisible(true);
addKeyListener(this);
}
public static void main(String args[]){
FrameDemo m = new FrameDemo();
}
public void keyPressed(KeyEvent evt){
int keyPressed=evt.getKeyCode();
nl.setText("Key = "+(char)keyPressed);
}
public void keyReleased(KeyEvent evt){};
public void keyTyped(KeyEvent evt){};
}
• Makes use of a set of Listeners ActionListener, ItemListener,
and AdjustmentListener - each for a specific task
• ActionListener 'listens' for actions like button presses and
textfield changes
• ItemListener 'listens' for actions like selections and
check/uncheck operations on multiple items (lists, choices,
checkboxes)
• AdjustmentListener 'listens' for actions on scrollbars
• How to use?
• implement the interface class ActionListener, ItemListener
and/or AdjustmentListener to your class
• Attach a source trigger to a component (i.e. addActionListener,
addItemListener, addAdjustmentListener)
• override ALL methods from interface class
• capture event (ActionEvent, ItemEvent, AdjusmentEvent)
• perform operation against event captured
• Some events can be triggered by the component themselves (e.g.
similar to the mouseEntered, mouseExited previously) and can
also be captured
• Example: Button also has mouseEntered and MouseExited
triggers which can be used to highlight mouse overs
• Works on buttons, fields etc.
• To use, implements ActionListener in the program code
• Add the ActionListener to the object to which an event will be
triggered
• Overload all abstract methods from ActionListener in program
code (i.e actionPerformed)
• Handle the triggered event in the chosen method
import java.awt.*;
import java.awt.event.*;
public class FrameDemo extends Frame implements ActionListener{
private Button btnCount;
public FrameDemo(){
setLayout (new FlowLayout());
btnCount = new Button("Close");
add(btnCount);
setSize(300,150);
setVisible(true);
btnCount.addActionListener(this);
}
public static void main(String args[]){
FrameDemo m = new FrameDemo();
}
public void actionPerformed(ActionEvent evt){
System.exit(0);
}
}
• What if multiple buttons declared under one identifier?
for (int i=0;i<3;i++){
Button btnarray = new Button("Button "+i);
add(btnarray);
btnarray.addActionListener(this);
}
• Use method to extract button details
public void actionPerformed(ActionEvent evt){
String btn=evt.getActionCommand();
if (btn.equals("Button 0"))
System.exit(0);
else if (btn.equals("Button 1"))
lbl.setText("Button 1 pressed");
else if (btn.equals("Button 2"))
lbl.setText("Button 2 pressed");
else if (btn=="Close")
System.exit(0);
}
• This slide mostly references any code using pure AWT
• The close button on the title bar on applications cannot be
referenced as a object.
• Java has prepared methods to anticipate actions such as closing
the window using the [ X ] button
• To use, add a window listener to the main container to listen when
an exit event is triggered
addWindowListener(new ExitListener());
• Handle the event when it occurs by overriding the ExitListener
public class ExitListener() extends WindowAdapter{
public void windowClosing(WindowEvent e){
System.exit(0);
}
}
• Similar method of implementing listeners – just different interface
classes and methods to override and on different components
• Not all components will work correctly with listeners (e.g. you
cannot addActionListener to a Frame)
Ref: http://docs.oracle.com/javase/7/docs/api/java/awt/event/ItemListener.html
http://docs.oracle.com/javase/7/docs/api/java/awt/event/AdjustmentListener.html
• Newer way to do Java GUIs
• You are allowed to use JavaFX if you want.
• Tutorial available at
https://docs.oracle.com/javafx/2/get_started/jfxpub-
get_started.htm
• There is no main()
• public class MainActivity extends AppCompatActivity
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.myfirstapp.MainActivity">
<EditText
android:id="@+id/editText"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:ems="10"
android:hint="@string/edit_message" <Button
android:inputType="textPersonName" android:id="@+id/button"
app:layout_constraintLeft_toLeftOf="parent" android:layout_width="wrap_content"
app:layout_constraintTop_toTopOf="parent" android:layout_height="wrap_content"
app:layout_constraintRight_toLeftOf="@+id/button" android:text="@string/button_send"
android:layout_marginLeft="16dp" /> app:layout_constraintBaseline_toBaselineOf="@+id/editText"
app:layout_constraintLeft_toRightOf="@+id/editText"
app:layout_constraintRight_toRightOf="parent"
android:layout_marginLeft="16dp"
android:layout_marginRight="16dp" />
</android.support.constraint.ConstraintLayout>
• Kept in strings.xml for easy translation without needing to access
the source code.
<resources>
<string name="app_name">My First App</string>
<string name="edit_message">Enter a message</string>
<string name="button_send">Send</string>
</resources>
• What you need to do on your own
• Try out all the code examples shown today on your own
• Refer to the online documentation at
https://docs.oracle.com/javase/8/docs/api/index.html?javax/swi
ng/package-summary.html
• Read up on the listeners
• Swing tutorial at https://docs.oracle.com/javase/tutorial/uiswing/
• JavaFX tutorial at
https://docs.oracle.com/javafx/2/get_started/jfxpub-
get_started.htm
NOTE: The content in this set of slides is
NOT ENOUGH to cover the entire content
of Java GUI/event programming .
You MUST put in your own effort to
research other methods not covered here
that WILL come out during exams OR are
required in your assignment