我正在查询我的Android应用程序的sqlite数据库。
然后我使用一个简单的游标适配器将数据绑定到列表视图。
从数据库中调用两个双打,在列表视图中,只显示6位数字。
示例:43.6234
和-116.203
在数据库中(我转储它)这些数字有更多的数字。
出了什么问题? 这是列表视图的行XML
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout android:id="@+id/relativeLayout2" android:layout_width="fill_parent" android:layout_height="fill_parent" xmlns:android="http://schemas.android.com/apk/res/android">
<TextView android:text="@string/ssid" android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/row_db_ssid" android:textSize="16dip"></TextView>
<TextView android:layout_height="wrap_content" android:layout_below="@+id/row_db_bssid" android:textSize="12dip" android:text="@string/lati" android:layout_width="wrap_content" android:id="@+id/row_db_latitude"></TextView>
<TextView android:text="@string/bssid" android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/row_db_bssid" android:layout_below="@+id/row_db_ssid" android:textSize="14dip"></TextView>
<TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:text="@string/rssi" android:textSize="16dip" android:id="@+id/row_db_rssi"></TextView>
<TextView android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_below="@+id/row_db_bssid" android:textSize="12dip" android:text="@string/longi" android:layout_width="wrap_content" android:id="@+id/row_db_longitude"></TextView>
</RelativeLayout>
答案 0 :(得分:0)
看了这里之后:krysanify.wordpress.com/2010/11/24 / ...我发现SimpleCursorAdapter中存在一个缺陷,它只是假设字段会丢失所需的精度字符串
我将SimpleCursorAdapter扩展为在我想要的行上使用Double是类。
public class WithLongAdapter extends SimpleCursorAdapter {
private int[] mFrom;
private int[] mTo;
/**
* SimpleCursorAdapter that also checks for Double values based on rows so they will not be truncated
* @param context pass this
* @param layout the row file
* @param c the Cursors
* @param from collums on cursor
* @param to rows on list
*/
public WithLongAdapter(Context context, int layout, Cursor c,
String[] from, int[] to) {
super(context, layout, c, from, to);
mTo = to; //have to make my own to and from because they are protected in SimpleCursorAdapter
if (c != null) {
int i;
int count = from.length;
if (mFrom == null || mFrom.length != count) {
mFrom = new int[count];
}
for (i = 0; i < count; i++) {
mFrom[i] = c.getColumnIndexOrThrow(from[i]);
}
} else {
mFrom = null;
}
}
@Override
public void bindView(View view, Context context, Cursor cursor) {
final ViewBinder binder = getViewBinder();
final int count = mTo.length;
final int[] from = mFrom;
final int[] to = mTo;
for (int i = 0; i < count; i++) {
final View v = view.findViewById(to[i]);
if (v != null) {
boolean bound = false;
if (binder != null) {
bound = binder.setViewValue(v, cursor, from[i]);
}
if (!bound) {
String text = cursor.getString(from[i]);
if (text == null) {
text = "";
} else if (R.id.row_db_latitude == v.getId()) { //added rows, if they are the ones I want get value of doulbe
text = String.valueOf(cursor.getDouble(from[i]));
}
else if (R.id.row_db_longitude == v.getId()) { //added row
text = String.valueOf(cursor.getDouble(from[i]));
}
if (v instanceof TextView) {
setViewText((TextView) v, text);
} else if (v instanceof ImageView) {
setViewImage((ImageView) v, text);
} else {
throw new IllegalStateException(
v.getClass().getName()
+ " is not a "
+ " view that can be bounds by this SimpleCursorAdapter");
}
}
}
}
}
}