Я хочу хранить настройки своего приложения в хранилище данных и сделать его легко доступным откуда угодно.
Например, чтобы иметь категорию настроек пользовательского интерфейса, иметь возможность доступа к ней и легко ее настраивать. из любого места при перекомпоновке различных частей пользовательского интерфейса при изменении конфигурации.
В настоящее время я использую библиотеку «compose-remember-preference», чтобы реализовать это, но мне нужно скопировать и вставить RememberXPreference. каждый раз, когда мне это нужно, и он будет получать предпочтения каждый раз, когда новый Composable, который его использует, составляется/перекомпонуется.
Есть ли лучший способ справиться с этим?
https://github.com/burnoo/compose-remember-preference
Вот пример того, как я использую его в двух местах:
@Composable
fun R2DroidTheme(
content: @Composable () -> Unit
) {
val isSystemDarkMode = isSystemInDarkTheme()
var defaultColorTuple = rememberStringPreference(
keyName = "ui.color_tuple", initialValue = colorTupleToJson(ColorTuples["Latte"]!!), defaultValue = colorTupleToJson(ColorTuples["Latte"]!!)
)
val (defaultContrast, setdefaultContrast) = rememberFloatPreference(keyName = "color.contrast_level", initialValue = 0.5f, defaultValue = 0.5f)
var (darkMode, setDarkMode) = rememberIntPreference(keyName = "ui.dark", initialValue = DarkMode.SYSTEM.value, defaultValue = DarkMode.SYSTEM.value )
var (amoled, setAmoled) = rememberBooleanPreference(keyName = "ui.amoled", initialValue = false, defaultValue = false)
var (materialYou, setMaterialYou) = rememberBooleanPreference(keyName = "ui.material_you", initialValue = false, defaultValue = false)
var (invertColor, setInvertColor) = rememberBooleanPreference(keyName = "color.inverted", initialValue = false, defaultValue = false)
val state = rememberDynamicThemeState(initialColorTuple = jsonToColorTuple(defaultColorTuple.value))
var dark by remember { mutableStateOf(isSystemDarkMode) }
when (darkMode) {
DarkMode.SYSTEM.value -> dark = isSystemDarkMode
DarkMode.LIGHT.value -> dark = false
DarkMode.DARK.value -> dark = true
}
MyTheme(
state = state,
defaultColorTuple = jsonToColorTuple(defaultColorTuple.value),
dynamicColor = materialYou,
amoledMode = amoled,
isDarkTheme = dark,
contrastLevel = defaultContrast.toDouble(),
style = PaletteStyle.TonalSpot,
isInvertColors = invertColor,
content = content,
)
}
@Composable
fun ColorTuplePreference(modifier: Modifier = Modifier, colorTuples: MutableMap = ColorTuples) {
val value = rememberStringPreference(
keyName = "ui.color_tuple", initialValue = colorTupleToJson(
ColorTuples["Latte"]!!
), defaultValue = colorTupleToJson(ColorTuples["Latte"]!!)
)
Box(
contentAlignment = Alignment.Center
) {
PreferenceCard(title = "foo", enabled = false, darkenOnDisable = false, modifier = modifier) {
LazyRow(
modifier = Modifier,
) {
items(colorTuples.keys.toList()) { key ->
val colorTuple = ColorTuples[key]
colorTuple?.let {
ColorTuplePreview(
modifier = Modifier.padding(horizontal = 4.dp),
onClick = { value.value = colorTupleToJson(colorTuple) },
colorTuple = colorTuple,
selected = colorTuple == jsonToColorTuple(value.value)
)
}
}
}
}
}
}
Подробнее здесь: https://stackoverflow.com/questions/784 ... data-store
Реализуйте поставщика настроек с помощью Jetpack Compose и хранилища данных. ⇐ Android
Форум для тех, кто программирует под Android
1714832299
Anonymous
Я хочу хранить настройки своего приложения в хранилище данных и сделать его легко доступным откуда угодно.
Например, чтобы иметь категорию настроек пользовательского интерфейса, иметь возможность доступа к ней и легко ее настраивать. из любого места при перекомпоновке различных частей пользовательского интерфейса при изменении конфигурации.
В настоящее время я использую библиотеку «compose-remember-preference», чтобы реализовать это, но мне нужно скопировать и вставить RememberXPreference. каждый раз, когда мне это нужно, и он будет получать предпочтения каждый раз, когда новый Composable, который его использует, составляется/перекомпонуется.
Есть ли лучший способ справиться с этим?
https://github.com/burnoo/compose-remember-preference
Вот пример того, как я использую его в двух местах:
@Composable
fun R2DroidTheme(
content: @Composable () -> Unit
) {
val isSystemDarkMode = isSystemInDarkTheme()
var defaultColorTuple = rememberStringPreference(
keyName = "ui.color_tuple", initialValue = colorTupleToJson(ColorTuples["Latte"]!!), defaultValue = colorTupleToJson(ColorTuples["Latte"]!!)
)
val (defaultContrast, setdefaultContrast) = rememberFloatPreference(keyName = "color.contrast_level", initialValue = 0.5f, defaultValue = 0.5f)
var (darkMode, setDarkMode) = rememberIntPreference(keyName = "ui.dark", initialValue = DarkMode.SYSTEM.value, defaultValue = DarkMode.SYSTEM.value )
var (amoled, setAmoled) = rememberBooleanPreference(keyName = "ui.amoled", initialValue = false, defaultValue = false)
var (materialYou, setMaterialYou) = rememberBooleanPreference(keyName = "ui.material_you", initialValue = false, defaultValue = false)
var (invertColor, setInvertColor) = rememberBooleanPreference(keyName = "color.inverted", initialValue = false, defaultValue = false)
val state = rememberDynamicThemeState(initialColorTuple = jsonToColorTuple(defaultColorTuple.value))
var dark by remember { mutableStateOf(isSystemDarkMode) }
when (darkMode) {
DarkMode.SYSTEM.value -> dark = isSystemDarkMode
DarkMode.LIGHT.value -> dark = false
DarkMode.DARK.value -> dark = true
}
MyTheme(
state = state,
defaultColorTuple = jsonToColorTuple(defaultColorTuple.value),
dynamicColor = materialYou,
amoledMode = amoled,
isDarkTheme = dark,
contrastLevel = defaultContrast.toDouble(),
style = PaletteStyle.TonalSpot,
isInvertColors = invertColor,
content = content,
)
}
@Composable
fun ColorTuplePreference(modifier: Modifier = Modifier, colorTuples: MutableMap = ColorTuples) {
val value = rememberStringPreference(
keyName = "ui.color_tuple", initialValue = colorTupleToJson(
ColorTuples["Latte"]!!
), defaultValue = colorTupleToJson(ColorTuples["Latte"]!!)
)
Box(
contentAlignment = Alignment.Center
) {
PreferenceCard(title = "foo", enabled = false, darkenOnDisable = false, modifier = modifier) {
LazyRow(
modifier = Modifier,
) {
items(colorTuples.keys.toList()) { key ->
val colorTuple = ColorTuples[key]
colorTuple?.let {
ColorTuplePreview(
modifier = Modifier.padding(horizontal = 4.dp),
onClick = { value.value = colorTupleToJson(colorTuple) },
colorTuple = colorTuple,
selected = colorTuple == jsonToColorTuple(value.value)
)
}
}
}
}
}
}
Подробнее здесь: [url]https://stackoverflow.com/questions/78429283/implement-a-setting-provider-with-jetpack-compose-and-data-store[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия