Search This Blog

Tuesday, 5 June 2012

Questions and Answer for Android Interview


1)What is Android?

Android is a stack of software for mobile devices which includes an Operating System, middleware and some key applications. The application executes within its own process and its own instance of Dalvik Virtual Machine. Many Virtual Machines run efficiently by a DVM device. DVM executes Java languages byte code which later transforms into .dex format files.
2)Can I write code for Android using C/C++?
Android applications are written using the Java programming language.
Android includes a set of core libraries that provides most of the functionality available in the core libraries of the Java programming language.
Every Android application runs in its own process, with its own instance of the Dalvik virtual machine. Dalvik has been written so that a device can run multiple VMs efficiently. The Dalvik VM executes files in the Dalvik Executable (.dex) format which is optimized for minimal memory footprint. The VM is register-based, and runs classes compiled by a Java language compiler that have been transformed into the .dex format by the included “dx” tool.
Android only supports applications written using the Java programming language at this time.
3)What languages does Android support for application development?
Android applications are written using the Java programming language.
4)What Virtual Machine Android runs on?
Dalvik virtual machine
5)Android Latest Version?
Android 4.0
 6)Creating an Android Application using the Eclipse Plugin
Using the Android Eclipse plugin is the fastest and easiest way to start creating a new Android application. The plugin automatically generates the correct project structure for your application, and keeps the resources compiled for you automatically.
It is still a good idea to know what is going on though. Take a look at Overview of an Android Application to understand the basics of how an Android application works.
It is also recommended that you take a look at the ApiDemos application and the other sample applications in the samples/ folder in the SDK.
Finally, a great way to started with Android development in Eclipse is to follow both the Hello Android and Notepad code tutorials. In particular, the start of the Hello Android tutorial is an excellent introduction to creating a new Android application in Eclipse.
7)What is Android Runtime?
Android includes a set of core libraries that provides most of the functionality available in the core libraries of the Java programming language.
Every Android application runs in its own process, with its own instance of the Dalvik virtual machine. Dalvik has been written so that a device can run multiple VMs efficiently. The Dalvik VM executes files in the Dalvik Executable (.dex) format which is optimized for minimal memory footprint. The VM is register-based, and runs classes compiled by a Java language compiler that have been transformed into the .dex format by the included “dx” tool.
8)Features of Android
  • Application framework enabling reuse and replacement of components
  • Dalvik virtual machine optimized for mobile devices
  • Integrated browser based on the open source WebKit engine
  • Optimized graphics powered by a custom 2D graphics library; 3D graphics based on the OpenGL ES 1.0 specification (hardware acceleration optional)
  • SQLite for structured data storage
  • Media support for common audio, video, and still image formats (MPEG4, H.264, MP3, AAC, AMR, JPG, PNG, GIF)
  • GSM Telephony (hardware dependent)
  • Bluetooth, EDGE, 3G, and WiFi (hardware dependent)
  • Camera, GPS, compass, and accelerometer (hardware dependent)
  • Rich development environment including a device emulator, tools for debugging, memory and performance profiling, and a plugin for the Eclipse IDE.
Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
9)Describe the APK format.
The APK file is compressed the AndroidManifest.xml file, application code (.dex files), resource files, and other files. A project is compiled into a single .apk file.

10)What are the advantages of Android?
     The following are the advantages of Android:
 *  The customer will be benefited from wide range of mobile applications to choose,         since the monopoly of wireless carriers like Orange and AT&T will be broken by Google       Android.
* Features like weather details, live RSS feeds, opening screen, icon on the opening screen can be customized
* Innovative products like the location-aware services, location of a nearby convenience store etc., are some of the additive facilities in  Android.
11)Describe Briefly the Android Application Architecture

Android Application Architecture has the following components:
Services like Network Operation
Intent - To perform inter-communication between activities or services
Resource Externalization - such as strings and graphics
Notification signaling users - light, sound, icon, notification, dialog etc.
Content Providers - They share data between application.

12)What is an adb

