Model-View-Controller - PowerPoint PPT Presentation

1 / 25
About This Presentation
Title:

Model-View-Controller

Description:

Model-View-Controller La UI de una aplicaci n est sujeta a muchos cambios: Cambio de UI para diferentes usuarios Los cambios en la UI deben ser f ciles a n ... – PowerPoint PPT presentation

Number of Views:37
Avg rating:3.0/5.0
Slides: 26
Provided by: doc138
Category:
Tags: controller | model | view

less

Transcript and Presenter's Notes

Title: Model-View-Controller


1
Model-View-Controller
? La UI de una aplicación está sujeta a muchos
cambios ? Cambio de UI para diferentes
usuarios ? Los cambios en la UI deben ser
fáciles aún en runtime ? Diferentes look and
feel no deben afectar el núcleo
funcional ? La misma información puede
mostrarse en ventanas diferentes ? Los
cambios en los datos subyacentes, deben
reflejarse inmediatamente en todas las
vistas ? Conviene separar procesamiento,
entradas y salidas
2
Model-View-Controller (MVC)
? MVC divide una aplicación UI en ? Modelo
Contiene el núcleo funcional y datos ? Vista
Muestra información al usuario ? Controlador
Maneja las entradas del usuario ?
VistasControladores UI ? Mecanismo de
Change-Propagation Único link entre Modelo
e UI.
3
La tríada de objetos MVC
UI
4
Dinámica del MVC
1. Una entrada del usuario es enviada por el
SO al controlador apropiado 2. El
controlador puede requerir a la Vista que
tenga el foco del evento.
V
M
C
5
Dinámica del MVC
3. Controlador requiere métodos del Modelo
para cambiar su estado 4. Modelo cambia su
estado interno
V
M
C
6
Dinámica del MVC
5. Modelo notifica a todas las Vistas
dependientes que hay datos que se
modificaron 6. Vistas requieren del Modelo
los valores de los datos actuales.
V
M
C
7
Dinámica del MVC
7. Modelo notifica a todos los Controladores
dependientes que hay datos que
cambiaron. 8. Controlador requiere del Modelo
los valores actuales de los datos.
V
M
C
8
Dinámica del MVC
9. Controlador informa a las Vistas si
se deshabilitan algunos
elementos. 10. Vistas requieren redibujado
V
M
C
9
Patrón Observer
? MVC es un patrón que puede ser expresado como
una combinación de otros patrones. ? La
interacción Modelo-Vista es generalmente
descripta usando el patrón Observer ?
Define una dependencia uno a muchos entre
objetos, de forma tal que cuando uno de
ellos (sujeto Observable) cambia su
estado, todos los que dependen de éste
(Observers) son notificados y actualizados
automáticamente.
10
Patrón Observer
11
Observers
Un sujeto puede tener cualquier cantidad de
observadores dependientes. Todos los observadores
son notificados cuando el sujeto experimenta un
cambio en su estado. En respuesta a ello cada
observador interroga al sujeto para sincronizar
su estado con el de éste.
12
Java Observer/Observable
? java.util.Observable (Subject) Cualquier clase
que desee ser observada debe extender esta
clase ? métodos para add/delete Observers
? métodos para notify todos los Observers de un
cambio (para indicar que hubo un
cambiosetchanged) Use Vector para almacenar
las referencias a los Observers ?
java.util.Observer (interface) debe ser
implementada por cualquier clase que quiera
actuar como Observer. ? update() en respuesta
a notifyObserver() ? Modelo de delegación de
eventos la fuente de eventos es Observable y
los listeners de eventos son Observers.
13
Ejemplo
// Un sujeto a observar ! public class
ConcreteSubject extends Observable private
String name private float price public
ConcreteSubject(String n, float p) name
n price p System.out.println("ConcreteSubject
creado " name " a " price) public
setPrice(float p)pricep//idem para
setName setChanged()//flag para indicar el
cambio en Observable notifyObservers(new
Float(price))
14
Ejemplo
// An observer of price changes. (Idem para
observar nombre) public class PriceObserver
implements Observer private float price public
PriceObserver() price 0 System.out.println("Pr
iceObserver creado Precio es " price) public
void update(Observable obj, Object arg) if (arg
instanceof Float) price ((Float)arg).floatValue
() System.out.println("PriceObserver Precio
cambia a " price)
15
Ejemplo
//Test public class TestObservers public static
void main(String args) // Create the Subject
and Observers. ConcreteSubject s new
ConcreteSubject("Corn Pops", 1.29f) PriceObserver
priceObs new PriceObserver() s.addObserver(pri
ceObs)//registro del observer con
Observable s.setPrice(4.57f)
16
Ejemplo
Salida del programa Test ConcreteSubject creado
Corn Pops a 1.29 PriceObserver creado Precio es
0.0 PriceObserver Precio cambia a 4.57
17
MVC y Swing
? Swing usa una arquitectura similar a MVC,
llamada Model-Delegate, muy difícil crear un
controlador genérico que no conozca los datos
específico de una vista. ? Colapsan Vista y
Controlador (UI) en un único objeto (UI
delegate, puesto que la UI se delega a este
objeto). ? Se pueden usar múltiples vistas de un
mismo modelo. ? Componentes pueden compartir un
mismo modelo. (JScrollBar, JSlider, ProgressBar
comparten el BoundedRangeModel), permitiendo la
conectividad automática entre componentes.
18
MVC y Swing
Component
UI-delegate
View
Model
Controller
19
MVC y Swing
20
MVC y Swing
21
Modelos en Swing
? En Swing muchos de los modelos son interfaces
? Ej. ButtonModel, ListModel, TableModel ?
Usualmente existe un modelo por defecto que se
asocia automáticamente con un componente ?
DefaultButtonModel implementa ButtonModel ?
Muchas aplicaciones no necesitan preocuparse por
ellos
22
Modelos en Swing
? Casi todos los componentes proveen el API del
modelo directamente. El componente puede ser
manipulado sin interactuar con el modelo para
nada.
//Ejemplo de la clase JSlider public int
getValue() return getModel().getValue()
//Podemos usar lo siguiente y evitar el
modelo JSlider slider new JSlider() int
value slider.getValue()
23
Views Controllers - Swing
? En Swing la expresión look and feel (LF) es
común ? Look (apariencia) es la Vista ? Feel
(comportamiento) es el Controlador ? Combinar la
Vista y el Controlador permite que que el LF
de un componente sea tratado como una unidad y
por tanto facilita los cambios en la UI. ?
Conocido como pluggable look feel (PLAF), se
puede cambiar la representación visual en tiempo
de ejecución
24
PLAF
25
PLAF
? Para cambiar el LF al de la plataforma nativa
del usuario try UIManager.setLookAndFeel
( UIManager.getCrossPlatformLookAndFeelClassName()
) catch (java.lang.ClassNotFoundException e)
// No puede cambiar el LF ? Para cambiar a
Metal LF (Java-native LF) try
UIManager.setLookAndFeel ( "javax.swing.plaf.met
al.MetalLookAndFeel") catch (java.lang.ClassNot
FoundException e) // Si no puede cambiar el LF
Write a Comment
User Comments (0)
About PowerShow.com