Marco Faella Elementi di programmazione di interfacce Grafiche. Il pattern OBSERVER.
|
|
|
- Celia Santini
- 9 anni fa
- Просмотров:
Транскрипт
1 Marco Faella Elementi di programmazione di interfacce Grafiche. Il pattern OBSERVER. 9 Lezione n. Parole chiave: Java Corso di Laurea: Informatica Insegnamento: Linguaggi di Programmazione II Docente: [email protected] A.A
2 Interfacce grafiche in Java Unico tra i linguaggi di programmazione più diffusi, Java offre nella sua libreria standard un framework per la realizzazione di interfacce grafiche (GUI) Tale framework si basa sulle due librerie Swing e AWT (Abstract Windowing Toolkit) AWT è stata introdotta con la prima versione di Java (1.0) AWT usa gli elementi grafici (widget) propri del sistema operativo ospite Quindi, i programmi presentano una diversa veste grafica in ciascun sistema operativo Swing, introdotta con Java 1.2, offre dei propri elementi grafici, identici per tutti i sistemi operativi Più esattamente, Swing si occupa di disegnare il contenuto delle finestre, mentre la cornice della finestra e la sua barra del titolo restano affidate alla GUI del sistema operativo Swing non sostituisce interamente AWT, ma si appoggia ad essa per alcune funzionalità Gran parte dei meccanismi presentati in questa lezione sono in realtà automatizzati dai moderni ambienti di sviluppo, come Netbeans ed Eclipse Tuttavia, resta comunque interessante conoscere il sistema sottostante, soprattutto dal punto di vista della progettazione In particolare, in queste librerie si possono vedere all'opera diversi design pattern
3 Creare una finestra Il seguente codice mostra come creare una finestra con Swing/AWT Eseguendo il programma, viene mostrata la finestra riportata nella figura a destra import java.awt.*; import javax.swing.*; public class FrameTest { public static void main(string[] args) { final int WIDTH=200, HEIGHT=200; } } // creo la finestra JFrame frame = new JFrame(); // imposto le dimensioni iniziali frame.setsize(width, HEIGHT); // imposto l'operazione di chiusura frame.setdefaultcloseoperation( JFrame.EXIT_ON_CLOSE); // mostro la finestra frame.setvisible(true); Figura 1: La finestra creata dal programma a sinistra.
4 Creare una finestra All'inizio, importiamo tutte le classi dei pacchetti java.awt e javax.swing, anche se in questo semplice esempio utilizziamo solo la classe javax.swing.jframe Poi, creiamo un oggetto di tipo JFrame e impostiamo alcune sue proprietà con opportuni metodi il metodo setsize imposta le dimensioni iniziali della finestra il metodo setdefaultcloseoperation serve ad impostare il comportamento del programma quando la finestra in questione viene chiusa il parametro JFrame.EXIT_ON_CLOSE (costante di classe) indica che il programma deve terminare quando la finestra viene chiusa L'ultima chiamata a metodo serve a rendere la finestra visibile A questo punto, il main termina Non termina l'intera applicazione, perché, essendo stata resa una finestra visibile, è partito automaticamente un nuovo thread che ne gestisce gli eventi L'applicazione terminerà solo quando l'utente cliccherà sull'apposita icona nella cornice della finestra
5 Aggiungere widget Aggiungiamo alla finestra creata precedentemente degli elementi grafici, come pulsanti e campi di testo, chiamati widget Di seguito sono riportati i passaggi principali, commentati nella prossima slide // creo la finestra JFrame frame = new JFrame(); // creo due pulsanti e un campo di testo JButton hellobutton = new JButton("Say Hello"); JButton goodbyebutton = new JButton("Say Goodbye"); final int FIELD_WIDTH = 20; JTextField textfield = new JTextField(FIELD_WIDTH); textfield.settext("click a button!"); // ottengo un riferimento al "pannello del contenuto" (contentpane) della finestra Container contentpane = frame.getcontentpane(); // imposto il layout del pannello contentpane.setlayout(new GridLayout(2,2)); // aggiungo al pannello i 3 elementi che ho creato contentpane.add(hellobutton); contentpane.add(goodbyebutton); contentpane.add(textfield);
6 Aggiungere widget I widget principali (pulsanti, caselle di testo, barre di scorrimento, checkbox, etc.) corrispondono ad altrettante classi (JButton, JTextField, etc.), tutte sottoclassi di Component Per aggiungere un widget ad una finestra, si ottiene prima il Container che rappresenta lo spazio inizialmente vuoto contenuto nella finestra, chiamando il metodo getcontentpane di JFrame La disposizione grafica dei widget all'interno di un Container si controlla impostando un layout Ciascun layout è identificato da una apposita classe, secondo le disposizioni del pattern STRATEGY, che sarà illustrato nella lezione successiva In questo caso, utilizziamo il layout GridLayout, che dispone gli elementi in una griglia I parametri (2,2) passati al costruttore rappresentano il numero di righe e di colonne della griglia Infine, si invoca il metodo add di Container, che aggiunge un elemento al contenitore Il risultato è quello nella figura a destra Figura 2: La finestra creata dal programma della slide precedente.
7 Gestione degli eventi Allo stato attuale, la pressione dei pulsanti non provoca nessuna reazione nell'applicazione Supponiamo di voler modificare il contenuto del campo di testo in corrispondenza della pressione di un pulsante A questo scopo, dobbiamo costruire un oggetto deputato a reagire all'evento pressione del pulsante Poi, registriamo questo oggetto come interessato a ricevere determinati eventi Questo tipo di oggetto viene chiamato listener (ascoltatore) e deve implementare l'interfaccia ActionListener: public interface ActionListener { void actionperformed(actionevent e); } Il metodo actionperformed viene richiamato automaticamente quando si genera un evento di interesse Per segnalare che un oggetto listener intende ricevere gli eventi generati da un determinato oggetto grafico, si chiama il metodo addactionlistener di quest'ultimo, passando il primo come argomento La prossima slide illustra i passaggi principali
8 Gestione degli eventi Il metodo main viene modificato come segue: // creo la finestra, etc.... // creo il campo di testo; notare il "final" final JTextField textfield = new JTextField(FIELD_WIDTH); textfield.settext("click a button!"); // classe locale che gestirà gli eventi class Ascoltatore implements ActionListener { public Ascoltatore(String s) { msg = s; } private String msg; public void actionperformed(actionevent event) { textfield.settext(msg); } } // creo il primo pulsante JButton hellobutton = new JButton("Say Hello"); // associo un oggetto osservatore al pulsante hellobutton.addactionlistener(new Ascoltatore("Hello, World")); // faccio lo stesso per il secondo pulsante JButton goodbyebutton = new JButton("Say Goodbye"); goodbyebutton.addactionlistener(new Ascoltatore("Goodbye, World!"));
9 Gestione degli eventi Con le modifiche della slide precedente, l'applicazione risponde alla pressione dei due pulsanti, inserendo le stringhe Hello, World e Goodbye, World nel campo di testo Utilizziamo la classe locale Ascoltatore per realizzare gli oggetti ascoltatori necessari Essendo locale, tale classe locale non è visibile al di fuori del metodo main La classe Ascoltatore può accedere alla variabile locale textfield, in quanto questa è stata dichiarata final Esercizio: modificare il codice in modo da utilizzare una o più classi anonime al posto della classe Ascoltatore Il metodo addactionlistener registra un ascoltatore interessato specificamente alla pressione di quel pulsante Il meccanismo degli eventi è molto più complesso, e prevede la possibilità di rilevare gli eventi più disparati, come i singoli movimenti del mouse o pressioni di tasti della tastiera E' possibile associare più listener alla stessa sorgente di eventi, chiamando più volte il metodo appropriato (in questo caso addactionlistener) quando si verificherà l'evento in questione, saranno chiamati tutti i listener registrati
10 Il pattern OBSERVER Il meccanismo di eventi ed ascoltatori viene codificato dal pattern OBSERVER, dove la metafora dell'ascolto viene sostituita da quella dell'osservazione Contesto: 1) Un oggetto (soggetto) genera eventi 2) Uno o più oggetti (osservatori) vogliono essere informati del verificarsi di tali eventi Soluzione: 1) Definire un'interfaccia, chiamata Observer e dotata di un metodo notify, che sarà implementata dagli osservatori 2) Il soggetto ha un metodo (chiamato attach) per registrare un osservatore 3) Il soggetto gestisce l'elenco dei suoi osservatori registrati 4) Quando si verifica un evento, il soggetto informa tutti gli osservatori registrati, invocando il loro metodo notify
11 Diagramma del pattern OBSERVER La figura a destra rappresenta il diagramma delle classi tipico del pattern OBSERVER Sono presenti la classe Subject (soggetto osservato) e l'interfaccia Observer (osservatore) Si noti la relazione di aggregazione unoa-molti tra Subject e Observer tale relazione indica che ogni oggetto di tipo Subject conserva un insieme di riferimenti ad oggetti di tipo Observer ovvero, ogni Subject tiene traccia degli osservatori che si sono registrati chiamando attach Figura 3: Diagramma UML del pattern OBSERVER.
12 Applicazione di OBSERVER La figura a destra rappresenta il diagramma delle classi che lega la classe JButton all'interfaccia ActionListener Come si vede, c'è una corrispondenza diretta con lo schema proprio del pattern OBSERVER, riportato sulla slide precedente In particolare, JButton ricopre il ruolo di Subject e ActionListener quello di Observer Figura 4: Diagramma UML dell'applicazione del pattern OBSERVER ai pulsanti delle interfacce grafiche create con Swing/AWT.
13 Supporto al pattern OBSERVER nella libreria standard Oltre che essere utilizzato dalle librerie grafiche, il pattern OBSERVER viene anche supportato dalla libreria standard tramite la classe Observable e l'interfaccia Observer, del package java.util L'interfaccia Observer rappresenta un generico osservatore il suo contenuto è il seguente: public interface Observer { void update(observable o, Object arg); } Il metodo update corrisponde a quello che nel pattern si chiama notify cioè, è il metodo che l'oggetto osservato invocherà al verificarsi degli eventi di interesse i due argomenti di update sono l'oggetto osservabile che sta chiamando e un argomento libero, che l'applicazione può utilizzare come vuole
14 Supporto al pattern OBSERVER nella libreria standard La classe Observable rappresenta un generico oggetto osservabile i suoi metodi principali sono i seguenti: public class Observable { public void addobserver(observer o) {... } public void notifyobservers(object arg) {... } } Il metodo addobserver aggiunge un osservatore a questo oggetto corrisponde al metodo attach del pattern Il metodo notifyobservers invoca il metodo update di tutti gli osservatori registrati, passando this come primo argomento e arg come secondo L'uso tipico di questa classe consiste nell'estenderla, in modo da aggiungere ad una nostra classe la capacità di essere osservata Altre classi nostre implementeranno Observer e fungeranno da osservatori In tal modo, non dovremo preoccuparci di implementare il meccanismo di registrazione e notifica degli osservatori Naturalmente, la classe che estende Observable perde la possibilità di utilizzare l'ereditarietà per altri scopi, visto che in Java è possibile estendere una sola classe
L Abstract Windowing Toolkit. Le GUI in Java. Il Frame. Cenni sull ereditarietà. Gianpaolo Cugola - Sistemi Informativi in Rete
Le GUI in Java L Abstract Windowing Toolkit Fino ad ora abbiamo usato le classi del pacchetto JavaBook per realizzare semplici interfacce grafiche (GUI) Si tratta di classi facili da usare...... ma che
La nostra finestra dovrebbe essere come mostra la figura: Diamo innanzitutto un occhiata alle componenti principali di input/output:
Esercitazione N4: Costruzione di una applicazione GUI utilizzando i componenti di base per realizzare l input e l output e cioè Label, TextBox, TextArea Button e Panel (Pannelli) I componenti che utilizzeromo
Programmazione in rete e laboratorio
Programmazione in rete e laboratorio 2001-02 JAVA Alberto Martelli PROGRAMMAZIONE GRAFICA Molti programmi interagiscono con l utente attraverso una interfaccia grafica GUI - Graphical User Interface Java
PROVA FINALE Ingegneria del software
PROVA FINALE Ingegneria del software Ing. Jody Marca [email protected] Laboratorio N 3 Cosa faremo oggi 2 Interfaccia grafica e SWING Lettura e scrittura di Files di properties Internazionalizzazione
L interfaccia grafica in Java
L interfaccia grafica in Java Java possiede due package per la creazione di interfacce grafiche java.awt javax.swing AWT (Abstract Widget Toolkit) presente già in Java 1.0, migliorato in Java 1.1. Invariato
Alessandro De Luca. Lezione, 13 maggio 2015
Basi Basi di di dati dati ee sistemi sistemi informativi informativi II mod.laboratorio mod.laboratorio Alessandro De Luca Università degli Studi di Napoli Federico II Lezione, Introduzione a Java Swing
Le basi della grafica in Java. Prof. Francesco Accarino IIS Altiero Spinelli via Leopardi 132 Sesto san Giovanni
Le basi della grafica in Java Prof. Francesco Accarino IIS Altiero Spinelli via Leopardi 132 Sesto san Giovanni Elaborazione classica o imperativa L elaborazione è concentrata nel momento centrale, durante
Java Applet. Linguaggi Corso M-Z - Laurea in Ingegneria Informatica A.A. 2009-2010
Linguaggi Corso M-Z - Laurea in Ingegneria Informatica A.A. 2009-2010 Alessandro Longheu http://www.diit.unict.it/users/alongheu [email protected] Java Applet 1 Application VS Applet Una
INTERFACCE GRAFICHE IN JAVA CON SWING DISPENSE
INTERFACCE GRAFICHE IN JAVA CON SWING DISPENSE La Gestione degli Eventi Ogni oggetto grafico è predisposto ad essere sollecitato in qualche modo dall utente (per esempio un pulsante può essere premuto).
Eventi di azione. // con interfaccia per eventi di azione
Eventi di azione (Interfaces ActionListener, Classes ActionEvent) Sono generati quando si premono bottoni, si selezionano voci di menù, si preme invio mentre si scrive in un campo di testo. In awt sono
Programmazione ad Oggetti. JFrame è la classe di base per le finestre Fornisce tutte le caratteristiche di una finestra vuota
Programmazione ad Oggetti Interfacce grafiche V 1.2 Marco Torchiano 2005 JFrame JFrame è la classe di base per le finestre Fornisce tutte le caratteristiche di una finestra vuota Barra del titolo Pulsanti
GUI e java swing. Elmenti della GUI. Eventi e listener contenitori componenti layout manager. caratteristiche speciali
GUI e java swing Raffaella Brighi, a.a. 2005/06 Corso di Laboratorio II. A.A. 2005-06 CdL Operatore Informatico Giuridico. Elmenti della GUI Eventi e listener contenitori componenti layout manager caratteristiche
I Layout Manager di java. Prof. Francesco Accarino IIS Altiero Spinelli via Leopardi 132 Sesto san Giovanni
I Layout Manager di java Prof. Francesco Accarino IIS Altiero Spinelli via Leopardi 132 Sesto san Giovanni Creazione di interfacce complesse con i layout manager La posizione di un componente aggiunto
Classi astratte. Master in Web Technology e Security luglio - settembre 2000. Interfacce
Master in Web Technology e Security luglio - settembre 2000 JAVA Alberto Martelli Parte III Programmazione grafica Classi astratte Vogliamo implementare un algoritmo di ordinamento di un array che sia
Marco Faella Il paradigma Model-View-Controller. Il pattern Strategy.
Marco Faella Il paradigma Model-View-Controller. Il pattern Strategy. 10 Lezione n. Parole chiave: Java Corso di Laurea: Informatica Insegnamento: Linguaggi di Programmazione II Email Docente: [email protected]
Principi di base della programmazione di interfacce grafiche in Java
Principi di base della programmazione di interfacce grafiche in Java Riccardo Silvestri 4 giugno 2010 Introduzione L'interfaccia grafica (Graphical User Interface, in breve GUI) facilita l'interazione
18 - Classi parzialmente definite: Classi Astratte e Interfacce
18 - Classi parzialmente definite: Classi Astratte e Interfacce Programmazione e analisi di dati Modulo A: Programmazione in Java Paolo Milazzo Dipartimento di Informatica, Università di Pisa http://www.di.unipi.it/
Programmazione Java: Interfacce grafiche (GUI)
Programmazione Java: Interfacce grafiche (GUI) [email protected] http://www.di.univaq.it/romina.eramo/tlp ( 1 ) (GUI) Interfacce grafiche Rendere facili le cose semplici e possibili le cose difficili
Corso Eclipse. Prerequisiti. 3 Window Builder
Corso Eclipse 3 Window Builder 1 Prerequisiti Conoscenza elementare ambiente Eclipse Conoscere la nomenclatura dei componenti delle interfacce grafiche Conoscere attributi e metodi dei principali componenti
Riassunto. GUI in Java con l AWT 1. Cos è una GUI. Oggi: GUI in Java, l AWT. GUI in Java. Un esempio. Stefano Mizzaro 1
Riassunto GUI in Java con l AWT 1 Stefano Mizzaro Dipartimento di matematica e informatica Università di Udine http://www.dimi.uniud.it/mizzaro [email protected] Programmazione, lezione 23 15 febbraio
Grafica swing in Java
Grafica swing in Java JFrame Costruttori public JFrame() Crea un nuovo Frame inizialmente invisibile public JFrame(Stringtitle) Crea un nuovo frame, inizialmente invisibile, con un testo specificato. Metodi
INTERFACCE GRAFICHE IN JAVA CON SWING DISPENSE
INTERFACCE GRAFICHE IN JAVA CON SWING DISPENSE INTRODUZIONE L interfaccia grafica del programma è composta dai cosiddetti componenti GUI (Graphics User Interface); essi sono dei componenti che servono
L interfaccia grafica con Java
L interfaccia grafica con Java 1/24 L interfaccia utente serve per la comunicazione tra utente e programma Distinguiamo le interfacce tra quelle a caratteri e quelle grafiche Le GUI (Graphical user interface)
Esercitazione n 6. Capacità di analisi e di estensione di progetti Componenti grafici e gestione di eventi Linguaggio Java:
Esercitazione n 6 Capacità di analisi e di estensione di progetti Componenti grafici e gestione di eventi Linguaggio Java: il package javax.swing (JFrame, JPanel, JButton, ) java.util.eventobject e sue
GRAFICA ED EVENTI SWING, AWT e JavaFX
GRAFICA ED EVENTI SWING, AWT e JavaFX argomenti JavaFX: architettura e gerarchia Componenti principali: Stage, Scene, contenuti Gestione degli eventi Java Package Grafici I package grafici che comprende
Gerarchia delle classi Classi astratte Interfacce (Eccezioni) Laboratorio di Programmazione - Esercitazio 1
Gerarchia delle classi Classi astratte Interfacce (Eccezioni) Laboratorio di Programmazione - Esercitazio 1 Gerarchia delle classi Una sottoclasse eredita metodi, variabili, etc. dalla superclasse... Per
Autore: Prof. Agostino Sorbara ITIS "M. M. Milano" Polistena (RC)
In questa lezione introduciamo alcuni strumenti che Java rende disponibili per la creazione di interfacce utente a manipolazione diretta, dette anche WYSISYG (what you see is what you get), con un elevato
Riassunto. GUI in Java con l AWT 1. Oggi: GUI in Java, l AWT. Oggi. GUI in Java. Cos è una GUI. Stefano Mizzaro 1
Riassunto GUI in Java con l AWT 1 Stefano Mizzaro Dipartimento di matematica e informatica Università di Udine http://www.dimi.uniud.it/mizzaro/ [email protected] Programmazione, lezione 20 20 novembre
Interfacce grafiche. Una GUI (Graphic User Interface) contiene vari componenti: bottoni, etichette, immagini...
Interfacce grafiche Una GUI (Graphic User Interface) contiene vari componenti: bottoni, etichette, immagini... Alcuni componenti ne contengono altri (ad esempio le finestre), e sono detti contenitori.
Sviluppo di Interfacce Grafiche in Java
Sviluppo di Interfacce Grafiche in Java Massimiliano de Leoni (con la supervisione del docente Massimo Mecella) Università di Roma La Sapienza - Sede di Latina Corso di Progettazione del Software A.A.
Eventi e listener per i componenti grafici
Eventi e listener per i componenti grafici Raffaella Brighi, a.a. 2005/06 Corso di Laboratorio II. A.A. 2005-06 CdL Operatore Informatico Giuridico. Eventi e listener Eventi e listener (ascoltatori) sono
Marco Faella Introduzione al corso
Marco Faella Introduzione al corso 1 Lezione n. Parole chiave: Java Corso di Laurea: Informatica Insegnamento: Linguaggi di Programmazione II Email Docente: [email protected] A.A. 2009-2010 Linguaggi
Prof. Pagani Corrado ESERCITAZIONI JAVA
Prof. Pagani Corrado ESERCITAZIONI JAVA PRIMA APPLICAZIONE CONSOLE Eseguire somma e media tra tre numeri ES 1 CODICE Non programmo sfruttando il paradigma ad oggetti (ho solo il metodo main che è static
A. Lorenzi, A. Rizzi Java. Programmazione ad oggetti e applicazioni Android Istituto Italiano Edizioni Atlas
Classi e oggetti A. Lorenzi, A. Rizzi Java. Programmazione ad oggetti e applicazioni Android Istituto Italiano Edizioni Atlas Oggetti La programmazione orientata agli oggetti, OOP (Object-Oriented Programming),
Fondamenti di informatica T-1 (A K) Esercitazione 2 Basi del linguaggio Java
Fondamenti di informatica T-1 (A K) Esercitazione 2 Basi del linguaggio Java AA 2018/2019 Tutor Lorenzo Rosa [email protected] 2 Programma Introduzione al calcolatore e Java Linguaggio Java, basi e
Esercitazioni di PROGETTAZIONE DEL SOFTWARE A.A. 2011-2012
Sapienza Università di Roma Facoltà di Ingegneria dell Informazione, Informatica e Statistica Corso di Laurea in Ingegneria Informatica ed Automatica Corso di Laurea in Ingegneria dei Sistemi Informatici
Campo Minato. in java
Campo Minato in java Il gioco campo rettangolare o quadrato suddiviso in tanti quadratini Il giocatore deve sminare il campo, cliccando sui quadratini, col tasto destro o col tasto sinistro il gioco cliccando
Corso sul linguaggio Java
Corso sul linguaggio Java Modulo JAVA5 B1 Gestione eventi 1 1 Prerequisiti Programmazione base in Java Utilizzo di classi e oggetti AWT o Swing Programmazione ad eventi 2 1 Introduzione Le interfacce create
Java GUI. Swing Java
Java GUI Swing Java 1 Introduzione n Componenti grafici di Java (Swing) Utilizzo di alcuni dei metodi per creare semplici finestre grafiche Accesso ai JavaDoc per usare meglio gli oggetti già pronti n
Interazioni col mondo: eventi
Interazioni col mondo: eventi Le interazioni di una GUI con il mondo esterno sono segnalate tramite eventi: click del mouse, inserimento di testo, selezione/attivazione... Gli eventi che memorizzano queste
Swing. Swing 1. Java e la grafica Java permette di realizzare agevolmente applicazioni grafiche Package java.awt
Swing Swing 1 Java e la grafica Java permette di realizzare agevolmente applicazioni grafiche Package java.awt il primo package grafico (Java 1.0) indipendente dalla piattaforma... o quasi! Package javax.swing
Programmazione. Cognome... Nome... Matricola... Prova scritta del 11 luglio 2014
Cognome................................ Nome................................... Matricola............................... Programmazione Prova scritta del 11 luglio 2014 TEMPO DISPONIBILE: 2 ore Negli esercizi
APPLICAZIONI & APPLET
APPLICAZIONI & APPLET Java è un ottimo linguaggio per costruire applicazioni anche non per Internet anche non grafiche ma si è diffuso storicamente, e trae forza, dal concetto di applet come piccola (?)
GRAFICO DI PARETO. variabile rispetto a cui si vuole ordinare (ossia nel nostro esempio
Si consideri il data set nel file Pareto.xls. GRAFICO DI PARETO Vediamo come costruire il grafico di Pareto con Excel. Questo grafico non costituisce un output standard pertanto sarà necessario compiere
TECNOLOGIE APPLICAZIONI WEB Linguaggio Java: Le Applet
Università degli Studi di Modena e Reggio Emilia Facoltà di Ingegneria Reggio Emilia CORSO DI TECNOLOGIE APPLICAZIONI WEB Linguaggio Java: Le Applet Prof. Franco Zambonelli Lucidi realizzati in collaborazione
Programmazione. Cognome... Nome... Matricola... Prova scritta del 22 settembre 2014. Negli esercizi proposti si utilizzano le seguenti classi:
Cognome................................ Nome................................... Matricola............................... Programmazione Prova scritta del 22 settembre 2014 TEMPO DISPONIBILE: 2 ore Negli