Android Debug Bridge, a command-line debugging application shipped with the SDK. It provides tools to browse the device, copy tools on the device, and forward ports for debugging.
14)What Programming languages does Android support for application development?
Android applications supports using Java Programming Language. which is coded in Java and complied using Android SDK
15)What is APK format.
The file itself is a compressed collection of an AndroidManifest.xml file, application code (.dex files), resource files, and other files. A project is compiled into a single .apk file.
16)How to Translate in android
The Google translator translates the data of one language into another language by using XMPP to transmit data. You can type the message in English and select the language which is understood by the citizens of the country in order to reach the message to the citizens.
17)What is activity?
An
Activity is an application component that provides a screen with which users can interact in order to do something, such as dial the phone, take a photo, send an email, or view a map. Each activity is given a window in which to draw its user interface.
18)What is an action?
A description of something that an Intent sender desires.
19)What Programming languages does Android support for application development?
Android applications supports using Java Programming Language. which is coded in Java and complied using Android SDK.
20)What is a resource?
A user-supplied XML, bitmap, or other file, injected into the application build process, which can later be loaded from code.
21)What is intent in Android?
A class (Intent) will describes what a caller desires to do. The caller will send this intent to Android's intent resolver, which finds the most suitable activity for the intent. E.g. opening a PDF document is an intent, and the Adobe Reader apps will be the perfect activity for that intent(class).
22)What is an activity?
A single screen in an application, with supporting Java code.
An activity presents a visual user interface for one focused endeavor the user can undertake.
For example, an activity might present a list of menu items users can choose from or it might display photographs along with their captions.
Each one is implemented as a subclass of the Activity base class.
23)What is a service?
A service doesn’t have a visual user interface, but rather runs in the background for an indefinite period of time.
For example, a service might play background music as the user attends to other matters, or it might fetch data over the network or calculate
something and provide the result to activities that need it.
Each service extends the Service base class.
24)What is a Broadcast receivers?
A broadcast receiver is a component that does nothing but receive and react to broadcast announcements.
For example, announcements that the timezone has changed, that the battery is low or that the user changed a language preference.
All receivers extend the BroadcastReceiver base class.
Broadcast receivers do not display a user interface. However, they may start an activity in response to the information they receive,
or they may use the NotificationManager to alert the user like(flashing the backlight, vibrating the device, playing a sound)
25)What is a content provider?
A content provider makes a specific set of the application’s data available to other applications.The content provider extends the ContentProvider
base class to implement a standard set of methods that enable other applications to retrieve and store data of the type it controls.
However, applications do not call these methods directly. Rather they use a ContentResolver object and call its methods instead.
26)How do you define the user interface?
XML Format is the best.
27)Does Android support the Bluetooth serial port profile?
Yes.
28)Can an application be started on powerup?
Yes.

29)What is a Sticky Intent?
sendStickyBroadcast() performs a sendBroadcast (Intent) known as sticky, i.e. the Intent you are sending stays around after the broadcast is complete, so that others can quickly retrieve that data through the return value of registerReceiver (BroadcastReceiver, IntentFilter). In all other ways, this behaves
packet that a communication protocol can pass. The size can be fixed by some standard or decided at the time of connection

Fragmentation is a process of breaking the IP packets into smaller pieces. Fragmentation is needed when the datagram is larger than the MTU. Each fragment becomes a datagram in itself and transmitted independently from source. When received by destination they are reassembled.
the same as sendBroadcast(Intent).

30)Example for sticky broadcast
When you call registerReceiver() for that action -- even with a null BroadcastReceiver -- you get the Intent that was last broadcast for that action. Hence, you can use this to find the state of the battery without necessarily registering for all future state changes in the battery.
31)How to start a browser instance with some url ?
1
Intent intent = new Intent(Intent.ACTION_VIEW);
2
Uri u = Uri.parse("http://google.com");

3
intent.setData(u);
4
startActivity(intent);
//Function called when return from a sub activity.
1
protected void onActivityResult(int requestCode, int resultCode, String data, Bundle extras) {
2
}
32)How to retrieve the device IMEI Number
1
TelephonyManager mTelephonyMgr = (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);
2
imei = mTelephonyMgr.getDeviceId();
33)How to call a subactivity?
1
Intent intent = new Intent(this, SubActivity.class);
2
//to pass data

3
addintent.putExtra(name, value);

