BaseAdapter适配器中要实现的4个方法含义

BaseAdapter需要重写的方法:


public int getCount();//在绘制视图时,会对其进行调用。

public Object getItem(int position);//可能在事件处理时,会调用。

public long getItemId(int position);//可能在事件处理时,会调用。

public View getView(int position, View convertView, ViewGroup parent);//在绘制视图时,会对其进行调用。

首先进去的getCount()这个方法,这返回的是list里面的个数,即你要显示在View上的item,
紧接着就是根据你的item如何来绘制一个view了,即getView可以引用事先定义好的xml来确定显示的效果并返回一个View对象作为一个Item显示出来。也正是在这个过程中完成了适配器的主要转换功能,把数据和资源以开发者想要的效果显示出来。即有多少个Item就调用多少次ListView,使得ListView的使用更为简单和灵活。
而getItem和getItemId方法将会在调用ListView的响应方法的时候被调用到。所以要保证ListView的各个方法有效的话,这两个方法也得重写。

listView在开始绘制的时候,系统首先调用getCount()函数,根据他的返回值得到 listView的长度,然后根据这个长度,调用getView()逐一绘制每一行。
如果你的 getCount()返回值是0的话,列表将不显示;同样return 1,就只显示一行。
系统显示列表时,首先实例化一个适配器(这里将实例化自定义的适配器)。

当手动完成适配时,必须手动映射数据,这需要重写getView()方法。系统在绘制列表的每一行的时候将调用此方法。
getView()有三个参数,
position表示将显示的是第几行,
covertView是从布局文件中inflate来的布局。
我们用LayoutInflater的方法将定义好的item.xml文件提取成View实例用来显示。然后将xml文件中的各个组件实例化(简单的findViewById()方法)。这样便可以将数据对应到各个组件上了。

但是按钮为了响应点击事件,需要为它添加点击监听 器,这样就能捕获点击事件。

至此一个自定义的listView就完成了,现在让我们回过头从新审视这个过程。
系统要绘制ListView了,他首先获得要绘制的这个列表的长度,然后开始绘制第一行,怎么绘制呢?
调用getView()函数。在这个函数里面首先获得一个View(实际上是一个 ViewGroup),然后再实例并设置各个组件,显示之。好了,绘制完这一行了。那再绘制下一行,直到绘完为止。

常见Adapter列表

Known Indirect Subclasses


ArrayAdapter<T>, BaseAdapter, CursorAdapter, 

HeaderViewListAdapter, ListAdapter, ResourceCursorAdapter, 

SimpleAdapter, SimpleCursorAdapter, SpinnerAdapter, WrapperListAdapter


  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在使用 Kotlin 语言中提取数据库中的照片并在 ListView 中显示,你可以按照以下步骤进行: 1. 创建一个 BaseAdapter 子类,用于在 ListView 中显示照片。 2. 在 BaseAdapter实现 getView() 方法,用于加载照片并将其显示在 ImageView 中。 3. 在 getView() 方法中查询数据库以获取照片数据。 4. 将获取的照片数据转换为位图格式。 5. 将位图显示在 ImageView 中。 以下是一个示例代码: ```kotlin class PhotoAdapter(private val context: Context, private val photoIds: List<Int>) : BaseAdapter() { override fun getCount(): Int { return photoIds.size } override fun getItem(position: Int): Any { return photoIds[position] } override fun getItemId(position: Int): Long { return photoIds[position].toLong() } override fun getView(position: Int, convertView: View?, parent: ViewGroup?): View { val view = convertView ?: LayoutInflater.from(context).inflate(R.layout.photo_item, parent, false) val imageView = view.findViewById<ImageView>(R.id.photoImageView) // 从数据库中获取照片数据 val photoId = photoIds[position] val cursor = db.rawQuery("SELECT photo_data FROM photos WHERE photo_id = ?", arrayOf(photoId.toString())) if (cursor.moveToFirst()) { // 将照片数据转换为位图格式 val photoData = cursor.getBlob(cursor.getColumnIndex("photo_data")) val bitmap = BitmapFactory.decodeByteArray(photoData, 0, photoData.size) // 将位图显示在ImageView上 imageView.setImageBitmap(bitmap) } cursor.close() return view } } ``` 在上面的代码中,我们首先创建了一个 PhotoAdapter 类,它继承自 BaseAdapter。在 getView() 方法中,我们首先根据当前位置从 photoIds 列表中获取 photoId。然后,我们查询数据库以获取照片数据。接下来,我们将照片数据转换为位图格式,并使用 BitmapFactory.decodeByteArray() 方法将其解码。最后,我们将位图显示在 ImageView 中。 请注意,这只是一个示例代码,你需要根据你的具体需求进行适当的修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值