Реализуйте поставщика настроек с помощью Jetpack Compose и хранилища данных.Android

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Реализуйте поставщика настроек с помощью Jetpack Compose и хранилища данных.

Сообщение 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)
)
}
}
}
}
}
}



Подробнее здесь: https://stackoverflow.com/questions/784 ... data-store
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»