34)How will you record a phone call in Android? How to get a handle on Audio Stream for a call in Android?
Permissions.PROCESS_OUTGOING_CALLS: Allows an application to monitor, modify, or abort outgoing calls.

35)How the nine-patch Image different from a regular bitmap? or Different between nine-patch Image vs regular Bitmap Image

It is one of a resizable bitmap resource which is being used as backgrounds or other images on the device. The NinePatch class allows drawing a bitmap in nine sections. The four corners are unscaled; the middle of the image is scaled in both axes, the four edges are scaled into one axis.

36)Explain about the exceptions of Android?      

 The following are the exceptions that are supported by Android
 InflateException : When an error conditions are occurred, this exception is thrown
 Surface.OutOfResourceException: When a surface is not created or resized, this exception is thrown
 SurfaceHolder.BadSurfaceTypeException: This exception is thrown from the lockCanvas() method, when invoked on a Surface whose is SURFACE_TYPE_PUSH_BUFFERS
 WindowManager.BadTokenException: This exception is thrown at the time of trying to add view an invalid WindowManager.LayoutParamstoken.

37)What dialog boxes are supported in android?Android supports 4 dialog boxes:

AlertDialog: An alert dialog box supports 0 to 3 buttons and a list of selectable elements, including check boxes and radio buttons. Among the other dialog boxes, the most suggested dialog box is the alert dialog box.
ProgressDialog: This dialog box displays a progress wheel or a progress bar. It is an extension of AlertDialog and supports adding buttons.
DatePickerDialog: This dialog box is used for selecting a date by the user.
TimePickerDialog: This dialog box is used for selecting time by the user.

38)Explain IP datagram, Fragmentation and MTU ?           

IP datagram can be used to describe a portion of IP data. Each IP datagram has set of fields arranged in an order. The order is specific which helps to decode and read the stream easily. IP datagram has fields like Version, header length, Type of service, Total length, checksum, flag, protocol, Time to live, Identification, source and destination ip address, padding, options and payload.

MTU:- Maximum Transmission Unit is the size of the largest

39)What is the TTL (Time to Live)? Why is it required?

TTL is a value in data packet of Internet Protocol. It communicates to the network router whether or not the packet should be in the network for too long or discarded. Usually, data packets might not be transmitted to their intended destination within a stipulated period of time. The TTL value is set by a system default value which is an 8-bit binary digit field in the header of the packet. The purpose of TTL is, it would specify certain time limit in seconds, for transmitting the packet header. When the time is exhausted, the packet would be discarded. Each router receives the subtracts count, when the packet is discarded, and when it becomes zero, the router detects the discarded packets and sends a message, Internet Control Message Protocol message back to the originating host.
What’s the difference between file, class and activity in android?
File – It is a block of arbitrary information, or resource for storing information. It can be of any type.
Class – Its a compiled form of .Java file . Android finally used this .class files to produce an executable apk
Activity – An activity is the equivalent of a Frame/Window in GUI toolkits. It is not a file or a file type it is just a class that can be extended in Android for loading UI elements on view.

Tuesday, 8 May 2012

Worker thread


Worker thread

Worker threads are background threads. They are the threads that are created separately, other than the UI thread. Since blocking the UI thread is restricted according to the rule, user should run the child processes and tasks in worker threads. 

An example for creation and working of worker thread is given below:

public void onClick(View v) {
    new Thread(new Runnable() {
        public void run() {
            Bitmap b = loadImageFromNetwork("http://example.com/image.png");
            mImageView.setImageBitmap(b);
        }
    }).start();
}

In the above example code, the download operation is handled by a second thread other than the UI thread. But the program violates the second rule. The imageView from UI thread is manipulating from this worker thread.

According to the second rule, UI could not be accessed from outside the UI thread. Solution for such a restriction is runOnUiThread(Runnable) method. The main or UI thread can be accessed from other threads using runOnUiThread(Runnable) method.
As a result, the specified runnable action passed through this method will run on the UI thread. The action will execute immediately, if the current thread is in the UI itself. Else the action will be posted to the event queue.

An example code:

MainClassName.this.runOnUiThread(new Runnable() {
                    public void run() {
                        textViewObject.setText("Set this " + value from worker thread + "!");
                    }
                });

