<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Flash Moments &#187; Design Patterns</title>
	<atom:link href="http://flashmoments.novelastudios.com/tag/design-patterns/feed/" rel="self" type="application/rss+xml" />
	<link>http://flashmoments.novelastudios.com</link>
	<description>ActionScript, Flash, and Flex</description>
	<lastBuildDate>Wed, 01 Dec 2010 02:59:17 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<item>
		<title>The Power of Separated Logic: Opening the Door</title>
		<link>http://flashmoments.novelastudios.com/flex/power-separated-logic-opening-door/#utm_source=feed&#038;utm_medium=feed&#038;utm_campaign=feed</link>
		<comments>http://flashmoments.novelastudios.com/flex/power-separated-logic-opening-door/#comments</comments>
		<pubDate>Thu, 10 Jun 2010 04:56:11 +0000</pubDate>
		<dc:creator>johntimothybailey</dc:creator>
				<category><![CDATA[flex]]></category>
		<category><![CDATA[Flex 4]]></category>
		<category><![CDATA[Design Patterns]]></category>
		<category><![CDATA[Spark Framework]]></category>

		<guid isPermaLink="false">http://flashmoments.novelastudios.com/?p=149</guid>
		<description><![CDATA[I have to give the Adobe Flash team big props on the new Spark framework&#8217;s focus on separated logic. Not only does it enhance my productivity and sanity, but it has opened wide the door for and encouraged the Flex community to create vast reusable code in ways that Flex 3 had problems encouraging developers [...]]]></description>
			<content:encoded><![CDATA[<div style="float:left;margin:0px 0px 0px 0px;"></div><p>I have to give the Adobe Flash team big props on the new Spark framework&#8217;s focus on separated logic. Not only does it enhance my productivity and sanity, but it has opened wide the door for and encouraged the Flex community to create vast reusable code in ways that Flex 3 had problems encouraging developers to do.<br />
For instance, the Spark separated layout structure with a DI slant has already saved time and encouraged so many layout concepts that are <strong>no longer component based</strong> solutions (<a href="http://saturnboy.com/2009/10/flow-layout/">example</a>). The community is now able to focus on solving small solutions and then combining them into greater solution for a given project!</p>
<p>I <em>expect</em> to see more focused classes coming soon.</p>
<p>UPDATE <span style="color: #808080;">(June 10, &#8217;10)</span>:<br />
The focus on solution driven instead of component has allowed Adobe to have features like Layout Mirroring (<a href="http://blogs.adobe.com/flexdoc/2010/05/layout_mirroring.html" target="_blank">link</a>). This further demonstrates the power of developing a DI driven framework. I encourage more of us to architect this way. OH MAN, did I really suggest us to architect like Adobe?!</p>
<img src="http://flashmoments.novelastudios.com/?ak_action=api_record_view&id=149&type=feed" alt="" />]]></content:encoded>
			<wfw:commentRss>http://flashmoments.novelastudios.com/flex/power-separated-logic-opening-door/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Parsing Algorithms &#8211; Creational Patterns</title>
		<link>http://flashmoments.novelastudios.com/architectural-pattern/parsing-algorithms-creational-patterns/#utm_source=feed&#038;utm_medium=feed&#038;utm_campaign=feed</link>
		<comments>http://flashmoments.novelastudios.com/architectural-pattern/parsing-algorithms-creational-patterns/#comments</comments>
		<pubDate>Sat, 27 Mar 2010 18:57:56 +0000</pubDate>
		<dc:creator>johntimothybailey</dc:creator>
				<category><![CDATA[ActionScript]]></category>
		<category><![CDATA[Architectural Pattern]]></category>
		<category><![CDATA[Programming Architecture]]></category>
		<category><![CDATA[Programming Practice]]></category>
		<category><![CDATA[Rants]]></category>
		<category><![CDATA[Recommendations]]></category>
		<category><![CDATA[Architecture]]></category>
		<category><![CDATA[as3]]></category>
		<category><![CDATA[Best Practices]]></category>
		<category><![CDATA[Design Patterns]]></category>
		<category><![CDATA[General Programming]]></category>
		<category><![CDATA[rant]]></category>
		<category><![CDATA[Suggestion]]></category>

		<guid isPermaLink="false">http://flashmoments.novelastudios.com/?p=85</guid>
		<description><![CDATA[This is as much a recommendation as a rant, so pardon me while I do both Situation Open-source project or foundational classes for use within your organization that contains methods for parsing data. Background Often, I&#8217;ve run into issues where I am using an open-source library (public or private) and I need to add extra [...]]]></description>
			<content:encoded><![CDATA[<div style="float:left;margin:0px 0px 0px 0px;"></div><p><em><span style="color: #888888;">This is as much a recommendation as a rant, so pardon me while I do both <img src='http://flashmoments.novelastudios.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </span></em></p>
<p><strong>Situation<br />
</strong>Open-source project or foundational classes for use within your organization that contains methods for parsing data.</p>
<p><strong>Background<br />
</strong>Often, I&#8217;ve run into issues where I am using an open-source library (public or private) and I need to add extra logic to a creational algorithm(s) and cannot or cannot easily do so. This is what has sparked me to write this post, because I am increasingly seeing these types of issues.</p>
<p><strong>Recommendation<br />
</strong>When creating algorithms that create objects from other objects (eg models and serialization) , please use offload the logic to accessible and easily modifiable methods. In Design Pattern terms, I&#8217;m requesting and ranting that the Factory Method Pattern, Strategy Pattern, or something similar be used. This only compounds in importance when there are several objects created in a single method!  &lt;&#8211; That right there is arguably bad practice in general for large projects.</p>
<p><strong>Example<br />
<span style="font-weight: normal;"><em><span style="color: #808080;">NOTE</span></em></span><span style="font-weight: normal;"><em><span style="color: #808080;">: Showing a simple example seems to not show the problem, but I&#8217;ll try. For a better example, please refer to &#8220;Real-Life Example&#8221; below.</span></em></span></strong></p>
<p><strong> </strong></p>
<p><strong>Mapping XML properties to models within a project.</strong></p>
<pre lang="Actionscript">protected updateList():void
{
var header:Header = new Header;
header.title = _xml.header.@title;
header.lang = _xml.header.@lang;
header.colors = _xml.header.colors.toArray();

var body:Body = _body;
var child:XML;
for (var i:Number = 0; i &lt; _xml.body.item.length(); ++i)
{
child = _xml.body.item[i];
body.getItemAt(i).text = child.@text;
}
}</pre>
<p><strong><span style="font-weight: normal;"><br />
</span></strong></p>
<p><strong>Real-Life Example<br />
<em><span style="color: #333333;">NOTE:</span></em><span style="font-weight: normal;"> I do not mean to pick on or criticize the fine work done by the peeps working on the <a title="OpenVideoPlayer Project" href="openvideoplayer.sourceforge.net/#utm_source=feed&amp;utm_medium=feed&amp;utm_campaign=feed">OpenVideoPlayer Project</a> and MUST EMPHASIZE that the project is very useful and saves time. This merely serves as an easy example to show. Moreover, I&#8217;ve written my fair share of problematic code along these lines too.</span></strong></p>
<p><strong> </strong></p>
<ul>
<li><span style="font-weight: normal;"><a href="https://sourceforge.net/tracker/?func=detail&amp;aid=2977117&amp;group_id=243060&amp;atid=1121331">https://sourceforge.net/tracker/?func=detail&amp;aid=2977117&amp;group_id=243060&amp;atid=1121331</a></span></li>
</ul>
<img src="http://flashmoments.novelastudios.com/?ak_action=api_record_view&id=85&type=feed" alt="" />]]></content:encoded>
			<wfw:commentRss>http://flashmoments.novelastudios.com/architectural-pattern/parsing-algorithms-creational-patterns/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Tween Library Preferences and Strategy Patterns</title>
		<link>http://flashmoments.novelastudios.com/actionscript/tween-library-preferences-strategy-patterns/#utm_source=feed&#038;utm_medium=feed&#038;utm_campaign=feed</link>
		<comments>http://flashmoments.novelastudios.com/actionscript/tween-library-preferences-strategy-patterns/#comments</comments>
		<pubDate>Mon, 18 Jan 2010 03:48:52 +0000</pubDate>
		<dc:creator>johntimothybailey</dc:creator>
				<category><![CDATA[ActionScript]]></category>
		<category><![CDATA[Programming Architecture]]></category>
		<category><![CDATA[Programming Practice]]></category>
		<category><![CDATA[Architecture]]></category>
		<category><![CDATA[as3]]></category>
		<category><![CDATA[Best Practices]]></category>
		<category><![CDATA[Design Patterns]]></category>
		<category><![CDATA[Strategy Pattern]]></category>

		<guid isPermaLink="false">http://flashmoments.novelastudios.com/?p=60</guid>
		<description><![CDATA[Problem: When it comes to Tween libraries, it&#8217;s either a project&#8217;s requirements and/or developer personal preferences that can conflict in selecting a library. Honestly, the library shouldn&#8217;t matter. The importance is that the objects are tweened. This is especially important when it comes to open-source projects, as the issue only compounds where it&#8217;s much more [...]]]></description>
			<content:encoded><![CDATA[<div style="float:left;margin:0px 0px 0px 0px;"></div><p><strong>Problem</strong>:<br />
When it comes to Tween libraries, it&#8217;s either a project&#8217;s requirements and/or developer personal preferences that can conflict in selecting a library. Honestly, <span style="text-decoration: underline;">the library shouldn&#8217;t matter</span>. <span style="text-decoration: underline;">The importance is that the objects are tweened</span>. This is especially important when it comes to open-source projects, as the issue only compounds where it&#8217;s much more likely that both personal preferences and project requirements will both be the issue with the open-source project.</p>
<p><strong>Solution:</strong> Use the Strategy Pattern</p>
<p><strong>Example</strong><em> (real-life example)</em>: <a title="Duncan Reid's Blog" href="http://blog.hy-brid.com/" target="_blank">Duncan Reid</a> created a <a title="Duncan Reid's ToolTip Class" href="http://blog.hy-brid.com/flash/25/simple-as3-tooltip/" target="_blank">ToolTip UI class</a> for ActionScript3. The problem I ran into was that fl.transitions.Tween was being used and I was working on an AS3 application that is using the now <a href="http://blog.greensock.com/tweenlite/" target="_blank">Greensock&#8217;s TweenLite</a>. The solution that Duncan and I discussed was to use a Strategy Pattern to decouple the Tween library from the ToolTip class itself and offload the reference onto implementation. In other words, by utilizing the Strategy Pattern, it allows the developer to decide which tweening library he/she would prefer to use. For Duncan Reid&#8217;s ToolTip UI I did the following:</p>
<ul>
<li>Added New Files:
<ul>
<li><em>com.hybrid.ui.strategies.IToolTipTweenStrategy</em></li>
<li><em>com.hybrid.ui.strategies.ToolTipTweenStrategy</em> &#8211; The only place where <em>fl.transitions.Tween</em> is being used/referenced</li>
</ul>
</li>
<li>ToolTip now has a required constructor parameter tweenStrategy which will accept anything implementing the IToolTipTweenStrategy</li>
</ul>
<p>This now means that the ToolTip UI class depends on one thing &#8211; the Tween Strategy. In fact, the strategy could be set to null (not given to the ToolTip), then no tweening would take place. Instead, the tooltip would just display or hide immediately. As such, the required construction param could be made optional (ie default set to null).</p>
<p>In action this simply looks like</p>
<pre lang="Actionscript">  new ToolTip(new com.hybrid.ui.strategies.ToolTipTweenStrategy)
  //OR
  new ToolTip(new com.novelastudios.ui.strategies.ToolTipTweenStrategy)</pre>
<p><strong>Source Files / Source Examples</strong> <em>(using Duncan Reid&#8217;s ToolTip UI)</em></p>
<ul>
<li>Example of dynamic strategy changing ( <a title="ToolTip Tween Strategy Visual Demo" href="http://sources.novelastudios.com/flash/tooltip/ToolTipExample.html" target="_blank">visual demo</a> / <a href="http://sources.novelastudios.com/flash/tooltip/srcview/index.html" target="_blank">source</a> )
<ul>
<li>Click the Radio Buttons at the top of the visual demo to switch between the different strategies.</li>
</ul>
</li>
<li>Implementing it into Duncan&#8217;s original example
<ul>
<li>Using fl.transitions.Tween ( <a href="http://sources.novelastudios.com/flash/tooltip/ToolTip_Fl_Tween.html" target="_blank">visual demo</a> / source <a href="http://sources.novelastudios.com/flash/tooltip/srcview/source/ToolTip_Fl_Tween.fla" target="_blank">.fla</a> | <a href="http://sources.novelastudios.com/flash/tooltip/srcview/source/ToolTip_Fl_Tween.as" target="_blank">.as</a> )</li>
<li>Using com.greensocks.TweenLite ( <a href="http://sources.novelastudios.com/flash/tooltip/ToolTip_Greensock_Tween.html" target="_blank">visual demo </a>/ source <a href="http://sources.novelastudios.com/flash/tooltip/srcview/source/ToolTip_Greensock_Tween.fla" target="_blank">.fla</a> | <a href="http://sources.novelastudios.com/flash/tooltip/srcview/source/ToolTip_Greensock_Tween.as" target="_blank">.as</a> )</li>
</ul>
</li>
</ul>
<p><strong>Note</strong><br />
The above source is not officially supported / maintained by Duncan Reid and as such I recommend that this simply be used as an example and refer you to his site and source code for production use.</p>
<p><strong>Additional Information</strong><br />
For more information on the Strategy Pattern with ActionScript3 checkout the following:</p>
<ul>
<li><a title="Simple Explanation" href="http://ntt.cc/2008/10/07/gang-of-four-gof-design-patterns-in-actionscript-strategy.html" target="_blank">Brief Explanation</a></li>
<li><a title="Bill Sanders' Explanation of the Strategy Pattern" href="http://www.as3dp.com/2008/11/09/actionscript-30-strategy-design-pattern-under-no-conditionals/" target="_blank">Bill Sanders&#8217; Explanation</a></li>
<li><a title="Sean Moore's Explanation" href="http://www.insideria.com/2008/11/exploring-the-strategy-design.html" target="_blank">Sean Moore&#8217;s Explanation</a></li>
</ul>
<img src="http://flashmoments.novelastudios.com/?ak_action=api_record_view&id=60&type=feed" alt="" />]]></content:encoded>
			<wfw:commentRss>http://flashmoments.novelastudios.com/actionscript/tween-library-preferences-strategy-patterns/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

