0

に変数がありcurrentDBますMainActivity.java。ユーザーが異なるタブを選択することに応じて、この変数を異なる値に初期化しています。対応するコードは次のとおりです。

@override
public void tab_selector(View v) {
    switch (v.getId()) {
        case R.id.veg_tab:
            setContentView(R.layout.vegetable);
            currentListView = (ListView) findViewById(R.id.veg_list);
            currentDB = "veg";
            break;
        case R.id.meat_tab :
            setContentView(R.layout.meat_drawer);
            currentListView = (ListView) findViewById(R.id.meat_list);
            currentDB = "meat";
            break;
        default:
            break;
    }

    currentList = mydb.getAllItems(currentDB);    // Definition below, works perfect
    itemAdder2.updateData(currentList);
    currentListView.setAdapter(itemAdder2);
}

DBHelper.java理想的には、テーブル名とアイテム ID を入力として受け取り、指定されたテーブルから対応する行を削除するメソッドがあります。

public Integer deleteItem (String dbName, int id)
{
    SQLiteDatabase db = this.getWritableDatabase();
    return db.delete(dbName,
            "id = ? ",
            new String[] { Integer.toString(id) });
}

これは、テーブルからすべてのデータを取得するもう 1 つの関数であり、完全に機能します。

public ArrayList<String> getAllItems(String dbName)
{
    ArrayList<String> array_list = new ArrayList<String>();

    //hp = new HashMap();
    SQLiteDatabase db = this.getReadableDatabase();
    Cursor res =  db.rawQuery( "select * from " + dbName, null );
    res.moveToFirst();

    while(res.isAfterLast() == false){
        array_list.add(res.getString(res.getColumnIndex(COLUMN_NAME)));
        res.moveToNext();
    }
    return array_list;
}

ListViewAdapterデータベースに保存されているデータを表示するために、カスタマイズした を作成しました。機能を使用して編集および削除するための関連ボタンを用意しましonClick()た。さて、私の問題は、 this 内でどのデータベースを参照するかを特定することListViewAdapterです。からにcurrentDB情報を渡すことができません。助けてください。前もって感謝します。次のコード スニペット:MainActivity.javaListViewAdapter.javaListViewAdapter.java

public class ListViewAdapter extends BaseAdapter {

Context mContext;
LayoutInflater mInflater;
ArrayList mArray;
DBHelper mydb;
String dbName;

public ListViewAdapter(Context context, LayoutInflater inflater) {
    mContext = context;
    mInflater = inflater;
    mArray = new ArrayList();
    mydb = new DBHelper(mContext);
    dbName = "veg";    // Didn't know what to do, tried to initialize manually, din't work :(
}

@Override
public int getCount() {
    return mArray.size();
}

@Override
public Object getItem(int position) {
    return mArray.get(position);
}

@Override
public long getItemId(int position) {
    // your particular data set uses String IDs
    // but you have to put something in this method
    return position;
}

@Override
public View getView(final int position, View convertView, final ViewGroup parent) {
    ViewHolder holder;

    // check if the view already exists
    // if so, no need to inflate and findViewById again!
    if (convertView == null) {

        // Inflate the custom row layout from your XML.
        convertView = mInflater.inflate(R.layout.list_item, null);

        // create a new "Holder" with subviews
        holder = new ViewHolder();
        holder.itemNameView = (TextView) convertView.findViewById(R.id.item_name);
        holder.itemExpiryView = (TextView) convertView.findViewById(R.id.item_expiry);

        // Taking care of the buttons
        holder.editButton = (Button) convertView.findViewById(R.id.button_edit);
        holder.deleteButton = (Button) convertView.findViewById(R.id.button_delete);

        // hang onto this holder for future recycling
        convertView.setTag(holder);
    } else {

        // skip all the expensive inflation/findViewById
        // and just get the holder you already made
        holder = (ViewHolder) convertView.getTag();
    }

    // Set listener on the buttons
    holder.editButton.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            Toast.makeText(mContext, "Edit Button CLicked", Toast.LENGTH_SHORT).show();
        }
    });

    holder.deleteButton.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
            deleteItem(position);            // Potential problem here??
            Toast.makeText(mContext, "Item deleted", Toast.LENGTH_SHORT).show();
        }
    });

    // More code after this

    // Grab the title and author from the JSON
    String name = "";
    String expiry = "7 days";

    // Write appropriate codes to obtain values for the string variables above
    name = (String) getItem(position);

    // Send these Strings to the TextViews for display
    holder.itemNameView.setText(name);
    holder.itemExpiryView.setText(expiry);

    return convertView;
}

// this is used so you only ever have to do
// inflation and finding by ID once ever per View
private static class ViewHolder {
    public TextView itemNameView;
    public TextView itemExpiryView;
    public Button editButton;
    public Button deleteButton;
}

public void updateData(ArrayList arrayPassed) {
    // update the adapter's data set
    mArray = arrayPassed;
    notifyDataSetChanged();
}

public void deleteItem(int pos){
    mArray.remove(pos);            // Ideally, shouldn't be there
    mydb.deleteItem(dbName, pos);  // Here I need to pass the appropriate dbName
    // mArray = mydb.getAllItems(); // Ideally should be there
    notifyDataSetChanged();
}

}

追加で何か必要な場合はお知らせください。言い換えやトピック、タグの変更は大歓迎です。初心者なので、正確に伝えることができません。あなたの助けに感謝。:)

4

4 に答える 4

0

ここで SharedPreferences を使用できると思います

于 2015-07-24T00:04:33.740 に答える