Introduction
I learn something new every project, and this one was no different. Â The one I want to talk about today is that designers can do a lot more in the designer developer workflow than I’ve previously experienced them doing.
I work with a Visual Designer named Dean.  His job is understand the needs of the client, translate those to the application, and create visual designs for it.  He then needs to repeate this process via iterations.  He discusses with the client how the application should work, how the GUI works to accomplish user stories, and why it works that way.  This is a 2 way street as the client’s input is taken into account as well.  He also adjusts the GUI for my needs.  As the the engineer responsible for creating our application, I’ll run into challenges that I couldn’t have foreseen.  I’ll then give Dean a call, explain my challenges, and discuss ways to solve it.  Sometimes these are compromises, sometimes these are just me getting clarifications on how things are supposed to work.
Context: Flash Designer Developer Workflow
From my experience in agencies, that’s how designers are supposed to work.  Icing is if their designs are kick ass, because then you get more excited to make it work.  The caveat back then were their FLA’s.  I’ve never, ever, had success with designers and FLA’s.  A FLA is the binary file used for the Flash IDE.  It contains all of your graphics, sounds, fonts, animations, and sometimes video and ActionScript.
For agency work, a lot of times your design assets would arrive in a FLA. Â The designer would sometimes create a shell of the entire site. Â The FLA could of been used as a prototype in meetings to help discuss with the client, and/or perhaps the designer was creating the real design in Flash to ensure it’s what they wanted. Â Bottom line, whatever I ended up getting FLA wise from a designer, I never used their FLA.
Instead, I’d create a FLA of my own, and port over the design elements I needed from the designer’s FLA. Â Developers and Designers use FLA’s in different ways. Â Additionally, Designers and Developers amongst their own kind use FLA’s in many different ways. Â The main reason Flash Developer Certification never lasted long at Macromedia/Adobe was because there were so many ways to develop Flash content. Â This is also why I never let designers touch my FLA; they’d end up breaking something, and both of us would have a hard time figuring out why.
The net result was a process of:
- Designer gives me FLA
- I create my FLA, and incorporate graphics from Designer’s FLA as needed
- If design changes, Designer sends a new FLA
- I update my FLA with new graphics/animations from Designer’s FLA
- repeat
Copying and pasting Symbols from FLA to FLA, or moving them from Library to Library, has worked pretty well since Flash 4. Â With the advent of source control into many developer workflows, this only solidified this workflow for me since you cannot tell what changed in a binary FLA from revision to revision. Â Instead, a developer would leave a comment for each source control commit (hopefully).
The above applies to image assets as well. Â If a designer gives me a Photoshop PSD, an Illustrator AI, or a Fireworks PNG, I’m usually the one that breaks out the image assets I need, and imports into the FLA the way I need them.
Flex Designer Developer Workflow
In Flex, things are slightly different. Â First off, there is no FLA. Â Flex is just like traditional web development. Â All of your files are in a folder, and it’s up to you to organize them, and check all of them into source control. Â While some Flash projects required multiple FLA’s, at least FLA’s were self-contained. Â In Flex… no such luck.
As such, Designers currently have no way to easily play in their own design sandbox, like they could using their own FLA.  I’ve read on blogs of some designers capable of using Design View in Flex.  That may work for simple form based projects that utilize the Flex components with minimal skinning and heavier usage of styles… but I don’t get to work on those projects.  The Design View still doesn’t correctly visually represent your application.  My projects are usually the same as the old Flash ones: Designer has crazy cool ideas, and some utilize the Flex components, others do not.  The justifications for not using the standard GUI controls for Flex, even if the Designer is fully aware of Flex’ repertoire, is that it’s the best GUI solution for the user.
What this means is that you lose fidelity of the Designer’s vision, and thus must revert to more primitive ways to communicate the design. Â Tools such as Photoshop, Illustrator, and Fireworks create wonderful designs, but they are not interactive, nor do they communicate application flow like Flash does. Â Thus, you’ve taken a step back in workflow. Â This results in more mistakes, more false starts, and generally more communication problems for the entire team, not just the Designer and Developer. Â Time and money lost; software is hard enough, zomg!!!
Now, Dean did a few things on this project that did help. Â The first was he created a master application example in After Effects. Â This did a few things. Â It really helped sell the client on the original design. Â It also served as a great reference point for me to recognize how a transition worked, or how functionality worked. Â I’d refer to it often. Â Additionally, we all used it as a communication tool since we’re all remote. Â Over the phone, we’d go, “Scrub to 1:37… see that fade on the top left?”, etc. Â Worked a heck of a lot better than referring to multiple flat wireframes and design comp PDF’s.
As you may know, After Effects is a video compositing tool. Â What this means is the output is a video file. Â Unlike Flash, there is no access to the individual design elements that made the animation. Â So, you can’t crack open an animation and see how the designer did it, and thus determine if it’s worthy to be used as is, or be re-created yourself.
For that, Dean created a skin file. Â Skin files done in Flash are different than traditional FLA’s used as the basis of a Flash application. Â Skin files are created soley for the purpose of using the skins in a Flex application. Â Flex has the ability to embed Skins created in Flash, and use them as design elements for Flex components. Â You typically do this via CSS. Â In fact, this is exactly how the skins for the Flex SDK 2 and 3 were created. Â You can actually go crack open this FLA in the Flex SDK and change to your hearts content.
Now, in the past, I’d usually do this. Â Whether given a Photoshop comp or a Flash file, I’d create a new skin FLA file, create all the skins for export, and embed in Flex via CSS. Â From my consulting, this is usually because Designers don’t have a clear picture of what Flex is capable of, nor how to design for it.
Not Dean. Â He knew exactly what he was doing. Â In fact, the expectations of the Project Manager were far and ahead of what I was used to. Â Apparently on some projects, Dean has actually mocked out Flex projects himself, creating the CSS and MXML with states/transitions himself to illustrate how things are supposed to look and work.
Naturally, alarm bells went off.  I did the MXML, but definitely had him handle the CSS with regards to fonts.  For the same reasons I cited for Flash FLA’s, I don’t want Designers creating MXML I’m not going to use.  Sometimes I don’t even use MXML, but instead create many ActionScript classes to make the component.  It’s more effective for the Designer and I to talk out how things work, or for the designer to create a sample FLA/MOV of how things should look.  The way you create MXML and ActionScript, like Flash, is very personal and there are 2 opposing goals; the Designer wants to communicate concepts, and the Developer wants to create encapsulation.
Conclusions
There are 2 important things here I want to emphasize. Â Dean created the skin FLA, and Dean handled the fonts in CSS. Â That alone is amazing. Â I’ve never had a Designer do that with me in Flex. Â It makes my job immensely easier, and faster. Â The fact that not only can we start the project with prepped assets, but as we iterate we can easily update those assets… that’s huge.
I’d like to think that I’m only lucky to be working with a great team at Enablus… but f that. Â You suckers don’t get off that easily. Â Instead, I recognize it as a maturation of Designers and Developers working on enough Flex projects together that Designers recognize the capabilities of Flex and how it works. Â That’s just wonderful. Â On the flip-side, I now have high expectations of the designers I work with.
Beware. Â If you don’t like it, blame Dean for his pimpness.
How Flash Catalyst Changes the Flex Workflow
How does Flash Catalyst fit into this work flow? Â The theory that I’ve read goes something like this:
- Designer does their usual discussion, sketches, wireframe, design comp iteration routine.
- Designer takes design comps (Photoshop, Illustrator, and/or Fireworks) into Flash Catalyst, and creates Application screens, states, and GUI controls.
- Designer skins each GUI control, or creates controls from design assets.
- Designer creates states and transitions of the application.
- Saves as FXG.
From here, the developer can:
- Open the FXG in Flex Builder
- Add the necessarey code.
- If the design changes, the Developer can use a diffing tool to merge in the changed FXG XML.
And that, ladies and gents, is complete bs. Â I’m certainly not working that way. Â I’ll do the same thing that’s worked for years in Flash:
- Create my own Flex project. Â Create all the framework classes I’ll need, package structure, and data model.
- Create a new Flex Project for the Designers’ FXG Flash Catalyst file.
- For the graphics XML I can use verbatim, great, I’ll use it and add code around it.
- For the majority, however, I’ll code custom components. Â A lot of the FXG I’ve seen from Flash Catalyst seems to ignore the best practice of putting styles into a single CSS file. Â So, I’ll make a case by case judgement on which components can be used verbatim, and which need to have configurable styles with the Designer’s design as the defaults.
- Anytime the Designer has an updated FXG, I’ll replace the FXG project I created from the Designer’s original FXG.  I’ll then either merge in the new assets and FXG I deem necessary, otherwise I’ll just refer to my updated and separate, FXG Flash Catalyst project for visual reference.
Like in Flash, Designers created MovieClips without a care in the world about how’d you actually code that stuff.  Sometimes, MovieClips weren’t the best way to go about it.  They shouldn’t care, either.  They should be able to design their vision how they see it.  It’s then up to us engineers to code it.  If we need to compromise and iterate, so be it, that’s how it works.  Done deal.
Flash Catalyst is no different.  The FXG a Designer creates via Flash Catalyst probably isn’t anything close to what I’d actually use in production code.  If they update their original file, fine, I’ll merge in manually the FXG, or parts of the FXG, I deem necessary.  It’s the same exact work flow I and others have used for years in Flash.
It’s important to realize that this is still a great thing. Â We now have a native design format with a working tool for Designers to work natively in Flex. Â We didn’t have that before, and we soon will. Â I just think everyone’s ideal of Designers creating FXG that’s usable out of the box is complete rubbish.
…at least for the projects I do. Â Again, some use the native Flex components, and some don’t. Â So yes, I’ll use some FXG natively with no changes, but not all. And the keywords here are “not all” meaning, I cannot use the FXG verbatim from Catalyst, nor do round trip. Â Regardless, I still think that’s ok as a version 1 for Flash Catalyst. Â However, if Adobe can pull off CSS file support in Flash Catalyst with Font embedding, then hell yeah, I’ll bitch a lot less. Â Pixel fonts for the epic win. Â High bar for Adobe.
Hey Jesse,
Great post. I was happy to see a lot of similarities in the way our main designer and I work on projects. A couple months back I did to presentations for our Flash User Group, one was keys to successful designer/developer workflows in Flash and Flex and the other was a preso on Improving designer/developer communication. With the technical level of projects these days pushing the limits of design and functionality, the subject is more important than ever.
We’ve been talking about the new workflow and came to similar conclusions. At my last 9-5, I was the UI designer for a WPF project using Blend for my work. After finding out that all the developers wanted was my XAML, I moved back to doing my work in Fireworks and using the Infragistics XAML exporter. Round tripping sounds great but in reality, no developer I know trusts any auto-generated code.
Hi Jesse,
What you’ve outlined here is very similar to what we do at EffectiveUI. We have “production designers” that make the skins, create the CSS, add the fonts and then make a “sandbox” application. They work directly with the visual designer and correctly recreate their vision in Flex. They will also add transitions and effects.This project can then be immediately used by the developers. We may on occasion use After Effects as well, for exactly the same reasons you outlined.
Another method we might use is the developers start building the application from wireframes. The designers get the design nailed down. Then the production designer may gain access to the repo where the project is and start integrating the skins directly in the working project. Of course, this depends on how comfortable people feel about doing that, but it’s something I’m doing on a current project and it works great. It’s always cool to see the look on a developer’s face when they do an update and the whole app has changed in appearance.
Regarding the exchange of the FXP project from Catalyst to Gumbo, I hear what you’re saying. And what about the round-tripping? I’m interested to see if/how workflows change with Catalyst in the mix.
Juan
Our designers don’t often get into Flash. We go from wireframes to designs to development. We’re trying a new experiment now with Flex, though, going from wireframes to development to design. The designers stay very much engaged in the whole process. So far, that’s worked very well.
I’m a Designer. I work directly in Flex and have since Flex 2 and I work in the Design view as well. I like it because I can get to the Flex Properties panel which contains a full list of all the available styles, effects, and events for each and every component.
I also use the Flex Design View because I must be able to see what I’m doing. Visualizing a fully branded Application is hard to do just in your head. Besides, Adobe put that view in there, so why not use it?
Now before you pass too much judgement and double over in fear on the code you think I’m generating, I do go back and clean up my code and I’m trying to follow the Flex programming standards established in the community.
AND
Know that I don’t only use the Design view. I use the source and debug view as well. I’m learning more about what Flex can and cannot do by actually do things IN Flex. Which I believe makes me a better Designer because I can Design more accurately if I’ve looked under the hood and have tested my theories first hand.
Now I’ve tried Catalyst, Flex Component Kit for Flash, Illustrator and Photoshop and I also work with a combination of all those Design tools to translate my Designs into a Flex Prototype. But in the end I’ve realized that if your going to Design for interactivity you’ve got to get your hands dirty in the nuts and bolts of Flex.
Now, I’m at the point of adding in more interactivity into my work straight in Flex. I’m building more robust prototypes and am very happy with the result. I’m beginning to really understand the power of Flex and I know I couldn’t of done that in the Design tools alone.
Now, I don’t think I’m going to be taking the place of a Developer anytime soon, and I respect the fact that there are many layers that I don’t understand. But I’m confident that Flex Builder is the way to go (for me anyway).
Holy fish, Dolores!!! You clearly won’t have any problems finding employment for the next 2 years.
Hi,
with the designer I currently work with, we work with flow diagrams, powerpoint, anything that gets the idea across of what is supposed to be happening. I then get to implement it in my ugly developper style. Finally I get PNGs from my designer and fit them in. In this way, the designer doesn’t need to think in code, only in functionality, and I don’t have to put up with any half-baked generated mxml. The flip side of this process is that it demands close integration, but it works quite well.
Ariel
I’m a Designer as well. currently studying for a Masters in interactive design.
and i think if your serious about designing UI’s its also essential that you know how the stuff behind the GUI works and the possibility’s it offers.
so for the last few years i took it upon myself to learn the technical aspects as well such as generally accepted coding standards, OOP, frameworks.
i am still learning a lot about it, and when working on larger projects i can
help developers by making the views and build custom components when its needed.
and in the design aspects it helps allot as well if you know some limitations and problems that developers normally run into
and sometime’s it saves me allot of time too for example with making animations its sometimes easier to do it in action script instead of the timeline.
and for smaller projects i have no longer a problem with doing the development myself.
Why are you people not working at the companies I consult for?
:: documents names and emails ::
Hi Jesse,
I ended up writing my own post on the subject, and since our designers are from different species, I find that it might complement your post nicely.
http://arielsommeria.com/blog/?p=67
I am a Flex coder who at times also has to do the UI design part. I learnt a few things from your long article. Appreciate if you could share one or two video tutorials too.
Thanks again.
Amazing post… it was fun reading it… mr dean.. you are the man.. :)