<

Screen Capture with ActionScript

Published on
13,696 Points
6,296 Views
4 Endorsements
Last Modified:
Approved
While working over numerous projects I often had the requirement for doing a screen capture in AS3.0. Unfortunately I found no "ready made" solutions in google search that suited my requirements. But I did come across some great resources which helped me to develop a component for screen capture, and thought I would share my experience (and code) with you.

With a hope that this will appeal and help someone else out there, I have posted it here:

The Solution :

Below is the Main mxml page developed using Adobe Flash Builder, SDK 4.1, Flash Player version 10.1.0. In this example I am doing a screen capture of the stage.
I have added a video and placed 3 buttons, Record, Stop and Play.
On clicking on the Record button, the recording of the page starts. Once you click on stop, it stops recording.
Then click on Play button to see the recorded version. You may have other things/animations on stage for recording too, I have just tried with an flv.
The recording play is basically bytesArray of an FLV created on run-time. You can save it to your server by passing this binary data to any back-end technology - ASP.Net or PHP, etc.

//Main.mxml
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
width="955" height="600"
addedToStage="onInit();"
frameRate="24" >

     <fx:Script>
<![CDATA[
             import com.dd.screencapture.ScreenCapture;
             import com.dd.screencapture.SimpleFlvWriter;

             private var screenCapture:ScreenCapture;

             private function onInit():void
             {
                  screenCapture = ScreenCapture.getInstance();
                  screenCapture.source = stage;
                  screenCapture.fps = 12;
                  screenCapture.size( 400, 300 );
                  screenCapture.x = 400;
                  screenCapture.y = 250;
                  stage.addChild( screenCapture );
             }

             private function startRecord( event:MouseEvent ):void
             {
                   screenCapture.record();
             }

             private function stopRecord( event:MouseEvent ):void
             {
                  screenCapture.stop();
             }

             private function playVideo( event:MouseEvent ):void
             {
                  screenCapture.play();
             }
      ]]>
   </fx:Script>
   <s:VideoDisplay width="400" height="300" source="assets/myVideo.flv" />

   <mx:HBox >
       <s:Button label="Record" click="startRecord( event );" />
       <s:Button label="Stop" click="stopRecord( event );" />
       <s:Button label="Play" click="playVideo( event );" />
   </mx:HBox>
</s:Application>

Open in new window


Place the ScreenCapture.swc in lib folder of the flex project. You may also use this swc for any ActionScript 3.0 projects. Kindly note that this requires Flash Player 10.1 to run properly.

Note: The below ScreenCapture.swc has been renamed to ScreenCapture.swc.txt for security reasons (so remember to remove the .txt extension when you save it). SWC is a Shockwave Flash component file. A SWC file is a zip-like file (packaged and expanded by means of the PKZIP archive format) generated by the Flash authoring tool.
ScreenCapture.swc.txt

Interestingly, you can save the screen capture as FLV format by using this piece of code below:
var saveFile:FileReference = new FileReference();
saveFile.save( screenCapture.data, "video.flv" );//screenCapture is the ScreenCapture instance created in the above code block.

Open in new window


Resources used: http://www.zeropointnine.com/blog/simpleflvwriteras-as3-class-to-create-flvs/
The links shows how to save BitmapData to an FLV in binary format and then save to dish using Adobe AIR, using FileStream. I have taken the part of writing the binary data for FLV and playing that FLV as stream on run-time.

This has been published at http://deepanjandas.wordpress.com/2011/02/05/screen-capture-with-actionscript/
4
Comment
1 Comment
 

Expert Comment

by:nardine zermok
Thanks to share your code, it's amazing and very easy to implement it.
however how can we manage the memory? as long as it's recording
all the bytes goes into the RAM, so it will be very useful to make some chunks
and send it in realtime on a server or local file to free the memory usage
0

Featured Post

Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Join & Write a Comment

The goal of the tutorial is to teach the user how to set there setting in Adobe Flash Media Live Encoder and YouTube for optimal video and audio quality.
The goal of the tutorial is to teach the user how to use the auto adjust feature and what the different options do. When your video is not working right you can choose the auto adjust feature to help choose your settings.

Keep in touch with Experts Exchange

Tech news and trends delivered to your inbox every month