Saturday, December 13, 2008

Flex cookbook beta - How do we display HTML in a Flex application?

Flex cookbook beta - How do we display HTML in a Flex application?

check out the component

Average rating

Blogged with the Flock Browser

Sunday, December 7, 2008

Automatically resize Text/TextArea based on content (autoSize) in Flex

Automatically resize Text/TextArea based on content (autoSize) in Flex

by Nicolas Noben

UPDATE: turns out that doesn’t always work. the autoSize property is not reliable at all…

This, should do!

var ta_height:uint = 25;

field.validateNow();

for(var i:int=0; i < field .mx_internal::getTextField().numLines; i++) {
ta_height += field.mx_internal::getTextField().getLineMetrics(i).height;
}

derivedHeight = ta_height;

Thanks Vaan.


Original post:

Adobe’s dodgy textHeight sure doesn’t do the trick. I end up getting a textfield of 2000px height while it clearly looks like 300 tops.

This, however, works.

the code

private function resizeMe(field:TextArea) :void
{
field.validateNow();
field.mx_internal::getTextField().autoSize = TextFieldAutoSize.LEFT;
field.height = field.mx_internal::getTextField().height;
}

Just use that on your TextArea or Text component:

creationComplete="resizeMe(this.myTextAreaInstance)"

Tuesday, November 11, 2008

Embedding XML in Flex

posted on
27 04 2007

This post is more of a test of my code embedding tool for wordpress. It’s called iG:Syntax Hiliter and it works like a charm. I dig the text view along with the pretty color coded view.

So, about embedding an XML file in a flex swf…Here’s an example of embedding an XML file, then tracing out data at compile time via actionscript. The best part is the the XML is compiled into the swf, and you can access any of the XML file’s properties by accessing it via the singleton XML Manager.

[as][Embed(source=”myXMLFile.xml”,mimeType=”application/octet-stream”)]
public static const XMLFILE:Class;
public static const MY_XML : XML = setConst();

private var cache : Object

public var dataXML : XML;
private static function setConst():XML{
var ba:ByteArray = new XMLFILE() as ByteArray;
trace(”compiling”);
return new XML(ba.readUTFBytes(ba.length));
}

private static var model : XMLManager;

public static function getInstance() : XMLManager
{
if ( model == null )
{
model = new XMLManager();

}
return model;
}

public function XMLManager()
{
if ( model != null )
{
throw new Error( “Only one XML Manager instance should be instantiated” );
}
dataXML = MY_XML;
cache = new Object();
}
[/as]

source

Tuesday, March 11, 2008

One Worst Post i've found about RIAs:

The Keene View: Really Idiotic Approaches to RIA: Flex, Silverlight and JavaFX

and here are some great comments in reply:

The Keene View: Really Idiotic Approaches to RIA: Flex, Silverlight and JavaFX: "Really Idiotic Approaches to RIA: Flex, Silverlight and JavaFX"

But one thing i liked about this post was it brought the greatness of RIAs into light :)
Here it goes:

"I just waded through a good article in DevX by Alexey Gavrilov on building Rich Internet Applications with Adobe Flex, Microsoft Silverlight and Sun JavaFX. The article worked step-by-step through how to build simple web applications with each of these products.

I had expected that there was some connection between Web 2.0, open source and the leaders in RIA. Instead, I found a set of time-warp technologies, each embodying its own uniquely idiotic approach. For the sake of brevity, I will here summarize the crowning idiocy of each approach:

* The fat-client approach. Microsoft has determined that the only problem with browser-based apps is that it doesn’t run fat client apps. Silverlight fixes that bug.

* The supermodel approach. Adobe was so entranced with the beauty of Flex’s audio-video capabilities that they forget to add little things like the ability to work with strings or dates.

* The once more with feeling approach. Sun decided to take another stab at making good on their most famous lie about Java, “write once, run anywhere.” Unfortunately for them, the Javascript Genie is out of the bottle.

None of these approaches supports Javascript as the primary scripting language. Don’t tell Adobe, Microsoft or Sun that Javascript is hot and that those crazy open source people are starting to assemble lightweight applications to run in web browsers.

Having said all this, the open source AJAX community has plenty of work to do in cleaning up its own house. The good news is that if this is what we’re fighting against, we have only ourselves to blame if the evil scientists win!


Comments start here
# posted by Christopher Keene @ 9:46 PM
Comments:
Silverlight 1.0's primary language IS javascript. Silverlight 1.1 does not have a primary language, you can use C#, VB, Python, Ruby, etc.

Flash's actionscript is related to ECMA Script (javascript) and can be programmed against the DOM and vise versa.

JavaFX is just a "me too" technology.
# posted by Anonymous Jeremiah Morrill : 9/13/2007 10:54 PM

Although it might not be immediately apparent, I am not claiming that any of these approaches are bad from a purely technical point of view. I am only claiming that they have little in common with the overall themes of Web 2.0 in general and AJAX in particular.

I think the power of Silverlight is in allowing a windows developer to use a consistent UI, the Windows Presentation Foundation (or WPF, on which you appear to be an expert) for building both Windows-based and browser-based applications.

For an existing Windows/.NET developer, Silverlight seems like a great GUI builder choice. However, it is unlikely that someone truly interested in the best and most open AJAX approach would pick Silverlight.
# posted by Blogger ckeene : 9/14/2007 10:22 AM

I for one hope Microsoft continues to get a clue, and decides to go with majority web standards in Internet Explorer. It has been such a pain getting things to display/work in IE correctly (javascript/Ajax).
# posted by Anonymous oreonix : 9/14/2007 5:43 PM

I would say chances are slim that Microsoft will decide to sleep with the enemy this late in the game.

As the market leader, they are best served by appearing to support the standards, but doing so in a way that really rigs the game in the favor of proprietary Windows APIs.

In that way, Silverlight is a perfect example of the Microsoft strategy - provide nominal support for AJAX while making damn sure that any existing Windows developer will have no interest in changing from WPF to AJAX components.
# posted by Blogger ckeene : 9/14/2007 6:05 PM

Well, it's also really idiotic that zillions of web developers are forced to reimplement all kinds of widgets (trees, tables, ...) over and over again because JavaScript/DOM simply sucks in this area...
# posted by Anonymous Anonymous : 9/15/2007 4:54 AM

Try using javascript for the screencast on your company's homepage and get back to us on this one!
# posted by Anonymous Anonymous : 9/16/2007 3:50 PM

To my two anonymous posters - although this post lambastes the proprietary, non-AJAX RIA players, I would be the first to admit that all is not peaches and cream in Javascript-land.

My very next post points towards what I think is needed to make the AJAX toolkits worthy contenders to become the next GUI builder heavyweights.

Yes, there need to be standardized widget libraries on top of Javascript, and not 12 different ones, just one clear leader.

By the way, Flash is great for multi-media screencasts. I'm not sure this is an area where Javascript should try to excel, but I am absolutely certain that Flash shouldn't try to take on Javascript in the programmatic arena.
# posted by Blogger ckeene : 9/16/2007 3:56 PM

You are right: Flex, Silverlight, ... shouldn't get all the Web 2.0 attention because these are the technologies behind Web 3.0 (and please don't tell me the semanctic web is 3.0 - the semantic web will probably be Web 5.0 or so).
# posted by Blogger Ria Flex : 9/17/2007 11:55 AM

You are an ignoramus. You need to write about something you know about like how to tie a pair of shoe laces together and take a picture of it.

Call AJAX what it really is: HTML/JAVASCRIPT/XMLHttp

Oh, that is new. What a nightmare to program in also. Get a grip dude! You are way out of touch on this one.

AJAX is tied to the same problems application (yes application, not content) web sites have had for a very long time. NO 100% cross browser compatibility. AJAX is just a new name for dynamic HTML.

Don't get me wrong. I love HTML. It is the best platform for content sharing and will always have a love for it. It just sucks for Internet applications.

Adobe, MS , et al do not want to replace HTML for Web 2.0. They want to redefine the tools we currently have to put applications on the sites that we see today.

OUT!
# posted by Anonymous Anonymous : 9/23/2007 11:17 PM

Thank you for sharing – I just love it when the trolls come out to play ;-)

Let’s see if I can find any actual content in your post to respond to – bear with me, it might take a while.

I think you are saying that ajax is bad because it is not cross browser. Let’s examine that for a second. Cross browser at this point is really shorthand for “runs the same on Firefox and Explorer.”

When we parse that a bit more, we find that more than half of the cross-browser problems come from Microsoft’s poor implementation of the standards. And hey, whadda ya know, Microsoft benefits from its poor implementation by getting witless developers (present company excluded of course) to adopt their proprietary, Microsoft-only solution as a reward for Microsoft’s poor implementation of the standards needed to make ajax work!

You don't suppose they do that on purpose do you?

And if you feel that Microsoft should not be rewarded for this kind of behavior, but do not have the weight of the EU behind you to slap a $600M fine on them, you can always choose a different proprietary solution and get locked into Adobe forever.

So your proposal, if I understand it, is that this open-source thing is just a crock, that nobody will ever get the cross-platform right, and the sooner we all just capitulate and fold up our tents, the sooner the caps-lock trolls will leave us alone?

Let me get back to you on that.
# posted by Blogger ckeene : 9/24/2007 11:31 AM

who the heck is screaming "it is not cross browser" today, 25th of September 2007

geez.... last time I had to deal with anything of significance not working in a common browser was XSLT in Safari 2. Safari 3 (on WINDOWS!) supports it just fine.

Javascript works, Ajax works, seems only Flex or compiled language developers ever say they do not. This is not 1998 people... (and BTW IE supported XHR long before any other browser)
# posted by Blogger traunic : 9/25/2007 8:30 AM

So just for fun I also did a post on the Webguild blog to keep the conversation rolling merrily along

WebGuild - User Experience, Developer Network, Internet Marketing
# posted by Blogger ckeene : 9/25/2007 11:55 AM

If this is this a debate of Flex vs. AJAX ("JavaScript"), let me chime in.

Flex is an elegant framework for complimenting ActionScript 3's already highly-structured OOP. With Flex, you can implement advanced design patterns necessary for very large applications, just like desktop application developers have been doing for years.

JavaScript is a little bit behind because it is based on the same ECMAScript that ActionScript 1 is based on. But in fairness, it is catching up because Adobe contributed the ActionScript 3 engine to Mozilla to power the next version of the Firefox JavaScript engine.

Reference this press release:
http://www.mozilla.com/en-US/press/mozilla-2006-11-07.html
# posted by Blogger Harry : 9/25/2007 5:10 PM

Dude, you put out a blogpost calling Flash and Silverlight RIA developers "idiotic" and then you complain about "trollish" responses. You are just getting back what you put out there. Try to be a bit more constructive next time and you will get more positive responses. I really hope you don't have kids since apparently you need this kind of stuff explained to you.

The point of RIA is to make the browser experience better. When people point their browser to a website, they do not care if it is written in Flash, Silverlight, or DHTML, they just want a good experience. Most of the high-end brands in the fashion, design, and entertainment worlds have invested heavily in gorgeous Flash websites that could not be done in DHTML cost effectively or if at all.

What are you going to tell shops with a ton of Visual Basic experience, go learn JavaScript and Dojo instead of using Silverlight and the Microsoft tools they already know? Total nonstarter. People should use whatever tools they know to get the job done.
# posted by Anonymous Anonymous : 9/27/2007 3:17 PM

Just wonna say somthing here about getting locked into a proprietary solution, and the idea that this is a reason to use ajax instead of silverlight or flash.

Supposedly the problem your getting at is that your making a product that runs inside something else and rely on that thing for your product to work. So how is using flash or silverlight different from using a browser? Your still relying on a browser created by someone else.

So we shouldn't use flash cos it's proprietary. your locked in. if adobe decide they don't wonna support you anymore then your screwd. how is internet explerer or firefox any different?

Maybe you still use html 3, and sometime in the (near?) future IE decides it can't implent html 3 anymore if it wants to be able to implent html X and still have a small enough browser to download and install quickly. BANG the proprietary daemond hits you in the ass and your site don't work no more.

Not only that, but you are relying on all the other browsers aswell. Lets say we're bothered about IE, firefox, safari and opera. Thats 4 different proprietary solutions you have to account for all at once. All with different agendas. Realy, standards don't count for poop unless everyone implements them right (which it's not always in their interest to do so (MS want you in silverlight so IE don't work like firefox)).

At least with flash, adobe are acountable to you, they depend on you for their income. it's in their interest to keep you happy. What the pluck does microsoft realy care if your html 3 site stops working in IE??? Adobe have proven they care... They have a new AVM 2 for AS 3 but they didn't leave the AVM 1 out of the new flash player. They could have, and that would have forced all AS devs to move to AS 3 and buy Flash CS3 straight away.

So in reality, your in safer hands when you go 'proprietary' than you are when you go 'open web standards' cos no one is actually acountable for their implementation. And cos you have the controlled 'proprietary' environment, they are free to go further and make them better. You can't even play a simple video in a browser with out some other plugin. In my view, once a proprietary solution has a large enough penetration, you can say standard shmandard. 90% flash player penetration makes actionscript the broadest, most solid standard around.
# posted by Anonymous doofmoof : 3/02/2008 9:20 AM

I know these posts are pretty old but I found them after checking out WaveRunner. You really put you and your product in a bad light by calling millions of developers "stupid". I work in the enterprise and have just scratched your product off of my list of environments to explore.
# posted by Anonymous Anonymous : 3/07/2008 6:30 AM

Monday, March 3, 2008

"Thermo" is an upcoming Adobe product

Thermo


"Thermo" is an upcoming Adobe product that makes it easy for
designers to create rich Internet application UIs. Thermo allows
designers to build on familiar workflows to visually create working
applications that easily flow into production and development.


Features


  • Use drawing tools to create original graphics, wireframe an
    application design, or manipulate artwork imported from Adobe Creative
    Suite tools.
  • Turn artwork from Adobe Photoshop, Illustrator, or Fireworks
    directly into functional components that use the original artwork as a
    “skin”.
  • Define and wire up interactive behavior, such as what to do when a user clicks on something, without having to write code.
  • Easily design UIs that work with dynamic data, such as a list
    of contacts or product information, without having access to the actual
    data source. Design-time sample data can be used as a realistic
    placeholder when laying out an application, testing interactivity, and
    choreographing motion.

Applications created in Thermo are Flex applications that can be
loaded directly into Flex Builder, providing a great roundtrip workflow
for designers collaborating with developers. The designer's work can be
incorporated directly into the production application with no loss of
fidelity, and designers can continue to refine the design throughout
the iterative development process.


Blogged with the Flock Browser

Friday, February 29, 2008

Flex cookbook beta - Chromeless AIR Application (Apple Shaped Application)

Flex cookbook beta - Chromeless AIR Application (Apple Shaped Application)

Problem Summary Many developers have expressed interest in how to create applications which do not have system chrome. It is a bit trickier than it would appear. This simple tutorial will build an application that looks like an apple and add AS3 code to allow the app to be moved and closed.

Solution Summary A chromeless (no system window) application that demonstrates how to use custom chrome for Flex Builder 3 Beta 3.

Explanation To make this project, you will need to use a *.gif file with a transparency. YOu can use the apple in the downloadable file below.

1. Make a new Flex project (type AIR).

2. In the /src folder, place your transparent GIF file.

3. in the first line of MXML, add the following attributes in bold below:


4. In the /src folder, open the XML file named "-app.xml" and modify the two lines of code below:


changed to:
none

and:


changed to:
true

Do this by removing the commenting characters.


5. Save and close the application descriptor file you modified in step 4.

6. Add the following style block to your project under the first line:


Application
{
/*make app window transparent*/
background-color:"";
background-image:"";
padding: 0px;
margin-top: 0;
margin-right: 0;
margin-bottom: 0;
margin-left: 0;
}


Note that without this, you would still have the AIR chrome.

7. Add the main panel and rest of the visual elements of the application. The code should now look like this:




Application
{
/*make app window transparent*/
background-color:"";
background-image:"";
padding: 0px;
margin-top: 0;
margin-right: 0;
margin-bottom: 0;
margin-left: 0;
}


source="assets/apple.gif" scaleContent="true" autoLoad="true"/>
fontFamily="Verdana" fontWeight="bold" fontSize="20" textAlign="center"/>



8. You can now build your application. Note that you cannot move it or close it by interacting with it. To close it, you have to right click or ctrl click on the dock icon and select "quit".

9. Add the new lines of code (in bold) to add these behaviors.




Application
{
/*make app window transparent*/
background-color:"";
background-image:"";
padding: 0px;
margin-top: 0;
margin-right: 0;
margin-bottom: 0;
margin-left: 0;
}



import flash.display.Bitmap;
import mx.events.CloseEvent;

public function init():void {
// Move the app when the panelis dragged
mainPanel.addEventListener( MouseEvent.MOUSE_DOWN, startMove );

}
public function startMove(event:MouseEvent):void {
stage.nativeWindow.startMove();
}
]]>

source="assets/apple.gif" scaleContent="true" autoLoad="true"/>
height="21"/>
fontFamily="Verdana" fontWeight="bold" fontSize="20" textAlign="center"/>



10. Run your application! Voila!

Flex cookbook beta - Taking screenshots of the display list in Flex 3 using the static ImageSnapshot.captureBitmapData() method

Flex cookbook beta - Taking screenshots of the display list in Flex 3 using the static ImageSnapshot.captureBitmapData() method

just looking for this from a long time .....

here i got it
Problem Summary
You want to take a snapshot of a Flex container or control at runtime and save it as a BitmapData object.

Solution Summary
The following example shows how you can take a snapshot of an item on the display list using the static ImageSnapshot.captureBitmapData() method, which returns a BitmapData object, as seen in the following snippet: var imageBitmapData:BitmapData = ImageSnapshot.captureBitmapData(source); swfLoader.source = new Bitmap(imageBitmapData);

Explanation
In the following example, clicking the “Take snapshot of DataGrid” button uses the static ImageSnapshot.captureBitmapData() method to return a BitmapData object which in turn is converted into a Bitmap object that is loaded into a SWFLoader control:




import mx.graphics.ImageSnapshot;



private function takeSnapshot(source:IBitmapDrawable):void {

var imageBitmapData:BitmapData = ImageSnapshot.captureBitmapData(source);

swfLoader.source = new Bitmap(imageBitmapData);

}

]]>


























click="takeSnapshot(dataGrid);" />





















NOTE: The ability to load a ByteArray object directly into a SWFLoader control was added in Flex 3 build 187814.

For more information, see http://blog.flexexamples.com/2007/11/17/taking-screenshots-in-flex-3-using-the-imagesnapshotcapturebitmapdata-method/ and http://blog.flexexamples.com/tag/imagesnapshot/.

Flex cookbook beta - How to use BlazeDS Remoting

Flex cookbook beta - How to use BlazeDS Remoting

Problem Summary You need to improve your data transfer performance. You also want to be able to directly invoke methods of Java objects deployed in your application server.

Solution Summary Using the BlazeDS RemoteObject, you can directly invoke methods of Java objects deployed in your application server, and consume the return value. The return value can be a value of a primitive data type, an object, a collection of objects, an object graph, etc.

Freelance