Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Practical Difference Between position and row id in onListItemClick()

I'm confused about the difference between postion and row id in ListActivity.onListItemClick().

The documentation has the following:

position  The position of the view in the list
id        The row id of the item that was clicked

Is there any practical difference between the two? I assume, since there are two different parameters, that there are situations where the values are different, but based on the wording used in the documentation, it's hard to see what that difference may be. Is it that one of them can hold the value of a database row ID provided by a Cursor or some other special capability?

like image 969
Paul Holden Avatar asked Oct 19 '12 00:10

Paul Holden


2 Answers

position: The position of the view in the list
id: The row id of the item that was clicked

A position starts from 0, top to bottom of the ListView, whereas to get a proper row id it is important that the cursor, which was passed to the adapter, contains a column called '_id' representing unique id for each row in the table.

If you are using an ArrayAdapter, position and id become the same. The id will be the returned value of Adapter.getItemId(int) so if you use an ArrayAdapter it will be the same as the position - a quick search of the ArrayAdapter source code shows it's using return position; to work out the id.

like image 127
Lazy Ninja Avatar answered Nov 14 '22 13:11

Lazy Ninja


The answer by Lazy Ninja is mostly correct, however overlooks the case of using an ArrayAdapter with a header view added by calling the ListView.addHeaderView(View) method.

If your list has a header item, it will be at position 0.

So the first "real" item in the list will have:

  • position = 1
  • id = 0

In general, position = id + number_of_header_views


This is important to realise if you decide to add a header view to a list in code that is already working correctly.

If you are accessing your items using position, then your code needs to be updated along the following lines:

  • use position - 1 as the index
  • use id as the index
  • use ListView.getItemAtPosition(int) instead of Adapter.getItem(int)

Also see this question for related discussion:

  • ListActivity with header and toast selecting wrong list item
like image 39
Richard Le Mesurier Avatar answered Nov 14 '22 11:11

Richard Le Mesurier