SlideShare a Scribd company logo
ANDROID SCRIPTING
 A Java-less approach to building apps

              Juan Gomez
          Android Dev @ Handmark, Inc
             Co-founder PythonKC
AGENDA

•   Android 101
•   Scripting Layer for Android (SL4A)
•   Basic tasks (WiFi, GPS, camera, SMS) and basic UI
•   Using WebViews and Javascript for better UIs
•   Advanced Scripts (Twisted, PyBluez)
•   Packaging your scripts on an APK
•   Q&A
ANDROID 101
An Android application is actually a collection of several
components, each defined in a file called AndroidManifest.xml

The 4 main types of components are:

  • Activities
  • Services
  • Content      Providers
  • Broadcast     Receivers
Apps are packaged on an APK file (myApp.apk)
INTENTS
•   Apps can communicate with each other by providing and consuming each
    other’s Intents
•   Intents “link” activities, services, and
    receivers together
•   Intents consists of
    •   An action (i.e. ACTION_VIEW)
    •   Categories (i.e. CATEGORY_DEFAULT)
    •   A URI (i.e. content://contacts/people/123)
    •   “Extras” metadata
•   Intents can also be sent to hard-coded class names (com.foo.FooActivity)
HOW DO I GET STARTED?

• Download       the Android SDK: http://developer.android.com/sdk

• Add Android      platforms and other packages to your SDK

• Install   the ADT plug-in for Eclipse (optional)

• Enable     app side-loading on your phone:

  •   Settings > Application > Unknown Sources
WHERE CAN I LEARN MORE?
• Android’s Dev Guide
  http://developer.android.com/guide
• Lots   of Android Books
• StackOverflow
• Recommended          resource:
  •   http://commonsware.com/
  •   The Busy Coder’s Guide to Android
      Development
  •   Yearly subscription
SCRIPTING LAYER FOR
              ANDROID (SL4A)
• Brings    scripting languages to Android
• Allows you to edit and execute scripts and interactive
 interpreters directly on the Android device.
• Scripts
       have access to many of the APIs available to full-
 fledged Android apps.
• Supported  languages include: Python, Perl, JRuby, Lua, BeanShell,
 JavaScript and Tcl
• There’s    limited support for PHP and Shell scripts
SL4A ARCHITECTURE
•   As it name implies, SL4A sits
    between the actual Android JVM
    (Dalvik) and the executable
    Scripts.
•   The Facade API exposes a subset
    of Android system API's via JSON
    RPC calls
•   Only the parts of Android's APIs
    which has been wrapped by
    facades are available to
    interpreter
•   This is a fundamental feature of
    SL4A added by Google to avoid
    security concerns.
WHAT CAN SL4A DO?
• Handle    intents
• Start   activities
• Make    phone calls
• Send    text messages
• Scan    bar codes
• Poll   location and sensor data
• Use    text-to-speech
HOW TO DOWNLOAD?




• Go   to: http://code.google.com/p/android-scripting/
HOW TO USE
   IT?
   SL4A installs as an App on
    your phone, you need to
  install separate interpreters
for each language you want to
               use
INTERPRETERS
 Open up the App, click on
Menu > View > Interpreters to
  get a list of the available
         interpreters
DOWNLOAD
Click on Menu > Add to get a
 list of new interpreters you
   can install on your phone
INSTALL
 Click on an Interpreter from
the list and this will download
  an .APK with the installer.
SCRIPTS
 When you open the SL4A
  app you get a list of your
available scripts. You can use a
  quick action menu to run,
      edit, save or delete
EDIT/RUN
 SL4A offers an environment
to edit and run scripts on the
   phone but really limited
USING ADB PUSH/PULL

• It’s
     easier to edit scripts on your computer using your favorite
  text editor and leverage the Android Debug Bridge (ADB) to
  load them on the phone.

• ADB    is installed on /<android_sdk_folder>/platform-tool/
  •   adb pull /mnt/sdcard/sl4a/scripts/Camera.js ~/Documents/
      sl4a_scripts/

  •   adb push ~/Documents/sl4a_scripts/Camera.js /mnt/sdcard/sl4a/
      scripts
Android Scripting
HELLO WORLD (PYTHON)


import android
droid = android.Android()
droid.makeToast('Hello,
Android!')
print 'Hello world!'
TAKING A PICTURE (JS)

load("/sdcard/
com.googlecode.rhinoforandroid/extras/rhino/
android.js");

var droid = new Android();

result = droid.cameraCapturePicture("/mnt/
sdcard/sl4a/pic.jpg", true);
WIFI
List all surrounding WiFi
   networks and their
connection information
LISTING WIFI NETWORKS (JS)
load("/sdcard/com.googlecode.rhinoforandroid/extras/rhino/
android.js");
var droid = new Android();
wifi_on = droid.checkWifiState();
if (wifi_on) {
    success = droid.wifiStartScan();
    if (success) {
         list_of_networks = droid.wifiGetScanResults();
         for (var i = 0; i < list_of_networks.length; i++) {
             for (attr in list_of_networks[i]) {
                 print(attr + ": " + list_of_networks[i][attr]);
             }
             print("n");
         }
    }
    droid.makeToast("Done obtaining list of WiFi networks!");
} else {
    droid.makeToast("WiFi radio is off");
}
USING GPS AND SMS (RUBY)
require "android";
def get_location(droid)
    droid.startLocating()
    droid.eventWaitFor("location")
    raw_location = droid.readLocation()
    droid.stopLocating()
    return raw_location["result"]["network"]
end

def format_address(loc_info)
    return loc_info["feature_name"] + " " + loc_info["thoroughfare"] + " " +
        loc_info["locality"] + ", " + loc_info["admin_area"] + " " +
        loc_info["postal_code"]
end

def get_address(droid, location)
    loc_info= droid.geocode(location["latitude"], location["longitude"])
    return format_address(loc_info["result"][0])
end

droid = Android.new
location = get_location droid
address = get_address droid, location
phone = droid.pickPhone
droid.smsSend phone["result"], "Greetings from SL4A, I'm at " + address
puts "done sending SMS with location"
BASIC UI
SL4A provides basic Android
  UI elements to be used in
scripts. But these UI elements
  are generally very limited
USING NATIVE TYPES AND
        LIBRARIES
import android
from datetime import date

droid = android.Android()
today = date.today()
droid.dialogCreateDatePicker(today.year, today.month, today.day)
droid.dialogShow()
selectedDate = droid.dialogGetResponse().result
first_date = date(selectedDate['year'], selectedDate['month'], selectedDate['day'])

droid.dialogCreateDatePicker(today.year, today.month, today.day)
droid.dialogShow()
selectedDate = droid.dialogGetResponse().result
second_date = date(selectedDate['year'], selectedDate['month'], selectedDate['day'])
timediff = abs(first_date - second_date)

droid.dialogCreateAlert("Difference", "Days: " + str(timediff.days))
droid.dialogSetPositiveButtonText('OK')
droid.dialogShow()
SIMPLE TWITTER CLIENT
                (RUBY)
require 'android'
require 'net/http'

droid = Android.new
url = URI.parse("http://twitter.com/statuses/update.xml")
req = Net::HTTP::Post.new(url.path)

req.basic_auth('user', 'password')
status = droid.getInput 'Twitter Update', "What's going on?"
req.set_form_data({'status' => status["result"],
                   'source' => 'Android'})

response = Net::HTTP.new(url.host, url.port).start do |http|
    http.request(req)
end

if response.code == "200"
  droid.makeToast "Your toot was successfully sent."
end
WEBVIEWS AS ADVANCED UI
<html>
  <head>
    <title>Text to Speech</title>
    <script>
       var droid = new Android();
       var speak = function() {
         droid.eventPost("say",
document.getElementById("say").value);
       }
    </script>
  </head>
  <body>
    <form onsubmit="speak(); return false;">
       <label for="say">What would you like to say?</
label>
       <input type="text" id="say" />
       <input type="submit" value="Speak" />
    </form>
  </body>
</html>
BACKGROUND SERVICE
You can create a background service that acts as a controller in
you favorite language to support your Web UI

 import android

 droid = android.Android()
 droid.webViewShow('file:///sdcard/sl4a/scripts/
 text_to_speech.html')
 while True:
     result = droid.eventWaitFor('say').result
     if result is not None:
         droid.ttsSpeak(result['data'])
ADVANCED SCRIPTS
• Python   is by far the most
  complete language on SL4A
• You can import more advanced
  libraries that are not part of the
  Python Standard Library.
• Like PyBluez for Bluetooth
• Or Twisted
  •   Twisted is an extremely powerful event-
      driven networking engine written in
      Python.
  •   Projects like BitTorrent and Launchpad
      use twisted as their networking engine.
PACKAGING YOU APP FOR
      THE GOOGLE PLAY STORE
•   For this step you will need Eclipse :(
•   Download the skeleton Android project from here:
    http://android-scripting.googlecode.com/hg/android/
    script_for_android_template.zip
•   Follow these instructions to configure the project:
    http://code.google.com/p/android-scripting/wiki/SharingScripts
•   Make sure you can generate an APK and do a test install.
•   Follow these instructions to sign your APK:
    http://developer.android.com/guide/publishing/app-signing.html
•   Viola! you can upload your APK to the Play Store
THAT’S IT FOR ME!
Thanks
To Our Sponsors
BEGINNERS PYTHON
                    WORKSHOP
•   The Beginners Python Workshop is a 2-day free event focused on
    teaching the basics of programming in the Python language.
•   Everybody is encouraged to attend, regardless of your previous
    experience with programming
•   The only requirements to attend are a laptop and a willingness to learn.
•   When:
    Friday, June 22nd 6pm - 10pm
    Saturday, June 23rd 10am - 4pm
•   Where:
    UMKC Campus 302 Flarsheim Hall
    5110 Rockhill Road, Kansas City, MO
            RSVP at: http://www.meetup.com/pythonkc/events/62339552
@_JUANDG
http://speakerdeck.com/u/juandg/p/androidscripting_kcdc2012#

More Related Content

PDF
Travis and fastlane
PDF
Appium Dockerization: from Scratch to Advanced Implementation - HUSTEF 2019
PDF
How React Native, Appium and me made each other shine @ContinuousDeliveryAmst...
PPTX
Fastlane
PDF
Ionic adventures - Hybrid Mobile App Development rocks
PPTX
Building full-stack Node.js web apps with Visual Studio Code
PDF
CocoaHeads Rennes #13 : CocoaPods
PDF
selenium-2-mobile-web-testing
Travis and fastlane
Appium Dockerization: from Scratch to Advanced Implementation - HUSTEF 2019
How React Native, Appium and me made each other shine @ContinuousDeliveryAmst...
Fastlane
Ionic adventures - Hybrid Mobile App Development rocks
Building full-stack Node.js web apps with Visual Studio Code
CocoaHeads Rennes #13 : CocoaPods
selenium-2-mobile-web-testing

What's hot (20)

PDF
Using google appengine
PDF
Cordova 101
PPTX
How we integrate & deploy Mobile Apps with Travis CI part 2
PPTX
Gdg ionic 2
PDF
HotPush with Ionic 2 and CodePush
PDF
Intro to PhoneGap
PPTX
Agility Requires Safety
PDF
Ionic CLI Adventures
PDF
Writing REST APIs with OpenAPI and Swagger Ada
PPTX
Writing automation tests with python selenium behave pageobjects
PPTX
Continuous Integration of Mobile Apps with Docker and Appium
PDF
Ane for 9ria_cn
PPTX
React native development with expo
PDF
Mastering Grails 3 Plugins - G3 Summit 2016
PDF
Deploy Angular to the Cloud (ngBucharest)
PDF
Drone Continuous Integration
PDF
Cocoa pods
PDF
Scale your Magento app with Elastic Beanstalk
PDF
Using Composer with WordPress - 2.0
PDF
Creating applications with Grails, Angular JS and Spring Security - GR8Conf U...
Using google appengine
Cordova 101
How we integrate & deploy Mobile Apps with Travis CI part 2
Gdg ionic 2
HotPush with Ionic 2 and CodePush
Intro to PhoneGap
Agility Requires Safety
Ionic CLI Adventures
Writing REST APIs with OpenAPI and Swagger Ada
Writing automation tests with python selenium behave pageobjects
Continuous Integration of Mobile Apps with Docker and Appium
Ane for 9ria_cn
React native development with expo
Mastering Grails 3 Plugins - G3 Summit 2016
Deploy Angular to the Cloud (ngBucharest)
Drone Continuous Integration
Cocoa pods
Scale your Magento app with Elastic Beanstalk
Using Composer with WordPress - 2.0
Creating applications with Grails, Angular JS and Spring Security - GR8Conf U...
Ad

Similar to Android Scripting (20)

PDF
Pycon2011 android programming-using_python
PDF
Day1 before getting_started
PPTX
Make Cross-platform Mobile Apps Quickly - SIGGRAPH 2014
PDF
Cs3430 lecture 14
PDF
Android : How Do I Code Thee?
PPTX
Make Mobile Apps Quickly
PDF
Introduction to Android Development and Security
PPT
2011 android
PPTX
Mobile Application development
PDF
First Android Experience
PDF
Android
KEY
Android Workshop
ODP
When Perl Met Android (YAPC::EU 2010)
KEY
Android lessons you won't learn in school
PDF
2011 june-kuala-lumpur-gtug-hackathon
PDF
Native Android Development with Spring
PPTX
Android Penetration Testing - Day 1
PDF
Exploring Google APIs with Python & JavaScript
PDF
Don Schwarz App Engine Talk
PDF
What is Google App Engine?
Pycon2011 android programming-using_python
Day1 before getting_started
Make Cross-platform Mobile Apps Quickly - SIGGRAPH 2014
Cs3430 lecture 14
Android : How Do I Code Thee?
Make Mobile Apps Quickly
Introduction to Android Development and Security
2011 android
Mobile Application development
First Android Experience
Android
Android Workshop
When Perl Met Android (YAPC::EU 2010)
Android lessons you won't learn in school
2011 june-kuala-lumpur-gtug-hackathon
Native Android Development with Spring
Android Penetration Testing - Day 1
Exploring Google APIs with Python & JavaScript
Don Schwarz App Engine Talk
What is Google App Engine?
Ad

More from Juan Gomez (6)

PDF
App Indexing: Blurring the Lines Between Your Website and App
PDF
REST is not enough: Using Push Notifications to better support your mobile cl...
PDF
Beating Android Fragmentation
PDF
Effective Android Messaging
PDF
Teach your kids how to program with Python and the Raspberry Pi
KEY
Gae icc fall2011
App Indexing: Blurring the Lines Between Your Website and App
REST is not enough: Using Push Notifications to better support your mobile cl...
Beating Android Fragmentation
Effective Android Messaging
Teach your kids how to program with Python and the Raspberry Pi
Gae icc fall2011

Recently uploaded (20)

PPTX
Cloud computing and distributed systems.
PDF
Chapter 3 Spatial Domain Image Processing.pdf
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PDF
Encapsulation_ Review paper, used for researhc scholars
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PPTX
Big Data Technologies - Introduction.pptx
PPT
“AI and Expert System Decision Support & Business Intelligence Systems”
PDF
A comparative analysis of optical character recognition models for extracting...
PDF
MIND Revenue Release Quarter 2 2025 Press Release
PPTX
Spectroscopy.pptx food analysis technology
PDF
Machine learning based COVID-19 study performance prediction
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PPTX
Programs and apps: productivity, graphics, security and other tools
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
Cloud computing and distributed systems.
Chapter 3 Spatial Domain Image Processing.pdf
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
20250228 LYD VKU AI Blended-Learning.pptx
Mobile App Security Testing_ A Comprehensive Guide.pdf
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Network Security Unit 5.pdf for BCA BBA.
Diabetes mellitus diagnosis method based random forest with bat algorithm
Encapsulation_ Review paper, used for researhc scholars
Advanced methodologies resolving dimensionality complications for autism neur...
Reach Out and Touch Someone: Haptics and Empathic Computing
Big Data Technologies - Introduction.pptx
“AI and Expert System Decision Support & Business Intelligence Systems”
A comparative analysis of optical character recognition models for extracting...
MIND Revenue Release Quarter 2 2025 Press Release
Spectroscopy.pptx food analysis technology
Machine learning based COVID-19 study performance prediction
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Programs and apps: productivity, graphics, security and other tools
Digital-Transformation-Roadmap-for-Companies.pptx

Android Scripting

  • 1. ANDROID SCRIPTING A Java-less approach to building apps Juan Gomez Android Dev @ Handmark, Inc Co-founder PythonKC
  • 2. AGENDA • Android 101 • Scripting Layer for Android (SL4A) • Basic tasks (WiFi, GPS, camera, SMS) and basic UI • Using WebViews and Javascript for better UIs • Advanced Scripts (Twisted, PyBluez) • Packaging your scripts on an APK • Q&A
  • 3. ANDROID 101 An Android application is actually a collection of several components, each defined in a file called AndroidManifest.xml The 4 main types of components are: • Activities • Services • Content Providers • Broadcast Receivers Apps are packaged on an APK file (myApp.apk)
  • 4. INTENTS • Apps can communicate with each other by providing and consuming each other’s Intents • Intents “link” activities, services, and receivers together • Intents consists of • An action (i.e. ACTION_VIEW) • Categories (i.e. CATEGORY_DEFAULT) • A URI (i.e. content://contacts/people/123) • “Extras” metadata • Intents can also be sent to hard-coded class names (com.foo.FooActivity)
  • 5. HOW DO I GET STARTED? • Download the Android SDK: http://developer.android.com/sdk • Add Android platforms and other packages to your SDK • Install the ADT plug-in for Eclipse (optional) • Enable app side-loading on your phone: • Settings > Application > Unknown Sources
  • 6. WHERE CAN I LEARN MORE? • Android’s Dev Guide http://developer.android.com/guide • Lots of Android Books • StackOverflow • Recommended resource: • http://commonsware.com/ • The Busy Coder’s Guide to Android Development • Yearly subscription
  • 7. SCRIPTING LAYER FOR ANDROID (SL4A) • Brings scripting languages to Android • Allows you to edit and execute scripts and interactive interpreters directly on the Android device. • Scripts have access to many of the APIs available to full- fledged Android apps. • Supported languages include: Python, Perl, JRuby, Lua, BeanShell, JavaScript and Tcl • There’s limited support for PHP and Shell scripts
  • 8. SL4A ARCHITECTURE • As it name implies, SL4A sits between the actual Android JVM (Dalvik) and the executable Scripts. • The Facade API exposes a subset of Android system API's via JSON RPC calls • Only the parts of Android's APIs which has been wrapped by facades are available to interpreter • This is a fundamental feature of SL4A added by Google to avoid security concerns.
  • 9. WHAT CAN SL4A DO? • Handle intents • Start activities • Make phone calls • Send text messages • Scan bar codes • Poll location and sensor data • Use text-to-speech
  • 10. HOW TO DOWNLOAD? • Go to: http://code.google.com/p/android-scripting/
  • 11. HOW TO USE IT? SL4A installs as an App on your phone, you need to install separate interpreters for each language you want to use
  • 12. INTERPRETERS Open up the App, click on Menu > View > Interpreters to get a list of the available interpreters
  • 13. DOWNLOAD Click on Menu > Add to get a list of new interpreters you can install on your phone
  • 14. INSTALL Click on an Interpreter from the list and this will download an .APK with the installer.
  • 15. SCRIPTS When you open the SL4A app you get a list of your available scripts. You can use a quick action menu to run, edit, save or delete
  • 16. EDIT/RUN SL4A offers an environment to edit and run scripts on the phone but really limited
  • 17. USING ADB PUSH/PULL • It’s easier to edit scripts on your computer using your favorite text editor and leverage the Android Debug Bridge (ADB) to load them on the phone. • ADB is installed on /<android_sdk_folder>/platform-tool/ • adb pull /mnt/sdcard/sl4a/scripts/Camera.js ~/Documents/ sl4a_scripts/ • adb push ~/Documents/sl4a_scripts/Camera.js /mnt/sdcard/sl4a/ scripts
  • 19. HELLO WORLD (PYTHON) import android droid = android.Android() droid.makeToast('Hello, Android!') print 'Hello world!'
  • 20. TAKING A PICTURE (JS) load("/sdcard/ com.googlecode.rhinoforandroid/extras/rhino/ android.js"); var droid = new Android(); result = droid.cameraCapturePicture("/mnt/ sdcard/sl4a/pic.jpg", true);
  • 21. WIFI List all surrounding WiFi networks and their connection information
  • 22. LISTING WIFI NETWORKS (JS) load("/sdcard/com.googlecode.rhinoforandroid/extras/rhino/ android.js"); var droid = new Android(); wifi_on = droid.checkWifiState(); if (wifi_on) { success = droid.wifiStartScan(); if (success) { list_of_networks = droid.wifiGetScanResults(); for (var i = 0; i < list_of_networks.length; i++) { for (attr in list_of_networks[i]) { print(attr + ": " + list_of_networks[i][attr]); } print("n"); } } droid.makeToast("Done obtaining list of WiFi networks!"); } else { droid.makeToast("WiFi radio is off"); }
  • 23. USING GPS AND SMS (RUBY) require "android"; def get_location(droid) droid.startLocating() droid.eventWaitFor("location") raw_location = droid.readLocation() droid.stopLocating() return raw_location["result"]["network"] end def format_address(loc_info) return loc_info["feature_name"] + " " + loc_info["thoroughfare"] + " " + loc_info["locality"] + ", " + loc_info["admin_area"] + " " + loc_info["postal_code"] end def get_address(droid, location) loc_info= droid.geocode(location["latitude"], location["longitude"]) return format_address(loc_info["result"][0]) end droid = Android.new location = get_location droid address = get_address droid, location phone = droid.pickPhone droid.smsSend phone["result"], "Greetings from SL4A, I'm at " + address puts "done sending SMS with location"
  • 24. BASIC UI SL4A provides basic Android UI elements to be used in scripts. But these UI elements are generally very limited
  • 25. USING NATIVE TYPES AND LIBRARIES import android from datetime import date droid = android.Android() today = date.today() droid.dialogCreateDatePicker(today.year, today.month, today.day) droid.dialogShow() selectedDate = droid.dialogGetResponse().result first_date = date(selectedDate['year'], selectedDate['month'], selectedDate['day']) droid.dialogCreateDatePicker(today.year, today.month, today.day) droid.dialogShow() selectedDate = droid.dialogGetResponse().result second_date = date(selectedDate['year'], selectedDate['month'], selectedDate['day']) timediff = abs(first_date - second_date) droid.dialogCreateAlert("Difference", "Days: " + str(timediff.days)) droid.dialogSetPositiveButtonText('OK') droid.dialogShow()
  • 26. SIMPLE TWITTER CLIENT (RUBY) require 'android' require 'net/http' droid = Android.new url = URI.parse("http://twitter.com/statuses/update.xml") req = Net::HTTP::Post.new(url.path) req.basic_auth('user', 'password') status = droid.getInput 'Twitter Update', "What's going on?" req.set_form_data({'status' => status["result"], 'source' => 'Android'}) response = Net::HTTP.new(url.host, url.port).start do |http| http.request(req) end if response.code == "200" droid.makeToast "Your toot was successfully sent." end
  • 27. WEBVIEWS AS ADVANCED UI <html> <head> <title>Text to Speech</title> <script> var droid = new Android(); var speak = function() { droid.eventPost("say", document.getElementById("say").value); } </script> </head> <body> <form onsubmit="speak(); return false;"> <label for="say">What would you like to say?</ label> <input type="text" id="say" /> <input type="submit" value="Speak" /> </form> </body> </html>
  • 28. BACKGROUND SERVICE You can create a background service that acts as a controller in you favorite language to support your Web UI import android droid = android.Android() droid.webViewShow('file:///sdcard/sl4a/scripts/ text_to_speech.html') while True: result = droid.eventWaitFor('say').result if result is not None: droid.ttsSpeak(result['data'])
  • 29. ADVANCED SCRIPTS • Python is by far the most complete language on SL4A • You can import more advanced libraries that are not part of the Python Standard Library. • Like PyBluez for Bluetooth • Or Twisted • Twisted is an extremely powerful event- driven networking engine written in Python. • Projects like BitTorrent and Launchpad use twisted as their networking engine.
  • 30. PACKAGING YOU APP FOR THE GOOGLE PLAY STORE • For this step you will need Eclipse :( • Download the skeleton Android project from here: http://android-scripting.googlecode.com/hg/android/ script_for_android_template.zip • Follow these instructions to configure the project: http://code.google.com/p/android-scripting/wiki/SharingScripts • Make sure you can generate an APK and do a test install. • Follow these instructions to sign your APK: http://developer.android.com/guide/publishing/app-signing.html • Viola! you can upload your APK to the Play Store
  • 33. BEGINNERS PYTHON WORKSHOP • The Beginners Python Workshop is a 2-day free event focused on teaching the basics of programming in the Python language. • Everybody is encouraged to attend, regardless of your previous experience with programming • The only requirements to attend are a laptop and a willingness to learn. • When: Friday, June 22nd 6pm - 10pm Saturday, June 23rd 10am - 4pm • Where: UMKC Campus 302 Flarsheim Hall 5110 Rockhill Road, Kansas City, MO RSVP at: http://www.meetup.com/pythonkc/events/62339552

Editor's Notes