commonMain.jetbrains.datalore.plot.config.PlotConfigScales.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of lets-plot-common Show documentation
Show all versions of lets-plot-common Show documentation
Lets-Plot JVM package without rendering part
/*
* Copyright (c) 2022. JetBrains s.r.o.
* Use of this source code is governed by the MIT license that can be found in the LICENSE file.
*/
package jetbrains.datalore.plot.config
import jetbrains.datalore.plot.base.*
import jetbrains.datalore.plot.builder.assemble.TypedScaleMap
import jetbrains.datalore.plot.builder.scale.GuideMapper
import jetbrains.datalore.plot.builder.scale.ScaleProvider
import jetbrains.datalore.plot.builder.scale.WithGuideBreaks
/**
* Front-end.
*/
internal object PlotConfigScales {
internal fun createScales(
layerConfigs: List,
transformByAes: Map, Transform>,
mappersByAes: Map, ScaleMapper<*>>,
scaleProviderByAes: Map, ScaleProvider<*>>,
): TypedScaleMap {
val setup = PlotConfigUtil.createPlotAesBindingSetup(
layerConfigs,
excludeStatVariables = false
)
// All aes used in bindings and x/y aes.
// Exclude "stat positional" because we don't know which of axis they will use (i.e. orientation="y").
// See also: PlotConfigClientSideUtil.createScalesForStatPositionalBindings()
val aesSet = setup.mappedAesWithoutStatPositional() + setOf(Aes.X, Aes.Y)
val variablesByMappedAes = setup.variablesByMappedAes
// Create scales for all aes.
val scaleByAes = HashMap, Scale<*>>()
for (aes in aesSet) {
val defaultName = PlotConfigUtil.defaultScaleName(aes, variablesByMappedAes)
val scaleProvider = scaleProviderByAes.getValue(aes)
@Suppress("MoveVariableDeclarationIntoWhen")
val transform = transformByAes.getValue(aes)
val scale = when (transform) {
is DiscreteTransform -> scaleProvider.createScale(defaultName, transform)
else -> {
transform as ContinuousTransform
val mapper = mappersByAes.getValue(aes)
val continuousRange = (mapper is GuideMapper && mapper.isContinuous)
@Suppress("UNCHECKED_CAST")
val guideBreaks: WithGuideBreaks? =
if (mapper is WithGuideBreaks<*>) mapper as WithGuideBreaks
else null
scaleProvider.createScale(defaultName, transform, continuousRange, guideBreaks)
}
}
scaleByAes[aes] = scale
}
return TypedScaleMap(scaleByAes)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy