commonMain.jetbrains.datalore.plot.base.geom.CrossBarGeom.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) 2020. 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.base.geom
import jetbrains.datalore.base.geometry.DoubleRectangle
import jetbrains.datalore.base.geometry.DoubleVector
import jetbrains.datalore.plot.base.*
import jetbrains.datalore.plot.base.geom.util.BarTooltipHelper
import jetbrains.datalore.plot.base.geom.util.CrossBarHelper
import jetbrains.datalore.plot.base.geom.util.GeomHelper
import jetbrains.datalore.plot.base.geom.util.HintColorUtil
import jetbrains.datalore.plot.base.render.LegendKeyElementFactory
import jetbrains.datalore.plot.base.render.SvgRoot
class CrossBarGeom : GeomBase() {
var fattenMidline: Double = 2.5
override val legendKeyElementFactory: LegendKeyElementFactory
get() = LEGEND_FACTORY
override fun buildIntern(
root: SvgRoot,
aesthetics: Aesthetics,
pos: PositionAdjustment,
coord: CoordinateSystem,
ctx: GeomContext
) {
val geomHelper = GeomHelper(pos, coord, ctx)
CrossBarHelper.buildBoxes(
root, aesthetics, pos, coord, ctx,
clientRectByDataPoint(ctx, geomHelper, isHintRect = false)
)
CrossBarHelper.buildMidlines(root, aesthetics, ctx, geomHelper, fattenMidline)
BarTooltipHelper.collectRectangleTargets(
listOf(Aes.YMAX, Aes.YMIN),
aesthetics, pos, coord, ctx,
clientRectByDataPoint(ctx, geomHelper, isHintRect = true),
{ HintColorUtil.colorWithAlpha(it) }
)
}
companion object {
const val HANDLES_GROUPS = false
private val LEGEND_FACTORY = CrossBarHelper.legendFactory(false)
private fun clientRectByDataPoint(
ctx: GeomContext,
geomHelper: GeomHelper,
isHintRect: Boolean
): (DataPointAesthetics) -> DoubleRectangle? {
return { p ->
val rect = if (!isHintRect &&
p.defined(Aes.X) &&
p.defined(Aes.YMIN) &&
p.defined(Aes.YMAX) &&
p.defined(Aes.WIDTH)
) {
val x = p.x()!!
val ymin = p.ymin()!!
val ymax = p.ymax()!!
val width = p.width()!! * ctx.getResolution(Aes.X)
val origin = DoubleVector(x - width / 2, ymin)
val dimensions = DoubleVector(width, ymax - ymin)
DoubleRectangle(origin, dimensions)
} else if (isHintRect &&
p.defined(Aes.X) &&
p.defined(Aes.MIDDLE) &&
p.defined(Aes.WIDTH)
) {
val x = p.x()!!
val middle = p.middle()!!
val width = p.width()!! * ctx.getResolution(Aes.X)
val origin = DoubleVector(x - width / 2, middle)
val dimensions = DoubleVector(width, 0.0)
DoubleRectangle(origin, dimensions)
} else {
null
}
rect?.let { geomHelper.toClient(it, p) }
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy