jetpack compose中实现丝滑的轮播图效果_jetpack compose 广告转场效果

本文介绍了如何在Jetpack Compose中使用Proto DataStore实现数据存储,包括从SharedPreferences迁移到Proto DataStore的步骤,以及Proto DataStore的类型安全优势。详细展示了Proto DataStore的依赖添加、架构定义、数据读写,并提供了迁移示例。
摘要由CSDN通过智能技术生成

现在可以开始将 SharedPreferences 迁移到 Preferences DataStore 了。因为 DataStore 的存在就是为了替代SP,所以谷歌早提供SharedPreferencesMigration属性用于SP数据迁移。其他代码与前面类似,只需向迁移列表传入 SharedPreferencesMigration属性,其中构造函数第二个参数 sharedPreferencesName 为所创建SP的文件名称,在本例中即为”test“。

private val Context.dataStore: DataStore by preferencesDataStore(
name = “preferences-test”,
// 新增部分
produceMigrations = { context ->
listOf(SharedPreferencesMigration(context, “test”))
}
)

由于键只能从 SharedPreferences 迁移一次,因此在我们迁移完毕后,需要将刚才临时创建的SP相关代码删除,此时的完整代码如下:
有一处需要注意的,在SP文件创建时,我们的key值设置为“number”,迁移后dataStore的key值也会被设置为“number”。所以与前面的例子相比,我们还需要将intPreferencesKey()函数中的key值更改为“number”。

class MainActivity : AppCompatActivity() {

// 创建:preferencesDataStore 委托可确保我们有一个 DataStore 实例在应用中具有该名称
private val Context.dataStore: DataStore by preferencesDataStore(
name = “preferences-test”,
produceMigrations = { context ->
listOf(SharedPreferencesMigration(context, “test”))
}
)
private val COUNTER = intPreferencesKey(“number”)

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

val tv = findViewById(R.id.tv_test)
val fab = findViewById(R.id.fab)

MainScope().launch {
dataStore.data
.map {
it[COUNTER] ?: 0
}.collect {
tv.text = it.toString()
}
}
fab.setOnClickListener {
MainScope().launch {
dataStore.edit {

  • 17
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值