Sunday 29 December 2013

Android APK (File format)


Android Application Package APK (.apk) is the set of compressed files used to distribute and install application software on well know Android Operating system by Google Inc.

Android apk contains the number of files that all contains program's code, assets, resources, permissions, certification and manifest file.

You can also check the contents of apk file by just following these steps.

  1. Rename .apk extension to .rar
  2. Extract these files with help of decompression tools such as Winrar or Winzip
Usually apk file contains the following file 

Android apk file format

  • lib
  • res
  • assets
  • classes.dex
  • AndroidManifest.xml
  • META-INF directory
  • resources.arsc

lib

It contains the compiled code that is specific to a software layer of a processor, the directory is split into more directories within it.
  • armeabi: compiled code for all ARM based processors only
  • armeabi-v7a: compiled code for all ARMv7 and above based processors only
  • x86: compiled code for x86 processors only
  • mips: compiled code for MIPS processors only

res

Contains the resources file such as layout, images and few xml files, which are not compiled into resources.arsc


Assets

It contains assets files specific to a particular project, which can be retrieved with use of Assets Manager, these files have been integrated to a project by the user. 



Classes.dex

It contains the compiled classes in the dex format, which is being understandable by Dalvik Virtual Machine


AndroidManifest.xml

 An additional Android manifest file, describing the name, version, access rights, referenced library files for the application. 


META-INF directory

Its java's internal meta directory contains the following files 
  • MANIFEST.MF: the Manifest file
  • CERT.RSA: The certificate of the application.
  • CERT.SF: The list of resources and SHA-1 digest of the corresponding lines in the MANIFEST.MF file

resources.arsc

Contains the pre compiled resources file such as layout, images and few xml files




Thursday 26 December 2013

Different ways to Install apk.

There are different ways to install apk other than market, here are few check it out.


  1.  Using USB 

  • Connect USB to your PC
  • If you device OS version is greater than 2.3 then 
    • Settings
    • Developer Option
    • Check Install from Unknown resource
  • If you device OS version is 2.3 or less 
    • Settings
    • Applications
    • Check Unknown resource
  • Copy apk file into your SD card or Phone Internal Memory
  • Locate the apk file & click on it. 
  • Select package installer 


    2. Using AirDroid



  • Select App as shown in red box for below image and also drag and drop apk into the green box shown. 

  •  Mission Accomplished 



      3. Using Command Line






Happy Installing....
Feel free to add any other mothod.

Thursday 12 December 2013

Android Native Data to HTML page

Here comes one more Blog on HTML5.

Have you ever tried sending data from Android native to HTML page? like SMS, Call, JSON Array etc.

This blog gives you a clear picture how to pass Data to HTML5.

I have created 2 methods getTimeAndroid() which passes String to setTime() (javascript method)and getValueJson() passes JsonArray to setJson() (javascript method) respectively.

You need a "JavascriptInterface" which is a class written by you in your activity, a HTML page where you define methods & pass arguments to Android java class.






Android Native code 



package com.rnd.rnd;

import java.text.SimpleDateFormat;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.annotation.SuppressLint;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.webkit.JavascriptInterface;
import android.webkit.WebView;

public class HtmlToAndroid extends Activity{
WebView mWebview;
@SuppressLint("SetJavaScriptEnabled")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.html_layout);
// Assing webview object
mWebview = (WebView)findViewById(R.id.webview);
// Load your html page here
// Enable javascript 
mWebview.getSettings().setJavaScriptEnabled(true);
// Adding javascript interface to your page. 
// Pass the JavaScriptInterface class & related String "AndroidNativeCode" which will be used to call android methods written below. 
mWebview.addJavascriptInterface(new JavaScriptInterface(this), "AndroidNativeCode");
mWebview.loadUrl("file:///android_asset/www/index.html");
}
public class JavaScriptInterface {
        Context mContext;

     
        JavaScriptInterface(Context c) {
            mContext = c;
        }

        // Simple method to pass Data to HTML
        
     @SuppressLint("SimpleDateFormat")
@JavascriptInterface
        public void getTimeAndroid() {
     
    long date = System.currentTimeMillis(); 

SimpleDateFormat sdf = new SimpleDateFormat("dd MMM yyyy HH:mm");
             mWebview.loadUrl("javascript:setTime('"+sdf.format(date)+"')");
     
        }
     
     // method to send JsonArray to HTML
     @JavascriptInterface
     public void getValueJson() throws JSONException
     {
    JSONArray jArray = new JSONArray();
      
     
      JSONObject jObject = new JSONObject();
      
      jObject.put("Name", "Jackson");
      jObject.put("Age","24");
      jArray.put(jObject);
      
      jObject = new JSONObject();
      jObject.put("Name", "Jenny");
      jObject.put("Age","23");
      jArray.put(jObject);
      
      jObject = new JSONObject();
      jObject.put("Name", "Fenny");
      jObject.put("Age","28");
      jArray.put(jObject);
      
      mWebview.loadUrl("javascript:setJson("+jArray+")");
          
      
     }
        
    }
}


HTML page

<html>
<head>
<title>Android is Awesome!!</title>

<script type="text/javascript">

function getTime()
{
AndroidNativeCode.getTimeAndroid();
}



function setTime(time)
{
document.getElementById('datetime').innerHTML = time;
}


function getJson()
{
AndroidNativeCode.getValueJson();
}

