MVC Model, View, Controller

Like dokumenter
JList, JTree, JTable. JList

Pensum SWING/MCV delen av TDT4180- MMI. Vår 2009 Dag Svanæs, IDI

MVC i Swing, trinn for trinn

EKSAMEN I FAG TDT MMI Lørdag 11. august 2012 Tid: kl

EKSAMEN I FAG TDT4180 MMI Mandag 18. mai 2009 Tid: kl

EKSAMEN I FAG TDT MMI Mandag 4. august 2008 Tid: kl

EKSAMEN I FAG TDT MMI Lørdag 4. juni 2005 Tid: kl

EKSAMEN I FAG TDT4180 MMI Onsdag 28. mai 2008 Tid: kl

Eksamensoppgave i TDT4180 Menneske-Maskin- Interaksjon (MMI)

EKSAMEN I FAG TDT4180 MMI Torsdag 27. mai 2010 Tid: kl

EKSAMEN I FAG TDT4180 MMI Lørdag 15. august 2009 Tid: kl

EKSAMEN I FAG TDT MMI Mandag 15. august 2011 Tid: kl

EKSAMEN I FAG TDT4180 MMI Lørdag 21. august 2010 Tid: kl

Grafisk Brukergrensesnitt

EKSAMEN I FAG TDT MMI Lørdag 26. mai 2012 Tid: kl

EKSAMEN I FAG TDT4180/IT2401 MMI Onsdag 23. mai 2007 Tid: kl

EKSAMEN I FAG TDT4180 MMI Onsdag 18. mai 2009 Tid: kl

NORGES TEKNISK-NATURVITENSKAPELIGE UNIVERSITET INSTITUTT FOR DATATEKNIKK OG INFORMASJONSVITENSKAP. Løsningsforslag

EKSAMEN I FAG TDT4180 MMI Torsdag 27. mai 2010 Tid: kl

Oppgave 1 (30%) Grensesnittdesign

EKSAMEN I FAG TDT4180 Menneske-maskin-interaksjon. Lørdag 27. juni 2006 Kl

Konseptuell modell, skjermdesign og konstruksjon

INF1010 Grafisk brukergrensesni3 med Swing og awt del 1 INF1010

NORGES TEKNISK-NATURVITENSKAPELIGE UNIVERSITET INSTITUTT FOR DATATEKNIKK OG INFORMASJONSVITENSKAP LØSNINGSFORSLAG

NORGES TEKNISK-NATURVITENSKAPELIGE UNIVERSITET INSTITUTT FOR DATATEKNIKK OG INFORMASJONSVITENSKAP

Grafiske brukergrensesnitt med Swing og AWT

Løsningsforslag (Løsningene i kursiv)

INF Våren Li' repe$sjon om Tråder og GUI. Stein Gjessing, Ins$tu' for informa$kk, Universitetet i Oslo. Ins$tu' for informa$kk

Gjennomgang av eksamen H99

INF1010. Grafisk brukergrensesni. med Swing og awt del 2. INF Grafisk brukergrensesni4 II

Vi lærte sist å lage vinduer. Om å lage et vindu. GUI (Graphical User Interface)-programmering. Inf GUI - del 2

EKSAMEN I FAG TDT4100 Objekt-orientert programmering. Fredag 3. juni 2005 KL

import javax.swing.*; import java.awt.*;

GUI-programmering, del 3 Vinduslyttere Dialogvinduer GUI-komponenten JTable Egne datamodellklasser. En oversikt over kapittel 19 i boka

INF Notater. Veronika Heimsbakk 10. juni 2012

JPanel. Komponent hieraki. Window/JWindow. Applet/JApplet. JDialog. JFrame

AVDELING FOR INGENIØRUTDANNING EKSAMENSOPPGAVE

INF1010 Grafisk brukergrensesni3 (GUI) med Swing/awt. del 1

AVDELING FOR INGENIØRUTDANNING EKSAMENSOPPGAVE

LO191D/LC191D Videregående programmering

NB!!! Veldig korte svar er gitt her. Disse burde det vært skrevet mer på ved en eksamen..

Repitisjonskurs. Arv, Subklasser og Grensesnitt

Løsningsforslag fra faglærere

. Ved sensur vl1 ahe bokstaverte deloppgaver (a, b, c,...) telle like mye.

