All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.jetbrains.datalore.base.spatial.QuadKey.kt Maven / Gradle / Ivy

/*
 * 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.base.spatial

import jetbrains.datalore.base.typedGeometry.*


data class QuadKey(
    val key: String
) {
    operator fun plus(other: QuadKey): QuadKey {
        return QuadKey(key + other.key)
    }

    val length = key.length
}

fun QuadKey.computeRect(): Rect {
    val origin = this.computeOrigin(EARTH_RECT)
    val dimension = EARTH_RECT.dimension / calulateQuadsCount(length).toDouble()

    val flippedY = EARTH_RECT.scalarBottom - (origin.scalarY + dimension.scalarY - EARTH_RECT.scalarTop)
    return Rect(origin.transform(newY = { flippedY }), dimension)
}

fun  QuadKey.computeRect(rect: Rect): Rect {
    return projectRect(rect)
}

fun  QuadKey.projectRect(rect: Rect): Rect {
    val origin = projectOrigin(rect)
    val dimension = rect.dimension / calulateQuadsCount(length).toDouble()

    return Rect(origin, dimension)
}

fun QuadKey.zoom() = length

fun  QuadKey.computeOrigin(mapRect: Rect): Vec {
    return projectOrigin(mapRect)
}

fun  QuadKey.projectOrigin(mapRect: Rect): Vec {
    var left = mapRect.scalarLeft
    var top = mapRect.scalarTop
    var width = mapRect.scalarWidth
    var height = mapRect.scalarHeight

    for (quadrant in key) {
        width /= 2.0
        height /= 2.0

        if (quadrant == '1' || quadrant == '3') {
            left += width
        }
        if (quadrant == '2' || quadrant == '3') {
            top += height
        }
    }
    return newVec(left, top)
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy