Android Kotlin中的自定义可滚动时间选择器
创始人
2024-08-14 15:30:14
0

要在Android Kotlin中创建自定义可滚动的时间选择器,可以使用RecyclerView和自定义适配器来实现。以下是一个示例代码:

首先,创建一个名为TimePickerAdapter的自定义适配器类:

import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import android.widget.TextView
import androidx.recyclerview.widget.RecyclerView

class TimePickerAdapter(private val timeList: List) :
    RecyclerView.Adapter() {

    private var selectedPosition = -1

    inner class TimeViewHolder(itemView: View) : RecyclerView.ViewHolder(itemView) {
        val timeTextView: TextView = itemView.findViewById(R.id.timeTextView)

        init {
            itemView.setOnClickListener {
                val position = adapterPosition
                if (position != RecyclerView.NO_POSITION) {
                    selectedPosition = position
                    notifyDataSetChanged()
                }
            }
        }
    }

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): TimeViewHolder {
        val itemView = LayoutInflater.from(parent.context)
            .inflate(R.layout.time_item, parent, false)
        return TimeViewHolder(itemView)
    }

    override fun onBindViewHolder(holder: TimeViewHolder, position: Int) {
        val currentTime = timeList[position]
        holder.timeTextView.text = currentTime

        if (selectedPosition == position) {
            holder.timeTextView.setTextColor(holder.itemView.context.resources.getColor(R.color.selected_time))
        } else {
            holder.timeTextView.setTextColor(holder.itemView.context.resources.getColor(R.color.default_time))
        }
    }

    override fun getItemCount(): Int {
        return timeList.size
    }
}

接下来,创建一个名为MainActivity的主活动类,并在其中设置RecyclerView和时间列表:

import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import androidx.recyclerview.widget.LinearLayoutManager
import androidx.recyclerview.widget.RecyclerView

class MainActivity : AppCompatActivity() {

    private lateinit var timeRecyclerView: RecyclerView
    private lateinit var timeAdapter: TimePickerAdapter

    private val timeList = listOf("09:00", "10:00", "11:00", "12:00", "13:00", "14:00", "15:00", "16:00")

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

        timeRecyclerView = findViewById(R.id.timeRecyclerView)
        timeRecyclerView.layoutManager = LinearLayoutManager(this)
        timeAdapter = TimePickerAdapter(timeList)
        timeRecyclerView.adapter = timeAdapter
    }
}

最后,创建一个名为time_item.xml的布局文件,定义时间选择器中每个时间项的外观:



确保在项目的res/values/colors.xml文件中定义selected_time和default_time颜色:



    #FF0000
    #000000

这样,你就可以在Android Kotlin中创建一个自定义的可滚动时间选择器了。

相关内容

热门资讯

安装Pillow时遇到了问题:... 遇到这个问题,可能是因为缺少libwebpmux3软件包。解决方法是手动安装libwebpmux3软...
安装React Native时... 当安装React Native时出现构建错误的情况,可以尝试以下解决方法:确保已经安装了最新版本的C...
安装Rails时构建webso... 在安装Rails时,如果构建websocket-driver时发生错误,可以尝试以下解决方法:更新系...
安装react-native-... 要安装react-native-onesignal并在应用关闭时仍能接收通知,可以按照以下步骤进行:...
安装Python库"... 安装Python库"firedrake"的解决方法如下:打开终端或命令提示符(Windows系统)。...
Apache Nifi在Kub... Apache Nifi可以在Kubernetes上运行,并且已经准备好用于生产环境。下面是一个使用H...
安装React Native时... 安装React Native时可能会出现各种错误,下面是一些常见错误和解决方法的代码示例:Error...
按转换模式过滤日志【%t】。 要按照转换模式过滤日志,可以使用正则表达式来实现。下面是一个示例代码,使用Java语言的Patter...
安装React-Scripts... 这是因为React-Scripts使用Facebook工具包中的一些脚本。 joinAdIntere...
安装QuickUMLS时遇到问... 安装QuickUMLS时遇到问题的解决方法可能因具体问题而异。以下是一些常见问题的解决方法,包含代码...