ModifierLocalModifierNode
interface ModifierLocalModifierNode : ModifierLocalReadScope, DelegatableNode
A androidx.compose.ui.Modifier.Node that is capable of consuming and providing ModifierLocal
values.
This is the androidx.compose.ui.Modifier.Node equivalent of the ModifierLocalConsumer and
ModifierLocalProvider interfaces.
Properties
val providedValues: ModifierLocalMap
The map of provided ModifierLocal <-> value pairs that this node is providing. This value must be overridden if you are going to provide any values. It should be overridden as a field-backed property initialized with values for all of the keys that it will ever possibly provide.
By default, this property will be set to an empty map, which means that this node will only
consume ModifierLocals and will not provide any new values.
If you would like to change a value provided in the map over time, you must use the provide
API.
override val <T> ModifierLocal<T>.current: T
Read a ModifierLocal that was provided by other modifiers to the left of this modifier, or
above this modifier in the layout tree.
Functions
fun <T> provide(key: ModifierLocal<T>, value: T)
This method will cause this node to provide a new value for key. This can be called at
any time on the UI thread, but in order to use this API, providedValues must be implemented
and key must be a key that was included in it.
By providing this new value, any ModifierLocalModifierNode below it in the tree will read
this value when reading current, until another ModifierLocalModifierNode provides a
value for the same key, however, consuming ModifierLocalModifierNodes will NOT be
notified that a new value was provided.
Code Examples
JustReadingOrProvidingModifierLocalNodeSample
@Composable
fun JustReadingOrProvidingModifierLocalNodeSample() {
class Logger {
fun log(string: String) {
println(string)
}
}
val loggerLocal = modifierLocalOf { Logger() }
class ProvideLoggerNode(logger: Logger) : ModifierLocalModifierNode, Modifier.Node() {
override val providedValues = modifierLocalMapOf(loggerLocal to logger)
}
data class ProvideLoggerElement(val logger: Logger) : ModifierNodeElement<ProvideLoggerNode>() {
override fun create() = ProvideLoggerNode(logger)
override fun update(node: ProvideLoggerNode) {
node.provide(loggerLocal, logger)
}
override fun InspectorInfo.inspectableProperties() {
name = "provideLogger"
properties["logger"] = logger
}
}
class SizeLoggerNode(var id: String) :
ModifierLocalModifierNode, LayoutAwareModifierNode, Modifier.Node() {
override fun onRemeasured(size: IntSize) {
loggerLocal.current.log("The size of $id was $size")
}
}
data class SizeLoggerElement(val id: String) : ModifierNodeElement<SizeLoggerNode>() {
override fun create() = SizeLoggerNode(id)
override fun update(node: SizeLoggerNode) {
node.id = id
}
override fun InspectorInfo.inspectableProperties() {
name = "logSize"
properties["id"] = id
}
}
fun Modifier.logSize(id: String) = this then SizeLoggerElement(id)
fun Modifier.provideLogger(logger: Logger) = this then ProvideLoggerElement(logger)
}
