Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to use addHeaderView to add a simple ImageView to a ListView

My target is simple. I want to add a "Red Rectangle" as a headerview to a ListView. so I create a simple activity

public class MainActivity extends Activity {
    private String[] adapterData = new String[] { "Afghanistan", "Albania", "Algeria", 
            "American Samoa", "Andorra", "Angola"}; 

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

        ListView lv;
        lv = (ListView)findViewById(R.id.list);

        LayoutInflater lf;
        View headerView;
        lf = this.getLayoutInflater();
        headerView = (View)lf.inflate(R.layout.header, null, false);

        lv.addHeaderView(headerView, null, false);

        lv.setAdapter(new ArrayAdapter<String>(this, R.layout.list_item, adapterData)); 
    }
}

activity_main.xml

<ListView xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/list"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#FF0" 
        android:cacheColorHint="#0000"
        android:paddingLeft="20dip"
        android:paddingRight="20dip"
        android:divider="#0000"
        android:scrollbarStyle="outsideOverlay" />

list_item.xml

<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/text1"
    android:layout_width="match_parent"
    android:layout_height="0dip"
    android:minHeight="40dip"
    android:singleLine="true"
    android:textAppearance="?android:attr/textAppearanceLarge"
    android:gravity="center_vertical"
/>

most important, header.xml

<?xml version="1.0" encoding="utf-8"?>
<ImageView xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="100dip"
    android:background="#F00"/>

But it doesn't seem to work. Nothing is displayed.

Can any give some suggestions on this? Your help is highly appreciated.

like image 356
user1764413 Avatar asked Oct 22 '12 05:10

user1764413


1 Answers

Old question, but I just copied it and run it and indeed the red doesn't show up.

You're missing one simple thing: Regardless of how you call inflate you always1 have to pass a parent view (second param) so that it can figure out which LayoutParams subclass to instantiate.
1: there are always1 exceptions

.inflate(R.layout.header, lv, false)

For more on the subject I highly suggest: http://www.doubleencore.com/2013/05/layout-inflation-as-intended/ (worth reading even a few times)

Your full code modified (xml files can stay as is):

public class MainActivity extends Activity {
    private static final String[] ADAPTER_DATA = {
            "Afghanistan", "Albania", "Algeria", "American Samoa", "Andorra", "Angola"
    };

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

        ListView list = (ListView) findViewById(R.id.list);
        View header = getLayoutInflater().inflate(R.layout.header, list, false);

        list.addHeaderView(header, null, false);
        list.setAdapter(new ArrayAdapter<String>(this, R.layout.list_item, ADAPTER_DATA));
    }
}
like image 162
TWiStErRob Avatar answered Sep 18 '22 18:09

TWiStErRob