Eksamensoppgave i TDT4180 Menneske-maskin-interaksjon

Eksekveringsrekkefølgen (del 1) Oppgave 1. Eksekveringsrekkefølgen (del 2) Kommentar til oppgave 1. } // class Bolighus

Løsningsforslag Test 2

LC191D/LO191D Videregående programmering mai 2010

UNIVERSITETET I OSLO

INF1010. Grafisk brukergrensesni. med Swing og awt del 2

GUI («Graphical User Interface») del 2

TDT4100 Objektorientert programmering

EKSAMEN I FAG SIF MMI OG GRAFIKK Lørdag 16. august 2003 Tid: kl

case forts. Alternativ 1 Alternativer Sammensetning Objekt-interaktor med valg

GUI - del 2. Stein Gjessing Inst for Informatikk Univ. i Oslo

Kalkulator-leksjonen (nesten ferdig)

HØGSKOLEN I SØR-TRØNDELAG Avdeling for informatikk og e-læring AITeL

Inf 1010 GUI - del 2

GUI («Graphical User Interface») del 2

Kapittel 7: Mer om arv

Vi lærte sist å lage vinduer. Om å lage et vindu. GUI (Graphical User Interface)-programmering. GUI - del 2

6108 Programmering i Java. Leksjon 8. GUI: Grafisk brukergrensesnitt. Del 2: Roy M. Istad 2015

Kapittel 15: Grafiske brukergrensesnitt. Del II

1- og 2-veis Innkapsling Java Stabel Kø Prio-kø Iterator. Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5)

class Book { String title; } class Dictionary extends Book { int wordcount; } class CartoonAlbum extends Book { int stripcount; }

1 t:n'v'\ekode LO325E. Alle ~vne og trykte. GOd'"j(jent kalkulator

Arv. Book book1 = new Book(); book1. title = "Sofies verden" class Book { String title; } class Dictiona ry extends Book {

1- og 2-veis Innkapsling Java Stabel Kø Prio-kø Iterator. Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5)

Object interaction. Innhold. Abstraksjon Grunnleggende programmering i Java Monica Strand 3. september 2007.

AMS-case forts. Eksemplifisering av modellbasert. tilnærming til design av brukergrensesnitt

OO-eksempel. Modellen ser slik ut: Studenter + antstudenter : int = 0

EKSAMEN I FAG TDT4100 Objektorientert programmering. Fredag 6. juni 2008 Kl

Uke mars 2005 GUI - del 2. GUI (Graphical User Interface)-programmering

UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet

< T extends Comparable<T> > Indre klasser mm. «Det du bør ha hørt om før oblig 4»

BOKMÅL Side 1 av 7. KONTINUASJONSEKSAMEN I FAG TDT4100 Objektorientert programmering / IT1104 Programmering, videregående kurs

INF1010 våren 2006 Uke 19: 9. mai 2006 Et større eksempel: Solitaire (kabal)

Oppsummering. Kort gjennomgang av klasser etc ved å løse halvparten av eksamen Klasser. Datastrukturer. Interface Subklasser Klasseparametre

TDT4100 Objektorientert programmering

Tittel Objektorientert systemutvikling 1. Eksamenstid, fra-til Ant. oppgaver 6

(MVC - Model, View, Control)

TDT4100 Objektorientert programmering

Mål med kurset. Java i INF Dagens tema. GUI med Swing. Dokumentasjon

Gjøre noe i hele treet = kalle på samme metode i alle objekten. Java datastruktur Klassestruktur

Dagens forelesning. Husk prøveeksamen Fredag 15/3-13 kl 12 i R1. Iterator-teknikken. Eksempel med bruk av Iterator og Iterable-grensesnittene

ANTDAGER = 358; I Ifra nyttår 08 til 08 1ed julaften

UNIVERSITETET I OSLO

Array&ArrayList Lagring Liste Klasseparametre Arrayliste Testing Lenkelister

Ol Emnekode: Faglig veileder: I L~~25 A - E!8 Viho~d~.1. F ntall oppga~ forsiden): ;;;handskr~vn-;

Algoritmer og datastrukturer Kapittel 3 - Delkapittel 3.1

EKSAMEN. TILLATTE HJELPEMIDLER: Alle trykte og skrevne. INNFØRING MED PENN, evt. trykkblyant som gir gjennomslag

