Version 40 (modified by Fran Boon, 14 years ago) ( diff )


Blueprint for Mobile Clients

We want clients on Mobile devices to be able to talk to Sahana Eden servers.

The simplest way to do this is to provide a layout for the web application suitable for smaller screens: BluePrintCSS

Ideally, though, they should have local storage for use completely offline & then be able to sync back to the server using whatever connectivity becomes available:

Using the open XForms standard means that we can support handsets using both Android & J2ME.

XForms editor:

XForms can be submitted using SMS by including the encoding format within the XForm so that client & server agree on the encoding:


OpenDataKit have a suite of tools to use on Android.


  • Get the jaxdroid work on Sahana compatibility merged into ODK Trunk
  • Send Images
    • Use ODK Collect to acquire photographic data through a form on the mobile client
    • Store images on the mobile device until a connection can be made to the server
    • Provide an interface in Sahana through which users can access ODK Collect to upload photos
    • Handle image storage on the server side when a user uploads a photo
    • See Sahana Eden Mobile Photo Upload Blueprint for additional information.
  • Send GPS Coordinates
    • GeoTagger is a sample Form for ODK which can be used as a template for what needs to be produced by controllers/ from location_id & image_id fields.
  • Support Component Tabs for a multi-table form
  • SMS: There are 2 APIs for sending SMS. 1 of which automatically splits up larger messages into multi-part SMS.
    • NCSU have produced some initial ODK Collect code for SMS.
      • This currently sends an SMS along with every HTTP submission of the GeoTagger form...this needs generalising to all forms & the SMS should only be sent after a prompt if the HTTP submission fails.
    • Want to be able to download Forms via SMS
      • Push updates from server
      • Pull requests from client
  • QR Code to download the Trunk version (which should update from this version & not default ODK location)
    • UserGuidelines on creating/embedding a custom QR code for a deployment-specific version


Documentation on the current implementation is here:

  • This needs updating to the latest version of JavaRosa

JavaRosa is a fast-developing framework which uses XForms & J2MEPolish:

This supports using Mesh4j to do synchronisation via SMS:


Another XForms/J2MEPolish client (Xfolite):

KUIX can be used to develop lightweight applications which work across may handhelds & forms can be customised easily via XML/CSS:

Old, un-maintained J2ME client for the PHP back-end, which just uses XML-RPC (=> requires Internet):


Sahana Software Foundation have a developer license which can be used by anyone interested in developing this.


jQuery Mobile

This has a lot of industry backing for a truly cross-platform solution:

Sencha Touch

Cross-platform (Android/iPhone) HTML5 environment based on ExtJS


Adding touch support to OpenLayers:

ExtMap Touch:

Taking the Map offline:

OpenStreetMap on Android:

Other projects



Note: See TracWiki for help on using the wiki.