Welcome!

Adobe Flex Authors: Matthew Lobas, PR.com Newswire, Shelly Palmer, Kevin Benedict

Related Topics: Adobe Flex, Java IoT, Machine Learning

Adobe Flex: Article

Adobe Flex: Program in Style or an Elevator Pitch

All students usually get excited by Adobe Flex, but each of them comes with different understanding of how to do things right

From Farata  Systems blog

We usually run Flex training for  private clients of Farata Systems , but once in a while we teach public classes for people with different programming background (my next Flex class at New York University starts in November).  All students usually get excited by Adobe Flex, but each of them comes with different understanding of how to do things right. So I’ll tell you the  story  that might have happened in a real life, but first, let me remind you of an old Indian tale about seven blind men and an elephant .  In short, one blind man touched the elephant’s head, the other one touched the tail, someone was by the leg. And each of them visualized an elephant differently based on what he touched…

My students usually arrive to the classroom early, but this time three seats were empty. Five minutes later I got a phone call from one of them explaining that they got stuck in the elevator and will stay there for another fifteen minute until the serviceman arrives. Needless to say that each of them had a laptop (do not leave home without it), so I gave them a short assignment to trying to help them use this time productively.

Here’s the assignment: Create a Window with a Panel  that can resize itself by clicking on the button +/- that is located in the right corner of the panel. One click should minimize the panel’s  height to  20 pixels, and a  subsequent  one should maximize to 100 pixels, and so on. 

For example, these are the two states of such panel:

 I forgot  to tell you that one of these guys was a Cobol programmer, the other one had Java background, and the third one was a Smalltalk fan.

From  Cobol to Flex

The Cobol programmer thought to himself,”I used to write long programs because during job interviews they would  ask how many lines of code did I write. These guys are different, so to earn a good grade, this program should be small ”. He finished the program on time and this is what it looked like:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
     <mx:Panel id="thePanel" title="The Panel" height="90" width="100%" headerHeight="20" />
     <mx:HBox width="100%" horizontalAlign="right" paddingRight="2">
       <mx:Label text="-"  fontSize="16" width="20" height="17" fontWeight="bold"
             id="minimizeActions"
             click="{if (minimizeActions.text=='+'){
                          minimizeActions.text='-';
                          thePanel.height=100;
                      } else {
                         minimizeActions.text='+';
                          thePanel.height=20;
                      }
                     }" />
     </mx:HBox>  
</mx:Application>

From  Java  to Flex

The Java programmer thought, “The standard Flex Panel class does not have the  property that remembers the current state of the Panel, but Flex components are easily extendable, so I’ll create a descendent of the Panel in ActionScript, add a private  state flag (minimized) , public setter and getter,  and resize function. This way my new Panel class will be reusable and self contained.”  This is his reusable ActionScript class called ResizableJPanel:

package {
            import mx.containers.Panel;
            public class ResizableJPanel extends Panel   {
                        // state of the panel
                       private  var isPanelMinimized:Boolean;                       

                        public function get minimized():Boolean{
                            return isPanelMinimized;    
                        }

                       public function set minimized(state:Boolean){
                             isPanelMinimized=state;
                        }
                        
                       public function resizeMe():void{
   
                        if (minimized){
        
                       minimized=false;
         
                     height=maxHeight;
           
                } else {
               
                 minimized=true;
                 
              height=minHeight;
                    
       }
            }    
  }       
}

This is Javist's  mxml code:

<?xml version="1.0" encoding="utf-8"?>

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" xmlns:local="*" layout="absolute"
     applicationComplete="minimizeActions.addEventListener(MouseEvent.CLICK, resizePanel);">
   <mx:Canvas id="theCanvas" height="100" width="100%" >                
     <local:ResizableJPanel id="thePanel"  height="90" width="100%"
             title="The Paaanel" minHeight="20" maxHeight="100" headerHeight="20" />
     <mx:HBox width="100%" horizontalAlign="right" paddingRight="2">
       <mx:Label text="-"  fontSize="16" width="20" height="17" fontWeight="bold"
             id="minimizeActions"  />
     </mx:HBox>
   </mx:Canvas>        
  <mx:Script>
       <![CDATA[
        function resizePanel(event:MouseEvent):void{
         if (thePanel.minimized){
             minimizeActions.text="-";
             thePanel.resizeMe();
             theCanvas.height=thePanel.maxHeight;
         } else {
             minimizeActions.text="+";
             thePanel.resizeMe();
             theCanvas.height=thePanel.minHeight;
         }
    }

       ]]>
   </mx:Script>