function setJson(Jsonobject)
{

var log="";
for(var i =0; i<Jsonobject.length;i++)
{
log+= Jsonobject[i].Name +" : "+ Jsonobject[i].Age + "<br> <br>" ;

}
document.getElementById('JsonDiv').innerHTML = log;
}
</script>

</head>

<body>
<br>
<h1>Android DATA to HTML</h1>
<br>
<Button onclick="getTime()">Time</Button>
<div id="datetime"></div>


<Button onclick="getJson()">JSon Data</Button>
<div id="JsonDiv"></div>

</div>


</body>
</html>



Android Layout


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <WebView
        android:id="@+id/webview"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</LinearLayout>

If you like it then please share it. Also if you know anything like please feel free to share

Also see 


  1. Also check out how to operate your Android phone from Window OS. 
  2. Android apk generation through command line 
  3. Android SQL browsing through Windows
  4. Access Android Native code from HTML
  5. ADB over Wifi 
  6. EditText to TextView conversion 
  7. SVN for Android Eclipse



Wednesday 4 December 2013

HTML to Android Code Access - android html


Acess Android native code from HTML, Its not that tough as you think to access native code of Android.
You just need a "JavascriptInterface" which is a class written by you in your activity, a HTML page where you define methods & pass arguments to Android java class.

I have created a sample Android java class to
1. Show a Toast Notification
2. Alert builder
3. Progress Dialog


1. Show a Toast Notification
From html you will call below method like this, where you will pass the message to your Toast Notification
AndroidNativeCode.showToast(message);



2. Alert builder
From html you will call below method like this, where you will pass the Title & Message for AlertBuilder

AndroidNativeCode.showAlertDialog(title,message);





3. Progress Dialog
From html you will call below method like this, where you will pass integer to ProgressDialog, which will be active for defined milliseconds by you.

AndroidNativeCode.showProgressDialog(parseInt(seconds));



Android java code is as follows

import android.app.Activity;
import android.app.AlertDialog;
import android.app.AlertDialog.Builder;
import android.app.ProgressDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.os.Bundle;
import android.os.Handler;
import android.webkit.JavascriptInterface;
import android.webkit.WebView;
import android.widget.Toast;

public class HtmlToAndroid extends Activity{
WebView mWebview;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.html_layout);

// Assing webview object
mWebview = (WebView)findViewById(R.id.webview);

// Load your html page here
mWebview.loadUrl("file:///android_asset/www/index.html");

// Enable javascript
mWebview.getSettings().setJavaScriptEnabled(true);

// Adding javascript interface to your page.
// Pass the JavaScriptInterface class & related String "AndroidNativeCode" which will be used to call android methods written below.
// ex  AndroidNativeCode.showToast("Your toast notification")
mWebview.addJavascriptInterface(new JavaScriptInterface(this), "AndroidNativeCode");


}

public class JavaScriptInterface {
        Context mContext;

   
        JavaScriptInterface(Context c) {
            mContext = c;
        }

        // Simple method to display Toast Notification
     @JavascriptInterface
        public void showToast(String toast) {
            Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
   
        }
   
     // Simple method to disply Alert Dialog
     @JavascriptInterface
        public void showAlertDialog(String title, String message)
        {
        Builder alert = new AlertDialog.Builder(mContext);
       
        alert.setTitle(title);
        alert.setMessage(message);
       
        alert.setPositiveButton("Cool",new  DialogInterface.OnClickListener() {

@Override
public void onClick(DialogInterface dialog, int which) {


}
});
       
        alert.show();
        }
   
   
     // Simple method to display Progress Dialog
     @JavascriptInterface
        public void showProgressDialog(int seconds)
        {
        final ProgressDialog l_progressDialog = new ProgressDialog(mContext);
       
        l_progressDialog.setMessage("HTML to Android code");
        l_progressDialog.setTitle("Wait for "+seconds+" miliseconds");
        l_progressDialog.setCanceledOnTouchOutside(false);
       
        l_progressDialog.show();
       
        Handler handler = new Handler();
    handler.postDelayed(new Runnable() {
    public void run() {
   
    l_progressDialog.dismiss();
    }
    }, seconds);
       
        }
     
    }
}



Layout code is as follows

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <WebView
        android:id="@+id/webview"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</LinearLayout>




HTML page which needs to be put in Android Project assets folder inside www folder. 

<html>
<head>
<title>Android is Awesome!!</title>

<script type="text/javascript">
function getAlert()
{
var title = document.getElementById('alert_title').value;
var message = document.getElementById('alert_message').value;
AndroidNativeCode.showAlertDialog(title,message);
}

function getToast()
{
var message = document.getElementById('toast_input').value;
AndroidNativeCode.showToast(message);
}

function getProgressDialog()
{
var seconds = document.getElementById('progress_input').value;
AndroidNativeCode.showProgressDialog(parseInt(seconds));
}

</script>

</head>

<body>
<br>
<center><h1>HTML to Android Native code access</h1></center>
<br><br>
<div>
Toast Message: <input type="text" id="toast_input"/>
<br>
<Button onclick="getToast()">Toast Message</Button>
</div>


<br><br>
<div>
Alert Dialog Title : &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<input type="text" id="alert_title"/>
<br>
Alert Dialog Message : <input type="text" id="alert_message"/>
<br>
<Button onclick="getAlert()">Get Alert</Button>
</div>


<br><br>
<div>
Progress Dialog Timing : <input type="number" id="progress_input"/>
<br>
<Button onclick="getProgressDialog()">Get Progress Dialog</Button>
</div>


</body>
</html>


Let me know if you have any doubts.