Я разрабатываю приложение для отслеживания воды, в котором необходимо доступно настройки, например, vumoUnit (мл/л) почти на всех экранах. Я внедрил настройки Manager (с использованием данных Datastore) и настройки STURESViewModel для обработки этого состояния. Тем не менее, я не уверен, является ли использование CompositionLocalProvider для состояния ViewModels (StateFlow - CollectASstateWithLifeCycle ()) хорошей практикой. < /P>
Проблема: < /p>
br /> Настройка объема употребления используется в 10+ композибельных устройствах (например, экраны статистики, формы ввода). < /p>
< /li>
Я хочу избежать передачи ViewModel или состояния явно через все композиции. /> viewModel: < /p>
@HiltViewModel
class SettingsViewModel @Inject constructor(private val settingsDataStore: SettingsDataStore) :
ViewModel() {
private val _settingState = MutableStateFlow(SettingsState())
val settingsState = _settingState.stateIn(
viewModelScope,
SharingStarted.WhileSubscribed(5000),
SettingsState()
)
var setKeepOnScreenCondition = true
init {
viewModelScope.launch {
loadSettings().onEach { settings ->
_settingState.update {
it.copy(
goalSetting = settings.goalSetting,
volumeUnitSetting = settings.volumeUnitSetting
)
}
setKeepOnScreenCondition = false
}.collect()
}
}
private fun loadSettings(): Flow = combine(
settingsDataStore.getIntFlow(key = GOAL_SETTING),
settingsDataStore.getStringFlow(key = VOLUME_UNIT_SETTING)
) { flows ->
val units = VolumeUnit.valueOf(flows[1] as String? ?: VolumeUnit.Liters.name)
SettingsState(
goalSetting = flows[0] as Int? ?: 1500,
volumeUnitSetting = units
)
}
fun changeVolumeUnit(value: VolumeUnit) {
viewModelScope.launch {
settingsDataStore.putString(value.name, key = VOLUME_UNIT_SETTING)
}
}
}
< /code>
compositionlocal setup: < /p>
@Composable
fun MyApp() {
val settingsViewModel: SettingsViewModel by viewModels()
val settingsState by settingsViewModel.settingsState.collectAsStateWithLifecycle()
CompositionLocalProvider(
LocalSettingsState provides settingsState
) {
AppNavigation()
}
}
val LocalSettingsState =
compositionLocalOf { SettingsState() }
< /code>
Использование в Composable: < /p>
@Composable
fun HomeScreen() {
val volumeUnit = LocalSettingsState.current.volumeUnitSetting
...
}
Подробнее здесь: https://stackoverflow.com/questions/793 ... compose-co
Надлежащий способ обмена настройками приложения содержится на всех экранах в JetPack Compose: CompositionLocal ⇐ Android
Форум для тех, кто программирует под Android
1738018921
Anonymous
Я разрабатываю приложение для отслеживания воды, в котором необходимо доступно настройки, например, vumoUnit (мл/л) почти на всех экранах. Я внедрил настройки Manager (с использованием данных Datastore) и настройки STURESViewModel для обработки этого состояния. Тем не менее, я не уверен, является ли использование CompositionLocalProvider для состояния ViewModels (StateFlow - CollectASstateWithLifeCycle ()) хорошей практикой. < /P>
Проблема: < /p>
br /> Настройка объема употребления используется в 10+ композибельных устройствах (например, экраны статистики, формы ввода). < /p>
< /li>
Я хочу избежать передачи ViewModel или состояния явно через все композиции. /> viewModel: < /p>
@HiltViewModel
class SettingsViewModel @Inject constructor(private val settingsDataStore: SettingsDataStore) :
ViewModel() {
private val _settingState = MutableStateFlow(SettingsState())
val settingsState = _settingState.stateIn(
viewModelScope,
SharingStarted.WhileSubscribed(5000),
SettingsState()
)
var setKeepOnScreenCondition = true
init {
viewModelScope.launch {
loadSettings().onEach { settings ->
_settingState.update {
it.copy(
goalSetting = settings.goalSetting,
volumeUnitSetting = settings.volumeUnitSetting
)
}
setKeepOnScreenCondition = false
}.collect()
}
}
private fun loadSettings(): Flow = combine(
settingsDataStore.getIntFlow(key = GOAL_SETTING),
settingsDataStore.getStringFlow(key = VOLUME_UNIT_SETTING)
) { flows ->
val units = VolumeUnit.valueOf(flows[1] as String? ?: VolumeUnit.Liters.name)
SettingsState(
goalSetting = flows[0] as Int? ?: 1500,
volumeUnitSetting = units
)
}
fun changeVolumeUnit(value: VolumeUnit) {
viewModelScope.launch {
settingsDataStore.putString(value.name, key = VOLUME_UNIT_SETTING)
}
}
}
< /code>
compositionlocal setup: < /p>
@Composable
fun MyApp() {
val settingsViewModel: SettingsViewModel by viewModels()
val settingsState by settingsViewModel.settingsState.collectAsStateWithLifecycle()
CompositionLocalProvider(
LocalSettingsState provides settingsState
) {
AppNavigation()
}
}
val LocalSettingsState =
compositionLocalOf { SettingsState() }
< /code>
Использование в Composable: < /p>
@Composable
fun HomeScreen() {
val volumeUnit = LocalSettingsState.current.volumeUnitSetting
...
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79392374/proper-way-to-share-app-settings-state-across-all-screens-in-jetpack-compose-co[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия