SimpleAdapter
  public
  
  
  
  class
  SimpleAdapter
  
  
  
  
    extends BaseAdapter
  
  
  
  
  
      implements
      
        Filterable, 
      
        ThemedSpinnerAdapter
      
  
  
| java.lang.Object | ||
| ↳ | android.widget.BaseAdapter | |
| ↳ | android.widget.SimpleAdapter | |
An easy adapter to map static data to views defined in an XML file. You can specify the data
 backing the list as an ArrayList of Maps. Each entry in the ArrayList corresponds to one row
 in the list. The Maps contain the data for each row. You also specify an XML file that
 defines the views used to display the row, and a mapping from keys in the Map to specific
 views.
 Binding data to views occurs in two phases. First, if a
 SimpleAdapter.ViewBinder is available,
 ViewBinder.setViewValue(android.view.View, Object, String)
 is invoked. If the returned value is true, binding has occurred.
 If the returned value is false, the following views are then tried in order:
 
- A view that implements Checkable (e.g. CheckBox). The expected bind value is a boolean.
-  TextView.  The expected bind value is a string and setViewText(android.widget.TextView, java.lang.String)is invoked.
-  ImageView. The expected bind value is a resource id or a string and
 setViewImage(android.widget.ImageView, int)orsetViewImage(android.widget.ImageView, java.lang.String)is invoked.
IllegalStateException is thrown.
Summary
| Nested classes | |
|---|---|
| 
        
        
        
        
        interface | SimpleAdapter.ViewBinderThis class can be used by external clients of SimpleAdapter to bind values to views. | 
| Inherited constants | 
|---|
| Public constructors | |
|---|---|
| 
      SimpleAdapter(Context context, List<? extends Map<String, ?>> data, int resource, String[] from, int[] to)
      Constructor | |
| Public methods | |
|---|---|
| 
        
        
        
        
        
        int | 
      getCount()
      How many items are in the data set represented by this Adapter. | 
| 
        
        
        
        
        
        View | 
      getDropDownView(int position, View convertView, ViewGroup parent)
      Gets a  | 
| 
        
        
        
        
        
        Resources.Theme | 
      getDropDownViewTheme()
      Returns the value previously set by a call to
  | 
| 
        
        
        
        
        
        Filter | 
      getFilter()
      Returns a filter that can be used to constrain data with a filtering pattern. | 
| 
        
        
        
        
        
        Object | 
      getItem(int position)
      Get the data item associated with the specified position in the data set. | 
| 
        
        
        
        
        
        long | 
      getItemId(int position)
      Get the row id associated with the specified position in the list. | 
| 
        
        
        
        
        
        View | 
      getView(int position, View convertView, ViewGroup parent)
      Get a View that displays the data at the specified position in the data set. | 
| 
        
        
        
        
        
        SimpleAdapter.ViewBinder | 
      getViewBinder()
      Returns the  | 
| 
        
        
        
        
        
        void | 
      setDropDownViewResource(int resource)
      Sets the layout resource to create the drop down views. | 
| 
        
        
        
        
        
        void | 
      setDropDownViewTheme(Resources.Theme theme)
      Sets the  | 
| 
        
        
        
        
        
        void | 
      setViewBinder(SimpleAdapter.ViewBinder viewBinder)
      Sets the binder used to bind data to views. | 
| 
        
        
        
        
        
        void | 
      setViewImage(ImageView v, int value)
      Called by bindView() to set the image for an ImageView but only if there is no existing ViewBinder or if the existing ViewBinder cannot handle binding to an ImageView. | 
| 
        
        
        
        
        
        void | 
      setViewImage(ImageView v, String value)
      Called by bindView() to set the image for an ImageView but only if there is no existing ViewBinder or if the existing ViewBinder cannot handle binding to an ImageView. | 
| 
        
        
        
        
        
        void | 
      setViewText(TextView v, String text)
      Called by bindView() to set the text for a TextView but only if there is no existing ViewBinder or if the existing ViewBinder cannot handle binding to a TextView. | 
| Inherited methods | |
|---|---|
Public constructors
SimpleAdapter
public SimpleAdapter (Context context, List<? extends Map<String, ?>> data, int resource, String[] from, int[] to)
Constructor
| Parameters | |
|---|---|
| context | Context: The context where the View associated with this SimpleAdapter is running | 
| data | List: A List of Maps. Each entry in the List corresponds to one row in the list. The
        Maps contain the data for each row, and should include all the entries specified in
        "from" | 
| resource | int: Resource identifier of a view layout that defines the views for this list
        item. The layout file should include at least those named views defined in "to" | 
| from | String: A list of column names that will be added to the Map associated with each
        item. | 
| to | int: The views that should display column in the "from" parameter. These should all be
        TextViews. The first N views in this list are given the values of the first N columns
        in the from parameter. | 
Public methods
getCount
public int getCount ()
How many items are in the data set represented by this Adapter.
| Returns | |
|---|---|
| int | Count of items. | 
See also:
getDropDownView
public View getDropDownView (int position, View convertView, ViewGroup parent)
Gets a View that displays in the drop down popup
 the data at the specified position in the data set.
