所以我现在已经四处寻找了大约4个小时,也许我只是不知道如何说出我的搜索,但我找不到我需要的东西。
我正在使用自定义适配器从我存储到sqlite数据库中的项目设置listview。我的游标将id,name,product_id,data,datetime发送到我的适配器。但我的适配器设置为只显示名称,数据&约会时间。
我需要能够点击名称,但让它转到我的下一个活动,并显示发送到适配器的product_id中的信息。示例我单击Apples,但它实际上是我的数据库中的product_id 505。除非我将product_id设置为textview,否则当我点击我的项目时,它不会显示正确的列表并搜索苹果。
如果不清楚,请告诉我,我会更好地解释。
**编辑**
所以我的数据库是这样的
_ID | PRODUCT_NAME | PRODUCT_ID | PRODUCT_DATA |日期 1苹果505新鲜苹果123456 2橙子506鲜橙123456 3猕猴桃507新鲜猕猴桃123456 4坚果508新鲜坚果123456
我的ListView显示了这个: 苹果 - FRESH APPLES - 日期 橘子 - 新鲜橙子 - 日期 Kiwi- FRESH KIWI - 日期 坚果 - 新鲜坚果 - 日期
当我点击Apples时,我希望它将PRODUCT_ID返回给我,而不是_ID,因此我可以将该product_id传递给我的下一个意图。
我的展示广告
public void displayListView()
{
DatabaseOperations db = new DatabaseOperations(this);
Cursor cursor = db.getProducts();
dataAdapter = new MainActivityAdapter(
this,
cursor,
0);
ListView listView = (ListView) findViewById(R.id.product_list);
// Assign adapter to ListView
listView.setAdapter(dataAdapter);
// listening to single list item on click
listView.setOnItemClickListener(new AdapterView.OnItemClickListener()
{
public void onItemClick(AdapterView<?> parent, View view,
int position, long ID)
{
TextView listText = (TextView) view.findViewById(R.id.name);
String product_name = listText.getText().toString();
Intent i = new Intent(MainActivity.this, product_detail.class);
i.putExtra("productName", product_name);
MainActivity.this.startActivity(i);
}
});
db.close();
}
我的适配器
public class MainActivityAdapter extends CursorAdapter
{
private LayoutInflater cursorInflater;
private Context c;
// Default constructor
public MainActivityAdapter(Context context, Cursor cursor, int flags)
{
super(context, cursor, flags);
cursorInflater = (LayoutInflater) context.getSystemService(
Context.LAYOUT_INFLATER_SERVICE);
c = context;
// Log.i("Custom-Adapter", "Starting up");
}
public void bindView(View view, Context context, Cursor list)
{
TextView PN = (TextView) view.findViewById(R.id.product_name);
TextView PI = (TextView) view.findViewById(R.id.product_data);
TextView date = (TextView) view.findViewById(R.id.date);
// SET OUR DATA FROM OUR CURSOR
String pn = list.getString( list.getColumnIndex("pn"));
String pi = list.getString( list.getColumnIndex("pi"));;
// NEED TO RECONVERT DATE THEN SHOW IT
Long millidate = list.getLong(list.getColumnIndex("dateTime"));
Date myDateNew = new Date(millidate);
String Sdate = getDate(millidate);
PN.setText(pn);
PI.setText(pi);
date.setText(Sdate);
}
public static String getDate(long milliSeconds)
{
Calendar cl = Calendar.getInstance();
cl.setTimeInMillis(milliSeconds); //here your time in miliseconds
String date = "" + cl.get(Calendar.DAY_OF_MONTH) + ":" + cl.get(Calendar.MONTH) + ":" + cl.get(Calendar.YEAR);
String time = "" + cl.get(Calendar.HOUR_OF_DAY) + ":" + cl.get(Calendar.MINUTE) + ":" + cl.get(Calendar.SECOND);
return date;
}
public View newView(Context context, Cursor cursor, ViewGroup parent)
{
//Log.i("Custom-Adapter", "newView Started");
// R.layout.list_row is your xml layout for each row
return cursorInflater.inflate(R.layout.activity_list, parent, false);
}
答案 0 :(得分:0)
一个好的选择是为所有名称创建一个数组并存储product_ids。
Goto Res-&gt; Strings创建一个字符串数组。
然后从数组中获取名称的相关product_id。
答案 1 :(得分:0)
当我点击苹果名称时,我想得到product_id。
我们可以通过多种方式实现它,但最常见的方式是:
选项1:
使用setTag
方法保存名称为id
的产品TextView
:
PN.setText(pn);
PN.setTag((list.getInt(list.getColumnIndex("product_id"))).toString());
现在使用getTag
方法获取product_id
中点击的产品onItemClick
:
String product_name = listText.getText().toString();
int product_id = Integer.parseInt(listText.getTag().toString());
选项2:
不是从TextView获取产品名称,而是使用onItemClick
中的适配器点击行光标:
Cursor cursor = (Cursor) dataAdapter.getItem(position);
String product_name = cursor.getString(cursor.getColumnIndex("pn"));
int product_id = cursor.getInt(cursor.getColumnIndex("product_id"));
....