<?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>Easy Flex</title>
	<atom:link href="http://evtimmy.com/feed/" rel="self" type="application/rss+xml" />
	<link>http://evtimmy.com</link>
	<description>Evtim on Flex SDK</description>
	<lastBuildDate>Mon, 12 Apr 2010 06:42:10 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Two Examples of Layout Animations</title>
		<link>http://evtimmy.com/2010/04/two-examples-of-layout-animations/</link>
		<comments>http://evtimmy.com/2010/04/two-examples-of-layout-animations/#comments</comments>
		<pubDate>Mon, 12 Apr 2010 06:42:10 +0000</pubDate>
		<dc:creator>Evtim</dc:creator>
				<category><![CDATA[3D]]></category>
		<category><![CDATA[Animation]]></category>
		<category><![CDATA[Custom Layout]]></category>
		<category><![CDATA[Spark Layouts]]></category>
		<category><![CDATA[Effects]]></category>
		<category><![CDATA[Layout]]></category>
		<category><![CDATA[Move3D]]></category>
		<category><![CDATA[Rotate3D]]></category>
		<category><![CDATA[Scrolling]]></category>
		<category><![CDATA[Spark]]></category>
		<category><![CDATA[WheelLayout]]></category>

		<guid isPermaLink="false">http://evtimmy.com/?p=318</guid>
		<description><![CDATA[ A few folks have been asking for the source of my Creating Custom Layouts in Flex 4 talk at the Flash Camp Boston event, and I finally found the time to post it here. My apologies for the delay.  Click on the image to go to the demo, right-click and select &#8220;view source&#8221; [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://evtimmy.com/wordpress/wp-content/uploads/2010/04/layout-animation/FlickrRIAModified.swf"><img class="alignleft size-thumbnail wp-image-320" title="layout-animation" src="http://evtimmy.com/wordpress/wp-content/uploads/2010/04/layout-animation-150x150.png" alt="layout-animation" width="150" height="150" /></a> A few folks have been asking for the source of my <a href="http://tv.adobe.com/watch/flash-camp-boston/creating-custom-layouts-in-flex-4-">Creating Custom Layouts in Flex 4</a> talk at the Flash Camp Boston event, and I finally found the time to post it here. My apologies for the delay.  Click on the image to go to the demo, right-click and select &#8220;view source&#8221; to get to the goods. <span id="more-318"></span> This is pretty much my old WheelLayout demo, but I added a couple of animations  to make things a little bit slicker:</p>
<ol>
<li>Clicking on any image in the WheelLayout mode will rotate all the elements until the selected item is centered in front. <em>In this animation the layout runs on every frame of the animation.</em></li>
<li>Selecting different layouts from the drop-down will animate the items&#8217; transformation. <em>In this animation the layout is disabled and is not running during the animation.</em></li>
</ol>
<h3>Animating the Scroll Position</h3>
<p>In the first animation I want the selected item to come &#8220;in view&#8221;. In the <em>WheelLayout</em> I&#8217;ve already implemented the standard API that calculates the scroll distance to an item &#8211; <em>getScrollPositionDeltaToElement()</em>. Now in the item renderer of the list &#8211; <em>FlickrThumbnail.mxml</em> &#8211; I detect when the item has been clicked and then create an animation for the scroll position of the parent <em>Group</em>:</p>

<div class="wp_syntax"><div class="code"><pre class="actionscript3" style="font-family:monospace;"><span style="color: #0033ff; font-weight: bold;">protected</span> <span style="color: #339966; font-weight: bold;">function</span> itemrenderer1_clickHandler<span style="color: #000000;">&#40;</span>event<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">MouseEvent</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">:</span><span style="color: #0033ff; font-weight: bold;">void</span>
<span style="color: #000000;">&#123;</span>
    <span style="color: #6699cc; font-weight: bold;">var</span> g<span style="color: #000066; font-weight: bold;">:</span>GroupBase = <span style="color: #004993;">parent</span> <span style="color: #0033ff; font-weight: bold;">as</span> GroupBase<span style="color: #000066; font-weight: bold;">;</span>
    <span style="color: #6699cc; font-weight: bold;">var</span> p<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Point</span> = g<span style="color: #000066; font-weight: bold;">.</span>layout<span style="color: #000066; font-weight: bold;">.</span>getScrollPositionDeltaToElement<span style="color: #000000;">&#40;</span><span style="color: #0033ff; font-weight: bold;">this</span><span style="color: #000066; font-weight: bold;">.</span>itemIndex<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
    <span style="color: #0033ff; font-weight: bold;">if</span> <span style="color: #000000;">&#40;</span>p<span style="color: #000000;">&#41;</span>
    <span style="color: #000000;">&#123;</span>
        <span style="color: #6699cc; font-weight: bold;">var</span> startX<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = g<span style="color: #000066; font-weight: bold;">.</span>horizontalScrollPosition<span style="color: #000066; font-weight: bold;">;</span>
        <span style="color: #6699cc; font-weight: bold;">var</span> startY<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = g<span style="color: #000066; font-weight: bold;">.</span>verticalScrollPosition<span style="color: #000066; font-weight: bold;">;</span>
        <span style="color: #6699cc; font-weight: bold;">var</span> anim<span style="color: #000066; font-weight: bold;">:</span>Animate = <span style="color: #0033ff; font-weight: bold;">new</span> Animate<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
        anim<span style="color: #000066; font-weight: bold;">.</span>motionPaths = <span style="color: #0033ff; font-weight: bold;">new</span> <span style="color: #000000;">&#91;</span>
            <span style="color: #0033ff; font-weight: bold;">new</span> SimpleMotionPath<span style="color: #000000;">&#40;</span><span style="color: #990000;">&quot;horizontalScrollPosition&quot;</span><span style="color: #000066; font-weight: bold;">,</span> startX<span style="color: #000066; font-weight: bold;">,</span> startX <span style="color: #000066; font-weight: bold;">+</span> p<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000066; font-weight: bold;">,</span> 500<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">,</span>
            <span style="color: #0033ff; font-weight: bold;">new</span> SimpleMotionPath<span style="color: #000000;">&#40;</span><span style="color: #990000;">&quot;verticalScrollPosition&quot;</span><span style="color: #000066; font-weight: bold;">,</span> startY<span style="color: #000066; font-weight: bold;">,</span> startY <span style="color: #000066; font-weight: bold;">+</span> p<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000066; font-weight: bold;">,</span> 500<span style="color: #000000;">&#41;</span>
        <span style="color: #000000;">&#93;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
        <span style="color: #6699cc; font-weight: bold;">var</span> interpolator<span style="color: #000066; font-weight: bold;">:</span>NumberInterpolatorWrapping =
			<span style="color: #0033ff; font-weight: bold;">new</span> NumberInterpolatorWrapping<span style="color: #000000;">&#40;</span>0<span style="color: #000066; font-weight: bold;">,</span> g<span style="color: #000066; font-weight: bold;">.</span>contentWidth <span style="color: #000066; font-weight: bold;">-</span> g<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">width</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
        <span style="color: #6699cc; font-weight: bold;">var</span> scrollLength<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = interpolator<span style="color: #000066; font-weight: bold;">.</span>getLength<span style="color: #000000;">&#40;</span>startX<span style="color: #000066; font-weight: bold;">,</span> startX <span style="color: #000066; font-weight: bold;">+</span> p<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
        anim<span style="color: #000066; font-weight: bold;">.</span>interpolator = interpolator<span style="color: #000066; font-weight: bold;">;</span>
        anim<span style="color: #000066; font-weight: bold;">.</span>duration = <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">max</span><span style="color: #000000;">&#40;</span>550<span style="color: #000066; font-weight: bold;">,</span> <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">min</span><span style="color: #000000;">&#40;</span>2500<span style="color: #000066; font-weight: bold;">,</span> scrollLength <span style="color: #000066; font-weight: bold;">*</span> 2<span style="color: #000000;">&#41;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
        anim<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">play</span><span style="color: #000000;">&#40;</span><span style="color: #000000;">&#91;</span>g<span style="color: #000000;">&#93;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
    <span style="color: #000000;">&#125;</span>
<span style="color: #000000;">&#125;</span></pre></div></div>

<p>One interesting thing to note is that because of the circular nature of the WheelLayout I wanted the animation to interpolate between the values in a wrap-around manner. For example scrolling from the last element to the first element shouldn&#8217;t scroll through any other elements since the first and last elements are visually next to each other. For that reason I implemented a custom interpolator &#8211; <em>NumberInterpolatorWrapping.as</em>.</p>
<h3>Animating Items between Different Layouts</h3>
<p>In this animation I wanted all the elements to move and rotate smoothly when I switch between various layouts. In this animation the start position is defined by the current layout and the end position is defined by the new layout. In-between, while the elements are being animated, they really don&#8217;t belong to any layout. For that reason, I disable the layout of the container for the duration of the animation using the <em>autoLayout </em>property of the parent <em>Group</em>.</p>
<p>For convenience I transition between the layouts using states:</p>

<div class="wp_syntax"><div class="code"><pre class="mxml" style="font-family:monospace;"><span style="color: #000000;"><span style="color: #7400FF;">&lt;s:states</span><span style="color: #7400FF;">&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;tile&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;wheel&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;vertical&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;horizontal&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:states</span><span style="color: #7400FF;">&gt;</span></span>
&nbsp;
<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:List</span> width=<span style="color: #ff0000;">&quot;100%&quot;</span> height=<span style="color: #ff0000;">&quot;100%&quot;</span></span>
<span style="color: #000000;">		dataProvider=<span style="color: #ff0000;">&quot;{photoFeed}&quot;</span></span>
<span style="color: #000000;">		itemRenderer=<span style="color: #ff0000;">&quot;FlickrThumbnail&quot;</span></span>
<span style="color: #000000;">		id=<span style="color: #ff0000;">&quot;theList&quot;</span> useVirtualLayout=<span style="color: #ff0000;">&quot;false&quot;</span><span style="color: #7400FF;">&gt;</span></span>
&nbsp;
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:layout</span>.vertical<span style="color: #7400FF;">&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:VerticalLayout</span> horizontalAlign=<span style="color: #ff0000;">&quot;center&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:layout</span>.vertical<span style="color: #7400FF;">&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:layout</span>.horizontal<span style="color: #7400FF;">&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:HorizontalLayout</span> verticalAlign=<span style="color: #ff0000;">&quot;middle&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:layout</span>.horizontal<span style="color: #7400FF;">&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:layout</span>.tile<span style="color: #7400FF;">&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:TileLayout</span> horizontalAlign=<span style="color: #ff0000;">&quot;center&quot;</span> verticalAlign=<span style="color: #ff0000;">&quot;bottom&quot;</span></span>
<span style="color: #000000;">                                      columnWidth=<span style="color: #ff0000;">&quot;112&quot;</span> rowHeight=<span style="color: #ff0000;">&quot;132&quot;</span></span>
<span style="color: #000000;">				      requestedColumnCount=<span style="color: #ff0000;">&quot;5&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:layout</span>.tile<span style="color: #7400FF;">&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:layout</span>.wheel<span style="color: #7400FF;">&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;my:WheelLayout</span> gap=<span style="color: #ff0000;">&quot;20&quot;</span> axisAngle=<span style="color: #ff0000;">&quot;{axisSlider.value}&quot;</span></span>
<span style="color: #000000;">		verticalCenterOffset=<span style="color: #ff0000;">&quot;{offsetSlider.value}&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:layout</span>.wheel<span style="color: #7400FF;">&gt;</span></span>
<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:List</span><span style="color: #7400FF;">&gt;</span></span></pre></div></div>

<p>Because the elements could be both moved and/or rotated in 2D or 3D, I use a parallel of both effects:</p>

<div class="wp_syntax"><div class="code"><pre class="mxml" style="font-family:monospace;"><span style="color: #000000;"><span style="color: #7400FF;">&lt;fx:Declarations</span><span style="color: #7400FF;">&gt;</span></span>
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Parallel</span> id=<span style="color: #ff0000;">&quot;myEffect&quot;</span> effectEnd=<span style="color: #ff0000;">&quot;myEffect_effectEndHandler(event)&quot;</span><span style="color: #7400FF;">&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Move</span>3D applyChangesPostLayout=<span style="color: #ff0000;">&quot;false&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Rotate</span>3D applyChangesPostLayout=<span style="color: #ff0000;">&quot;false&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:Parallel</span><span style="color: #7400FF;">&gt;</span></span>
<span style="color: #000000;"><span style="color: #7400FF;">&lt;/fx:Declarations</span><span style="color: #7400FF;">&gt;</span></span></pre></div></div>

<p>And finally, when I switch from one layout state to another, I want to run the effect. Now I need to perform the following steps:</p>
<ol>
<li>Make the effect target all of the elements.</li>
<li>Capture the start values (the position and rotation defined by the old layout).</li>
<li>Switch the layout (by changing the state) and call <em>validateNow()</em> so that all elements are positioned and/or rotated by the new layout.</li>
<li>Turn off the <em>autoLayout</em> property so that the new layout doesn&#8217;t interfere with the running effect.</li>
<li>Run the effect. Note that at this point the effect is going to capture the animation end values &#8211; the position/rotation defined by the new layout. I&#8217;ve already captured the start values at step 2, so I&#8217;m all set.</li>
<li>When the effect is done, turn the layout back on.</li>
</ol>

<div class="wp_syntax"><div class="code"><pre class="actionscript3" style="font-family:monospace;"><span style="color: #0033ff; font-weight: bold;">private</span> <span style="color: #339966; font-weight: bold;">function</span> animateTo<span style="color: #000000;">&#40;</span>toState<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">String</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">:</span><span style="color: #0033ff; font-weight: bold;">void</span>
<span style="color: #000000;">&#123;</span>
    <span style="color: #009900; font-style: italic;">// Make sure any previous animation is stopped.</span>
    <span style="color: #0033ff; font-weight: bold;">if</span> <span style="color: #000000;">&#40;</span>myEffect<span style="color: #000066; font-weight: bold;">.</span>isPlaying<span style="color: #000000;">&#41;</span>
        myEffect<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">stop</span><span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
    <span style="color: #009900; font-style: italic;">// Add targets</span>
    myEffect<span style="color: #000066; font-weight: bold;">.</span>targets = <span style="color: #0033ff; font-weight: bold;">new</span> <span style="color: #004993;">Array</span><span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
    <span style="color: #0033ff; font-weight: bold;">for</span> <span style="color: #000000;">&#40;</span><span style="color: #6699cc; font-weight: bold;">var</span> i<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">int</span> = <span style="color: #000000; font-weight:bold;">0</span><span style="color: #000066; font-weight: bold;">;</span> i <span style="color: #000066; font-weight: bold;">&lt;</span> theList<span style="color: #000066; font-weight: bold;">.</span>dataGroup<span style="color: #000066; font-weight: bold;">.</span>numElements<span style="color: #000066; font-weight: bold;">;</span> i<span style="color: #000066; font-weight: bold;">++</span><span style="color: #000000;">&#41;</span>
        myEffect<span style="color: #000066; font-weight: bold;">.</span>targets<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">push</span><span style="color: #000000;">&#40;</span>theList<span style="color: #000066; font-weight: bold;">.</span>dataGroup<span style="color: #000066; font-weight: bold;">.</span>getElementAt<span style="color: #000000;">&#40;</span>i<span style="color: #000000;">&#41;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
    <span style="color: #009900; font-style: italic;">// Create Transition for all elements</span>
    myEffect<span style="color: #000066; font-weight: bold;">.</span>captureStartValues<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
    <span style="color: #009900; font-style: italic;">// Go to the end state</span>
    <span style="color: #6699cc; font-weight: bold;">var</span> fromState<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">String</span> = <span style="color: #0033ff; font-weight: bold;">this</span><span style="color: #000066; font-weight: bold;">.</span>currentState<span style="color: #000066; font-weight: bold;">;</span>
    setCurrentState<span style="color: #000000;">&#40;</span>toState<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
    <span style="color: #009900; font-style: italic;">// Validate everything before turning off the layout</span>
    theList<span style="color: #000066; font-weight: bold;">.</span>validateNow<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
    <span style="color: #009900; font-style: italic;">// Turn the layout off before running the effect</span>
    theList<span style="color: #000066; font-weight: bold;">.</span>dataGroup<span style="color: #000066; font-weight: bold;">.</span>autoLayout = <span style="color: #0033ff; font-weight: bold;">false</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
    <span style="color: #009900; font-style: italic;">// Play the effect</span>
    myEffect<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">play</span><span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
<span style="color: #000000;">&#125;</span>
&nbsp;
<span style="color: #0033ff; font-weight: bold;">protected</span> <span style="color: #339966; font-weight: bold;">function</span> myEffect_effectEndHandler<span style="color: #000000;">&#40;</span>event<span style="color: #000066; font-weight: bold;">:</span>EffectEvent<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">:</span><span style="color: #0033ff; font-weight: bold;">void</span>
<span style="color: #000000;">&#123;</span>
    theList<span style="color: #000066; font-weight: bold;">.</span>dataGroup<span style="color: #000066; font-weight: bold;">.</span>autoLayout = <span style="color: #0033ff; font-weight: bold;">true</span><span style="color: #000066; font-weight: bold;">;</span>
<span style="color: #000000;">&#125;</span></pre></div></div>

<p>Note that my demo has one limitation &#8211; I needed to turn off virtual layout so that everything works fine. If I have virtual layout running, I&#8217;m not guaranteed that the old and new layouts will assign the items to the same item renderers.<br />
Click on the image at the top to go to the demo, where you can select &#8220;view source&#8221; from the right-click menu to get the code.</p>
]]></content:encoded>
			<wfw:commentRss>http://evtimmy.com/2010/04/two-examples-of-layout-animations/feed/</wfw:commentRss>
		<slash:comments>11</slash:comments>
		</item>
		<item>
		<title>Extending HorizontalLayout to Support Baseline (Align to Text)</title>
		<link>http://evtimmy.com/2010/02/extending-horizontallayout-to-support-baseline-align-to-text/</link>
		<comments>http://evtimmy.com/2010/02/extending-horizontallayout-to-support-baseline-align-to-text/#comments</comments>
		<pubDate>Fri, 26 Feb 2010 08:06:42 +0000</pubDate>
		<dc:creator>Evtim</dc:creator>
				<category><![CDATA[Custom Layout]]></category>
		<category><![CDATA[Spark Layouts]]></category>
		<category><![CDATA[align to text]]></category>
		<category><![CDATA[alignment]]></category>
		<category><![CDATA[baseline]]></category>
		<category><![CDATA[Layout]]></category>

		<guid isPermaLink="false">http://evtimmy.com/?p=265</guid>
		<description><![CDATA[The current Spark HorizontalLayout unfortunately doesn&#8217;t support baseline alignment. If I want to have, for example, a Label and a Button positioned so that their text aligns, I usualy use absolute position (nudging things up or down) or baseline constraints with BasicLayout/Canvas.  But then again, I always find myself needing this feature in a [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://evtimmy.com/wordpress/wp-content/uploads/2010/02/hlayoutbaseline/HLayoutBaseline.swf"><img class="alignleft size-thumbnail wp-image-266" style="margin-left: 10px; margin-right: 10px;" title="hlayoutbaseline" src="http://evtimmy.com/wordpress/wp-content/uploads/2010/02/hlayoutbaseline-150x150.png" alt="hlayoutbaseline" width="150" height="150" /></a>The current Spark <em>HorizontalLayout </em>unfortunately doesn&#8217;t support <em>baseline </em>alignment. If I want to have, for example, a <em>Label </em>and a <em>Button</em> positioned so that their text aligns, I usualy use absolute position (nudging things up or down) or <em>baseline </em>constraints with <em>BasicLayout</em>/<em>Canvas</em>.  But then again, I always find myself needing this feature in a <em>HorizontalLayout </em>and so I finally decided to tackle it on. It turns out it&#8217;s pretty easy to extend the stock Spark <em>HorizontalLayout</em>, not to mention using it is a breeze with the Spark layout architecture (yay Spark!).<span id="more-265"></span></p>
<h3>Baseline Concepts in Flex</h3>
<ul>
<li>Each <em>IVisualElement </em>has a <em>baselinePosition</em>. This is the vertical distance from element&#8217;s top (origin) to its text base.</li>
<li>To align an <em>IVisualElement</em>&#8217;s text to a specific point within its parent, say A=100, we roughly do the following <span style="color: #ff6600;">element.y = A &#8211; element.baselinePosition</span>.</li>
<li>Each IVisualElement has a <em>baseline</em> constraint. How this is going to be used is up to the parent layout. By default <em>BasicLayout</em>/<em>Canvas </em>interpret it as the position within the parent to which the element&#8217;s text base should be aligned, meaning that the actual calculation is <span style="color: #ff6600;">element.y = element.baseline &#8211; element.baselinePosition</span>.</li>
</ul>
<h3>What I Want</h3>
<ol>
<li>Still keep all the cool functionality of the HorizontalLayout without copying code.</li>
<li>Ability to specify a <span style="color: #339966;"><em>global baseline</em></span>. The layout should position all the elements such that their text aligns to that <span style="color: #339966;"><em>global baseline</em></span>. I also want the ability to individually offset the elements from the <em><span style="color: #339966;">global baseline</span></em>. I want the element&#8217;s <em>baseline </em>constraint, if specified, to serve as such an offset.</li>
<li>If I&#8217;m too lazy to specify the <em><span style="color: #339966;">global baseline</span></em>, the layout should calculate it for me. In that case there shouldn&#8217;t be any extra space around the elements and the layout&#8217;s borders.</li>
<li>The <span style="color: #339966;"><em>global baseline</em></span> should be <span style="color: #0000ff;">[Bindable]</span>. Since the layout is calculating it in certain cases, I want to be able to read it back whenever its value changes.</li>
</ol>
<p>Here&#8217;s an example of the layout in action:  <a href="http://evtimmy.com/wordpress/wp-content/uploads/2010/02/hlayoutbaseline-simple.png"><img class="alignleft size-full wp-image-297" title="hlayoutbaseline-simple" src="http://evtimmy.com/wordpress/wp-content/uploads/2010/02/hlayoutbaseline-simple.png" alt="hlayoutbaseline-simple" width="232" height="47" /></a></p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
</pre></td><td class="code"><pre class="mxml" style="font-family:monospace;"><span style="color: #000000;">&lt;?xml version=<span style="color: #ff0000;">&quot;1.0&quot;</span> encoding=<span style="color: #ff0000;">&quot;utf-8&quot;</span>?<span style="color: #7400FF;">&gt;</span></span>
<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Application</span> xmlns:fx=<span style="color: #ff0000;">&quot;http://ns.adobe.com/mxml/2009&quot;</span></span>
<span style="color: #000000;">               xmlns:s=<span style="color: #ff0000;">&quot;library://ns.adobe.com/flex/spark&quot;</span></span>
<span style="color: #000000;">               xmlns:mx=<span style="color: #ff0000;">&quot;library://ns.adobe.com/flex/mx&quot;</span></span>
<span style="color: #000000;">               xmlns:local=<span style="color: #ff0000;">&quot;*&quot;</span><span style="color: #7400FF;">&gt;</span></span>
&nbsp;
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:BorderContainer</span> horizontalCenter=<span style="color: #ff0000;">&quot;0&quot;</span> verticalCenter=<span style="color: #ff0000;">&quot;0&quot;</span></span>
<span style="color: #000000;">                       minWidth=<span style="color: #ff0000;">&quot;0&quot;</span> minHeight=<span style="color: #ff0000;">&quot;0&quot;</span><span style="color: #7400FF;">&gt;</span></span>
&nbsp;
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:layout</span><span style="color: #7400FF;">&gt;</span></span>
             <span style="color: #000000;"><span style="color: #7400FF;">&lt;local:HBaselineLayout</span> verticalAlign=<span style="color: #ff0000;">&quot;baseline&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:layout</span><span style="color: #7400FF;">&gt;</span></span>
&nbsp;
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:CheckBox</span> label=<span style="color: #ff0000;">&quot;hello&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Button</span> label=<span style="color: #ff0000;">&quot;button&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Label</span> text=<span style="color: #ff0000;">&quot;and label&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
&nbsp;
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:BorderContainer</span><span style="color: #7400FF;">&gt;</span></span>
&nbsp;
<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:Application</span><span style="color: #7400FF;">&gt;</span></span></pre></td></tr></table></div>

<h3>Implementation</h3>
<ol>
<li>I extended the <em>HorizontalLayout </em>class and had to override the <em>verticalAlign </em>property getter in order to modify the enum metadata and add &#8220;baseline&#8221; as an option.</li>
<li>I added a <span style="color: #339966;"><em>globalBaseline</em> </span>property. I had to override the <em>updateDisplayList()</em> method. After the super.updateDisplayList() has finished with sizing and positioning the elements, I&#8217;d iterate over them and position them using something like this <span style="color: #ff6600;">element.setLayoutBoundsPosition(element.getLayoutBoundsX(), globalBaseline + element.baseline &#8211; element.baselinePosition)</span>.</li>
<li>Calculating the <span style="color: #339966;"><em>globalBaseline </em></span>is easy enough. If all the elements are aligned at the <span style="color: #339966;"><em>globalBaseline</em></span>, then a certain portion of each element will be above that line and the rest will be below the line &#8211; top portion and bottom portion. Then I have <span style="color: #ff6600;">topPortion = element.baseline &#8211; element.baselinePosition</span> and <span style="color: #ff6600;">bottomPortion = element.height &#8211; element.baseline + element.baselinePosition</span>. Now since I don&#8217;t want any extra space around the elements I want the element that sticks out the most above the <span style="color: #339966;"><em>globalBaseline </em></span>to touch the top edge of the container, while the element that sticks out the most below the <span style="color: #339966;"><em>globalBaseline </em></span>to touch the bottom edge of the container. Therefore the <span style="color: #339966;"><em>globalBaseline </em></span>is going to be the maximum of the top portions, while the measured height of the container is going to be the<span style="color: #ff6600;"> <span style="color: #339966;"><em>globalBaseline </em></span></span>+ the maximum of the bottom portions. I created a helper function to calculate the maximums of the top and bottom portions and used it in the overridden <em>measure()</em> and <em>updateDisplayList()</em> methods.</li>
<li>Finally, I added a property <span style="color: #339966;"><em>actualBaseline </em></span>and made sure to dispatch an event when it changes. I update the <em><span style="color: #339966;">actualBaseline </span></em>at the end of <em>updateDisplayList()</em> so that at the time of the event it&#8217;s certain that all elements are already sized and positioned correctly.</li>
</ol>
<p>Here&#8217;s an <a href="http://evtimmy.com/wordpress/wp-content/uploads/2010/02/hlayoutbaseline/HLayoutBaseline.swf">example</a> of a working app, to get the source right-click on the application and select &#8220;view source&#8221;.</p>
]]></content:encoded>
			<wfw:commentRss>http://evtimmy.com/2010/02/extending-horizontallayout-to-support-baseline-align-to-text/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>VerticalAlign for VGroup and HorizontalAlign for HGroup</title>
		<link>http://evtimmy.com/2010/01/verticalalign-for-vgroup-and-horizontalalign-for-hgroup/</link>
		<comments>http://evtimmy.com/2010/01/verticalalign-for-vgroup-and-horizontalalign-for-hgroup/#comments</comments>
		<pubDate>Mon, 25 Jan 2010 02:13:49 +0000</pubDate>
		<dc:creator>Evtim</dc:creator>
				<category><![CDATA[Spark Layouts]]></category>
		<category><![CDATA[alignment]]></category>
		<category><![CDATA[Flex 4]]></category>
		<category><![CDATA[Layout]]></category>
		<category><![CDATA[Scrolling]]></category>
		<category><![CDATA[Spark]]></category>

		<guid isPermaLink="false">http://evtimmy.com/?p=239</guid>
		<description><![CDATA[ Recently I checked in the major axis alignment update to VGroup, HGroup, VerticalLayout, HorizontalLayout. It brings parity to the Flex 4 Spark layouts relative to the MX containers HBox and VBox that are well known from previous versions of Flex (and have had those alignment options for long time now). 
Now VGroup and VerticalLayout [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://evtimmy.com/wordpress/wp-content/uploads/2010/01/majoraxisalignment.swf"><img class="alignleft size-thumbnail wp-image-240" title="majoraxisalignment" src="http://evtimmy.com/wordpress/wp-content/uploads/2010/01/majoraxisalignment-150x150.png" alt="majoraxisalignment" width="150" height="150" /></a> Recently I checked in the major axis alignment update to <em>VGroup</em>, <em>HGroup</em>, <em>VerticalLayout</em>, <em>HorizontalLayout</em>. It brings parity to the Flex 4 Spark layouts relative to the MX containers <em>HBox</em> and <em>VBox </em>that are well known from previous versions of Flex (and have had those alignment options for long time now). <span id="more-239"></span></p>
<p>Now <em>VGroup </em>and <em>VerticalLayout </em>have a &#8220;<em>verticalAlign</em>&#8221; property with the three supported values of &#8220;<em>top</em>&#8220;, &#8220;<em>middle</em>&#8220;, &#8220;<em>bottom</em>&#8220;.  Accordingly <em>HGroup </em>and <em>HorizontalLayout </em>get a &#8220;<em>horizontalAlign</em>&#8221; property with the supported values of &#8220;<em>left</em>&#8220;, &#8220;<em>center</em>&#8221; and &#8220;<em>right</em>&#8220;.  The alignment modes work for the layouts with and without virtualization enabled.<br />
An important difference to note is that when &#8220;<em>clipAndEnableScrolling</em>&#8221; is set to &#8220;<em>true</em>&#8221; and the containers are scrolling (the content is bigger than the container), the Spark layouts ensure that the entire content can be scrolled in view by internally reverting to the &#8220;<em>top</em>&#8220;/&#8221;<em>left</em>&#8221; alignment respectively.</p>
<p>When playing with the attached sample, you&#8217;ll notice difference between the clipping and the non-clipping containers when scrolling is in effect (drag the slider left to force smaller height for the containers).</p>
<p>The sample was compiled with SDK version 4.0.0.13553, source: <a href="http://evtimmy.com/wordpress/wp-content/uploads/2010/01/majoraxisalignment.mxml">MajorAxisAlignment.mxml</a></p>
]]></content:encoded>
			<wfw:commentRss>http://evtimmy.com/2010/01/verticalalign-for-vgroup-and-horizontalalign-for-hgroup/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Drag and Drop Skinning in Spark</title>
		<link>http://evtimmy.com/2010/01/drag-and-drop-skinning-in-spark/</link>
		<comments>http://evtimmy.com/2010/01/drag-and-drop-skinning-in-spark/#comments</comments>
		<pubDate>Tue, 19 Jan 2010 06:16:04 +0000</pubDate>
		<dc:creator>Evtim</dc:creator>
				<category><![CDATA[drag and drop]]></category>
		<category><![CDATA[skinning]]></category>

		<guid isPermaLink="false">http://evtimmy.com/?p=198</guid>
		<description><![CDATA[
Customize the ItemRenderer&#8217;s &#8220;dragging&#8221; state.  The drag indicator is the image that the user sees when they select and item and drag it away from the source container. By default the Spark List creates a drag indicator by duplicating all the ItemRenderers for the items being dragged. Therefore a natural way to customize the drag [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://evtimmy.com/wordpress/wp-content/uploads/2010/01/dndlistskinning.swf"><img class="alignleft size-thumbnail wp-image-199" title="dndlistskinning" src="http://evtimmy.com/wordpress/wp-content/uploads/2010/01/dndlistskinning-150x150.png" alt="dndlistskinning" width="150" height="150" /></a></p>
<p><span style="color: #ff6600;">Customize the <em>ItemRenderer</em>&#8217;s &#8220;<em>dragging</em>&#8221; state</span>.  The <em>drag indicator</em> is the image that the user sees when they select and item and drag it away from the source container. By default the Spark List creates a <em>drag indicator</em> by duplicating all the <em>ItemRenderers </em>for the items being dragged. Therefore a natural way to customize the drag indicator is by customizing the <em>ItemRenderer </em>skin. Spark makes that easy by introducing the  optional &#8220;<em>dragging</em>&#8221; state.<br />
<span style="color: #ff6600;">Customize the <em>List</em>&#8217;s optional &#8220;<em>dropIndicator</em>&#8221; skin part</span>.  The <em>drop indicator</em> is the image that the user sees as an indicator of where the dragged items are going to be inserted in the destination container.  By default, the Spark List displays a horizontal/vertical line along the gap between the at the insertion point.  Spark makes that easy by automatically managing the &#8220;<em>dropIndicator</em>&#8221; optional dynamic skin part.</p>
<p><span id="more-198"></span></p>
<h2>Customize the Drag Indicator</h2>
<p>I&#8217;ll set up a custom ItemRenderer and I&#8217;ll flesh out the optional &#8220;dragging&#8221; state.<br />
CustomDraggingItemRenderer.mxml:</p>

<div class="wp_syntax"><div class="code"><pre class="mxml" style="font-family:monospace;"><span style="color: #000000;">&lt;?xml version=<span style="color: #ff0000;">&quot;1.0&quot;</span> encoding=<span style="color: #ff0000;">&quot;utf-8&quot;</span>?<span style="color: #7400FF;">&gt;</span></span>
<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:ItemRenderer</span> focusEnabled=<span style="color: #ff0000;">&quot;false&quot;</span> </span>
<span style="color: #000000;">				xmlns:fx=<span style="color: #ff0000;">&quot;http://ns.adobe.com/mxml/2009&quot;</span> </span>
<span style="color: #000000;">				xmlns:s=<span style="color: #ff0000;">&quot;library://ns.adobe.com/flex/spark&quot;</span><span style="color: #7400FF;">&gt;</span></span>
&nbsp;
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:states</span><span style="color: #7400FF;">&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;normal&quot;</span> <span style="color: #7400FF;">/&gt;</span></span>            
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;hovered&quot;</span> <span style="color: #7400FF;">/&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;selected&quot;</span> <span style="color: #7400FF;">/&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;normalAndShowsCaret&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;hoveredAndShowsCaret&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;selectedAndShowsCaret&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:State</span> name=<span style="color: #ff0000;">&quot;dragging&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:states</span><span style="color: #7400FF;">&gt;</span></span>
&nbsp;
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Rect</span> left=<span style="color: #ff0000;">&quot;0&quot;</span> right=<span style="color: #ff0000;">&quot;0&quot;</span> top=<span style="color: #ff0000;">&quot;0&quot;</span> bottom=<span style="color: #ff0000;">&quot;-1&quot;</span> includeIn=<span style="color: #ff0000;">&quot;dragging&quot;</span><span style="color: #7400FF;">&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:stroke</span><span style="color: #7400FF;">&gt;</span></span>
			<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:SolidColorStroke</span> color=<span style="color: #ff0000;">&quot;0xDDBBCC&quot;</span> weight=<span style="color: #ff0000;">&quot;1&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:stroke</span><span style="color: #7400FF;">&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:fill</span><span style="color: #7400FF;">&gt;</span></span>
			<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:SolidColor</span> color=<span style="color: #ff0000;">&quot;0x5010CC&quot;</span> alpha=<span style="color: #ff0000;">&quot;0.3&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
		<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:fill</span><span style="color: #7400FF;">&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:Rect</span><span style="color: #7400FF;">&gt;</span></span>
	<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Label</span> id=<span style="color: #ff0000;">&quot;labelDisplay&quot;</span> verticalCenter=<span style="color: #ff0000;">&quot;0&quot;</span> </span>
<span style="color: #000000;">			 left=<span style="color: #ff0000;">&quot;3&quot;</span> right=<span style="color: #ff0000;">&quot;3&quot;</span> top=<span style="color: #ff0000;">&quot;6&quot;</span> bottom=<span style="color: #ff0000;">&quot;4&quot;</span> </span>
<span style="color: #000000;">			 fontWeight.dragging=<span style="color: #ff0000;">&quot;bold&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
&nbsp;
<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:ItemRenderer</span><span style="color: #7400FF;">&gt;</span></span></pre></div></div>

<p>When the Spark List creates the duplicate ItemRenderes for the drag indicator, it will set them to their &#8220;dragging&#8221; state. Note that at that point the List&#8217;s data item will be rendered by two ItemRender instances &#8211; one to display the item in the List itself and one to display the item in the drag indicator.</p>
<h2>Customize the Drop Indicator</h2>
<p>I&#8217;ll set up a custom List skin. I&#8217;ll replace the &#8220;dropIndicator&#8221; skin part. Note that since the part is a dynamic part (created only during drag-and-drop operation) it&#8217;s placed inside the &lt;fx:Declarations/&gt; tag.<br />
CustomDropIndicatorListSkin.mxml:</p>

<div class="wp_syntax"><div class="code"><pre class="mxml" style="font-family:monospace;"> <span style="color: #000000;"><span style="color: #7400FF;">&lt;fx:Declarations</span><span style="color: #7400FF;">&gt;</span></span>
    <span style="color: #000000;"><span style="color: #808080; font-style: italic;">&lt;!--- </span>
<span style="color: #000000;">          Defines the appearance of the the List's drop indicator.</span>
<span style="color: #000000;">          To customize the drop indicator appearance, create a custom ListSkin class.</span>
<span style="color: #000000;">          The List's layout takes care to size and position the dropIndicator.</span>
<span style="color: #000000;">          The size of the &lt;code&gt;</span></span>dropIndicator<span style="color: #000000;">&lt;/code<span style="color: #7400FF;">&gt;</span></span> is typically set to the size of the 
          gaps between the items.
          The minimum and maximum settings are typically respected only in the direction
          along the major axis (the gap axis).  For example a VerticalLayout ignores the 
          <span style="color: #000000;">&lt;code<span style="color: #7400FF;">&gt;</span></span>minWidth<span style="color: #000000;">&lt;/code<span style="color: #7400FF;">&gt;</span></span> and <span style="color: #000000;">&lt;code<span style="color: #7400FF;">&gt;</span></span>maxWidth<span style="color: #000000;">&lt;/code<span style="color: #7400FF;">&gt;</span></span> settings, 
          but respect <span style="color: #000000;">&lt;code<span style="color: #7400FF;">&gt;</span></span>minHeight<span style="color: #000000;">&lt;/code<span style="color: #7400FF;">&gt;</span></span> and <span style="color: #000000;">&lt;code<span style="color: #7400FF;">&gt;</span></span>maxHeight<span style="color: #000000;">&lt;/code<span style="color: #7400FF;">&gt;</span></span>. 
&nbsp;
          @copy spark.components.List#dropIndicator
    --&gt;
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;fx:Component</span> id=<span style="color: #ff0000;">&quot;dropIndicator&quot;</span><span style="color: #7400FF;">&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Group</span> minWidth=<span style="color: #ff0000;">&quot;3&quot;</span> minHeight=<span style="color: #ff0000;">&quot;3&quot;</span> maxWidth=<span style="color: #ff0000;">&quot;3&quot;</span> maxHeight=<span style="color: #ff0000;">&quot;3&quot;</span><span style="color: #7400FF;">&gt;</span></span>
			<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Line</span> width=<span style="color: #ff0000;">&quot;20&quot;</span> left=<span style="color: #ff0000;">&quot;3&quot;</span> verticalCenter=<span style="color: #ff0000;">&quot;2&quot;</span><span style="color: #7400FF;">&gt;</span></span>
				<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:stroke</span><span style="color: #7400FF;">&gt;</span></span>
					<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:SolidColorStroke</span> color=<span style="color: #ff0000;">&quot;0xFF0000&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
				<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:stroke</span><span style="color: #7400FF;">&gt;</span></span>
			<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:Line</span><span style="color: #7400FF;">&gt;</span></span>
&nbsp;
			<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:Path</span> left=<span style="color: #ff0000;">&quot;50&quot;</span> verticalCenter=<span style="color: #ff0000;">&quot;-2&quot;</span> scaleX=<span style="color: #ff0000;">&quot;-1&quot;</span> </span>
<span style="color: #000000;">					data=<span style="color: #ff0000;">&quot;M 0 5 L 30 5 26 0 40 8 26 16 30 11 0 11 Z&quot;</span><span style="color: #7400FF;">&gt;</span></span>
				<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:stroke</span><span style="color: #7400FF;">&gt;</span></span>
					<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:LinearGradientStroke</span> rotation=<span style="color: #ff0000;">&quot;5&quot;</span> weight=<span style="color: #ff0000;">&quot;1&quot;</span><span style="color: #7400FF;">&gt;</span></span>
						<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:GradientEntry</span> color=<span style="color: #ff0000;">&quot;0xD8D8D8&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
						<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:GradientEntry</span> color=<span style="color: #ff0000;">&quot;0x000000&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
					<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:LinearGradientStroke</span><span style="color: #7400FF;">&gt;</span></span>
				<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:stroke</span><span style="color: #7400FF;">&gt;</span></span>
				<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:fill</span><span style="color: #7400FF;">&gt;</span></span>
					<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:LinearGradient</span> rotation=<span style="color: #ff0000;">&quot;90&quot;</span><span style="color: #7400FF;">&gt;</span></span>
						<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:GradientEntry</span> color=<span style="color: #ff0000;">&quot;0xD8D8D8&quot;</span> <span style="color: #7400FF;">/&gt;</span></span>
						<span style="color: #000000;"><span style="color: #7400FF;">&lt;s:GradientEntry</span> color=<span style="color: #ff0000;">&quot;0x888888&quot;</span> <span style="color: #7400FF;">/&gt;</span></span>
					<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:LinearGradient</span><span style="color: #7400FF;">&gt;</span></span>
				<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:fill</span><span style="color: #7400FF;">&gt;</span></span>
			<span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:Path</span><span style="color: #7400FF;">&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:Group</span><span style="color: #7400FF;">&gt;</span></span>
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;/fx:Component</span><span style="color: #7400FF;">&gt;</span></span>
<span style="color: #000000;"><span style="color: #7400FF;">&lt;/fx:Declarations</span><span style="color: #7400FF;">&gt;</span></span></pre></div></div>

<p>Click on the image at the top of the page to see the example in action. The sources are available <a href='http://evtimmy.com/wordpress/wp-content/uploads/2010/01/dndlistskinning.zip'>here</a>. The example was compiled with the Gumbo Flex SDK build 13553.</p>
]]></content:encoded>
			<wfw:commentRss>http://evtimmy.com/2010/01/drag-and-drop-skinning-in-spark/feed/</wfw:commentRss>
		<slash:comments>13</slash:comments>
		</item>
		<item>
		<title>Calculating the Projected Bounds using Utils3D.projectVector()</title>
		<link>http://evtimmy.com/2009/12/calculating-the-projected-bounds-using-utils3dprojectvector/</link>
		<comments>http://evtimmy.com/2009/12/calculating-the-projected-bounds-using-utils3dprojectvector/#comments</comments>
		<pubDate>Tue, 15 Dec 2009 07:23:47 +0000</pubDate>
		<dc:creator>Evtim</dc:creator>
				<category><![CDATA[3D]]></category>
		<category><![CDATA[bounds]]></category>
		<category><![CDATA[perspectiveProjection]]></category>
		<category><![CDATA[Utils3D]]></category>

		<guid isPermaLink="false">http://evtimmy.com/?p=173</guid>
		<description><![CDATA[If you are playing with objects in 3D and want their projected bounds, there&#8217;s a neat flash functionality for that &#8211; Utils3D.projectVector(). However it may not be that apparent how to use it. Here I&#8217;m showing a small helper function that does the trick.
The projectVector() method actually takes a Matrix3D for a parameter. Note that [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://evtimmy.com/wordpress/wp-content/uploads/2009/12/projectedbounds.swf"><img class="size-full wp-image-178 alignleft" title="projectedbounds" src="http://evtimmy.com/wordpress/wp-content/uploads/2009/12/projectedbounds.png" alt="projectedbounds" width="142" height="124" /></a>If you are playing with objects in 3D and want their projected bounds, there&#8217;s a neat flash functionality for that &#8211; Utils3D.projectVector(). However it may not be that apparent how to use it. Here I&#8217;m showing a small helper function that does the trick.<br />
<span id="more-173"></span>The projectVector() method actually takes a Matrix3D for a parameter. Note that here you should pass in the Matrix3D of the object in question combined with the perspective projection of its parent. This is not as trivial as it seems, as you&#8217;d need to also translate by the projectionCenter and the focalLength:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>16
17
18
19
20
</pre></td><td class="code"><pre class="actionscript3" style="font-family:monospace;"><span style="color: #009900; font-style: italic;">// Setup the matrix</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> centerX<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = projection<span style="color: #000066; font-weight: bold;">.</span>projectionCenter<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> centerY<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = projection<span style="color: #000066; font-weight: bold;">.</span>projectionCenter<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #004993;">matrix</span><span style="color: #000066; font-weight: bold;">.</span>appendTranslation<span style="color: #000000;">&#40;</span><span style="color: #000066; font-weight: bold;">-</span>centerX<span style="color: #000066; font-weight: bold;">,</span> <span style="color: #000066; font-weight: bold;">-</span>centerY<span style="color: #000066; font-weight: bold;">,</span> projection<span style="color: #000066; font-weight: bold;">.</span>focalLength<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #004993;">matrix</span><span style="color: #000066; font-weight: bold;">.</span>append<span style="color: #000000;">&#40;</span>projection<span style="color: #000066; font-weight: bold;">.</span>toMatrix3D<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span></pre></td></tr></table></div>

<p>After that just pass in the matrix and the point to be projected to Utils3D.projectVector(). Then translate the result by centerX and centerY.<br />
Here&#8217;s the helper function source, it takes in bounds, the matrix of the object and the perspective projection and returns the projected 2D bounds:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
</pre></td><td class="code"><pre class="actionscript3" style="font-family:monospace;"><span style="color: #0033ff; font-weight: bold;">public</span> static <span style="color: #339966; font-weight: bold;">function</span> projectBounds<span style="color: #000000;">&#40;</span>bounds<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Rectangle</span><span style="color: #000066; font-weight: bold;">,</span>
 <span style="color: #004993;">matrix</span><span style="color: #000066; font-weight: bold;">:</span>Matrix3D<span style="color: #000066; font-weight: bold;">,</span>
 projection<span style="color: #000066; font-weight: bold;">:</span>PerspectiveProjection<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Rectangle</span>
 <span style="color: #000000;">&#123;</span>
 <span style="color: #009900; font-style: italic;">// Setup the matrix</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> centerX<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = projection<span style="color: #000066; font-weight: bold;">.</span>projectionCenter<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> centerY<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = projection<span style="color: #000066; font-weight: bold;">.</span>projectionCenter<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #004993;">matrix</span><span style="color: #000066; font-weight: bold;">.</span>appendTranslation<span style="color: #000000;">&#40;</span><span style="color: #000066; font-weight: bold;">-</span>centerX<span style="color: #000066; font-weight: bold;">,</span> <span style="color: #000066; font-weight: bold;">-</span>centerY<span style="color: #000066; font-weight: bold;">,</span> projection<span style="color: #000066; font-weight: bold;">.</span>focalLength<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #004993;">matrix</span><span style="color: #000066; font-weight: bold;">.</span>append<span style="color: #000000;">&#40;</span>projection<span style="color: #000066; font-weight: bold;">.</span>toMatrix3D<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
<span style="color: #009900; font-style: italic;">// Project the corner points</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> pt1<span style="color: #000066; font-weight: bold;">:</span>Vector3D = <span style="color: #0033ff; font-weight: bold;">new</span> Vector3D<span style="color: #000000;">&#40;</span>bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">left</span><span style="color: #000066; font-weight: bold;">,</span> bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">top</span><span style="color: #000066; font-weight: bold;">,</span> 0<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> pt2<span style="color: #000066; font-weight: bold;">:</span>Vector3D = <span style="color: #0033ff; font-weight: bold;">new</span> Vector3D<span style="color: #000000;">&#40;</span>bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">right</span><span style="color: #000066; font-weight: bold;">,</span> bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">top</span><span style="color: #000066; font-weight: bold;">,</span> 0<span style="color: #000000;">&#41;</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> pt3<span style="color: #000066; font-weight: bold;">:</span>Vector3D = <span style="color: #0033ff; font-weight: bold;">new</span> Vector3D<span style="color: #000000;">&#40;</span>bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">left</span><span style="color: #000066; font-weight: bold;">,</span> bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">bottom</span><span style="color: #000066; font-weight: bold;">,</span> 0<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> pt4<span style="color: #000066; font-weight: bold;">:</span>Vector3D = <span style="color: #0033ff; font-weight: bold;">new</span> Vector3D<span style="color: #000000;">&#40;</span>bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">right</span><span style="color: #000066; font-weight: bold;">,</span> bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">bottom</span><span style="color: #000066; font-weight: bold;">,</span> 0<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 pt1 = Utils3D<span style="color: #000066; font-weight: bold;">.</span>projectVector<span style="color: #000000;">&#40;</span><span style="color: #004993;">matrix</span><span style="color: #000066; font-weight: bold;">,</span> pt1<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 pt2 = Utils3D<span style="color: #000066; font-weight: bold;">.</span>projectVector<span style="color: #000000;">&#40;</span><span style="color: #004993;">matrix</span><span style="color: #000066; font-weight: bold;">,</span> pt2<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 pt3 = Utils3D<span style="color: #000066; font-weight: bold;">.</span>projectVector<span style="color: #000000;">&#40;</span><span style="color: #004993;">matrix</span><span style="color: #000066; font-weight: bold;">,</span> pt3<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 pt4 = Utils3D<span style="color: #000066; font-weight: bold;">.</span>projectVector<span style="color: #000000;">&#40;</span><span style="color: #004993;">matrix</span><span style="color: #000066; font-weight: bold;">,</span> pt4<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
<span style="color: #009900; font-style: italic;">// Find the bounding box in 2D</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> maxX<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">max</span><span style="color: #000000;">&#40;</span><span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">max</span><span style="color: #000000;">&#40;</span>pt1<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000066; font-weight: bold;">,</span> pt2<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">,</span> <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">max</span><span style="color: #000000;">&#40;</span>pt3<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000066; font-weight: bold;">,</span> pt4<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000000;">&#41;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> minX<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">min</span><span style="color: #000000;">&#40;</span><span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">min</span><span style="color: #000000;">&#40;</span>pt1<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000066; font-weight: bold;">,</span> pt2<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">,</span> <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">min</span><span style="color: #000000;">&#40;</span>pt3<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000066; font-weight: bold;">,</span> pt4<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span><span style="color: #000000;">&#41;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> maxY<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">max</span><span style="color: #000000;">&#40;</span><span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">max</span><span style="color: #000000;">&#40;</span>pt1<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000066; font-weight: bold;">,</span> pt2<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">,</span> <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">max</span><span style="color: #000000;">&#40;</span>pt3<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000066; font-weight: bold;">,</span> pt4<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000000;">&#41;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #6699cc; font-weight: bold;">var</span> minY<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">min</span><span style="color: #000000;">&#40;</span><span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">min</span><span style="color: #000000;">&#40;</span>pt1<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000066; font-weight: bold;">,</span> pt2<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">,</span> <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">min</span><span style="color: #000000;">&#40;</span>pt3<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000066; font-weight: bold;">,</span> pt4<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span><span style="color: #000000;">&#41;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
<span style="color: #009900; font-style: italic;">// Add back the projection center</span>
 bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">x</span> = minX <span style="color: #000066; font-weight: bold;">+</span> centerX<span style="color: #000066; font-weight: bold;">;</span>
 bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">y</span> = minY <span style="color: #000066; font-weight: bold;">+</span> centerY<span style="color: #000066; font-weight: bold;">;</span>
 bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">width</span> = maxX <span style="color: #000066; font-weight: bold;">-</span> minX<span style="color: #000066; font-weight: bold;">;</span>
 bounds<span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">height</span> = maxY <span style="color: #000066; font-weight: bold;">-</span> minY<span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #0033ff; font-weight: bold;">return</span> bounds<span style="color: #000066; font-weight: bold;">;</span>
 <span style="color: #000000;">&#125;</span></pre></td></tr></table></div>

<p>The full source is here <a href='http://evtimmy.com/wordpress/wp-content/uploads/2009/12/projectedbounds.mxml'>projectedbounds.mxml</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://evtimmy.com/2009/12/calculating-the-projected-bounds-using-utils3dprojectvector/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Spark Layouts with Flex 4 Beta</title>
		<link>http://evtimmy.com/2009/10/spark-layouts-with-flex-4-beta/</link>
		<comments>http://evtimmy.com/2009/10/spark-layouts-with-flex-4-beta/#comments</comments>
		<pubDate>Sun, 11 Oct 2009 19:14:10 +0000</pubDate>
		<dc:creator>Evtim</dc:creator>
				<category><![CDATA[Uncategorized]]></category>

		<guid isPermaLink="false">http://evtimmy.com/?p=153</guid>
		<description><![CDATA[Just a quick post to link to my layouts  article on the Adobe dev connection. It uses the same FlowLayout as an example, so no surprises in that department. Check it out, comments and feedback greatly appreciated.
]]></description>
			<content:encoded><![CDATA[<p>Just a quick post to link to my layouts  <a href="http://www.adobe.com/devnet/flex/articles/spark_layouts.html">article</a> on the Adobe dev connection. It uses the same FlowLayout as an example, so no surprises in that department. Check it out, comments and feedback greatly appreciated.</p>
]]></content:encoded>
			<wfw:commentRss>http://evtimmy.com/2009/10/spark-layouts-with-flex-4-beta/feed/</wfw:commentRss>
		<slash:comments>18</slash:comments>
		</item>
		<item>
		<title>WheelLayout Source and Quick Mashup</title>
		<link>http://evtimmy.com/2009/06/wheellayout-source-and-quick-mashup/</link>
		<comments>http://evtimmy.com/2009/06/wheellayout-source-and-quick-mashup/#comments</comments>
		<pubDate>Fri, 26 Jun 2009 07:38:24 +0000</pubDate>
		<dc:creator>Evtim</dc:creator>
				<category><![CDATA[Custom Layout]]></category>
		<category><![CDATA[Quick mash-up]]></category>
		<category><![CDATA[3D]]></category>
		<category><![CDATA[Flickr]]></category>
		<category><![CDATA[WheelLayout]]></category>

		<guid isPermaLink="false">http://evtimmy.com/?p=136</guid>
		<description><![CDATA[A few folks have been asking for the source code of the WheelLayout. I created it as a proof-of-concept that our Spark layout APIs are sufficient for creation of 3D layouts. And just to showcase it in action, I decided to grab quickly the Flex3 Halo FlickrRIA, port it to Flex 4, and mash it [...]]]></description>
			<content:encoded><![CDATA[<p>A few folks have been asking for the source code of the WheelLayout. I created it as a proof-of-concept that our Spark layout APIs are sufficient for creation of 3D layouts. And just to showcase it in action, I decided to grab quickly the Flex3 Halo <a href="http://learn.adobe.com/wiki/display/Flex/1d.+RIA+Tutorial">FlickrRIA</a>, port it to Flex 4, and mash it up with the WheelLayout.</p>
<p><a href="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/flickrriamodified1.swf"><img class="alignnone size-thumbnail wp-image-166" title="wheellayout" src="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/wheellayout-150x150.png" alt="wheellayout" width="150" height="150" /></a></p>
<p><span id="more-136"></span><em>This example was compiled with the now oldish 4.0.0.7052 Flex SDK build. </em></p>
<p>The source code that I used is <a href="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/flickriaandwheellayout.zip">here</a>. I’ve actually checked it in our flex4test project and therefore the up-to-date source is available from this <a href="http://opensource.adobe.com/svn/opensource/flex/sdk/trunk/development/eclipse/flex/sparkTest/src/testWheel.mxml">location</a> (of course it’s outside of the SDK, so it’s not supported <img src='http://evtimmy.com/wordpress/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> )<br />
<em></em></p>
]]></content:encoded>
			<wfw:commentRss>http://evtimmy.com/2009/06/wheellayout-source-and-quick-mashup/feed/</wfw:commentRss>
		<slash:comments>8</slash:comments>
		</item>
		<item>
		<title>Check Out Hans&#8217;s Article on Spark Viewports and Scrolling</title>
		<link>http://evtimmy.com/2009/06/check-out-hans-article-on-spark-viewports-and-scrolling/</link>
		<comments>http://evtimmy.com/2009/06/check-out-hans-article-on-spark-viewports-and-scrolling/#comments</comments>
		<pubDate>Fri, 19 Jun 2009 21:56:07 +0000</pubDate>
		<dc:creator>Evtim</dc:creator>
				<category><![CDATA[Uncategorized]]></category>

		<guid isPermaLink="false">http://evtimmy.com/?p=128</guid>
		<description><![CDATA[Just a quick note that Hans Muller has started a seriese  of articles regarding Flex on his blog. His spiffy article  here  has some very good info about the Spark Viewports and Scrolling  
Also you can check out how little I had to do to implement scrolling support in a custom layout here.
Enjoy!
]]></description>
			<content:encoded><![CDATA[<p>Just a quick note that Hans Muller has started a seriese  of articles regarding Flex on his blog. His spiffy article  <a href="http://hansmuller-flex.blogspot.com/2009/06/introduction-to-viewports-and-scrolling.html">here</a>  has some very good info about the Spark Viewports and Scrolling <img src='http://evtimmy.com/wordpress/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>Also you can check out how little I had to do to implement scrolling support in a custom layout <a href="http://evtimmy.com/2009/06/flowlayout-part-2-gap-verticalalign-and-scrolling/">here</a>.</p>
<p>Enjoy!</p>
]]></content:encoded>
			<wfw:commentRss>http://evtimmy.com/2009/06/check-out-hans-article-on-spark-viewports-and-scrolling/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>FlowLayout Part 2 &#8211; Gap, VerticalAlign and Scrolling</title>
		<link>http://evtimmy.com/2009/06/flowlayout-part-2-gap-verticalalign-and-scrolling/</link>
		<comments>http://evtimmy.com/2009/06/flowlayout-part-2-gap-verticalalign-and-scrolling/#comments</comments>
		<pubDate>Thu, 11 Jun 2009 06:53:39 +0000</pubDate>
		<dc:creator>Evtim</dc:creator>
				<category><![CDATA[Custom Layout]]></category>
		<category><![CDATA[Flex 4]]></category>
		<category><![CDATA[Layout]]></category>
		<category><![CDATA[Scrolling]]></category>
		<category><![CDATA[Spark]]></category>

		<guid isPermaLink="false">http://evtimmy.com/?p=80</guid>
		<description><![CDATA[In part one here, the FlowLayout had really basic functionality.  I decided to demonstrate how to add layout properties to the custom Spark layouts and how to enable scrolling.]]></description>
			<content:encoded><![CDATA[<p>In part one <a href="http://evtimmy.com/?p=3">here</a>, the FlowLayout had really basic functionality.  I decided to demonstrate how to add layout properties to the custom Spark layouts and how to enable scrolling.</p>
<p><span id="more-80"></span>Let me show off the end result first:</p>

    <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" id="swfobj_0" width="400" height="300" align="center">
      <param name="movie" value="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/flowtest-props-and-scrolling2.swf" />
      <param name="align" value="center" />
      <!--[if !IE]>-->
      <object type="application/x-shockwave-flash" data="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/flowtest-props-and-scrolling2.swf" width="400" height="300" align="center">
      <!--<![endif]-->
        <p>The Flash plugin is required to view this object.</p>
      <!--[if !IE]>-->
      </object>
      <!--<![endif]-->
    </object>

<p>And the source code is available <a href="http://evtimmy.com/wordpress/wp-content/uploads/2009/10/flowtestpropsandscrolling2.zip">here</a>.</p>
<p><em>Update: The source has been updated to compile with Flash Builder / Flex SDK beta 2. I also added a horizontalAlign property, just because I can =)</em></p>
<h3>Adding a Layout Property</h3>
<p>I want to implement two properties &#8211; a horizontalGap for between the elements within a row, and verticalAlign which will control how the elements within the row are aligned. For the latter, I&#8217;ll have &#8220;top&#8221;, &#8220;middle&#8221; and &#8220;bottom&#8221; as options, and of course I&#8217;ll have to beef up the FlowLayout to support elements with various heights.</p>
<p>I&#8217;ll add the properties directly to the FlowLayout class. When the value changes, I need to invalidate the container which will cause the layout to run its updateDisplayList() and at that point I&#8217;ll take into account the new values:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
</pre></td><td class="code"><pre class="actionscript3" style="font-family:monospace;">    <span style="color: #009900; font-style: italic;">//---------------------------------------------------------------</span>
    <span style="color: #009900; font-style: italic;">//  horizontalGap</span>
    <span style="color: #009900; font-style: italic;">//---------------------------------------------------------------</span>
&nbsp;
    <span style="color: #0033ff; font-weight: bold;">private</span> <span style="color: #6699cc; font-weight: bold;">var</span> _horizontalGap<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = <span style="color: #000000; font-weight:bold;">10</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
    <span style="color: #0033ff; font-weight: bold;">public</span> <span style="color: #339966; font-weight: bold;">function</span> <span style="color: #0033ff; font-weight: bold;">set</span> horizontalGap<span style="color: #000000;">&#40;</span><span style="color: #004993;">value</span><span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">:</span><span style="color: #0033ff; font-weight: bold;">void</span>
    <span style="color: #000000;">&#123;</span>
        _horizontalGap = <span style="color: #004993;">value</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
        <span style="color: #009900; font-style: italic;">// We must invalidate the layout</span>
        <span style="color: #6699cc; font-weight: bold;">var</span> layoutTarget<span style="color: #000066; font-weight: bold;">:</span>GroupBase = <span style="color: #004993;">target</span><span style="color: #000066; font-weight: bold;">;</span>
        <span style="color: #0033ff; font-weight: bold;">if</span> <span style="color: #000000;">&#40;</span>layoutTarget<span style="color: #000000;">&#41;</span>
            layoutTarget<span style="color: #000066; font-weight: bold;">.</span>invalidateDisplayList<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
    <span style="color: #000000;">&#125;</span>
&nbsp;
    <span style="color: #009900; font-style: italic;">//---------------------------------------------------------------</span>
    <span style="color: #009900; font-style: italic;">//  verticalAlign</span>
    <span style="color: #009900; font-style: italic;">//---------------------------------------------------------------</span>
&nbsp;
    <span style="color: #0033ff; font-weight: bold;">private</span> <span style="color: #6699cc; font-weight: bold;">var</span> _verticalAlign<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">String</span> = <span style="color: #990000;">&quot;bottom&quot;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
    <span style="color: #0033ff; font-weight: bold;">public</span> <span style="color: #339966; font-weight: bold;">function</span> <span style="color: #0033ff; font-weight: bold;">set</span> verticalAlign<span style="color: #000000;">&#40;</span><span style="color: #004993;">value</span><span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">String</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">:</span><span style="color: #0033ff; font-weight: bold;">void</span>
    <span style="color: #000000;">&#123;</span>
        _verticalAlign = <span style="color: #004993;">value</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
        <span style="color: #009900; font-style: italic;">// We must invalidate the layout</span>
        <span style="color: #6699cc; font-weight: bold;">var</span> layoutTarget<span style="color: #000066; font-weight: bold;">:</span>GroupBase = <span style="color: #004993;">target</span><span style="color: #000066; font-weight: bold;">;</span>
        <span style="color: #0033ff; font-weight: bold;">if</span> <span style="color: #000000;">&#40;</span>layoutTarget<span style="color: #000000;">&#41;</span>
            layoutTarget<span style="color: #000066; font-weight: bold;">.</span>invalidateDisplayList<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
    <span style="color: #000000;">&#125;</span></pre></td></tr></table></div>

<p>Then I will add a drop-down and a slider in the flowTest.mxml to configure the the properties like this:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
</pre></td><td class="code"><pre class="mxml" style="font-family:monospace;">    <span style="color: #000000;"><span style="color: #808080; font-style: italic;">&lt;!-- The slider to control the horizontal gap --&gt;</span></span>
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:HSlider</span> id=<span style="color: #ff0000;">&quot;hGapSlider&quot;</span> minimum=<span style="color: #ff0000;">&quot;0&quot;</span> maximum=<span style="color: #ff0000;">&quot;50&quot;</span></span>
<span style="color: #000000;">                         value=<span style="color: #ff0000;">&quot;10&quot;</span> liveDragging=<span style="color: #ff0000;">&quot;true&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
&nbsp;
    <span style="color: #000000;"><span style="color: #808080; font-style: italic;">&lt;!-- The drop-down to select vertical alignment --&gt;</span></span>
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:DropDownList</span> id=<span style="color: #ff0000;">&quot;vAlign&quot;</span> requiresSelection=<span style="color: #ff0000;">&quot;true&quot;</span><span style="color: #7400FF;">&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:ArrayCollection</span><span style="color: #7400FF;">&gt;</span></span>
            <span style="color: #000000;"><span style="color: #7400FF;">&lt;fx:String</span><span style="color: #7400FF;">&gt;</span></span>bottom<span style="color: #000000;"><span style="color: #7400FF;">&lt;/fx:String</span><span style="color: #7400FF;">&gt;</span></span>
            <span style="color: #000000;"><span style="color: #7400FF;">&lt;fx:String</span><span style="color: #7400FF;">&gt;</span></span>middle<span style="color: #000000;"><span style="color: #7400FF;">&lt;/fx:String</span><span style="color: #7400FF;">&gt;</span></span>
            <span style="color: #000000;"><span style="color: #7400FF;">&lt;fx:String</span><span style="color: #7400FF;">&gt;</span></span>top<span style="color: #000000;"><span style="color: #7400FF;">&lt;/fx:String</span><span style="color: #7400FF;">&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:ArrayCollection</span><span style="color: #7400FF;">&gt;</span></span>
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:DropDownList</span><span style="color: #7400FF;">&gt;</span></span>                         
&nbsp;
    <span style="color: #000000;"><span style="color: #808080; font-style: italic;">&lt;!-- A Spark List --&gt;</span></span>
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:List</span> id=<span style="color: #ff0000;">&quot;list1&quot;</span> width=<span style="color: #ff0000;">&quot;{widthSlider.value}&quot;</span></span>
<span style="color: #000000;">            selectedIndex=<span style="color: #ff0000;">&quot;7&quot;</span></span>
<span style="color: #000000;">            dataProvider=<span style="color: #ff0000;">&quot;{new ArrayCollection(</span>
<span style="color: #000000;">            'The quick fox jumped over the lazy sleepy\n\dog'.split(' '))}&quot;</span><span style="color: #7400FF;">&gt;</span></span>
&nbsp;
        <span style="color: #000000;"><span style="color: #808080; font-style: italic;">&lt;!-- Configure the layout to be the FlowLayout --&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;s:layout</span><span style="color: #7400FF;">&gt;</span></span>
            <span style="color: #000000;"><span style="color: #7400FF;">&lt;my:FlowLayout</span><span style="color: #cc66cc;">1</span> verticalAlign=<span style="color: #ff0000;">&quot;{vAlign.selectedItem}&quot;</span></span>
<span style="color: #000000;">                            horizontalGap=<span style="color: #ff0000;">&quot;{hGapSlider.value}&quot;</span><span style="color: #7400FF;">/&gt;</span></span>
        <span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:layout</span><span style="color: #7400FF;">&gt;</span></span>
    <span style="color: #000000;"><span style="color: #7400FF;">&lt;/s:List</span><span style="color: #7400FF;">&gt;</span></span></pre></td></tr></table></div>

<p>Then the harder part &#8211; actually implementing the support for these properties in the FlowLayout&#8217;s updateDisplayList() method.  Since I&#8217;ll need to know the row height before I can decide how to position the elements, I&#8217;ll have to replace my original loop with a little more complicated code, something along the lines of:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
</pre></td><td class="code"><pre class="actionscript3" style="font-family:monospace;">        <span style="color: #009900; font-style: italic;">// loop through the elements</span>
        <span style="color: #009900; font-style: italic;">// while we can start a new row</span>
        <span style="color: #6699cc; font-weight: bold;">var</span> rowStart<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">int</span> = <span style="color: #000000; font-weight:bold;">0</span><span style="color: #000066; font-weight: bold;">;</span>
        <span style="color: #0033ff; font-weight: bold;">while</span> <span style="color: #000000;">&#40;</span>rowStart <span style="color: #000066; font-weight: bold;">&lt;</span> count<span style="color: #000000;">&#41;</span>
        <span style="color: #000000;">&#123;</span>
            <span style="color: #009900; font-style: italic;">// The row always contains the start element</span>
            element = layoutTarget<span style="color: #000066; font-weight: bold;">.</span>getElementAt<span style="color: #000000;">&#40;</span>rowStart<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
            <span style="color: #6699cc; font-weight: bold;">var</span> rowWidth<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> = element<span style="color: #000066; font-weight: bold;">.</span>getPreferredBoundsWidth<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
            <span style="color: #6699cc; font-weight: bold;">var</span> rowHeight<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">Number</span> =  element<span style="color: #000066; font-weight: bold;">.</span>getPreferredBoundsHeight<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
            <span style="color: #009900; font-style: italic;">// Find the end of the current row</span>
            <span style="color: #6699cc; font-weight: bold;">var</span> rowEnd<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">int</span> = rowStart<span style="color: #000066; font-weight: bold;">;</span>
            <span style="color: #0033ff; font-weight: bold;">while</span> <span style="color: #000000;">&#40;</span>rowEnd <span style="color: #000066; font-weight: bold;">+</span> 1 <span style="color: #000066; font-weight: bold;">&lt;</span> count<span style="color: #000000;">&#41;</span>
            <span style="color: #000000;">&#123;</span>
                element = layoutTarget<span style="color: #000066; font-weight: bold;">.</span>getElementAt<span style="color: #000000;">&#40;</span>rowEnd <span style="color: #000066; font-weight: bold;">+</span> 1<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
                <span style="color: #009900; font-style: italic;">// Since we haven't resized the element just yet, get its preferred size</span>
                elementWidth = element<span style="color: #000066; font-weight: bold;">.</span>getPreferredBoundsWidth<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
                elementHeight = element<span style="color: #000066; font-weight: bold;">.</span>getPreferredBoundsHeight<span style="color: #000000;">&#40;</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
                <span style="color: #009900; font-style: italic;">// Can we add one more element to this row?</span>
                <span style="color: #0033ff; font-weight: bold;">if</span> <span style="color: #000000;">&#40;</span>rowWidth <span style="color: #000066; font-weight: bold;">+</span> hGap <span style="color: #000066; font-weight: bold;">+</span> elementWidth <span style="color: #000066; font-weight: bold;">&gt;</span> containerWidth<span style="color: #000000;">&#41;</span>
                    <span style="color: #0033ff; font-weight: bold;">break</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
                rowWidth <span style="color: #000066; font-weight: bold;">+</span>= hGap <span style="color: #000066; font-weight: bold;">+</span> elementWidth<span style="color: #000066; font-weight: bold;">;</span>
                rowHeight = <span style="color: #004993;">Math</span><span style="color: #000066; font-weight: bold;">.</span><span style="color: #004993;">max</span><span style="color: #000000;">&#40;</span>rowHeight<span style="color: #000066; font-weight: bold;">,</span> elementHeight<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
                rowEnd<span style="color: #000066; font-weight: bold;">++;</span>
            <span style="color: #000000;">&#125;</span>
&nbsp;
            <span style="color: #009900; font-style: italic;">// Layout all the elements within the row</span>
            <span style="color: #0033ff; font-weight: bold;">for</span> <span style="color: #000000;">&#40;</span><span style="color: #6699cc; font-weight: bold;">var</span> i<span style="color: #000066; font-weight: bold;">:</span><span style="color: #004993;">int</span> = rowStart<span style="color: #000066; font-weight: bold;">;</span> i <span style="color: #000066; font-weight: bold;">&lt;</span>= rowEnd<span style="color: #000066; font-weight: bold;">;</span> i<span style="color: #000066; font-weight: bold;">++</span><span style="color: #000000;">&#41;</span>
            <span style="color: #000000;">&#123;</span>
                element = layoutTarget<span style="color: #000066; font-weight: bold;">.</span>getElementAt<span style="color: #000000;">&#40;</span>i<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
                <span style="color: #000066; font-weight: bold;">...</span>
                <span style="color: #009900; font-style: italic;">// Position the element</span>
                element<span style="color: #000066; font-weight: bold;">.</span>setLayoutBoundsPosition<span style="color: #000000;">&#40;</span><span style="color: #004993;">x</span><span style="color: #000066; font-weight: bold;">,</span> <span style="color: #004993;">y</span> <span style="color: #000066; font-weight: bold;">+</span> elementY<span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span>
            <span style="color: #000000;">&#125;</span>
&nbsp;
            <span style="color: #009900; font-style: italic;">// Next row will start with the first element after the current row's end</span>
            rowStart = rowEnd <span style="color: #000066; font-weight: bold;">+</span> <span style="color: #000000; font-weight:bold;">1</span><span style="color: #000066; font-weight: bold;">;</span>
&nbsp;
            <span style="color: #009900; font-style: italic;">// Update the position to the beginning of the row</span>
            <span style="color: #000066; font-weight: bold;">...</span>
        <span style="color: #000000;">&#125;</span></pre></td></tr></table></div>

<h3>Enabling Scrolling</h3>
<p>Now I&#8217;m almost done, but I want the FlowLayout to be scrollable. In theory this would mean that I need do the following steps:</p>
<ol>
<li> Add scroll-bars.</li>
<li>Hook up the scroll-bars with the layout&#8217;s horizontalScrollPosition and verticalScrollPosition properties.</li>
<li>Calculate the ranges for the scroll-bars and keep them in sync whenever the values change.</li>
</ol>
<p>In practice, I can save a lot of work by using a ready stock Spark component &#8211; the Scroller. Without going into too much details, the Scroller can wrap a container and automatically put up scroll-bars, keeping everything in sync with the container&#8217;s layout.  And since in my flowTest.mxml I&#8217;m using a List, the Scroller is already in there!!! It&#8217;s a part of the List default skin <img src='http://evtimmy.com/wordpress/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' />   Now all that&#8217;s left to do for me is actually calculate the ranges for the scroll bars. This is basically the total width and height of the scrollable area of the container a.k.a. the &#8220;content size&#8221;.</p>
<p>Calculating the content size is easy enough &#8211; I&#8217;ll just find the maximum extents of all the children while I&#8217;m resizing and arranging them in the FlowLayout&#8217;s updateDisplayList(). At the very end of that method I&#8217;ll set the updated content size like this:</p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>144
145
146
147
</pre></td><td class="code"><pre class="actionscript3" style="font-family:monospace;">        <span style="color: #009900; font-style: italic;">// Set the content size which determines the scrolling limits</span>
        <span style="color: #009900; font-style: italic;">// and is used by the Scroller to calculate whether to show up</span>
        <span style="color: #009900; font-style: italic;">// the scrollbars when the the scroll policy is set to &quot;auto&quot;</span>
        layoutTarget<span style="color: #000066; font-weight: bold;">.</span>setContentSize<span style="color: #000000;">&#40;</span>maxRowWidth<span style="color: #000066; font-weight: bold;">,</span> <span style="color: #004993;">y</span><span style="color: #000000;">&#41;</span><span style="color: #000066; font-weight: bold;">;</span></pre></td></tr></table></div>

<p>That&#8217;s it!</p>
]]></content:encoded>
			<wfw:commentRss>http://evtimmy.com/2009/06/flowlayout-part-2-gap-verticalalign-and-scrolling/feed/</wfw:commentRss>
		<slash:comments>15</slash:comments>
		</item>
		<item>
		<title>FlowLayout &#8211; a Spark Custom Layout Example</title>
		<link>http://evtimmy.com/2009/06/flowlayout-a-spark-custom-layout-example/</link>
		<comments>http://evtimmy.com/2009/06/flowlayout-a-spark-custom-layout-example/#comments</comments>
		<pubDate>Mon, 01 Jun 2009 08:10:49 +0000</pubDate>
		<dc:creator>Evtim</dc:creator>
				<category><![CDATA[Custom Layout]]></category>
		<category><![CDATA[Flex 4]]></category>
		<category><![CDATA[Layout]]></category>

		<guid isPermaLink="false">http://evtimmy.com/wordpress/?p=3</guid>
		<description><![CDATA[I&#8217;ve been working on the Flex SDK team for more than a year now, primarily playing with the Spark layouts.  One of the new Spark features is the &#8220;assignable layouts&#8221;.  The stock layouts have been separated into their own classes and the containers can be assigned different layouts at run-time.  This modularization allows anyone to [...]]]></description>
			<content:encoded><![CDATA[<p>I&#8217;ve been working on the Flex SDK team for more than a year now, primarily playing with the Spark layouts.  One of the new Spark features is the &#8220;assignable layouts&#8221;.  The stock layouts have been separated into their own classes and the containers can be assigned different layouts at run-time.  This modularization allows anyone to create their own cool custom layouts and use them with any of the Spark containers.</p>
<p><span id="more-3"></span></p>
<p>I want to show how easy it is to create a custom Spark layout.  I&#8217;ve chosen a flow layout example where all the elements are arranged horizontally, wrapping to the next row when the width limit of the container is reached.  For simplicity I&#8217;m going to assume that all elements are of equal height.</p>
<p><strong><em><strong><em>Update: Check out part 2 of the article <a title="here" href="http://evtimmy.com/2009/06/flowlayout-part-2-gap-verticalalign-and-scrolling/">here</a>.</em></strong></em></strong></p>
<h3>Step 1 &#8211; Simple List Application with a Stock TileLayout</h3>
<p>For starter, let&#8217;s get a simple application going with a Spark List with a few items. I&#8217;m going to add a slider that controls the width of the List. By default the List&#8217;s layout is the VerticalLayout, but I&#8217;m going to switch it to the stock TileLayout just to contrast it with the FlowLayout that I&#8217;m going to put together further below.</p>
<p style="text-align: center;">
    <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" id="swfobj_1" width="400" height="300" align="center">
      <param name="movie" value="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/simple-tile.swf" />
      <param name="align" value="center" />
      <!--[if !IE]>-->
      <object type="application/x-shockwave-flash" data="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/simple-tile.swf" width="400" height="300" align="center">
      <!--<![endif]-->
        <p>The Flash plugin is required to view this object.</p>
      <!--[if !IE]>-->
      </object>
      <!--<![endif]-->
    </object>
</p>
<p>And the source code:</p>
<div id="attachment_16" class="wp-caption aligncenter" style="width: 610px"><img class="size-full wp-image-16" title="a-simple-flow-layout-step11" src="http://evtimmy.com/wordpress/wp-content/uploads/2009/05/a-simple-flow-layout-step11.png" alt="List with TileLayout" width="600" height="550" /><p class="wp-caption-text">FlowTest.mxml</p></div>
<h3>Step 2 &#8211; A Custom Layout Skeleton Class</h3>
<p>Next step is creating the skeleton for the custom layout. I&#8217;ll create a new AS class FlowLayout.as, and since it is a custom layout, it must subclass LayoutBase.  The LayoutBase provides a lot of default functionality, but the most important methods I need to override are updateDisplayList() and measure().</p>
<ul>
<li>updateDisplayList() is called by the container to size and arrange the container&#8217;s elements.</li>
<li>measure() is called to calculate the default size of the container based on the container&#8217;s elements. I&#8217;m not going to override measure(), as the List skin already has default size.</li>
</ul>
<div id="attachment_22" class="wp-caption aligncenter" style="width: 610px"><img class="size-full wp-image-22" title="a-simple-flow-layout-step2" src="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/a-simple-flow-layout-step2.png" alt="FlowLayout.as" width="600" height="240" /><p class="wp-caption-text">FlowLayout.as</p></div>
<h3>Step 3 &#8211; Make Sure It Does Something</h3>
<p>Now I&#8217;m going to iterate through all of the container&#8217;s elements.  I&#8217;ll access the container through the layout&#8217;s &#8220;target&#8221; property, which is of type GroupBase.  To work with the elements I&#8217;ll be using the ILayoutElement interface, specifically the following APIs:</p>
<ul>
<li>setLayoutBoundsSize(width, height) &#8211; where I can also pass in NaN leaving the element to size itself to its preferred size.</li>
<li>getLayoutBoundsWidth(), getLayoutBoundsHeight() &#8211; to get the current bounds of the element.</li>
<li>setLayoutBoundsPosition(x, y) &#8211; to position the element.  Coordinates are relative to the container&#8217;s origin.</li>
</ul>
<p>Before delving into too much coding, let&#8217;s just size every element to it&#8217;s preferred size, stagger them vertically by 10 pixels each and setup the List to use the the new FlowLayout.</p>

    <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" id="swfobj_2" width="400" height="300" align="center">
      <param name="movie" value="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/flowtest-flow-layout-basic.swf" />
      <param name="align" value="center" />
      <!--[if !IE]>-->
      <object type="application/x-shockwave-flash" data="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/flowtest-flow-layout-basic.swf" width="400" height="300" align="center">
      <!--<![endif]-->
        <p>The Flash plugin is required to view this object.</p>
      <!--[if !IE]>-->
      </object>
      <!--<![endif]-->
    </object>

<p>And the source code:</p>
<div id="attachment_24" class="wp-caption aligncenter" style="width: 610px"><img class="size-full wp-image-24" title="a-simple-flow-layout-step3" src="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/a-simple-flow-layout-step3.png" alt="a-simple-flow-layout-step3" width="600" height="530" /><p class="wp-caption-text">FlowLayout.as</p></div>
<p style="text-align: center;">
<div id="attachment_25" class="wp-caption aligncenter" style="width: 610px"><img class="size-full wp-image-25" title="a-simple-flow-layout-step31" src="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/a-simple-flow-layout-step31.png" alt="The update to the flowText.mxml" width="600" height="170" /><p class="wp-caption-text">The update to the flowText.mxml</p></div>
<h3>Final Step &#8211; Finish the FlowLayout</h3>
<p>And now let&#8217;s finish the FlowLayout &#8211; I want to arrange elements left to right, space them by 10 pixels, and move the elements down when there&#8217;s not enough space to fit in the containerWidth.  With a couple of lines I get the final result:</p>

    <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" id="swfobj_3" width="400" height="300" align="center">
      <param name="movie" value="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/flowtest-final.swf" />
      <param name="align" value="center" />
      <!--[if !IE]>-->
      <object type="application/x-shockwave-flash" data="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/flowtest-final.swf" width="400" height="300" align="center">
      <!--<![endif]-->
        <p>The Flash plugin is required to view this object.</p>
      <!--[if !IE]>-->
      </object>
      <!--<![endif]-->
    </object>

<p>And the final code looks like this:</p>
<p><a href="http://11011.net/software/vspaste"></a></p>
<div id="attachment_29" class="wp-caption aligncenter" style="width: 610px"><img class="size-full wp-image-29" title="a-simple-flow-layout-step4" src="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/a-simple-flow-layout-step4.png" alt="Final source code of the FlowLayout.as" width="600" height="810" /><p class="wp-caption-text">Final source code of the FlowLayout.as</p></div>
<p>Hope you enjoyed it!</p>
<p>Download the source files <a href="http://evtimmy.com/wordpress/wp-content/uploads/2009/06/flowlayout.zip">here.</a></p>
]]></content:encoded>
			<wfw:commentRss>http://evtimmy.com/2009/06/flowlayout-a-spark-custom-layout-example/feed/</wfw:commentRss>
		<slash:comments>33</slash:comments>
		</item>
	</channel>
</rss>