Only using the methods like runOnUiThread(Runnable), the program can touch the UI views.

Handlers and Runnable

A better solution to process the messages delivered from the UI thread is handlers. The runnable objects can also be processed using the handlers. Runnable is a command that can be executed. It is used to run the code in other thread.

An example that users handlers and runnable objects in worker thread is given here;

WorkerThreadActivity.class

package com.febi.worker;

import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;

import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.view.View;
import android.widget.ImageView;

public class WorkerThreadActivity extends Activity{
          ImageView image;
          String url="http://icons.iconarchive.com/icons/icons-land/sport/256/Soccer-Ball-icon.png";
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main); 
    }
    public void onClick(View v){ 
        final Handler threadHandler; 
        final Context cbt; 
         
        cbt = this; 
        threadHandler = new Handler(); 
         
        new Thread(new Runnable() { 
            @Override 
            public void run() {
                  
                threadHandler.post(new Runnable() { 
                    @Override 
                    public void run() { 
//                        
                            
                             InputStream is = null;
                             try{
                             URL ulrn = new URL(url);
                        HttpURLConnection con = (HttpURLConnection)ulrn.openConnection();
                        is = con.getInputStream();
                             }catch(Exception e)
                             {
                                      Log.i("LOGCAT Run", ""+e);
                             }
                        Bitmap bmp = BitmapFactory.decodeStream(is);

                            
                             ImageView image=(ImageView)findViewById(R.id.imageView1);
                             image.setImageBitmap(bmp);
                    } 
                }); 
            } 
        }).start();
       
      AlertDialog.Builder ab = new AlertDialog.Builder(cbt); 
      ab.setMessage("A message sent from UI thread"); 
      ab.show();
    } 
         
}

main.xml

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

    <TextView
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/hello" />
   
    <Button android:layout_width="100dp"
        android:layout_height="wrap_content"
        android:text="Click Me"
        android:onClick="onClick"
        />

    <ImageView
        android:id="@+id/imageView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        />

</LinearLayout>

Set permission for Internet in manifest file ;

<uses-permission android:name="android.permission.INTERNET"/>

JSON Parsing


JSON Parsing

JSON is JavaScript Object Notation. JSON parsing is the most comfort and straightforward method to parse responses from web services. It is also a better option other than the xml parsing method.

A sample example that parses the data from a web server; http://api.androidhive.info/contacts/ is given below. This program fetches and parses only name and email data from the web.
JSONParsingExample.class

package php.sql;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.os.Bundle;
import android.util.Log;
import android.view.View;

public class JSONParsingExample  extends Activity
{
          InputStream is;
          String result = "";
          String data = "";
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
    }
    public void click(View v)
    {

        //http post
        try{
                HttpClient httpclient = new DefaultHttpClient();
                HttpPost httppost = new HttpPost("http://api.androidhive.info/contacts/");
                //httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
                HttpResponse response = httpclient.execute(httppost);
                HttpEntity entity = response.getEntity();
                is = entity.getContent();
        }catch(Exception e){
                Log.e("log_tag", "Error in http connection "+e.toString());
        }
       
        //convert response to string
        try{
                BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
                StringBuilder sb = new StringBuilder();
                String line = null;
                while ((line = reader.readLine()) != null) {
                        sb.append(line + "\n");
                }
                is.close();
          
                result=sb.toString();
        }catch(Exception e){
                Log.e("log_tag", "Error converting result "+e.toString());
        }
         
        //parse json data
        try{
     
         
          JSONObject jObj = new JSONObject(result);
          JSONArray jArray =jObj.getJSONArray("contacts");
              //JSONArray jArray = new JSONArray(result);
               
                for(int i=0;i<jArray.length();i++){
                        JSONObject json_data = jArray.getJSONObject(i);
                     
                        String std=json_data.getString("name");
                        String place=json_data.getString("email");
                     
                        data=data+"\n"+std+"  "+place;
                        Log.i("log_tag",result);
                       
                }
        }
       
        catch(JSONException e)
        {
                Log.e("log_tag", "Error parsing data "+e.toString());
        }
        new AlertDialog.Builder(this).setPositiveButton("Ok",new OnClickListener() {

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

            }
    }).setMessage(data).setTitle("Student Details").create().show();
    }
}

