We need to inflate a listview in 2 cases.
1. When we want to display a listview at run time
2. When we need a custom listview
We will see both the cases with examples.
Case 1: In this example we will inflate a listview. See how
Android Layout File
File: res/layout/main.xml
File: res/layout/activity_main.xml
The same thing we can do without inflating in a simple way by including listview in our main.xml and adding
final ListView listview = (ListView) findViewById(R.id.listview);
instead of
final LayoutInflater inflater = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);
ListView t = (ListView)inflater.inflate(R.layout.activity_main,null);
ILayout = (LinearLayout)findViewById(R.id.layout1);
ILayout.addView(t);
Case 2: We will create a custom listview having a image & text in it. To create a custom listview,we need to create custom adapter. In this example we will use arrayadapter for easy understanding. You will need 2 layout files. One, main.xml, will define the attributes of the ListView. The other, mainlvitem.xml, will be the layout of each individual row in the ListView.
File: res/layout/main.xml:
We have used default images which comes with drawable folder ic_launcher in this program.However you can use any other image as you want. You need to put those images in appropriate folder.
1. When we want to display a listview at run time
2. When we need a custom listview
We will see both the cases with examples.
Case 1: In this example we will inflate a listview. See how
Android Layout File
File: res/layout/main.xml
<linearlayout android:id="@+id/layout1" android:layout_height="match_parent" android:layout_width="match_parent" android:orientation="vertical" xmlns:android="http://schemas.android.com/apk/res/android"> <textview android:id="@+id/namelabel" android:layout_height="wrap_content" android:layout_width="wrap_content" android:text="Text Paragraph."> </textview> </linearlayout>We have another layout file activity_main having listview in it.
File: res/layout/activity_main.xml
<ListView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/listview" android:layout_width="fill_parent" android:layout_height="fill_parent" android:cacheColorHint="#EEEEEE" android:background="#CCCCCC" />We are going to inflate layout activity_main in our main activity.Our main inflatelistview activity is as follows.
package com.example.inflatelistview; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import android.os.Bundle; import android.app.Activity; import android.content.Context; import android.view.LayoutInflater; import android.view.Menu; import android.widget.AdapterView; import android.widget.ArrayAdapter; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.TextView; public class inflatelistview extends Activity { LinearLayout ILayout; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); final LayoutInflater inflater = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE); ListView t = (ListView)inflater.inflate(R.layout.activity_main,null); ILayout = (LinearLayout)findViewById(R.id.layout1); ILayout.addView(t); String[] values = new String[] { "Item1","Item2","Item3","Item4"}; final ArrayListlist = new ArrayList (); for (int i = 0; i < values.length; ++i) { list.add(values[i]); } final OurArrayAdapter adapter = new OurArrayAdapter(this, android.R.layout.simple_list_item_1, list); t.setAdapter(adapter); } private class OurArrayAdapter extends ArrayAdapter { HashMap MapValue = new HashMap (); public OurArrayAdapter(Context context, int textViewResourceId, List objects) { super(context, textViewResourceId, objects); for (int i = 0; i < objects.size(); ++i) { MapValue.put(objects.get(i), i); } } @Override public long getItemId(int position) { String item = getItem(position); return MapValue.get(item); } @Override public boolean hasStableIds() { return true; } } }
The same thing we can do without inflating in a simple way by including listview in our main.xml and adding
final ListView listview = (ListView) findViewById(R.id.listview);
instead of
final LayoutInflater inflater = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);
ListView t = (ListView)inflater.inflate(R.layout.activity_main,null);
ILayout = (LinearLayout)findViewById(R.id.layout1);
ILayout.addView(t);
Case 2: We will create a custom listview having a image & text in it. To create a custom listview,we need to create custom adapter. In this example we will use arrayadapter for easy understanding. You will need 2 layout files. One, main.xml, will define the attributes of the ListView. The other, mainlvitem.xml, will be the layout of each individual row in the ListView.
File: res/layout/main.xml:
<ListView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/listview" android:layout_width="fill_parent" android:layout_height="fill_parent" android:cacheColorHint="#EEEEEE" android:background="#CCCCCC" />Next File,res/layout/mainlvitem.xml:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="horizontal" android:paddingLeft="4dp" android:paddingRight="15dp" android:paddingTop="13dp" android:paddingBottom="13dp" android:weightSum="1" android:background="#FFFFFF" > <ImageView android:id="@+id/img" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_vertical" android:layout_weight="0.10" /> <TextView android:id="@+id/txt" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_gravity="center" android:gravity="left" android:layout_weight="0.90" android:paddingLeft="10dp" android:textColor="#222222"/> </LinearLayout>Now the main activity is
package com.example.inflatelistview; import android.app.Activity; import android.content.Context; import android.os.Bundle; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ArrayAdapter; import android.widget.ImageView; import android.widget.ListView; import android.widget.TextView; public class customlistview extends Activity { // We will declare some variables within the class, but outside of any method so that // any method can use them. ListView lv; // The ListView we will be building // A String[] array that will hold the names of the items. String[] mItems = { "Item1", "Item2", "Item3" }; // An Integer[] array that will hold the resource drawables that will be displayed as icons. Integer[] mIcons = { R.drawable.ic_launcher, R.drawable.ic_launcher, R.drawable.ic_launcher }; // ----------------------------------------------- // onCreate() // ----------------------------------------------- @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // Here we will take the ListView that we declared in activity_main layout lv = (ListView) findViewById(R.id.listview); // Instead of using a regular ArrayAdapter to pull Strings from an array, // we will create a custom ArrayAdapter below. This bit of code sets the adapter // of our ListView, lv, to our customer adapter. ArrayAdapteradapter = new CustomAdapter(this, R.layout.mainlvitem, mItems); lv.setAdapter(adapter); } // end onCreate // ----------------------------------------------- // This is our custom ArrayAdapter, CustomAdapter // ----------------------------------------------- public class CustomAdapter extends ArrayAdapter { public CustomAdapter(Context context, int textViewResourceId, String[] objects) { super(context, textViewResourceId, objects); } @Override public View getView(int position, View convertView, ViewGroup parent) { // Inflate the layout, mainlvitem.xml, in each row. LayoutInflater inflater = customlistview.this.getLayoutInflater(); View row = inflater.inflate(R.layout.mainlvitem, parent, false); // Declare and define the TextView, "item." This is where // the name of each item will appear. TextView item = (TextView)row.findViewById(R.id.txt); item.setText(mItems[position]); // Declare and define the TextView, "icon." This is where // the icon in each row will appear. ImageView icon=(ImageView)row.findViewById(R.id.img); icon.setImageResource(mIcons[position]); return row; } } // end CustomAdapter }
We have used default images which comes with drawable folder ic_launcher in this program.However you can use any other image as you want. You need to put those images in appropriate folder.