在 kotlin 中实现定时器的两种方法
最编程
2024-07-09 21:58:54
...
一、viewModel+自定义接口的方式实现
注意点:viewModel中不要传入context的相关内容,容易内存泄露,如果需要上下文对象,可以继承ViewModel类的子类AndroidViewModel类,而不是ViewModel类.
class TimeViewModel:ViewModel() {
private lateinit var timer:Timer
private var currentSecond=0
fun startTimer(){
timer=Timer()
currentSecond=0
val timerTask=object :TimerTask(){
override fun run() {
currentSecond++
if (onTimeChangeListener!=null){
onTimeChangeListener.onTimeChanged(currentSecond)
}
}
}
timer.schedule(timerTask,1000,1000)
}
interface OnTimeChangeListener{
fun onTimeChanged(second:Int)
}
private lateinit var onTimeChangeListener: OnTimeChangeListener
fun setOnTimeChangeListener(onTimeChangeListener: OnTimeChangeListener){
this.onTimeChangeListener=onTimeChangeListener
}
override fun onCleared() {
super.onCleared()
timer.cancel()
}
}
activity或者fragment中的调用:
private fun timeListener(){
val timeViewModel= ViewModelProvider(this)[TimeViewModel::class.java]
timeViewModel.setOnTimeChangeListener(object :TimeViewModel.OnTimeChangeListener{
override fun onTimeChanged(second: Int) {
activity?.runOnUiThread {
binding.textviewTime.text="TIME:$second"
}
}
})
timeViewModel.startTimer()
}
二、viewModel+LiveData的实现
注意区分一下setValue:只能用于主线程,
postValue:可以用在主线程,也可以子线程
class TimeWithLivedataViewModel:ViewModel() {
private lateinit var timer: Timer
private var currentSecond=0
private var second:MutableLiveData<Int> = MutableLiveData()
fun getCurrentSecond():MutableLiveData<Int>{
return second
}
fun startTimer(){
timer=Timer()
currentSecond=0
val timerTask=object :TimerTask(){
override fun run() {
currentSecond++
second.postValue(currentSecond)
}
}
timer.schedule(timerTask,1000,1000)
}
}
liveData.observe()方法对Livedata包装的数据进行观察,反过来,当我们需要修改livedata包装的数据的时候,可以通过postValue/setValue来完成,这个方式只是会插入当前的数据中,不会重新开始执行,如果想重新开始,则需要修改viewmodel中的初始值.
private fun timeLiveData(){
val timeWithLivedataViewModel=ViewModelProvider(this)[TimeWithLivedataViewModel::class.java]
val liveData=timeWithLivedataViewModel.getCurrentSecond()
liveData.observe(requireActivity()){second->
binding.textviewTime.text="TIME:$second"
}
binding.btnTime.setOnClickListener {
liveData.postValue(0)
// timeWithLivedataViewModel.currentSecond=0
}
timeWithLivedataViewModel.startTimer()
}
此外,livedata的observe方法的最后一行代码可以看出,livedata可以感知页面的生命周期,获取页面的状态
上一篇: 主流定时任务解决方案的完整横截面
推荐阅读
-
在 ts 中实现类 java hashmap 的简单方法
-
在 Win11 中安装 PostgreSQL 数据库,两种方法的详细步骤
-
Java 8新特性探究(十三)JavaFX 8新特性以及开发2048游戏-JavaFX历史## 跟java在服务器端和web端成绩相比,桌面一直是java的软肋,于是Sun公司在2008年推出JavaFX,弥补桌面软件的缺陷,请看下图JavaFX一路走过来的改进 从上图看出,一开始推出时候,开发者需使用一种名为JavaFX Script的静态的、声明式的编程语言来开发JavaFX应用程序。因为JavaFX Script将会被编译为Java bytecode,程序员可以使用Java代码代替。 JavaFX 2.0之后的版本摒弃了JavaFX Script语言,而作为一个Java API来使用。因此使用JavaFX平台实现的应用程序将直接通过标准Java代码来实现。 JavaFX 2.0 包含非常丰富的 UI 控件、图形和多媒体特性用于简化可视化应用的开发,WebView可直接在应用中嵌入网页;另外 2.0 版本允许使用 FXML 进行 UI 定义,这是一个脚本化基于 XML 的标识语言。 从JDK 7u6开始,JavaFx就与JDK捆绑在一起了,JavaFX团队称,下一个版本将是8.0,目前所有的工作都已经围绕8.0库进行。这是因为JavaFX将捆绑在Java 8中,因此该团队决定跳过几个版本号,迎头赶上Java 8。 ##JavaFx8的新特性 ## ###全新现代主题:Modena 新的Modena主题来替换原来的Caspian主题。不过在Application的start方法中,可以通过setUserAgentStylesheet(STYLESHEET_CASPIAN)来继续使用Caspian主题。 参考http://fxexperience.com/2013/03/modena-theme-update/ ###JavaFX 3D 在JavaFX8中提供了3D图像处理API,包括Shape3D (Box, Cylinder, MeshView, Sphere子类),SubScene, Material, PickResult, LightBase (AmbientLight 和PointLight子类),SceneAntialiasing等。Camera类也得到了更新。从JavaDoc中可以找到更多信息。 ###富文本 强化了富文本的支持 ###TreeTableView ###日期控件DatePicker 增加日期控件 ###用于 CSS 结构的公共 API
-
挂载在Linux中的作用及实现方法独到详解
-
配置HP FC存储设备多路径驱动的方法在linux和Windows操作系统中即可实现
-
两种方法恢复在LINUX中误删除文件的(部分成功)
-
在JSP中引入Java和Vue的实现方法
-
让div内容在HTML中居中的两种方法:方法二
-
在Bootstrap中实现水平和垂直方向的div居中方法
-
在HTML中实现div元素垂直居中的三种方法