flex/as3 architecture and dependency injection frameworks overview

23
© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential. Flex/ActionScript 3.0 Architecture and Dependency Injection Frameworks Overview Piotr Walczyszyn | Platform Evangelist var blog:URLRequest = new URLRequest("http://riaspace.com"); var twitter:URLRequest = new URLRequest("http://twitter.com/pwalczyszyn");

Upload: piotr-walczyszyn

Post on 10-May-2015

4.177 views

Category:

Technology


2 download

DESCRIPTION

This is my presentation deck from Adobe MAX 2010. It is about Flex/AS3 architectural patterns and DI frameworks.

TRANSCRIPT

Page 1: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Flex/ActionScript 3.0 Architecture and Dependency Injection Frameworks Overview Piotr Walczyszyn | Platform Evangelist

var blog:URLRequest = new URLRequest("http://riaspace.com");var twitter:URLRequest = new URLRequest("http://twitter.com/pwalczyszyn");

Page 2: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Agenda

  Architectural Patterns

  MVC

  Presentation Model

  Other

  DI Frameworks

  Sample app overview

  Mate

  Parsley

  Robotlegs

  Spring ActionScript

  Swiz

2

Page 3: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential. 3

Model View Controller

Page 4: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

  Model View Controller

Model View Controller Diagrams

4

Page 5: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

  Model View Controller

  Model View Controller & Command Pattern

Model View Controller Diagrams

5

Page 6: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential. 6

Presentation Model

Page 7: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Presentation Model Diagrams

  Presentation Model

7

Page 8: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Presentation Model Diagrams

  Presentation Model

  Presentation Model with Command Pattern

8

Page 9: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential. 9

Other

Page 10: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Model View Presenter

  Model View Presenter (Passive View)

10

Page 11: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Model View Presenter

  Model View Presenter (Passive View)

  Model View Presenter (Supervising Controller)

11

Page 12: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Spark Architecture

12

MXML

Graphics Layout

Animation Parts States

Skin

CSS properties

ActionScript

Component

Behavior Logic Data

Spark Component

Model

Page 13: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Spark Architecture

13

Page 14: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential. 19

AS3/Flex DI Frameworks == Commodities

Page 15: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

AS3/Flex microarchitecture frameworks

20

Page 16: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

LOADING_USERS

Demo Application

21

Page 17: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

USERS_LIST_STATE

Demo Application

22

Page 18: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

ADD_USER_STATE

Demo Application

23

Page 19: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Demo Application Diagram

24

Page 20: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Typical microarchitecture elements

  Configuration

  DI implementation

  Event/Messaging bus

  Command pattern API

  Helper classes

25

Page 21: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential. 26

Frameworks Demo

Page 22: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.

Links

  Frameworks:

  Mate - http://mate.asfusion.com/

  Parsley - http://www.spicefactory.org/parsley/

  Robotlegs - http://www.robotlegs.org/

  Spring ActionScript - http://www.springactionscript.org/

  Swiz - http://swizframework.org/

  UsersAdmin projects: http://github.com/pwalczyszyn/MAX-2010-Projects

27

Page 23: Flex/AS3 Architecture And Dependency Injection Frameworks Overview

© 2010 Adobe Systems Incorporated. All Rights Reserved. Adobe Confidential.