This is an (Android only atm) ane for performing base tasks on device.
- Get OS Version String
- Show Text Display (Android Toast)
- Set Full Screen (Android Immersive mode)
- Share Image (User selects an installed app (e.g. Facebook or Twitter) to share image with)
- Device Vibration
- Native Dialogs (Alert and Confirmation)
Compiled .swc and .ane files are included in the bin directory, but to perform a clean build; set the properties in build.properties.template appropriately, change its name to build.properties and run the default ant target in build.xml in the root directory.
The BaseMobileTasks Actionscript class is a Singleton instance and should be accessed with BaseMobileTasks.instance
. Before doing so it is recommended to first check if it is supported on the current platform with the static method BaseMobileTasks.isSupported()
.
To get the OS Version:
if (BaseMobileTasks.isSupported())
// version = e.g. '5.0.1' - may also be null, so should check before using
var osVersion:String = BaseMobileTasks.instance.getOSVersion();
To display a text message (Toast text):
if (BaseMobileTasks.isSupported())
// May also use BaseMobileTasks.TEXT_DISPLAY_SHORT
BaseMobileTasks.instance.showTextDisplay("Hello World", BaseMobileTasks.TEXT_DISPLAY_LONG);
To go into full screen (note: requires Android 4.4 or higher. If full screen is your only requirement, try the air-fullscreen-ane for more features and options):
if (BaseMobileTasks.isSupported())
{
var actualScreenDimensions:Array = BaseMobileTasks.instance.setFullscreen();
if (actualScreenDimensions != null)
{
var actualWidth:int = actualScreenDimensions[0];
var actualHeight:int = actualScreenDimensions[1];
}
else
{
// Either an error has occurred or user is on an Android device less than 4.4. You could check with getOSVersion() 1st if desired.
// Store screen width and height another way (e.g. stage.fullScreenWidth && stage.fullScreenHeight)
}
}
To share an image, first save the image to a public directory (I recommend creating an appropriately named folder within File.userDirectory
) on the device then send its path to the ane like so:
private function ShareImage(image:BitmapData)
{
// can't share
if (!BaseMobileTasks.isSupported())
return;
var file:File = File.userDirectory.resolvePath("MyApp" + File.separator + "imageName.jpg");
var imageBytes:ByteArray = image.encode(image.rect, new JPEGEncoderOptions(80));
var stream:FileStream = new FileStream();
stream.open(file, FileMode.WRITE);
stream.writeBytes(imageBytes);
stream.close();
BaseMobileTasks.instance.addEventListener(BaseMobileTaskEvent.IMAGE_SHARED, onImageShared);
BaseMobileTasks.instance.addEventListener(BaseMobileTaskEvent.SHARE_IMAGE_ERROR, onImageShareErr);
var title:String = "Share Image from MyApp!";
BaseMobileTasks.instance.shareImage(file.nativePath, title);
}
private function onImageShared(e:BaseMobileTaskEvent):void
{
// important to remove event listeners from Singleton instance
BaseMobileTasks.instance.removeEventListener(BaseMobileTaskEvent.IMAGE_SHARED, onImageShared);
BaseMobileTasks.instance.removeEventListener(BaseMobileTaskEvent.SHARE_IMAGE_ERROR, onImageShareErr);
// User has been presented with a list of apps to share with. He or she may still decide not to share.
}
private function onImageShareErr(e:BaseMobileTaskEvent):void
{
// important to remove event listeners from Singleton instance
BaseMobileTasks.instance.removeEventListener(BaseMobileTaskEvent.IMAGE_SHARED, onImageShared);
BaseMobileTasks.instance.removeEventListener(BaseMobileTaskEvent.SHARE_IMAGE_ERROR, onImageShareErr);
trace("Could not share image: " + e.reason);
}
To vibrate device:
if (BaseMobileTasks.isSupported())
// If vibration is supported on device, device will vibrate for 250 milliseconds
BaseMobileTasks.instance.vibrate(250);
To display alert dialog (this will show a native dialog with a single button labeled 'OK'. No events will be dispatched):
private function showAlert():void
{
if (!BaseMobileTasks.isSupported())
return;
var message:String = "Hello World";
BaseMobileTasks.instance.displayAlertDialog(message);
}
To display confirmation dialog (this will show a native dialog with two buttons - one to cancel and one to accept. User interaction will trigger an event - either BaseMobileTaskEvent.CONFIRMATION_POSITIVE or BaseMobileTaskEvent.CONFIRMATION_NEGATIVE):
private function showConfirmation():void
{
if (!BaseMobileTasks.isSupported())
return;
var title:String = "Delete file?";
var message:String = "This will permanently delete the selected file";
var acceptLabel:String = "Delete";
var rejectLabel:String = "Cancel";
BaseMobileTasks.instance.addEventListener(BaseMobileTaskEvent.CONFIRMATION_POSITIVE, onAccepted);
BaseMobileTasks.instance.addEventListener(BaseMobileTaskEvent.CONFIRMATION_NEGATIVE, onRejected);
BaseMobileTasks.instance.displayConfirmationDialog(message, title, acceptLabel, rejectLabel);
}
private function onAccepted(e:BaseMobileTaskEvent):void
{
BaseMobileTasks.instance.removeEventListener(BaseMobileTaskEvent.CONFIRMATION_POSITIVE, onAccepted);
BaseMobileTasks.instance.removeEventListener(BaseMobileTaskEvent.CONFIRMATION_NEGATIVE, onRejected);
// User has accepted dialog - delete the file
}
private function onRejected(e:BaseMobileTaskEvent):void
{
BaseMobileTasks.instance.removeEventListener(BaseMobileTaskEvent.CONFIRMATION_POSITIVE, onAccepted);
BaseMobileTasks.instance.removeEventListener(BaseMobileTaskEvent.CONFIRMATION_NEGATIVE, onRejected);
// User has canceled the delete - act accordingly
}
Include the .swc file in your project and, when compiling, be sure the .ane file is inside your extdir. For more info, RTFM.
In your app descriptor include the extension id like:
<extensions>
<extensionID>com.onebyonedesign.basemobiletasks</extensionID>
</extensions>
If planning to share images, be sure to include the Android permission to write to external storage:
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
If planning to vibrate device, be sure to include the Android permission to do so:
<uses-permission android:name="android.permission.VIBRATE"/>
- The .swc and .ane files included in the bin directory were compiled using AIR 16.0 sdk and swf-version 27 (16.0)