Eks 1: Binærtre Binærtretraversering Eks 2: Binærtre og stakk

AVDELING FOR INGENIØRUTDANNING EKSAMENSOPPGAVE. Antall sider (Inkl forsiden): 8. Alle trykte og håndskrevne

INF1010, 21. februar Om å gå gjennom egne beholdere (iteratorer) Stein Gjessing Inst. for Informatikk Universitetet i Oslo

HØGSKOLEN I SØR-TRØNDELAG

Eksamensoppgave Vår 2012 Ordinær eksamen Bokmål. Videregående programmering. Eksamensdato: Studium/klasse: 2. klasse

Eksamensoppgave i TDT4100 Objektorientert programmering med Java

UNIVERSITETET I OSLO

Et enkelt rammeverk for kjøring av OpenGL-programmer i Java

Løse reelle problemer

Transkript:

MVC Model, View, Controller Basert på tredeling av funksjonalitet Modell holder underliggende data View leser og visualiserer data Controller tolker input og endrer data Fordeler kan bytte ut hver enkelt del flere view mot samme data automatisk koordinering Mer komplekst

MVC-arkitekturen binder sammen komponenter og data

MVC i Swing View Controller lese vha. get-metoder endre vha. set/ add-metoder Modell endringshendelser

Typisk modell Klasse med uavhengige attributter kalt properties, basert på domenemodell F.eks. Person-klasse: name og email, begge String-objekter dateofbirth, java.util.date-objekter Modellen må ha to egenskaper metoder for å lese og skrive attributtene kunne sende ut endringshendelser

Basert på JPanel Typisk komponent JLabel med tekst tilsvarende attributtnavn komponent tilpasset attributtets klasse/datatype F.eks. PersonPanel: JTextField for name (ingen syntaksbegrensninger) JTextField for address JPanel-komponenten har en modell-property leser og skriver modellens attributter lytter til endringer i modellens attributter

JavaBeans-baserte modeller En JavaBean har visse egenskaper og følger visse navngivingskonvensjoner Alle JavaBeans har et sett såkalte properties av ulike kategorier Alle JavaBeans er kodet iht. visse konvensjoner navngiving av metoder for å lese og skrive properties, read-metode: public <type> get<property>, f.eks. public String getname() write-metode: public void set<property>(<type> p), f.eks. public void setname(string name) generering av hendelser ved endringer av properties hendelsesklasse: PropertyChangeEvent metoder for å registrere PropertyChangeListener-lyttere: add/removepropertychangelistener

Typisk kallsekvens 1. Komponenter legger seg til som lytter på modell 2. Modellen legger lytteren inn i liste 3. Komponenten (eller annet objekt) endrer på en property i modellen 4. Modellen lager en endringshendelse og kaller endringsmetoden til alle lytterne 5. Lytterne reagerer på endringshendelsen. Lytterne får endringshendelsen uavhengig av hvilket objekt som endret property en

Bound properties En bound property genererer en PropertyChangeEvent ved endring Hver endring av property må skje gjennom set-metode, også interne endringer dersom property ens nye verdi er ulik den gamle, må endringen kringkastes lyttende objekter (dvs. registrerte objekter som implementerer PropertyChangeListener-grensesnittet) Mekanikken kan delegeres til et PropertyChangeSupportobjekt, som håndterer registrering av lyttere og kringkasting av hendelser add/removepropertychangelistener firepropertychange

Class PropertyChangeSupport public class PropertyChangeSupport This is a utility class that can be used by beans that support bound properties. You can use an instance of this class as a member field of your bean and delegate various work to it. Constructor: PropertyChangeSupport(Object sourcebean) Constructs a PropertyChangeSupport object. Methods: void addpropertychangelistener(propertychangelistener listener) Add a PropertyChangeListener to the listener list. void firepropertychange(string propertyname, boolean oldvalue, boolean newvalue) Report a boolean bound property update to any registered listeners.

Interface PropertyChangeListener public interface PropertyChangeListener extends EventListener A "PropertyChange" event gets fired whenever a bean changes a "bound" property. You can register a PropertyChangeListener with a source bean so as to be notified of any bound property updates. public void propertychange(propertychangeevent evt) This method gets called when a bound property is changed. Parameters: evt - A PropertyChangeEvent object describing the event source and the property that has changed.

