Blog

  • Remote & Local Debugging in Flash & Flex

    There are a plethora of new and old tools out there to debug your Flash movies. However, just a reminder you can use Flash to see your trace statements and use your debugger while a SWF is running in a browser. Steps are as follows:

    1. Close all browsers and Flash.
    2. Go to your Flash installation directory, and look in the players directory. Mine on my PC is:
      C:\Program Files\Macromedia\Flash MX 2004\Players
    3. Make a folder called “backup”. Cut and paste the following files into it:
      • SAFlashPlayer.data
      • SAFlashPlayer.exe
      • SAFlashPlayer.rsrc
    4. Go into the debug folder, and copy the same files. Paste them one directory up, in the players folder. These are the files Flash MX 2004 Professional will utilize to make a debuggable SWF.
    5. Go back in the debug folder and install the appropriate debug player. The AX one is for IE (ActiveX), and other uses of embedded Flash, OSX for duh, exe for Firefox, and hqx for non-OSX Macs (maybe Linux? :: shrugs ::).
    6. Re-open Flash, and when compiling your FLA, make sure Debugging is enabled in your File > Publish Settings, Flash Tab > Debugging Permitted. This will ensure your SWD file, the ASCII holder of your ActionScript, will be created upon each compile. Careful, though; it has the nasty habit of caching just like ASO’s, causing the code you are debugging to be different than what’s in the SWF running. Delete if you’re paranoid like me.
    7. Open your Debugger, and ensure “Enable Remote Debugging” is on (drop down menu, top right).
    8. Finally, upload your SWF and SWD file to your server. When you hit the SWF in a browser, it’ll ask where do you want to connect; choose localhost, and go back to Flash if it doesn’t auto-focus it back for you; click OK (assuming no password), and your Output window should show traces, and your Debugger should work as normal (although a tad slower).

    This’ll work for Flex too; it comes with a debug player in:
    C:\Program Files\Macromedia\Flex\bin

    For offline debugging where Flash is embedded, such as Zinc, you can log using Afterthought.

    There are a plethora of other debugging tools as well, a lot made in Flash, but just so you know you have your standard ones by default which can be used for web deployed content.

    If you have one you know of not mentioned here, please feel free to leave a link in the comments; we’d all like to hear about it.

  • Flex Chronicles#11: Nesting Tags For Attributes

    I’m not a big fan of doing ActionScript inline within tags and/or within attributes. However, it does make data binding to properties extremely simple. Example, if you want to show a city & state based on a result from a webservice that takes a zipcode, you can do:

    <mx:Label id="cityState_lbl" text="{ws.result}" />

    Extremely simple binding. I’d personally rather do this in code because I’m an MXML purist, but you cannot deny the power of it.

    What I just learned today was that sometimes naturally your data binding results from web services can be long making your MXML unreadable since you have a long object property name list in your MXML attribute tag.

    I’ve always wondered why the dataProvider tag starts with a lowercase “d”, for example like the ComboBox:

    <mx:ComboBox id="SoftwareSelection">
    

    <mx:dataProvider>
    <mx:Array>
    <mx:String>Macromedia Flex</mx:String>
    <mx:String>Macromedia Dreamweaver</mx:String>
    <mx:String>Macromedia ColdFusion</mx:String>
    <mx:String>Macromedia Flash</mx:String>
    </mx:Array>
    </mx:dataProvider>

    </mx:ComboBox></pre>

    That always threw me off, but today I learned why.

    You can nest ANY attribute of a Component/Class/Tag in Flex. So, for the above, if your webservice result is obnoxiously long, you can instead nest it for readability:

    <mx:Label id="cityState_lbl">
    <mx:text>
    {yourLongWebServiceName.result.nestedPropName}
    </mx:text>
    </mx:Label>

    Wow… that’s awesome! Thanks David George for that pimp technique.

  • Hormone Appears to Increase Trust

    Next time I have allergies and hit the nasal spray, I’ll end up using Internet Explorer and install the Yahoo! Toolbar…

    NOT!

    Hormone Appears to Increase Trust

    Via her majesty.

  • DataSelector: Data Interaction Core of the v2 Framework for Your Views

    I managed to get DataSelector to work earlier this week and wanted to share how cool it is once you get it working.

    Introduction

    DataSelector is a mixin class in the Flash MX 2004 Professional v2 component framework (hereafter referred to as the v2 framework). It’s full classpath is:

    mx.controls.listclasses.DataSelector

    It is used to give a UIComponent the core attributes of working with the common data methods and properties that are prevalent in the v2 framework.

    So, if you want your component to have all of the dataProvider methods like addItem, removeItemAt (to interact with a dataProvider thus implementing the DataProvider API), as well as the useful properties to query the View (your UIComponent) such as selectedItem, selectedIndex, and value, this is the class to use. It also gives your UIComponent a dataProvider property, and when it changes, calls invalidate for you. There are a plethora of functions and properties given to you to make more effecient redraws when the model does change.

    Why should I care?

    Why would you use this? I like it because I don’t feel like proxying all of the DataProvider API calls myself; I can just use the DataSelector, and it automatically gives my class all of those methods instead of me having to write them manually. Secondly, all of the fine grained control over how a dataProvider’s data is changed, as well as keeping track of which item is selected, etc., is all handled for you.

    Inheritance vs. Mixin

    Why can’t you just inherit from it? As I said, it’s a mixin. Since ActionScript 2.0 does not support multiple inerhitance, you must either use an Interface, Composition, __resolve, or a mixin. A mixin is basically a Decorator that at runtime adds methods at properties to a class’s prototype. Since ActionScript 2.0 supports prototype, this means anything added on a class’ prototype is effectively the same thing as a class member variable or class function.

    It manages to compile correctly because a plethora of the base classes of the v2 framework define properties & methods (and the DataSelector template) to ensure the compiler finds the functions and properties that will be there at runtime. So, even though no dataProvider exists in your code at authortime, it will at runtime, so you have to define it so the compiler doesn’t bitch.

    Implementing

    DataSelector comes with a template that defines all of these properties and methods for you so you can just copy and paste it into your class file. The only two things you have to do to use it are:

    1. import both DataSelector, and DataProvider
    2. call their initialize functions in static varible references. This ensures they are actually used and referenced so the compiler exports the class, AND since it’s static, it’ll only happen once; when your class is instantiated

    Like so:

    import mx.core.UIComponent;
    import mx.controls.listclasses.DataSelector;
    import mx.controls.listclasses.DataProvider;
    
    class YourClass extends UIComponent
    {
            // your DataSelector template will go here
            
            public static var mixIt:Boolean = DataSelector.Initialize(YourClass);
            public static var mixIt2:Boolean = DataProvider.Initialize(Array);
    }
    

    Then, you can just react to any data changes in your draw/size/doLayout function (doLayout assuming you extend View instead of UIComponent).

    createClassObject(YourClass, "test", 0);
    test.dataProvider = ["one", "two", "three"];
    test.addItem({label: "four", data: 4});
    test.selectedIndex = 0;
    trace(test.selectedItem);
    

    Conclusion

    Now, in all fairness some MVC purists will say that this is a violation since this allows your View to be bound to the Model via the dataProvider, which is itself a controversial way of handling data in Flash. I argue that the Controller is the one who bound them so it’s legal. Additionally, in MVP, a modelChanged event is triggered upon using a DataProvider API function like addItem, but the View gets the event and reacts, not the Presenter. Anwyay, I like it and it helps my custom components integrate nicely in the v2 framework.