main.xml

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

    <Button android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Generate Result"
        android:layout_marginTop="40dp"
        android:layout_gravity="center"
       
        android:onClick="click"/>
</LinearLayout>

XML Parsing

AndroidXmlParsingActivity.class

package com.androidhive.xmlparsing;

import java.util.ArrayList;
import java.util.HashMap;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;

import android.app.ListActivity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.TextView;

public class AndroidXMLParsingActivity extends ListActivity {

          // All static variables
          static final String URL = "http://api.androidhive.info/pizza/?format=xml";
          // XML node keys
          static final String KEY_ITEM = "item"; // parent node
          static final String KEY_ID = "id";
          static final String KEY_NAME = "name";
          static final String KEY_COST = "cost";
          static final String KEY_DESC = "description";

          @Override
          public void onCreate(Bundle savedInstanceState) {
                   super.onCreate(savedInstanceState);
                   setContentView(R.layout.main);

                   ArrayList<HashMap<String, String>> menuItems = new ArrayList<HashMap<String, String>>();

                   XMLParser parser = new XMLParser();
                   String xml = parser.getXmlFromUrl(URL); // getting XML
                   Document doc = parser.getDomElement(xml); // getting DOM element

                   NodeList nl = doc.getElementsByTagName(KEY_ITEM);
                   // looping through all item nodes <item>
                   for (int i = 0; i < nl.getLength(); i++) {
                             // creating new HashMap
                             HashMap<String, String> map = new HashMap<String, String>();
                             Element e = (Element) nl.item(i);
                             // adding each child node to HashMap key => value
                             map.put(KEY_ID, parser.getValue(e, KEY_ID));
                             map.put(KEY_NAME, parser.getValue(e, KEY_NAME));
                             map.put(KEY_COST, "Rs." + parser.getValue(e, KEY_COST));
                             map.put(KEY_DESC, parser.getValue(e, KEY_DESC));

                             // adding HashList to ArrayList
                             menuItems.add(map);
                   }

                   // Adding menuItems to ListView
                   ListAdapter adapter = new SimpleAdapter(this, menuItems,
                                      R.layout.list_item,
                                      new String[] { KEY_NAME, KEY_DESC, KEY_COST }, new int[] {
                                                          R.id.name, R.id.desciption, R.id.cost });

                   setListAdapter(adapter);

                   // selecting single ListView item
                   ListView lv = getListView();

                   lv.setOnItemClickListener(new OnItemClickListener() {

                             @Override
                             public void onItemClick(AdapterView<?> parent, View view,
                                                int position, long id) {
                                      // getting values from selected ListItem
                                      String name = ((TextView) view.findViewById(R.id.name)).getText().toString();
                                      String cost = ((TextView) view.findViewById(R.id.cost)).getText().toString();
                                      String description = ((TextView) view.findViewById(R.id.desciption)).getText().toString();
                                     
                                      // Starting new intent
                                      Intent in = new Intent(getApplicationContext(), SingleMenuItemActivity.class);
                                      in.putExtra(KEY_NAME, name);
                                      in.putExtra(KEY_COST, cost);
                                      in.putExtra(KEY_DESC, description);
                                      startActivity(in);

                             }
                   });
          }
}

XMLParser.class

package com.androidhive.xmlparsing;

import java.io.IOException;
import java.io.StringReader;
import java.io.UnsupportedEncodingException;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;

import android.util.Log;

public class XMLParser {

          // constructor
          public XMLParser() {

          }

          /**
           * Getting XML from URL making HTTP request
           * @param url string
           * */
          public String getXmlFromUrl(String url) {
                   String xml = null;

                   try {
                             // defaultHttpClient
                             DefaultHttpClient httpClient = new DefaultHttpClient();
                             HttpPost httpPost = new HttpPost(url);

                             HttpResponse httpResponse = httpClient.execute(httpPost);
                             HttpEntity httpEntity = httpResponse.getEntity();
                             xml = EntityUtils.toString(httpEntity);

                   } catch (UnsupportedEncodingException e) {
                             e.printStackTrace();
                   } catch (ClientProtocolException e) {
                             e.printStackTrace();
                   } catch (IOException e) {
                             e.printStackTrace();
                   }
                   // return XML
                   return xml;
          }
         