</mx:Application>

From  Smalltalk to Flex

The Smalltalk guy thought, “Let me see if the standard Panel is a dynamic class. If not I’ll extend  it just to make it dynamic and will be assigning the panel’s state on the fly. I hope Yakov is not one of these object-oriented Nazis”. This is his panel ActionScript class that just adds a dynamic behavior to the Panel:

package{
    import mx.containers.Panel;
    public dynamic class ResizableSmtPanel extends Panel
            {
    }     
}

His mxml class looked like this:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" xmlns="*" layout="absolute">
     <ResizableSmtPanel title="The Panel" id="thePanel"  height="90" width="100%" 
                            minHeight="20" maxHeight="100" headerHeight="20">
     </ResizableSmtPanel>
     <mx:HBox width="100%" horizontalAlign="right" paddingRight="2">
           <mx:Label text="-"  fontSize="16" width="20" height="17" fontWeight="bold"
             id="minimizeActions" click="resizePanel()" />
      </mx:HBox>
  <mx:Script>

            <![CDATA[

        function resizePanel():void{
             if (thePanel.minimized){
                  minimizeActions.text="-";
                  thePanel.minimized=false;
                 thePanel.height=thePanel.maxHeight;
         } else {
                   minimizeActions.text="+";
                   thePanel.minimized=true;
                   thePanel.height=thePanel.minHeight;
         }
      }
            ]]>
</mx:Script>

Since we are not in the classroom, I’m not going to go to  a code review and lengthy discussions, I will just say the I gave an “A” to each of these guys...and here's the Flex version:

<?xml version="1.0" encoding="utf-8"?>

<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" xmlns="*" layout="absolute">
<mx:Component className="ResizablePanel">
   <mx:Panel>
    <mx:Script>
 
     [Bindable]  
     public var minimized:Boolean = false;
    </mx:Script>
 </mx:Panel>
</mx:Component>

<ResizablePanel title="The Panel" id="thePanel"  minimized="false" height="{thePanel.minimized?thePanel.minHeight:thePanel.maxHeight}" width="99%"
                            minHeight="20" maxHeight="100" headerHeight="20"/>
     <mx:HBox width="99%" horizontalAlign="right" paddingRight="2">
           <mx:Label text="{thePanel.minimized?'+':'-'}"  fontSize="16" width="20" height="17" fontWeight="bold"
             id="minimizeActions" click="{thePanel.minimized=!thePanel.minimized}" />
      </mx:HBox>
</mx:Application>

What’s the morale of this story? Learn another language,  no matter what’s your current background. Initially you will try to bring your own culture to this new language, but eventually your horizons will broaden, which will make you a better programmer.

P.S. Isn’t it  funny that  the Cobol guy’s version was the shortest one? But was it the best one?  Can you offer a different solution?

More Stories By Yakov Fain

Yakov Fain is a Java Champion and a co-founder of the IT consultancy Farata Systems and the product company SuranceBay. He wrote a thousand blogs (http://yakovfain.com) and several books about software development. Yakov authored and co-authored such books as "Angular 2 Development with TypeScript", "Java 24-Hour Trainer", and "Enterprise Web Development". His Twitter tag is @yfain

Comments (2) View Comments

Share your thoughts on this story.

Add your comment
You must be signed in to add a comment. Sign-in | Register

In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.


Most Recent Comments
Daniel Szmulewicz 06/19/08 12:08:17 PM EDT

Shalom,

OK, so this post is two years old, but I just found it today and appreciated it a lot. Very instructive, indeed. Since you asked for more versions to achieve the desired resizeable canvas, may I offer mine. It is in the line of the Flex version offered at the end, only simplified.

Here it is:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" xmlns="*" layout="absolute">
<mx:Script>
[Bindable]
public var minimized:Boolean = false;
</mx:Script>

<mx:Panel title="The Panel" id="thePanel" height="{minimized?thePanel.minHeight:thePanel.maxHeight}" width="99%" minHeight="20" maxHeight="100" headerHeight="20"/>

<mx:HBox width="99%" horizontalAlign="right" paddingRight="2">
<mx:Label text="{minimized?'+':'-'}" fontSize="16" width="20" height="17" fontWeight="bold" click="{minimized=!minimized}" />
</mx:HBox>
</mx:Application>

Thanks again.

Daniel Szmulewicz

PS: I'm looking for a job. Do I win one?

AJAXWorld News Desk 09/23/06 03:16:38 PM EDT

We usually run Flex training for private clients of Farata Systems, but once in a while we teach public classes for people with different programming background (my next Flex class at New York University starts in November). All students usually get excited by Adobe Flex, but each of them comes with different understanding of how to do things right. So I'll tell you the story that might have happened in a real life, but first, let me remind you of an old Indian tale about seven blind men and an elephant. In short, one blind man touched the elephant's head, the other one touched the tail, someone was by the leg. And each of them visualized an elephant differently based on what he touched.

IoT & Smart Cities Stories
Discussions of cloud computing have evolved in recent years from a focus on specific types of cloud, to a world of hybrid cloud, and to a world dominated by the APIs that make today's multi-cloud environments and hybrid clouds possible. In this Power Panel at 17th Cloud Expo, moderated by Conference Chair Roger Strukhoff, panelists addressed the importance of customers being able to use the specific technologies they need, through environments and ecosystems that expose their APIs to make true ...
"Space Monkey by Vivent Smart Home is a product that is a distributed cloud-based edge storage network. Vivent Smart Home, our parent company, is a smart home provider that places a lot of hard drives across homes in North America," explained JT Olds, Director of Engineering, and Brandon Crowfeather, Product Manager, at Vivint Smart Home, in this SYS-CON.tv interview at @ThingsExpo, held Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA.
We are seeing a major migration of enterprises applications to the cloud. As cloud and business use of real time applications accelerate, legacy networks are no longer able to architecturally support cloud adoption and deliver the performance and security required by highly distributed enterprises. These outdated solutions have become more costly and complicated to implement, install, manage, and maintain.SD-WAN offers unlimited capabilities for accessing the benefits of the cloud and Internet. ...
Business professionals no longer wonder if they'll migrate to the cloud; it's now a matter of when. The cloud environment has proved to be a major force in transitioning to an agile business model that enables quick decisions and fast implementation that solidify customer relationships. And when the cloud is combined with the power of cognitive computing, it drives innovation and transformation that achieves astounding competitive advantage.
In an era of historic innovation fueled by unprecedented access to data and technology, the low cost and risk of entering new markets has leveled the playing field for business. Today, any ambitious innovator can easily introduce a new application or product that can reinvent business models and transform the client experience. In their Day 2 Keynote at 19th Cloud Expo, Mercer Rowe, IBM Vice President of Strategic Alliances, and Raejeanne Skillern, Intel Vice President of Data Center Group and G...
DXWorldEXPO LLC announced today that "IoT Now" was named media sponsor of CloudEXPO | DXWorldEXPO 2018 New York, which will take place on November 11-13, 2018 in New York City, NY. IoT Now explores the evolving opportunities and challenges facing CSPs, and it passes on some lessons learned from those who have taken the first steps in next-gen IoT services.
The current age of digital transformation means that IT organizations must adapt their toolset to cover all digital experiences, beyond just the end users’. Today’s businesses can no longer focus solely on the digital interactions they manage with employees or customers; they must now contend with non-traditional factors. Whether it's the power of brand to make or break a company, the need to monitor across all locations 24/7, or the ability to proactively resolve issues, companies must adapt to...
"IBM is really all in on blockchain. We take a look at sort of the history of blockchain ledger technologies. It started out with bitcoin, Ethereum, and IBM evaluated these particular blockchain technologies and found they were anonymous and permissionless and that many companies were looking for permissioned blockchain," stated René Bostic, Technical VP of the IBM Cloud Unit in North America, in this SYS-CON.tv interview at 21st Cloud Expo, held Oct 31 – Nov 2, 2017, at the Santa Clara Conventi...
Founded in 2000, Chetu Inc. is a global provider of customized software development solutions and IT staff augmentation services for software technology providers. By providing clients with unparalleled niche technology expertise and industry experience, Chetu has become the premiere long-term, back-end software development partner for start-ups, SMBs, and Fortune 500 companies. Chetu is headquartered in Plantation, Florida, with thirteen offices throughout the U.S. and abroad.
René Bostic is the Technical VP of the IBM Cloud Unit in North America. Enjoying her career with IBM during the modern millennial technological era, she is an expert in cloud computing, DevOps and emerging cloud technologies such as Blockchain. Her strengths and core competencies include a proven record of accomplishments in consensus building at all levels to assess, plan, and implement enterprise and cloud computing solutions. René is a member of the Society of Women Engineers (SWE) and a m...