有没有办法在更新数据后刷新 baseadapter 中的自定义视图?

Is there any way to refresh custom view inside baseadapter after updating data?

我在列表视图上显示的基本适配器内有一个自定义视图。目前我可以更新数据库中的项目,但我无法刷新视图。我想在updating.Is之后自动刷新视图 反正有刷新吗?请看看我的代码。

这是模型 class-

class Item_Detail {
   var qty:Int = 0
   var id:Int = 0
   constructor()}

这是数据库处理程序-

  val Detail: List<Item_Detail>
    get() {
        val bb=this.writableDatabase
        val seItem=ArrayList<Item_Detail>()
        val myPath=DB_PATH + REAL_DATABASE
        val db=SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READONLY)
        val selectQuery="Select * From Transaction_table Where date='$rowview_date' And location='$rowview_location'"
        val cursor=db.rawQuery(selectQuery, null)

        if (cursor.moveToFirst()) {

            do {
                val item=Item_Detail()
                item.id=cursor.getInt(cursor.getColumnIndex("_id2"))
                item.qty=cursor.getInt(cursor.getColumnIndex("quantity2"))
                seItem.add(item)
            } while(cursor.moveToNext())
        }
        db.close()
        return seItem
    }

这是 MainActivity-

class Detail : AppCompatActivity() {

internal lateinit var db: DataBaseHelper
internal var seItem: List<Item_Detail> = ArrayList<Item_Detail>()

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_detail)

    db = DataBaseHelper(this)
    detail_date.text = rowview_date.toString()
    detail_location.text = rowview_location.toString()
    getDetail()


}
private fun getDetail() {
    seItem = db.Detail
    val adapter = Adapter_detail(this, seItem,this)
    list_detail.adapter=adapter
    list_detail.invalidate()
}}

这是适配器class-

  class Adapter_detail(
    internal var activity: Activity,
    internal var stitem: List<Item_Detail>,
    val context:Context

    ) : BaseAdapter() {

internal lateinit var db: DataBaseHelper
internal var inflater: LayoutInflater

init {
    inflater = activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater
}

override fun getView(position: Int, convertView: View?, parent: ViewGroup?): View {

    val rowView:View
    rowView = inflater.inflate(R.layout.detail_row, null)
    rowView.detail_id.text = stitem[position].id.toString()
    rowView.detail_qty.text = stitem[position].qty.toString()


    rowView.btn_detail.setOnClickListener{
        db=DataBaseHelper(context)//Initiate the database
        val builder=android.app.AlertDialog.Builder(context)
        inflater=activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater

        val view=inflater.inflate(R.layout.edit_layout, null)
        builder.setView(view)
        val dialog: android.app.AlertDialog=builder.create()

        var tran_edit=view.findViewById<EditText>(R.id.edt_edit)
        tran_edit.setText(stitem[position].qty.toString())

        dialog.show()

        var btn_edt=view.findViewById<Button>(R.id.btn_edit)
        btn_edt.setOnClickListener {
            val item=Item(
                Integer.parseInt(stitem[position].id.toString()),
                Integer.parseInt(1.toString()),
                tran_edit.text.toString(),
                name.toString(),
                record_date.toString(),
                record_location.toString(),
                master_record.toString().toInt()
            )
            db.updateItem(item)
            dialog.dismiss()
        }
    }

    return rowView

}

override fun getItem(position: Int): Any {
    return stitem[position]
}

override fun getItemId(position: Int): Long {
    return stitem[position].id!!.toLong()
}

override fun getCount(): Int {
    return stitem.size
}

刷新数据时,您需要在 adapter 对象上调用 notifyDataSetChanged()。您需要进行以下更改才能使用它,

MainActivity

class Detail : AppCompatActivity() {

    internal lateinit var db: DataBaseHelper
    internal var seItem: MutableList<Item_Detail> = ArrayList<Item_Detail>()
    internal lateinit var adapter : Adapter_detail

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_detail)

        db = DataBaseHelper(this)
        detail_date.text = rowview_date.toString()
        detail_location.text = rowview_location.toString()
        adapter = Adapter_detail(this, seItem,this)
        list_detail.adapter=adapter
        getDetail()
    }

    private fun getDetail() {
        adapter.refresh(db.Detail)
    }

}

适配器类

class Adapter_detail(
    internal var activity: Activity,
    internal var stitem: MutableList<Item_Detail>,
    val context:Context

    ) : BaseAdapter() {

    ...

    fun refresh(newList: List<Item_Detail>) {
         stitem.clear()
         stitem.addAll(newList)
         notifyDataSetChanged()
    }

}

N.B. I wrote this solution using mobile so please excuse any syntax error. Let me know if it works?

P.S。有一个更好的适配器实现,即 CursorAdapter,它专为与数据库游标一起使用而设计。你可以按照这个tutorial来集成它。

Update

我忘了一件事,您需要在执行更新操作的 getView() 函数中的 ClickListener 回调中调用 refresh()。因此,它将如下所示,

override fun getView(position: Int, convertView: View?, parent: ViewGroup?): View {
    ...

        btn_edt.setOnClickListener {
            val item= ...
            db.updateItem(item)
            dialog.dismiss()
            refresh(db.Detail)
        }
    }

    return rowView
}