SimpleCursorAdapter
public
class
SimpleCursorAdapter
extends ResourceCursorAdapter
java.lang.Object | ||||
↳ | android.widget.BaseAdapter | |||
↳ | android.widget.CursorAdapter | |||
↳ | android.widget.ResourceCursorAdapter | |||
↳ | android.widget.SimpleCursorAdapter |
An easy adapter to map columns from a cursor to TextViews or ImageViews
defined in an XML file. You can specify which columns you want, which
views you want to display the columns, and the XML file that defines
the appearance of these views.
Binding occurs in two phases. First, if a
SimpleCursorAdapter.ViewBinder
is available,
ViewBinder#setViewValue(android.view.View, android.database.Cursor, int)
is invoked. If the returned value is true, binding has occured. If the
returned value is false and the view to bind is a TextView,
setViewText(android.widget.TextView, java.lang.String)
is invoked. If the returned value
is false and the view to bind is an ImageView,
setViewImage(android.widget.ImageView, java.lang.String)
is invoked. If no appropriate
binding can be found, an IllegalStateException
is thrown.
If this adapter is used with filtering, for instance in an
AutoCompleteTextView
, you can use the
SimpleCursorAdapter.CursorToStringConverter
and the
FilterQueryProvider
interfaces
to get control over the filtering process. You can refer to
convertToString(android.database.Cursor)
and
CursorAdapter.runQueryOnBackgroundThread(java.lang.CharSequence)
for more information.
Summary
Nested classes | |
---|---|
interface |
SimpleCursorAdapter.CursorToStringConverter
This class can be used by external clients of SimpleCursorAdapter to define how the Cursor should be converted to a String. |
interface |
SimpleCursorAdapter.ViewBinder
This class can be used by external clients of SimpleCursorAdapter to bind values fom the Cursor to views. |
Inherited constants |
---|
Public constructors | |
---|---|
SimpleCursorAdapter(Context context, int layout, Cursor c, String[] from, int[] to)
This constructor is deprecated.
This option is discouraged, as it results in Cursor queries
being performed on the application's UI thread and thus can cause poor
responsiveness or even Application Not Responding errors. As an alternative,
use |
|
SimpleCursorAdapter(Context context, int layout, Cursor c, String[] from, int[] to, int flags)
Standard constructor. |
Public methods | |
---|---|
void
|
bindView(View view, Context context, Cursor cursor)
Binds all of the field names passed into the "to" parameter of the constructor with their corresponding cursor columns as specified in the "from" parameter. |
void
|
changeCursorAndColumns(Cursor c, String[] from, int[] to)
Change the cursor and change the column-to-view mappings at the same time. |
CharSequence
|
convertToString(Cursor cursor)
Returns a CharSequence representation of the specified Cursor as defined by the current CursorToStringConverter. |
SimpleCursorAdapter.CursorToStringConverter
|
getCursorToStringConverter()
Returns the converter used to convert the filtering Cursor into a String. |
int
|
getStringConversionColumn()
Return the index of the column used to get a String representation of the Cursor. |
SimpleCursorAdapter.ViewBinder
|
getViewBinder()
Returns the |
void
|
setCursorToStringConverter(SimpleCursorAdapter.CursorToStringConverter cursorToStringConverter)
Sets the converter used to convert the filtering Cursor into a String. |
void
|
setStringConversionColumn(int stringConversionColumn)
Defines the index of the column in the Cursor used to get a String representation of that Cursor. |
void
|
setViewBinder(SimpleCursorAdapter.ViewBinder viewBinder)
Sets the binder used to bind data to views. |
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. |
Cursor
|
swapCursor(Cursor c)
Swap in a new Cursor, returning the old Cursor. |
Inherited methods | |
---|---|
Public constructors
SimpleCursorAdapter
public SimpleCursorAdapter (Context context, int layout, Cursor c, String[] from, int[] to)
This constructor is deprecated.
This option is discouraged, as it results in Cursor queries
being performed on the application's UI thread and thus can cause poor
responsiveness or even Application Not Responding errors. As an alternative,
use LoaderManager
with a CursorLoader
.
Constructor the enables auto-requery.
Parameters | |
---|---|
context |
Context |
layout |
int |
c |
Cursor |
from |
String |
to |
int |
SimpleCursorAdapter
public SimpleCursorAdapter (Context context, int layout, Cursor c, String[] from, int[] to, int flags)
Standard constructor.
Parameters | |
---|---|
context |
Context : The context where the ListView associated with this
SimpleListItemFactory is running |
layout |
int : resource identifier of a layout file that defines the views
for this list item. The layout file should include at least
those named views defined in "to" |
c |
Cursor : The database cursor. Can be null if the cursor is not available yet. |
from |
String : A list of column names representing the data to bind to the UI. Can be null
if the cursor is not available yet. |
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. Can be null if the cursor is not available yet. |
flags |
int : Flags used to determine the behavior of the adapter,
as per CursorAdapter#CursorAdapter(Context, Cursor, int) . |
Public methods
bindView
public void bindView (View view, Context context, Cursor cursor)
Binds all of the field names passed into the "to" parameter of the
constructor with their corresponding cursor columns as specified in the
"from" parameter.
Binding occurs in two phases. First, if a
SimpleCursorAdapter.ViewBinder
is available,
ViewBinder#setViewValue(android.view.View, android.database.Cursor, int)
is invoked. If the returned value is true, binding has occured. If the
returned value is false and the view to bind is a TextView,
setViewText(android.widget.TextView, java.lang.String)
is invoked. If the returned value is
false and the view to bind is an ImageView,
setViewImage(android.widget.ImageView, java.lang.String)
is invoked. If no appropriate
binding can be found, an IllegalStateException
is thrown.
Parameters | |
---|---|
view |
View : Existing view, returned earlier by newView |
context |
Context : Interface to application's global information |
cursor |
Cursor : The cursor from which to get the data. The cursor is already
moved to the correct position. |
Throws | |
---|---|
IllegalStateException |
if binding cannot occur |
changeCursorAndColumns
public void changeCursorAndColumns (Cursor c, String[] from, int[] to)
Change the cursor and change the column-to-view mappings at the same time.
Parameters | |
---|---|
c |
Cursor : The database cursor. Can be null if the cursor is not available yet. |
from |
String : A list of column names representing the data to bind to the UI. Can be null
if the cursor is not available yet. |
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. Can be null if the cursor is not available yet. |
convertToString
public CharSequence convertToString (Cursor cursor)
Returns a CharSequence representation of the specified Cursor as defined by the current CursorToStringConverter. If no CursorToStringConverter has been set, the String conversion column is used instead. If the conversion column is -1, the returned String is empty if the cursor is null or Cursor.toString().
Parameters | |
---|---|
cursor |
Cursor : the Cursor to convert to a CharSequence |
Returns | |
---|---|
CharSequence |
a non-null CharSequence representing the cursor |
getCursorToStringConverter
public SimpleCursorAdapter.CursorToStringConverter getCursorToStringConverter ()
Returns the converter used to convert the filtering Cursor into a String.
Returns | |
---|---|
SimpleCursorAdapter.CursorToStringConverter |
null if the converter does not exist or an instance of
SimpleCursorAdapter.CursorToStringConverter |
getStringConversionColumn
public int getStringConversionColumn ()
Return the index of the column used to get a String representation of the Cursor.
Returns | |
---|---|
int |
a valid index in the current Cursor or -1 |
getViewBinder
public SimpleCursorAdapter.ViewBinder getViewBinder ()
Returns the ViewBinder
used to bind data to views.
Returns | |
---|---|
SimpleCursorAdapter.ViewBinder |
a ViewBinder or null if the binder does not exist |
setCursorToStringConverter
public void setCursorToStringConverter (SimpleCursorAdapter.CursorToStringConverter cursorToStringConverter)
Sets the converter used to convert the filtering Cursor into a String.
Parameters | |
---|---|
cursorToStringConverter |
SimpleCursorAdapter.CursorToStringConverter : the Cursor to String converter, or
null to remove the converter |
setStringConversionColumn
public void setStringConversionColumn (int stringConversionColumn)
Defines the index of the column in the Cursor used to get a String representation of that Cursor. The column is used to convert the Cursor to a String only when the current CursorToStringConverter is null.
Parameters | |
---|---|
stringConversionColumn |
int : a valid index in the current Cursor or -1 to use the default
conversion mechanism |
setViewBinder
public void setViewBinder (SimpleCursorAdapter.ViewBinder viewBinder)
Sets the binder used to bind data to views.
Parameters | |
---|---|
viewBinder |
SimpleCursorAdapter.ViewBinder : the binder used to bind data to views, can be null to
remove the existing binder |
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. Intended to be overridden by Adapters that need to filter strings retrieved from the database.
Parameters | |
---|---|
v |
ImageView : ImageView to receive an image |
value |
String : the value retrieved from the cursor |
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. Intended to be overridden by Adapters that need to filter strings retrieved from the database.
Parameters | |
---|---|
v |
TextView : TextView to receive text |
text |
String : the text to be set for the TextView |
swapCursor
public Cursor swapCursor (Cursor c)
Swap in a new Cursor, returning the old Cursor. Unlike
changeCursor(android.database.Cursor)
, the returned old Cursor is not
closed.
Parameters | |
---|---|
c |
Cursor : The new cursor to be used. |
Returns | |
---|---|
Cursor |
Returns the previously set Cursor, or null if there was not one. If the given new Cursor is the same instance is the previously set Cursor, null is also returned. |
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 2024-04-11 UTC.