          /**
           * Getting XML DOM element
           * @param XML string
           * */
          public Document getDomElement(String xml){
                   Document doc = null;
                   DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
                   try {

                             DocumentBuilder db = dbf.newDocumentBuilder();

                             InputSource is = new InputSource();
                           is.setCharacterStream(new StringReader(xml));
                           doc = db.parse(is);

                             } catch (ParserConfigurationException e) {
                                      Log.e("Error: ", e.getMessage());
                                      return null;
                             } catch (SAXException e) {
                                      Log.e("Error: ", e.getMessage());
                      return null;
                             } catch (IOException e) {
                                      Log.e("Error: ", e.getMessage());
                                      return null;
                             }

                  return doc;
          }
         
          /** Getting node value
            * @param elem element
            */
           public final String getElementValue( Node elem ) {
               Node child;
               if( elem != null){
                   if (elem.hasChildNodes()){
                       for( child = elem.getFirstChild(); child != null; child = child.getNextSibling() ){
                           if( child.getNodeType() == Node.TEXT_NODE  ){
                               return child.getNodeValue();
                           }
                       }
                   }
               }
               return "";
           }
           
           /**
            * Getting node value
            * @param Element node
            * @param key string
            * */
           public String getValue(Element item, String str) {           
                             NodeList n = item.getElementsByTagName(str);              
                             return this.getElementValue(n.item(0));
                   }
}

SingleMenuItemActivity.class

package com.androidhive.xmlparsing;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.widget.TextView;

public class SingleMenuItemActivity  extends Activity {
         
          // XML node keys
          static final String KEY_NAME = "name";
          static final String KEY_COST = "cost";
          static final String KEY_DESC = "description";
          @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.single_list_item);
       
        // getting intent data
        Intent in = getIntent();
       
        // Get XML values from previous intent
        String name = in.getStringExtra(KEY_NAME);
        String cost = in.getStringExtra(KEY_COST);
        String description = in.getStringExtra(KEY_DESC);
       
        // Displaying all values on the screen
        TextView lblName = (TextView) findViewById(R.id.name_label);
        TextView lblCost = (TextView) findViewById(R.id.cost_label);
        TextView lblDesc = (TextView) findViewById(R.id.description_label);
        
        lblName.setText(name);
        lblCost.setText(cost);
        lblDesc.setText(description);
    }
}

main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical">
          <!-- Main ListView
                    Always give id value as list(@android:id/list)
          -->
    <ListView
        android:id="@android:id/list"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"/>

</LinearLayout>

list_item.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal"> 
    <LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">
                   <!-- Name Label -->
        <TextView
            android:id="@+id/name"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:textColor="#dc6800"
            android:textSize="16sp"
            android:textStyle="bold"
            android:paddingTop="6dip"
            android:paddingBottom="2dip" />
                   <!-- Description label -->
        <TextView
            android:id="@+id/desciption"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:textColor="#acacac"
            android:paddingBottom="2dip">
        </TextView>
        <!-- Linear layout for cost and price Cost: Rs.100 -->
        <LinearLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        <!-- Cost Label -->
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textColor="#5d5d5d"
            android:gravity="left"
            android:textStyle="bold"
            android:text="Cost: " >
        </TextView>
        <!-- Price Label -->
        <TextView
            android:id="@+id/cost"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textColor="#acacac"
            android:textStyle="bold"
            android:gravity="left">
        </TextView>
        </LinearLayout>
    </LinearLayout>

</LinearLayout>

single_list_item.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="match_parent"
  android:layout_height="match_parent">
  <!-- Name Label -->
  <TextView android:id="@+id/name_label"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:textSize="25dip"
            android:textStyle="bold"
            android:paddingTop="10dip"
            android:paddingBottom="10dip"
            android:textColor="#dc6800"/>
  <!-- Description Label -->
  <TextView android:id="@+id/description_label"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:textColor="#acacac"/>
  <!-- Price Label -->
  <TextView android:id="@+id/cost_label"
                   android:layout_width="fill_parent"
                   android:layout_height="wrap_content"
                   android:textStyle="bold"/>
</LinearLayout>