| Parameters | |
|---|---|
| position | int: index of the item whose view we want. | 
| convertView | View: the old view to reuse, if possible. Note: You should
        check that this view is non-null and of an appropriate type before
        using. If it is not possible to convert this view to display the
        correct data, this method can create a new view. | 
| parent | ViewGroup: the parent that this view will eventually be attached to | 
| Returns | |
|---|---|
| View | a Viewcorresponding to the data at the
         specified position. | 
getDropDownViewTheme
public Resources.Theme getDropDownViewTheme ()
Returns the value previously set by a call to
 setDropDownViewTheme(android.content.res.Resources.Theme).
| Returns | |
|---|---|
| Resources.Theme | the Resources.Themeagainst which drop-down views are
         inflated, ornullif one has not been explicitly set | 
getFilter
public Filter getFilter ()
Returns a filter that can be used to constrain data with a filtering pattern.
This method is usually implemented by Adapter
 classes.
| Returns | |
|---|---|
| Filter | a filter used to constrain data | 
getItem
public Object getItem (int position)
Get the data item associated with the specified position in the data set.
| Parameters | |
|---|---|
| position | int: Position of the item whose data we want within the adapter's
 data set. | 
| Returns | |
|---|---|
| Object | The data at the specified position. | 
See also:
getItemId
public long getItemId (int position)
Get the row id associated with the specified position in the list.
| Parameters | |
|---|---|
| position | int: The position of the item within the adapter's data set whose row id we want. | 
| Returns | |
|---|---|
| long | The id of the item at the specified position. | 
See also:
getView
public View getView (int position, View convertView, ViewGroup parent)
Get a View that displays the data at the specified position in the data set. You can either
 create a View manually or inflate it from an XML layout file. When the View is inflated, the
 parent View (GridView, ListView...) will apply default layout parameters unless you use
 LayoutInflater.inflate(int, android.view.ViewGroup, boolean)
 to specify a root view and to prevent attachment to the root.
| Parameters | |
|---|---|
| position | int: The position of the item within the adapter's data set of the item whose view
        we want. | 
| convertView | View: The old view to reuse, if possible. Note: You should check that this view
        is non-null and of an appropriate type before using. If it is not possible to convert
        this view to display the correct data, this method can create a new view.
        Heterogeneous lists can specify their number of view types, so that this View is
        always of the right type (seeBaseAdapter.getViewTypeCount()andBaseAdapter.getItemViewType(int)). | 
| parent | ViewGroup: The parent that this view will eventually be attached to | 
| Returns | |
|---|---|
| View | A View corresponding to the data at the specified position. | 
See also:
getViewBinder
public SimpleAdapter.ViewBinder getViewBinder ()
Returns the ViewBinder used to bind data to views.
| Returns | |
|---|---|
| SimpleAdapter.ViewBinder | a ViewBinder or null if the binder does not exist | 
setDropDownViewResource
public void setDropDownViewResource (int resource)
Sets the layout resource to create the drop down views.
| Parameters | |
|---|---|
| resource | int: the layout resource defining the drop down views | 
setDropDownViewTheme
public void setDropDownViewTheme (Resources.Theme theme)
Sets the Resources.Theme against which drop-down views are
 inflated.
 
 By default, drop-down views are inflated against the theme of the
 Context passed to the adapter's constructor.
| Parameters | |
|---|---|
| theme | Resources.Theme: the theme against which to inflate drop-down views ornullto use the theme from the adapter's context | 
See also:
setViewBinder
public void setViewBinder (SimpleAdapter.ViewBinder viewBinder)
Sets the binder used to bind data to views.
| Parameters | |
|---|---|
| viewBinder | SimpleAdapter.ViewBinder: the binder used to bind data to views, can be null to
        remove the existing binder | 
See also:
setViewImage
public void setViewImage (ImageView v, int value)
Called by bindView() to set the image for an ImageView but only if
 there is no existing ViewBinder or if the existing ViewBinder cannot
 handle binding to an ImageView.
 This method is called instead of setViewImage(android.widget.ImageView, java.lang.String)
 if the supplied data is an int or Integer.
| Parameters | |
|---|---|
| v | ImageView: ImageView to receive an image | 
| value | int: the value retrieved from the data set | 
See also:
setViewImage
public void setViewImage (ImageView v, String value)
Called by bindView() to set the image for an ImageView but only if
 there is no existing ViewBinder or if the existing ViewBinder cannot
 handle binding to an ImageView.
 By default, the value will be treated as an image resource. If the
 value cannot be used as an image resource, the value is used as an
 image Uri.
 This method is called instead of setViewImage(android.widget.ImageView, int)
 if the supplied data is not an int or Integer.
| Parameters | |
|---|---|
| v | ImageView: ImageView to receive an image | 
| value | String: the value retrieved from the data set | 
See also:
setViewText
public void setViewText (TextView v, String text)
Called by bindView() to set the text for a TextView but only if there is no existing ViewBinder or if the existing ViewBinder cannot handle binding to a TextView.
| Parameters | |
|---|---|
| v | TextView: TextView to receive text | 
| text | String: the text to be set for the TextView | 
Content and code samples on this page are subject to the licenses described in the Content License. Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
Last updated 2025-02-10 UTC.