Klassediagram PropertyChangeSupport JPanel 1 PersonPanel getmodel() : Person setmodel(person) 0..n model 1 Person getname() : String setname(string) addpropertychangelistener(propertychangelistener) 0..n pcs 1 listeners <<Interface>> PropertyChangeListener 0..n propertychange()

Typisk kallsekvens panel : PersonPanel addpropertychangelistener person : Person pcs : PropertyChangeSupport addpropertychangelistener setname firepropertychange propertychange configurepanel

Person-klassen (model) En attributt: name (kunne i tillegg ha hatt f.eks. address, e-mail,,) Metoder for lese og skrive attributtverdier get/set-metodepar for hvert felt get-metodene er parameterløse og returnerer objekt av type tilsvarende attributtets set-metoden tar ett parameter av type tilsvarende attributtets og returnerer ingenting (void) Property-navn-konstanter objekt (String) som identifiserer property, f.eks. public final static NAME_PROPERTY = name ; konstantverdien brukes bl.a. i endringshendelsesobjekter for å angi hvilken property som er endret lyttere sjekker typisk hvilken property som er endret, for å kunne reagere riktig, f.eks. oppdatere tilsvarende tekstfelt

Person-klassen (model) Metoder for håndtere endringslyttere addpropertychangelistener(propertychangelistener) removepropertychangelistener(propertychangelistener) Beskyttet metode for å fyre av endringshendelser protected firepropertychange(property, oldvalue, newvalue) Delegerer til privat PropertyChangeSupport-instans private PropertyChangeSupport pcs = new PropertyChangeSupport(this);... public void addpropertychangelistener(propertychangelistener listener) { pcs.addpropertychangelistener(listener); }... protected void firepropertychange(string prop, Object old, Object ny) { pcs.firepropertychange(prop, oldvalue, newvalue); }

import java.beans.propertychangesupport; import java.beans.propertychangelistener; public class Person { public final static String NAME_PROPERTY = "Name"; private PropertyChangeSupport pcs; private String name = null; public Person() { pcs = new PropertyChangeSupport(this); } public String getname() { return name; } public void setname(string name) { String oldvalue = this.name; this.name = name; pcs.firepropertychange(name_property, oldvalue, name); } public void addpropertychangelistener(propertychangelistener listener) { pcs.addpropertychangelistener(listener); } }

PersonPanel-klassen (view) Modell-referanse et modell-attributt av typen Person all visning og editering skjer på dette objektet merk at modellen kan være null Property-orienterte subkomponenter JLabel tilsvarende property-navnet Lytter til property-endringer implements PropertyChangeListener public void propertychange(propertychangeevent evt)

