【Android】kotlin RecyclerView遍历json实现列表数据
创始人
2024-11-15 13:34:57
0

需求

效果图如下 :
在这里插入图片描述
这个ui看起来简单, 其实要实现几个功能点
1. json数据的遍历
2. RecyclerView实现循环的列表
3. 每块元素里的元素点击 : 未选中的话, 首次点击显示"selected", 点击"selected"则进行下一步数据处理
4. 设置默认的选择的元素, 显示selected

代码

1. layout/item_region.xml 组件元素

    // 这里的高度需要注意, 就是每个需要遍历的元素的高度, 千万要写成不match_parent                                                                  

2. activity_update_region.xml 主页面

                               

3. Myactivity.kt

import kotlinx.android.synthetic.main.activity_update_area.regionListRecyclerView  data class Country(val name: String, val code: Int, var selected: Boolean)  /**  * 设置页  */ class AreaupdateActivity : AppCompatActivity() {     private lateinit var adapter: SimpleAdapter      override fun onCreate(savedInstanceState: Bundle?) {         super.onCreate(savedInstanceState)         setContentView(R.layout.activity_update_area)          // 读取文件内容         val jsonString = loadJsonFromAssets(this, "country.json")         val gson = Gson()         val countryName = "China"         val countrys: List = gson.fromJson(jsonString, type) 		// 设置默认的被选中的countryName selected          if (countryName != null) {             for (item in countrys) {                 if (item.name == countryName){                     item.selected = true                 }             }         }          regionListRecyclerView.layoutManager = LinearLayoutManager(this)         adapter = SimpleAdapter(countrys)         regionListRecyclerView.adapter = adapter 		 		// 元素的点击事件         adapter.setOnItemClickListener(object : SimpleAdapter.OnItemClickListener {             override fun onItemClick(position: Int, item: Country) {                 println("我点击的$item")                 adapter.notifyItemChanged(position, item) // .indexOf(item)             }         })     } 	 	// 如果JSON文件位于assets目录下, 这是处理非代码资源文件(如文本、JSON等)的方式。通过AssetManager来访问这些文件。     fun loadJsonFromAssets(context: Context, fileName: String): String {         val assetManager = context.assets         val reader: BufferedReader         var jsonString: String = ""         try {             reader = BufferedReader(InputStreamReader(assetManager.open(fileName)))             jsonString = reader.use { it.readText() }         } catch (e: Exception) {             e.printStackTrace()             // 处理异常情况         }         return jsonString     } 	 	// SimpleAdapter 适配器, 监听列表元素 	// 为了代码的优雅, 应该单独写在Adapter里     class SimpleAdapter(private val countrys: List) :         RecyclerView.Adapter() {         private var selectedPosition = RecyclerView.NO_POSITION         inner class SimpleViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {             val regionName: TextView = itemView.findViewById(R.id.regionName)             val selectedBtn: TextView = itemView.findViewById(R.id.selectedBtn)              init {                  itemView.setOnClickListener {                     // 在这里处理点击事件                     onItemClickListener?.let { listener ->                         selectedPosition = adapterPosition                         notifyDataSetChanged()                         if (selectedPosition != RecyclerView.NO_POSITION) {                             listener.onItemClick(selectedPosition, getItem(selectedPosition))                         }                     }                 }             }         }          override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): SimpleViewHolder {             val view = LayoutInflater.from(parent.context)                 .inflate(R.layout.item_region, parent, false)             return SimpleViewHolder(view)         }          interface OnItemClickListener {             fun onItemClick(position: Int, item: Country)         }          private var onItemClickListener: OnItemClickListener? = null          fun setOnItemClickListener(listener: OnItemClickListener) {             onItemClickListener = listener         }          override fun onBindViewHolder(holder: SimpleViewHolder, position: Int) {             val currentItem = getItem(position)             holder.regionName.text = countrys[position].name              // 点击的显示selected, 其他隐藏             holder.selectedBtn.visibility = if (position == selectedPosition) View.VISIBLE else View.INVISIBLE             // 初始化数据 currentItem.selected为true的显示             // 点击的时候 原currentItem.selected为true的变为false, 点击的这个元素selected显示              if (currentItem.selected) {                  currentItem.selected = !currentItem.selected                 holder.selectedBtn.visibility = View.VISIBLE                   println("我显示着")             }              // 点击selected             holder.selectedBtn.setOnClickListener {                 var countryStr = currentItem.name                 CoroutineScope(Dispatchers.IO).launch {                     updateInfo(countryStr) // 更新用户数据(自定义function)                 }             }         }          override fun getItemCount(): Int = countrys.size          fun getItem(position: Int): Country {             return countrys[position]         }     } } 

4. assets/country.json (示例)

[{ 		"selected": false, 		"country_id": 100006, 		"country_code": 244, 		"name": "Angola", 		"country_name_cn": "安哥拉", 		"ab": "AO" 	}, 	{ 		"selected": false, 		"country_id": 100008, 		"country_code": 355, 		"name": "Albania", 		"country_name_cn": "阿尔巴尼亚", 		"ab": "AL" 	}] 

完成!
其中难点是上述第3条功能, 因为需要操作item里的元素, 相比item, 里面的元素更难获取和操作, 其次是selected的初始化和两次点击的操作, 还有点击时其他selected的隐藏

对比uniapp的感受 :
① 组件的适配器和数据监听交给开发者去写, 此为难度一, 而uniapp仅需一个v-for完成遍历
② 点击事件的处理, Android需要开发者自己找到选中的元素及其子元素, 再对其及其兄弟元素操作, 有点类似jquery, 操作dom节点, 而非vue一样操作数据, 逻辑性会更强一些

相关内容

热门资讯

透视神器!德普之星辅助工具如何... 透视神器!德普之星辅助工具如何设置,微信小程序微乐破解器2024,高科技教程(有挂教程)这是一款可以...
玩家交流!九游破解版真的假的,... >>您好:九游破解版真的假的确实是有挂的,很多玩家在这款九游破解版真的假的游戏中打牌都会发现很多用户...
第7分钟辅助挂!新道游挂,福建... 第7分钟辅助挂!新道游挂,福建天天开心辅助工具(熟悉开挂透视辅助下载)1、下载安装好福建天天开心辅助...
透视科技!雀神挂件价格,新西楚... 透视科技!雀神挂件价格,新西楚大厅辅助,技巧教程(发现有挂);亲,新西楚大厅辅助这款游戏原来确实可以...
终于清楚!广东闲来辅助软件,火... 终于清楚!广东闲来辅助软件,火神大厅辅助器(有挂教学开挂辅助平台);打开点击测试直接进入微信(136...
9分钟辅助挂!途游辅助器,好友... 9分钟辅助挂!途游辅助器,好友赣南脚本插件(领会开挂透视辅助安装)这是一款可以让一直输的玩家,快速成...
透视玄学!we-poker靠谱... 透视玄学!we-poker靠谱吗,微信卡农辅助,靠谱教程(有挂技巧);无需打开直接搜索打开薇:136...
实操分享!jj斗地主捕鱼辅助,... 乐乐围棋入门辅助是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微...
2分钟辅助挂!闲聚辅助器,佛手... 佛手在线辅助器苹果版是一款专注玩家量身打造的游戏记牌类型软件,在佛手在线辅助器苹果版这款游戏中我们可...
透视最新!wepoker祈福有... 透视最新!wepoker祈福有用吗,新西部辅助是什么意思,新2026教程(有挂解密);无需打开直接搜...