为了实现listview 我们需要实现一个adapter
list view中样式的布局现就一个TextView,我会手动去创建这个简单的文本列表。增加一个名为TestAdapter文件,包括如下代码:
TODO("not implemented") //To change body of created functions use File | Settings | File Templates.在你重写方法时这段代码要删除,不然直接会报错,现在直接上 adapter 的代码
@Suppress("UNREACHABLE_CODE")
class TestAdapter(var itemList: ArrayList<String>, var context: Context) : BaseAdapter() {
override fun getCount(): Int {
return itemList.size
}
override fun getView(position: Int, convertView: View?, parent: ViewGroup?): View {
var hoder: TestViewhoder
val view: View
if (convertView == null) {
view = View.inflate(context, R.layout.item, null)
hoder = TestViewhoder(view)
view.tag = hoder
} else {
view = convertView
hoder = view.tag as TestViewhoder
}
hoder.str.text = itemList[position]
return view
}
override fun getItem(position: Int): Any {
return itemList.get(position)
}
override fun getItemId(position: Int): Long {
return position.toLong()
}
}
class TestViewhoder(var viewItem: View) {
var str: TextView = viewItem.findViewById(R.id.str) as TextView
}然后是样式布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:id="@+id/str"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>在mainActivity里面实现 xml布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content">
</LinearLayout>
<ImageView
android:id="@+id/imageview"
android:layout_width="match_parent"
android:layout_height="100dp"
android:layout_gravity="center"
android:layout_marginTop="60dp"
android:src="@mipmap/ic_launcher" />
<Button
android:id="@+id/jion"
android:layout_marginTop="20dp"
android:background="@color/colorPrimary"
android:layout_marginLeft="20dp"
android:layout_marginRight="20dp"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="登陆"
android:textSize="20sp"
/>
<ListView
android:layout_marginTop="10dp"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/lvlist"
android:saveEnabled="false"
/>
</LinearLayout>实现方法
@Suppress("UNREACHABLE_CODE")
class MainActivity : AppCompatActivity() {
var itemList = ArrayList<String>()
private var adapter: TestAdapter? = null
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
inidata()
adapter = TestAdapter(itemList, this)
jion.setOnClickListener({
// Toast.makeText(this,"进入" ,Toast.LENGTH_SHORT).show()
lvlist.adapter = adapter
})
}
这里给集合添加数据的方式多种多样,这添加方式通熟易懂
fun inidata() {
var i: Int = 0
var end: Int = 10
while (i < end) {
itemList.add("" + i)
i++
}
}版权声明:本文为m0_71272694原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。