import java.beans.*; import java.awt.event.*; import javax.swing.*; public class PersonPanel extends JPanel implements PropertyChangeListener { private Person model; private JTextField namefield; private JButton clearbutton; public PersonPanel() { namefield = new JTextField(); namefield.setcolumns(20); namefield.addactionlistener(new mytextaction()); add(namefield); clearbutton = new JButton("Clear"); clearbutton.addactionlistener(new ClearButtonAction()); add(clearbutton); } /** Action for text field * */ class mytextaction implements ActionListener { public void actionperformed(actionevent e) { model.setname(namefield.gettext()); } } /** Action for clearbutton * */ class ClearButtonAction implements ActionListener { public void actionperformed(actionevent e) { model.setname(""); } }

// Set model public void setmodel(person themodel) { model = themodel; model.addpropertychangelistener(this); } } // PropertyChangeListener public void propertychange(propertychangeevent evt) { if (evt.getpropertyname() == Person.NAME_PROPERTY) { namefield.settext(model.getname()); } }

Persons-prosjektet: Person-klassen er modellen til to PersonPanel view. Person-objektet (modellen) er observerbare alle vesentlige egenskaper kan leses vha. getmetoder Modellen sier fra når disse egenskapene endres lyttere kan registrere seg, så de får endringshendelser

import javax.swing.jpanel; import javax.swing.jframe; public class PersonPanelExample_Simple extends JPanel { private PersonPanel personpanela, personpanelb; private Person model; public PersonPanelExample_Simple() { model = new Person(); personpanela = new PersonPanel(); personpanela.setmodel(model); add(personpanela); personpanelb = new PersonPanel(); personpanelb.setmodel(model); add(personpanelb); } model model } public static void main(string args[]) { JFrame frame = new JFrame("..."); frame.add(new PersonPanelExample_Simple()); frame.pack(); frame.setvisible(true); }

Basiskomponenter Layout JList

Kontrollelementer

Hvordan bli kjent med en ny komponent Prøv den med SwingSet2-demo! Hva heter klassen og hvor ligger den i hierarkiet? JButton, arver fra AbstractButton JCheckBox, arver fra JToggleButton, som arver fra AbstractButton Hvilke data håndterer den og hvordan leses/settes de(t)? sannhetsverdier (boolean), leses/settes med isselected/setselected Hvilke vesentlige egenskaper har den? har ikon og tekst for angi mening (get/seticon, get/settext) Hvilke syntaktiske hendelser genererer komponenten og for hvilke egenskaper? Hvilket lyttergrensesnitt og metoder og hendelsesklasser inngår i håndtering av hendelsen? action-hendelsen for selected-egenskapen ActionListener, actionperformed og ActionEvent addactionlistener og removeactionlistener Prøv den i en enkel Swing-applikasjon!

JCheckBox Prøv den med SwingSet2-demo Hva heter klassen og hvor ligger den i hierarkiet? JCheckBox, arver fra JToggleButton, som arver fra Hvilke data håndterer den og hvordan leses/settes de(t)? sannhetsverdi (boolean) isselected/setselected Hvilke vesentlige egenskaper har den? ikon og tekst get/seticon og get/settext Hvilke syntaktiske hendelser genererer komponenten og for hvilke egenskaper? Hvilket lyttergrensesnitt og metoder og hendelsesklasser inngår i håndtering av hendelsen? action-hendelsen for selected-egenskapen ActionListener, actionperformed og ActionEvent addactionlistener og removeactionlistener Prøv den i en enkel Swing-applikasjon!

JSlider Prøv den med SwingSet2-demo Hva heter klassen og hvor ligger den i hierarkiet? JSlider, arver direkte fra JComponent Hvilke data håndterer den og hvordan leses/settes de(t)? heltallsverdi innen intervall get/setvalue, setminimum, setmaximum Hvilke vesentlige egenskaper har den? såkalte ticks m/tekst metoder for å angi hvilke ticks som finnes og om de og deres tekst skal tegnes Hvilke syntaktiske hendelser genererer komponenten og for hvilke egenskaper? Hvilket lyttergrensesnitt og metoder og hendelsesklasser inngår i håndtering av hendelsen? change-hendelsen for value-egenskapen ChangeListener, statechanged og ChangeEvent addchangelistener og removechangelistener Prøv den i en enkel Swing-applikasjon!

JTextField Prøv den med SwingSet2-demo Hva heter klassen og hvor ligger den i hierarkiet? JTextField, arver fra JTextComponent Hvilke data håndterer den og hvordan leses/settes de(t)? tekst (String) get/settext Hvilke vesentlige egenskaper har den? skriftstype (Font) og antall kolonner (columns) get/setfont, get/setcolumns Hvilke syntaktiske hendelser genererer komponenten og for hvilke egenskaper? Hvilket lyttergrensesnitt og metoder og hendelsesklasser inngår i håndtering av hendelsen? action-hendelsen for text-egenskapen ved trykk på ENTER-tast ActionListener, actionperformed og ActionEvent addactionlistener og removeactionlistener Prøv den i en enkel Swing-applikasjon!

JComboBox Prøv den med SwingSet2-demo Hva heter klassen og hvor ligger den i hierarkiet? JComboBox, arver fra JComponent Hvilke data håndterer den og hvordan leses/settes de(t)? lister (model) og valg av ett element (selection) get/setmodel, get/setselecteditem, get/setselectedindex Hvilke vesentlige egenskaper har den? om tekstfeltet er editerbart: get/seteditable Hvilke syntaktiske hendelser genererer komponenten og for hvilke egenskaper? Hvilket lyttergrensesnitt og metoder og hendelsesklasser inngår i håndtering av hendelsen? item-hendelsen for selecteditem/selectedindex-egenskapen action-hendelsen for selecteditem/selectedindex-egenskapen Prøv den i en enkel Swing-applikasjon!

JSpinner Prøv den med SwingSet2-demo Hva heter klassen og hvor ligger den i hierarkiet? JSpinner, arver fra JComponent Hvilke data håndterer den og hvordan leses/settes de(t)? objekter som inngår i en ordnet sekvens iht. reglene implementert i en SpinnerModel og getnextvalue/getpreviousvalue-metodene (se kodeeksempel) get/setvalue Hvilke vesentlige egenskaper har den?? Hvilke syntaktiske hendelser genererer komponenten og for hvilke egenskaper? Hvilket lyttergrensesnitt og metoder og hendelsesklasser inngår i håndtering av hendelsen? change-hendelsen for value-egenskapen Prøv den i en enkel Swing-applikasjon!

JFormattedTextField Prøv den med SwingSet2-demo Hva heter klassen og hvor ligger den i hierarkiet? JFormattedTextField, arver fra JTextField Hvilke data håndterer den og hvordan leses/settes de(t)? objekter som har en tekstsyntaks iht. reglene implementert i en JFormattedTextField.AbstractFormatter og valuetostring/stringtovalue-metodene (se kodeeksempel) get/setvalue Hvilke vesentlige egenskaper har den?? Hvilke syntaktiske hendelser genererer komponenten og for hvilke egenskaper? Hvilket lyttergrensesnitt og metoder og hendelsesklasser inngår i håndtering av hendelsen? propertychange-hendelsen for value-egenskapen PropertyChangeListener, propertychanged og PropertyChangeEvent addpropertychangelistener og removepropertychangelistener Prøv den i en enkel Swing-applikasjon!

Eksempel: J... Prøv den med SwingSet2-demo Hva heter klassen og hvor ligger den i hierarkiet? J, arver fra J Hvilke data håndterer den og hvordan leses/settes de(t)? <type> get/set Hvilke vesentlige egenskaper har den?? Hvilke syntaktiske hendelser genererer komponenten og for hvilke egenskaper? Hvilket lyttergrensesnitt og metoder og hendelsesklasser inngår i håndtering av hendelsen? -hendelsen for -egenskapen Listener, Performed og Event addlistener og removelistener Prøv den i en enkel Swing-applikasjon!

Oppsummering Alle basiskomponenter har samme struktur klassenavn og superklasse dataverdi(er) essensielle egenskaper hendelser og tilhørende grensesnitt, metoder og klasser Å bli kjent med en komponent innebærer å oppsøke informasjon om hver del og prøve den ut Hendelser De fleste komponenter har egne typer hendelser Noen komponenter følger JavaBeans-mønsteret og genererer PropertyChangeEvent er

JList, JTree, JTable JList

JList ListModel ListSelectionModel ListCellRenderer

JList View lese vha. get-metoder MVC Modellen Model Controller endre vha. set/ add-metoder endringshendelser

JList ListModel JList sitt modell-grensesnitt, altså den delen som fyller modell-rollen ListSelectionModel Håndtering av bruker-interaksjon, altså en del av controller-rollen ListCellRenderer Styrer visning av elementene i lista, altså en del av view-rollen

Scrolling JList støtter ikke scrolling. Det må legges på eksplisitt. Det gjøres ved å pakke den inn i en JScrollPane JScrollPane myjscrollpane = new JScrollPane(myJList); myjscrollpane.setverticalscrollbarpolicy( JScrollPane.VERTICAL_SCROLLBAR_ALWAYS); add(myjscrollpane);

Objekt- : ListDataListener diagram modell : ListModel list : JList model : ListSelectionListener renderer renderer : ListCellRenderer selectionmodel selection : ListSelectionModel : Component

Interface ListModel, JList sin modell get-metoder (gir tilgang til data) getsize() størrelsen til lista getelementat(index) elementene i lista lyttere og hendelser registrering av lytter: add/removelistdatalistener(listdatalistener l)

Interface ListDataListener JList implementerer denne Void contentschanged(listdataevent e) Sent when the contents of the list has changed in a way that's too complex to characterize with the previous methods. Void intervaladded(listdataevent e) Sent after the indices in the index0,index1 interval have been inserted in the data model. Void intervalremoved(listdataevent e) Sent after the indices in the index0,index1 interval have been removed from the data model.

DefaultListModel Alle JList får automatisk en modell av klassen DefaultListModel. Vi kan legge inn en slik direkte: private JList myjlist; private DefaultListModel model; public JListExample_1() { model = new DefaultListModel(); myjlist = new JList(model); model.addelement("linje 1"); model.addelement("linje 2"); model.addelement("linje 3"); add(myjlist); }

JList og ListModel... Sentrale teknikk delegering Hendelse-lytter-pattern XxxEvent-klasse XxxListener-interface add/removexxxlistener Sentrale klasser/objekter ListModel ListDataListener ListDataEvent Sentrale metoder : ListDataListener list : JList addlistdatalistener og contentschanged getsize og getelementat 1: addlistdatalistener(listdatalistener) 2: contentschanged(listdataevent) 3: getsize( ) model 4: getelementat(int) mo de ll : Li stmo de l

ListSelectionModel Den eneste interaksjonen en JList støtter er tre typer seleksjon: seleksjon av enkelt element seleksjon av sekvens av elementer seleksjon av sett av sekvenser, altså ingen begrensning på seleksjonen Det er JList sin listselectionmodel-property, som håndterer seleksjonen objektet inneholder og manipulerer seleksjonen, basert på brukerens interaksjon modusen (selectionmode-property en) angir hvilken av de tre typene seleksjonslogikk som gjelder

Seleksjon ListSelectionModel-klassen håndterer logikken SINGLE_SELECTION Valg av kun ett elemenent Valg av nytt element fjerner eksisterende valg SINGLE_INTERVAL_SELECTION Valg av flere etterfølgende elementer Shift-klikk for å utvide seleksjonen i begge retninger MULTIPLE_INTERVAL_SELECTION Valg uten begrensninger på antall eller intervaller Control-klikk toggler enkelt-elementer Shift-klikk utvider seleksjonen

ListSelectionListener JList kringkaster endringer i seleksjonen til sine ListSelectionListenerlyttere Ved å registrere en slik lytter, kan andre klasser/objekter reagere på brukerens endringer i seleksjonen Typisk bruk 1 list-detail- pattern : liste med elementer, med ekstra panel med detaljer Viktige egenskaper vises i lista, med detaljer i et panel ved siden av. Når seleksjonen endres, oppdateres detalj-panelet Typisk bruk 2 Action-objekter bruker seleksjon for å utføre oppgaven sin, dvs. hente ut objekt å utføre aksjon på Seleksjonen brukes også for å aktivere/deaktivere aksjonen

...seleksjon Sentrale teknikker delegering Hendelse-lytter-pattern XxxEvent-klasse XxxListener-interface add/removexxxlistener Sentrale klasser/objekter ListSelectionModel ListSelectionListener ListSelectionEvent Sentrale metoder JList.addListSelectionListener ListSelectionListener.valueChanged list : JList 8: ad dl istse le cti on Liste ne r(l istse le cti on Liste ne r) : L istse le cti on Liste ne r 10: valuechanged(listselectionevent) 9: addlistselectionlistener(listselectionlistener) selectionmodel : ListSelectionModel

View-delen av JList ListCellRenderer interface som bygger bro mellom JList sine behov for å tegne rader i lista og Componentsubklasser gjenbruker en eksisterende Component-subklasse for å tegne hver linje i en JList ved å skrive egne komponenter for visning av liste-elementer, kan JList skreddersys visning av egne data

JList og ListCellRenderer JList delegerer tegning av hver element i lista til en ListCellRenderer getcellrenderer ListCellRenderer configurerer og returnerer en Component getlistcellrenderercomponent Component-objektet har en (foretrukket) størrelse og kan tegne seg selv getpreferredsize paintcomponent Siste Swing-versjon støtter layout i flere kolonner

JList og ListCellRenderer... list : JList 5: getlistcellrenderercomponent(jlist, Object, int, boolean, boolean) renderer renderer : ListCellRenderer 6: getpreferredsize( ) Sentral teknikk delegering Sentrale klasser/objekter ListCellRenderer Component 7: paint(graphics) : Component

JList og ListCellRenderer... Omtrentlig sekvens av operasjoner spør ListModel om størrelse getsize() itererer over alle elementene spør om verdi getelementat(int) ber renderer konfigurere og returnere komponent spør om størrelsen og gir plass ber komponenten tegne seg selv posisjon og størrelse huskes slik at en vet hvilke linjer som er hvor for hver linje som endres, gjentas dette, f.eks. verdi, seleksjon og fokus