© Copyright SELA software & Education Labs Ltd. 14-18 Baruch Hirsch St.Bnei Brak 51202 Israel www.sela.co.il.

Slides:



Advertisements
Similar presentations
MicroKernel Pattern Presented by Sahibzada Sami ud din Kashif Khurshid.
Advertisements

Expression Blend 4 – deep dive
COM vs. CORBA.
Or How I Learned to Stop Worrying and Love the Binding Bryan Anderson.
OOP Design Patterns Chapters Design Patterns The main idea behind design patterns is to extract the high level interactions between objects and.
OOAD Using the UML - Use-Case Analysis, v 4.2 Copyright  Rational Software, all rights reserved 1/18 Use Case Analysis – continued Control Classes.
Component Patterns – Architecture and Applications with EJB copyright © 2001, MATHEMA AG Component Patterns Architecture and Applications with EJB JavaForum.
Satzinger, Jackson, and Burd Object-Orieneted Analysis & Design
Mark Rees Microsoft Consulting Services OFC409 Windows Workflow Foundation (WF) Primer Creating WF programs in Visual Studio Creating workflow templates.
Software Engineering Module 1 -Components Teaching unit 3 – Advanced development Ernesto Damiani Free University of Bozen - Bolzano Lesson 2 – Components.
Real world Windows Phone development Igor
Object-Oriented Analysis and Design
Building Silverlight Applications Using the MVVM pattern An Introduction by Peter Messenger Senior Developer – Qmastor
CMPT 370: Information Systems Design Instructor: Curtis Cartmill, Simon Fraser University – Summer 2003 Lecture Topic: Layered Architecture Class Exercise:
Design Patterns academy.zariba.com 1. Lecture Content 1.What are Design Patterns? 2.Creational 3.Structural 4.Behavioral 5.Architectural 6.Design Patterns.
The chapter will address the following questions:
UNIT-V The MVC architecture and Struts Framework.
A Free sample background from © 2001 By Default!Slide 1.NET Overview BY: Pinkesh Desai.
Chapter 7 Designing Classes. Class Design When we are developing a piece of software, we want to design the software We don’t want to just sit down and.
Behavioral Patterns  Behavioral patterns are patterns whose purpose is to facilitate the work of algorithmic calculations and communication between classes.
Introduction to the Enterprise Library. Sounds familiar? Writing a component to encapsulate data access Building a component that allows you to log errors.
The Design Discipline.
Why Analysis Process Refer to earlier chapters Models what the system will do makes it easier for understanding no environment considered (hence, system.
MVC pattern and implementation in java
Architecture Of ASP.NET. What is ASP?  Server-side scripting technology.  Files containing HTML and scripting code.  Access via HTTP requests.  Scripting.
CIS 375—Web App Dev II ASP.NET 2 Introducing Web Forms.
XForms: A case study Rajiv Shivane & Pavitar Singh.
Building SOLID Software with Dependency Injection Jeremy Rosenberg.
MVC and MVP. References enter.html enter.html
Model View Controller (MVC) Rick Mercer with a wide variety of others 1.
ASP.NET and Model View Control Jesper Tørresø ITNET2 F08.
An Introduction to Software Architecture
Virtual techdays INDIA │ Nov 2010 Developing Office Biz Application using WPF on Windows 7 Sarang Datye │ Sr. Consultant, Microsoft Sridhar Poduri.
SOFTWARE DESIGN AND ARCHITECTURE LECTURE 07. Review Architectural Representation – Using UML – Using ADL.
XRules An XML Business Rules Language Introduction Copyright © Waleed Abdulla All rights reserved. August 2004.
Alcatel-Lucent CDC Workshop, Coaching & Knowledge Transfer Architecture.
Module 12 Attached Properties and Behaviors in WPF.
Software Design Patterns (1) Introduction. patterns do … & do not … Patterns do... provide common vocabulary provide “shorthand” for effectively communicating.
Distribution and components. 2 What is the problem? Enterprise computing is Large scale & complex: It supports large scale and complex organisations Spanning.
Part VII: Design Continuous
Introduction to Java Beans CIS 421 Web-based Java Programming.
SOFTWARE DESIGN AND ARCHITECTURE LECTURE 13. Review Shared Data Software Architectures – Black board Style architecture.
OO Methodology Elaboration Iteration 2 - Design Patterns -
Nikhil Kothari Software Architect Microsoft Corporation Session Code: WUX312.
Design Patterns Software Engineering CS 561. Last Time Introduced design patterns Abstraction-Occurrence General Hierarchy Player-Role.
Windows 10 UWP MVVM In Depth
1 Catching up on Rich Clients (round 1) Mike Ormond, Mike Taulty Developer & Platform Group Microsoft Ltd
MVC WITH CODEIGNITER Presented By Bhanu Priya.
Chapter 11: Advanced Inheritance Concepts. Objectives Create and use abstract classes Use dynamic method binding Create arrays of subclass objects Use.
Model View ViewModel Architecture. MVVM Architecture components.
Copyright © 2004, Keith D Swenson, All Rights Reserved. OASIS Asynchronous Service Access Protocol (ASAP) Tutorial Overview, OASIS ASAP TC May 4, 2004.
Windows 8 apps and the MVVM pattern SILVERLIGHTSHOW.NET WEBINARS SERIES GILL CLEEREN, October 16 th
© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel
Programming with MVVM Miguel A. Castro Architect -
Part of the Microsoft.NET Framework 3.0 Tomer Shamam.NET Technologies Expert Sela Group
High degree of user interaction Interactive Systems: Model View Controller Presentation-abstraction-control.
Adam Schultz MVVM and WPF. MVVM Model, View, ViewModel A software architecture designed to separate out User Interface design, Business Logic, and Data.
In Windows 8 Store Applications
Real world Windows Phone development
Important New Concepts In WPF
Data Transport for Online & Offline Processing
MPCS – Advanced java Programming
Java Beans Sagun Dhakhwa.
Distribution and components
Introduction to the MVVM Pattern
Objects First with Java
Model-View-Controller Patterns and Frameworks
An introduction to MVVM using WPF NISCHAL S
An Introduction to Software Architecture
Brown Bag Seminar Summer 2007
Presentation transcript:

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 2 Separated Presentation Patterns MVVM

Motivation Supervising Presenter Presentation Model Model View ViewModel © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 3

Client application retrieves domain data, displays it and allows the user to change it. Defining all the application logic in controls makes them complex and difficult to understand, maintain, evolve, test and re-use. Separated presentation patterns cleanly separate out the visual portions of your application from the business and presentation logic portions. Having a clean separation allows: – Developers to focus on application logic – Designers to focus on visual aspects – Unit test independently © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 4

5 Model Presenter View IView Also known as Supervising Controller The View bound directly to the Model The Presenter coordinates any additional interaction between the View and the Model that cannot be achieved through simple data binding. The Presenter encapsulates presentation logic that interprets user gestures into actions against the Model; it also translates changes in the Model into user interface actions.

The Presentation Model provides a façade over the Model and coordinates all of the View's interaction with it. The Presentation Model is designed to be easily consumed by a View – The View can call methods, use data binding, commands, and other behaviors to interact with it. The Presentation Model also frequently adapts the underlying Model’s data into a form that is easier to represent in the user interface. The popular MVVM pattern is a variant of this pattern. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 6 Model Presentation Model View

Known as MVVM. MVVM is an implementation of Presentation Model designed specifically for use with WPF and Silverlight. Very popular in the WPF and Silverlight community. The View-ViewModel interaction is done through Data Binding only. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 7 Model ViewModel View Data Binding

Benefits of MVVM The Model The View The ViewModel View-ViewModel Gluing Triggering ViewModel Actions Attached Behaviors © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 8

Share a project with a designer, and have the flexibility for design work and development work to happen near-simultaneously. Solution thorough unit testing. Reusable components, both within and across projects in the organization. Flexibility to change the user interface without having to refactor other logic in the code base. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 9

The Model represents an application domain object. In a rich client application, the Model is part of the business layer, and represent a business entity. The Model is responsible for holding and manipulating the business data. In a thin client application, the Model usually represents only a server side data contract and not the business that manipulates it. – Usually there is a service layer which transports data-contracts to and from the server. The Model shouldn’t contain any logic to directly interact with the user: – Not responsible for formatting text to look prettier on the screen. – Not responsible for holding any visual element. – Must not reference any WPF element. The model may contain data validation. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 10

To maximize re-use opportunities, models should not contain any use case–specific or user task–specific behavior or application logic. The model may also include the code to support data access and caching, though typically a separate data repository or service is employed for this. Often, the model and data access layer are generated as part of a data access or service strategy, such as the ADO.NET Entity Framework, WCF Data Services, or WCF RIA Services. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 11

Doesn’t reference any type defined in PresentationFramework.dll, System.Windows.Forms, PresentationCore, etc. Theoretically, can be displayed in a Console Application. Doesn’t translate any content for the UI (Localized or Formatted resource). In a thin client application, doesn’t contain business logic (this should be implemented by the server). – May contain client-specific business logic which is not related to the UI In a rich client application, no need of additional logic concerning working with the model. – Encapsulates business logic and data queries from the UI Raises only events when requiring feedback from the user. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 12

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 13 Customer is a domain object – a model It is not related to any UI technology In that specific case, It provides validation logic In other cases it may implement the INotifyPropertyChanged interface (more on this later)

Data Visualization implementation. The view is the only piece the end user interacts with. A view may have behaviors associated with it. The view manages input (key presses, mouse movements, touch gestures, etc) which mapped to properties, method calls and commands of the view- model. The view is not responsible for maintaining its state. Instead, it will synchronize this with the view-model. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 14

Actually the view comes in two flavors: UserControl and DataTemplate. Use user-control when the view: – Is well-know at design time and can be statically created – Requires code-behind (event handling, animation control, visual tree manipulation, hit testing, access the view-model, etc.) – Should be easily designed from VS and Blend Use data-template when the view: – Is unknown at design time and must be dynamically created (you mustn't create a View from a ViewModel, it breaks the MVVM concept) – Should provide better decoupling from the view-model (data-template by definition has no code-behind) – Implicit data-template is supported (Silverlight 4 doesn’t support implicit data-templates only Silverlight 5 will) You may combine both by creating a data-template and a user-control as the single child of the data-template visual tree. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 15

Drop event like MouseMove and other input related events are view behaviors, hence handled by the view and mapped to view-model properties, method calls and commands. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 16

Since we can’t register events in data-template the view must be simple. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 17

This approach comes in handy later, when trying to connect the view with the view-model. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 18

Free of logic that affects more than the UI itself. There’s exactly one UserControl per each ViewModel class. References the view model through its DataContext property. Uses only the ViewModel and not the Model. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 19

The view-model is a key piece of the pattern because it introduces Presentation Separation. The view-model holds the presentation logic behind the view, which may include: presentation algorithms, error handling, fetching data and interaction with other view-models. The view model coordinates the view's interaction with the model. The view-model does all the preparation so the view can easily bound with it using data binding. The view-model may also expose methods and commands for complex scenarios where there is no simple data-binding solution – in that case the view may be coupled with the view-model but not vice versa. The view model may define logical states that the view can represent visually to the user. A view-model may be composite in terms of other view-models. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 20

The view-model becomes wholly responsible for the model in this scenario: – Interacts with the model to fetch and manipulate business data – It may expose the model directly, or properties related to the model, for data-binding – It may reference data services in order to fetch and manipulate the data it exposes to the view © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 21

The view and the view-model communicate via data- binding (usually), method calls, properties and events. The view-model exposes not only models, but other properties, such as state information and commands. The view handles its own UI events, then maps them to the view-model via commands. The models and properties on the view-model are updated from the view via two-way data binding. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 22

In general, a view should have exactly one view-model. A view may be composed of other views, each with its own view-model. View models might compose other view-models when necessary. A single view-model might be used by multiple views. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 23

The view-model notifies on property changes. Exposes models and state via properties to the view. Call services to fetch data. Implements business logic. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 24

“Simple” to use and “easy” to test. Tracks property changes and report them via INotifyPropertyChanged. All properties either return another ViewModel, a primitive data type or a collection of one of these. Doesn’t combine two or more properties to a new one (use value converter instead). There are commands for every action the view can trigger on the ViewModel. Totally independent of the current UI. Doesn’t reference any visual element. Every action is exposed as a command. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 25

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 26

Actually, there are three ways connecting the view and view- model together. View First – The view creates or discovers the view model. – The view typically binds to the view model as a resource, uses a view- model locator pattern, or has the view model injected via MEF, Unity, or other. ViewModel First – The view-model is responsible for creating the view and binding itself to the view. – View as data template flavor comes in handy using this approach. Marriage – Third class (such as Controller) creates or discovers both the view and the view-model, then connects them toghether. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 27

Discovering or creating the view-model from the view can be done directly or indirectly. Creating the view-model directly is not recommended: – Couples the view with a specific view-model – The view model may have dependencies that the view can’t resolve The view-model can be retrieved indirectly using a View-model Locator, DI Container such as Unity or MEF, other. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 28

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 29 A View Model Locator is responsible to create or to locate the view-model. The view can use the view-model locator to retrieve the view. The View Model Locator can be created as XAML resource and the view can resolve the view-model declaratively. <UserControl... DataContext="{Binding MyViewModel, Source={StaticResource ViewModelLocator}}">...

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 30

A DI container provides an easy way to resolve an object such as view-model with all of its dependencies. Using a DI container, a view-model can be easily retrieved by the corresponding view. There are several free DI containers in the market: – Castle Windsor based on the Castle MicroKernel: Castle Windsor Licensed under Apache 2 Well documented and very popular Well documented – Spring.NET Spring.NET Licensed under Apache 2 Written by Mark Pollack – Unity Unity Licensed as MS-PL Written by Chris Tavares.Chris Tavares Build on the "kernel" of ObjectBuilder: – Ninject formerly "Titan" Ninject Licensed under Apache 2 Was quiet, but has recently sprung back to life. Written by Nate KohariNate Kohari The view-model locator can be based on a DI container. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 31

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 32 The Managed Extensibility Framework (MEF) is a new library shipping in the.NET Framework 4 and in Silverlight 4 that simplifies the design of composable systems that can be extended by third parties after they have been deployed. MEF opens up your applications, allowing new functionality to be incrementally introduced by application developers, framework authors and third-party extenders. [Export(typeof(ISurfaceViewModel)), PartCreationPolicy(CreationPolicy.NonShared)] public class SurfaceViewModel : NotificationObject, ISurfaceViewModel { [Import] private ISurface Surface { get; set; } public int SurfaceWidth { get { return Surface.Dimensions.Width; } } public int SurfaceHeight { get { return Surface.Dimensions.Height; } }

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 33

Since we are not dealing with UI elements in the view-model anymore, there should be a simple way for the View to trigger actions on the view-model. Actually there are several options: – Delegate events from the view to the view-model by invoking view-model methods directly from the view code behind. – Expose commands as properties from the view-model so the view can bind them to UI elements from XAML or code behind. The second option using commands has several benefits: – Much less boilerplate code to write in the view code behind. – Easy way to bind actions from design tools such as Blend. – Command has availability state hence there is no need for special care in such case. – Great solution for views implemented as DataTemplate. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 34

WPF introduces Routed Command as default implementation for the ICommand interface. WPF routed commands deliver command messages through UI elements in the visual tree. Separating the UI from the logic, the view-model handles commands outside the visual tree. The WPF routed command implementation is not suitable in that case since we currently don’t have access to the visual tree. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 35

Handling commands off the visual tree, we should have custom implementation of the WPF ICommand interface. Relaying command is a custom implementation of ICommand which simply relays the command execution to the view-model instance using a simple delegate. Relaying command doesn’t depend on any visual tree. The view-model instantiate relaying commands, and expose them to the view as properties. Since the view-model handles the execution of the command, we don’t necessarily have to pass arguments. The view-model already knows the view state. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 36

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 37

Sometimes there is no option or there is no declarative way to bind the view to the view-model: – Several properties that don’t support data-binding, such as TreeView.SelectedItem. – Methods should be activated on the view such as ListBox.ScrollIntoView. – Trigger actions when routed events are raised by the view, such as mouse, keyboard and touch events. WPF Attached Properties mechanism can be used to close this gap. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 38

Attached property is a property that is defined by a different type than the element to which the property is applied Attached property is commonly used by most of WPF’s layout elements Attached properties are sophisticated way for extending a well known, well used element with functionality and/or state, without using inheritance. You can think of attached properties as extension- properties used from XAML or code behind. Using attached properties you can implement several patterns such as Attached Behavior. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 39

The code snippet below shows how to create, register and then use an attached property public static class TreeViewProperties { public static readonly DependencyProperty SelectedItemProperty = DependencyProperty.RegisterAttached(“SelectedItem", typeof(object), typeof(TreeViewProperties), new PropertyMetadata(null, SelectedItemChanged)); private static void SelectedItemChanged( DependencyObject d, DependencyPropertyChangedEventArgs e) { // Implement Attached Property Logic } public object void SetSelectedItem(UIElement element, object value) { element.SetValue(SelectedItemProperty, value); } public static string GetSelectedItem(UIElement element) { return element.GetValue(SelectedItemProperty); } public static class TreeViewProperties { public static readonly DependencyProperty SelectedItemProperty = DependencyProperty.RegisterAttached(“SelectedItem", typeof(object), typeof(TreeViewProperties), new PropertyMetadata(null, SelectedItemChanged)); private static void SelectedItemChanged( DependencyObject d, DependencyPropertyChangedEventArgs e) { // Implement Attached Property Logic } public object void SetSelectedItem(UIElement element, object value) { element.SetValue(SelectedItemProperty, value); } public static string GetSelectedItem(UIElement element) { return element.GetValue(SelectedItemProperty); }

Use Case – You want to add drag-n-drop functionality to ItemsControl/Selector elements you’re using. Solution 1: Create a view for holding the elements, and implement drag-n-drop by settings properties, subscribing events and calling methods directly or source/target in the view’s code behind. Solution 2: Create custom ListBox, ListView,… DataGrid controls and implement drag-n-drop on each. Solution 3: Use attached properties to attach drag-n- drop behavior with any ItemsControl/Selector instance. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 41

You can simply use a static class with several attached properties as shown below. The disadvantage of using a static class is that each state requires an attached property. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 42

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 43

Microsoft Expression Blend 3 introduces behaviors, which are reusable pieces of packaged code, based on Attached Properties, that can be dragged onto any object, and then fine-tuned by changing their properties. Behaviors allow you to add interactivity to your applications without having to write any code. Blend 3 attached behavior comes in two flavors: – Triggers and Actions – Behaviors © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 44

You can think of triggers and actions as cause-and- effect relationships. A Trigger reacts to the cause and invokes one or more Actions. Trigger is an object that listens for a specific condition, such as an event or a property change, and invokes one or more associated Actions. Triggers are extensible, so you can create custom triggers. An Action is an object that can only do something. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 45

To develop custom triggers and actions, first you should have Blend 3 or Blend 3 SDK installed Second you have to add reference to: System.Windows.Interactivity The assembly above is part of Blend 3 SDK. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 46

To implement a trigger, simply create a class which derives from TriggerBase © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 47

To implement an action, simply create a class which derives from TriggerAction You can implement a custom action that targets different object using TargetedTriggerAction © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 48

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 49

One way to allow users to customize the functionality of your Behavior is to expose Commands as properties of the behavior. © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 50 A Behavior can act without any external notification from a Trigger or a Trigger-like item. While some condition needs to be met, it doesn't have to be invoked by a Trigger.

To implement a behavior, simply create a class which derives from Behavior © Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 51

© Copyright SELA software & Education Labs Ltd Baruch Hirsch St.Bnei Brak Israel 52

Separated presentation patterns cleanly separate out the visual portions of your application from the business and presentation logic portions. Separating view from business provides and easy way for unit testing MVVM is a popular pattern especially for WPF and SL. Having a clean separation allows: Developers to focus on application logic Designers to focus on visual aspects Unit test independently