Constructor for View Classweb.cse.ohio-state.edu/software/2221/web-sw1/...• A simple constructor...

Post on 17-Jul-2020

3 views 0 download

transcript

Constructor for View Class

7 January 2019 OSU CSE 1

Tasks To Be Performed• A simple constructor for the view class has four

main jobs:1. Create the JFrame being extended2. Set up the GUI widgets to be used and “lay out”

these widgets in the main application window3. Set up the observers by registering (in our

examples) the object being constructed, i.e., this, with each of the GUI widgets that might have events of interest to the application

4. Start the main application window

7 January 2019 OSU CSE 2

1: Create the JFramesuper("Simple GUI Demo");

7 January 2019 OSU CSE 3

External (GUI) Effectthis

7 January 2019 OSU CSE 4

External (GUI) Effectthis

7 January 2019 OSU CSE 5

Nothing illustrated in these slides actually becomes visible to the user until later!

2: Set Up GUI Widgets (Text)...this.inputText = new JTextArea("",

LINES_IN_TEXT_AREAS,

LINE_LENGTHS_IN_TEXT_AREAS);

...

JScrollPane inputTextScrollPane =

new JScrollPane(this.inputText);

7 January 2019 OSU CSE 6

2: Set Up GUI Widgets (Text)...this.inputText = new JTextArea("",

LINES_IN_TEXT_AREAS,

LINE_LENGTHS_IN_TEXT_AREAS);

...

JScrollPane inputTextScrollPane =

new JScrollPane(this.inputText);

7 January 2019 OSU CSE 7

5 lines,each of length 20

External (GUI) Effectthis.inputText

7 January 2019 OSU CSE 8

inputTextScrollPane

External (GUI) Effectthis.inputText

7 January 2019 OSU CSE 9

inputTextScrollPaneThe scrollbars in JScrollPanes

actually arise only when needed; not needed yet, but illustrated here.

2: Set Up GUI Widgets (Buttons)...this.copyButton =

new JButton("Copy Input");

7 January 2019 OSU CSE 10

External (GUI) Effect

this.copyButton

7 January 2019 OSU CSE 11

2: ... and Lay Out GUI WidgetsJPanel buttonPanel =

new JPanel(

new GridLayout(

ROWS_IN_BUTTON_PANEL_GRID,

COLUMNS_IN_BUTTON_PANEL_GRID));

...

buttonPanel.add(this.resetButton);buttonPanel.add(this.copyButton);

7 January 2019 OSU CSE 12

2: ... and Lay Out GUI WidgetsJPanel buttonPanel =

new JPanel(

new GridLayout(

ROWS_IN_BUTTON_PANEL_GRID,

COLUMNS_IN_BUTTON_PANEL_GRID));

...

buttonPanel.add(this.resetButton);buttonPanel.add(this.copyButton);

7 January 2019 OSU CSE 13

1 row,2 columns

External (GUI) Effect

buttonPanel

7 January 2019 OSU CSE 14

2: ... and Lay Out GUI Widgetsthis.setLayout(new GridLayout(

ROWS_IN_THIS_GRID,

COLUMNS_IN_THIS_GRID));

...

this.add(inputTextScrollPane);this.add(buttonPanel);this.add(outputTextScrollPane);

7 January 2019 OSU CSE 15

2: ... and Lay Out GUI Widgetsthis.setLayout(new GridLayout(

ROWS_IN_THIS_GRID,

COLUMNS_IN_THIS_GRID));

...

this.add(inputTextScrollPane);this.add(buttonPanel);this.add(outputTextScrollPane);

7 January 2019 OSU CSE 16

3 rows,1 column

2: ... and Lay Out GUI Widgetsthis.setLayout(new GridLayout(

ROWS_IN_THIS_GRID,

COLUMNS_IN_THIS_GRID));

...

this.add(inputTextScrollPane);this.add(buttonPanel);this.add(outputTextScrollPane);

7 January 2019 OSU CSE 17

Remember:the two buttons

are in this panel.

External (GUI) Effectthis

7 January 2019 OSU CSE 18

External (GUI) Effectthis

7 January 2019 OSU CSE 19

Remember:none of this is visible to the

user yet.

3: Set Up the Observersthis.resetButton.addActionListener(this);this.copyButton.addActionListener(this);

7 January 2019 OSU CSE 20

Internal (non-GUI) Effect

7 January 2019 OSU CSE 21

4: Start the Main Windowthis.pack();this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

this.setVisible(true);

7 January 2019 OSU CSE 22

External (GUI) Effect: Now Visiblethis

7 January 2019 OSU CSE 23

External (GUI) Effect: Now Visiblethis

7 January 2019 OSU CSE 24

The only code you wrote that executes now is the callback method for the two buttons:this.actionPerformed.