commonMain.jetbrains.datalore.vis.svg.SvgUtils.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vis-svg-portable Show documentation
Show all versions of vis-svg-portable Show documentation
The Let-Plot Kotlin API depends on this artifact.
The newest version!
/*
* Copyright (c) 2019. 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.vis.svg
import jetbrains.datalore.base.geometry.DoubleVector
import jetbrains.datalore.base.observable.property.Property
import jetbrains.datalore.base.observable.property.WritableProperty
import jetbrains.datalore.base.values.Color
import kotlin.math.max
import kotlin.math.min
object SvgUtils {
private val OPACITY_TABLE: DoubleArray = DoubleArray(256)
init {
for (alpha in 0..255) {
OPACITY_TABLE[alpha] = alpha / 255.0
}
}
fun opacity(c: Color): Double {
return OPACITY_TABLE[c.alpha]
}
fun alpha2opacity(colorAlpha: Int): Double {
return OPACITY_TABLE[colorAlpha]
}
fun toARGB(c: Color): Int {
return toARGB(c.red, c.green, c.blue, c.alpha)
}
fun toARGB(c: Color, alpha: Double): Int {
return toARGB(
c.red,
c.green,
c.blue,
max(0.0, min(255.0, alpha * 255)).toInt()
)
}
fun toARGB(r: Int, g: Int, b: Int, alpha: Int): Int {
val rgb = (r shl 16) + (g shl 8) + b
return (alpha shl 24) + rgb
}
internal fun colorAttributeTransform(color: Property, opacity: Property): WritableProperty {
return object : WritableProperty {
override fun set(value: Color?) {
color.set(SvgColors.create(value))
if (value != null) {
opacity.set(opacity(value))
} else {
opacity.set(1.0)
}
}
}
}
fun transformMatrix(element: SvgTransformable, a: Double, b: Double, c: Double, d: Double, e: Double, f: Double) {
element.transform().set(SvgTransformBuilder().matrix(a, b, c, d, e, f).build())
}
fun transformTranslate(element: SvgTransformable, x: Double, y: Double) {
element.transform().set(SvgTransformBuilder().translate(x, y).build())
}
fun transformTranslate(element: SvgTransformable, vector: DoubleVector) {
transformTranslate(element, vector.x, vector.y)
}
fun transformTranslate(element: SvgTransformable, x: Double) {
element.transform().set(SvgTransformBuilder().translate(x).build())
}
fun transformScale(element: SvgTransformable, x: Double, y: Double) {
element.transform().set(SvgTransformBuilder().scale(x, y).build())
}
fun transformScale(element: SvgTransformable, x: Double) {
element.transform().set(SvgTransformBuilder().scale(x).build())
}
fun transformRotate(element: SvgTransformable, a: Double, x: Double, y: Double) {
element.transform().set(SvgTransformBuilder().rotate(a, x, y).build())
}
fun transformRotate(element: SvgTransformable, a: Double) {
element.transform().set(SvgTransformBuilder().rotate(a).build())
}
fun transformSkewX(element: SvgTransformable, a: Double) {
element.transform().set(SvgTransformBuilder().skewX(a).build())
}
fun transformSkewY(element: SvgTransformable, a: Double) {
element.transform().set(SvgTransformBuilder().skewY(a).build())
}
fun copyAttributes(source: SvgElement, target: SvgElement) {
for (attributeSpec in source.attributeKeys) {
@Suppress("UNCHECKED_CAST")
val spec = attributeSpec as SvgAttributeSpec
target.setAttribute(spec, source.getAttribute(attributeSpec).get())
}
}
fun pngDataURI(base64EncodedPngImage: String): String {
return StringBuilder("data:image/png;base64,")
.append(base64EncodedPngImage)
.toString()
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy