After saw what’s happend during the Google I/O, I decide to make some experiments with Dart.
If you don’t know what is Dart I explain in a while: Dart is a new language that allow to structure your code in OOP manner with strong typing but with a lot of flexibility.
It’s so similar to Javascript but give you the opportunities to create classes, libraries, isolates (a good implementation to use shared-memory threads) and so on.
For an Actionscript developer, Dart seems to be the natural evolution to Javascript, during last week, also, Adobe announced an extension for Flash that allow to export Flash animations directly to Dart, so another good point on why choice this great new language.
Starting to work with Dart is very very simple, you have only to download Dart from the website and you will find inside the zip the DartEditor, an editor based on Eclipse that will become your new IDE to write Dart application.
When you are working with Dart to create the UI of your project, you can use HTML and CSS and if you have some Javascript library to integrate with Dart, you can do that!!!
With Dart you can decide to create a client or server side project, you can also export your client project for chromium or Javascript, so it’s very flexible and powerful as you can see.
I will not explain how to install Dart and getting started with it because in the official website the “get started” section is well documented, so I prefer to start with an example of a video player, if it’s your first approach to Dart I suggest to take a look, before go ahead with this post, to that section on the official website.
For the UI part of my example I’ve used Topcoat and Dart for the business logic of my video player.
Topcoat is a new Adobe UI library dedicated to style in a good and fast way the main components in a web or mobile application, if you have worked with Flex is more or less the same concept of a theme, so when you don’t want to waste your time creating a custom UI you can easily use Topcoat for your prototypes or example.
Beginning from the UI side, after created a new Dart project, I create an HTML file where I add a title, an instance of video component, and a div with some buttons and a slider to manage the volume:
<div class="centerClass"> <h1>VideoPlayer made with DartJS</h1> <video id="video" width="640" height="420"/> </div> <div class="centerClass"> <a id="playBtn" class="light-button">Play</a> <a id="resumeBtn" class="light-button">Restart</a> <span id="currTime">00:00/00:00</span> <span><input id="volume" type="range" class="dark-slider" value="100"/></span> </div>
After that I created my class in the DartEditor, all Dart classes have the extension .dart.
At the beginning of this class I’ve retrieve the id of my components inside the HTML file with query method, as you can see below, it allows me to work with them directly from my Dart class:
volumeSlider = query("#volume"); currTimeDisplay = query("#currTime"); player = query("#video"); playBtn = query("#playBtn"); restartBtn = query("#resumeBtn");
Then I loaded my mp4 file inside the video component and I’ve added all listeners that I need to intercept events from user or from the video instance:
player.src = "video/test.mp4"; //player listeners player.onLoadStart.listen(checkLoading); player.onEnded.listen(restartVideo); player.onTimeUpdate.listen(refreshData); // buttons listeners volumeSlider.onChange.listen(setVolume); restartBtn.onClick.listen(restartVideo); playBtn.onClick.listen(playVideo);
After that I’ve only to add the business logic for any interaction and everything will be done:
void refreshData(event){ currTimeDisplay.text = returnDisplayTime(player.currentTime) + "/" + returnDisplayTime(player.duration); } void checkLoading(event){ //after video si loaded I play it player.play(); isWorking = true; playBtn.text = "Pause"; } void playVideo(MouseEvent event){ //managing if I've to play or pause the video if(isWorking){ isWorking = false; player.pause(); playBtn.text = "Play"; } else { isWorking = true; player.play(); playBtn.text = "Pause"; } } void setVolume(event){ //setting volume video value (from 0 to 1) player.volume = int.parse(volumeSlider.value)/100; } void restartVideo(event){ player.load(); player.play(); }
When you have finished you can easily export your project to Javascript from the DartEditor menu (Tools > Generate Javascript) and publish on your website.
Finally this is the link to download the entire project.
As you can see Dart is not a complex language in particular if you have a solid understanding of OOP language, I personally think that many Actionscript developers will be find in Dart a good approach to Javascript and probably new stimulus on create new engaging experiences.