为了实现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版权协议,转载请附上原文出处链接和本声明。