我正在开发一个小应用程序,可以帮助我跟踪我的营养。现在,我使用Adapter构建一个布局。为此,我使用的是SimpleCursorAdapter,因为所有需要的数据都来自我的数据库。一切都很顺利,除了一件事:
所有复选框都具有相同的ID。所以我无法检查每一个。有一个解决方案,我知道它是如何解决的,但在这种情况下我不能使用xml文件生成ID,因为我不知道下次运行应用程序时会有多少个复选框。
这是我的代码:
public void getIdAndDate()
{
db = new DATABASE(this);
SQLiteDatabase sqldb = db.getReadableDatabase();
String[] Columns = {"_id", "date"};
int[] toViews = {R.id.entry_id, R.id.entry_date};
Cursor cursor1;
cursor1 = sqldb.query(db.TABLE_DAILY_CONSUMPTION, Columns, null, null, null, null, null);
numRows = cursor1.getCount();
int id[] = new int[numRows];
String date[] = new String[numRows];
for(int i = 0; i<numRows; i++)
{
cursor1.moveToNext();
id[i] = cursor1.getInt(0);
date[i] = cursor1.getString(1);
}
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, R.layout.layout_entry, cursor1, Columns, toViews, 0);
entries.setAdapter(adapter);
}
这是我的布局:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/entry_id"
android:layout_alignParentTop="true"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:textSize="20sp"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/entry_date"
android:layout_gravity="center_horizontal"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:textSize="20sp"/>
<CheckBox
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/entry_selection"
android:layout_gravity="right"
android:layout_alignParentTop="true"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"
/>
我真的想弄清楚如何解决问题,但我甚至无法想象我有哪些可能性。
答案 0 :(得分:0)
为了将Id
动态设置为任何视图,首先在资源文件中定义一个id:
<resources>
<item name="custom_id" type="id" />
</resources>
然后在你的代码中:
view.setId(R.id.custom_id);
答案 1 :(得分:0)
问题解决了。我不再使用复选框了。相反,我正在使用我已经拥有的条目并使用setOnItemClickListener并创建一个新函数来处理选择。新代码:
public void getIdAndDate()
{
db = new DATABASE(this);
SQLiteDatabase sqldb = db.getReadableDatabase();
String[] Columns = {"_id", "date"};
int[] toViews = {R.id.entry_id, R.id.entry_date};
Cursor cursor1;
cursor1 = sqldb.query(db.TABLE_DAILY_CONSUMPTION, Columns, null, null, null, null, null);
numRows = cursor1.getCount();
int id[] = new int[numRows];
String date[] = new String[numRows];
for(int i = 0; i<numRows; i++)
{
cursor1.moveToNext();
id[i] = cursor1.getInt(0);
date[i] = cursor1.getString(1);
}
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, R.layout.layout_entry, cursor1, Columns, toViews, 0);
entries.setAdapter(adapter);
entries.setOnItemClickListener(mMessageClickedHandler);
}
private AdapterView.OnItemClickListener mMessageClickedHandler = new AdapterView.OnItemClickListener()
{
public void onItemClick(AdapterView parent, View v, int position, long id)
{
selections(v, (int)id);
}
};
public void selections(View view, int id)
{
if(Counter < 7)
{
if(selections[0] == id || selections[1] == id || selections[2] == id || selections[3] == id || selections[4] == id || selections[5] == id || selections[6] == id)
{
MESSAGE.message(db.context, "Diese Auswahl hast du bereits getroffen!");
}
else
{
selections[Counter] = id;
view.setBackgroundColor(0xAACCCCCC);
Counter++;
}
}
else
{
MESSAGE.message(db.context, "Du hast die maximal mögliche Anzahl an Auswahl getroffen!");
}
}