将onclick设置为不可见的项目

时间:2015-05-04 04:30:14

标签: android listview onclick cursor adapter

所以我现在已经四处寻找了大约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);
}

2 个答案:

答案 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"));
....