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

com.skillw.particlelib.pobject.bezier.ThreeRankBezierCurve.kt Maven / Gradle / Ivy

There is a newer version: 1.6.7-beta-6
Show newest version
package com.skillw.particlelib.pobject.bezier

import taboolib.common.util.Location
import com.skillw.particlelib.pobject.ParticleObject
import java.util.function.Consumer

/**
 * 表示一条三阶贝塞尔曲线
 *
 * 给定四点, 自动生成一条三阶贝塞尔曲线
 *
 * @param p0 连续点
 * @param p1 控制点
 * @param p2 控制点
 * @param p3 连续点
 * @param step 每个粒子的间隔(也即步长)
 * @author Zoyn
 */
class ThreeRankBezierCurve constructor(
    p0: Location,
    p1: Location,
    p2: Location,
    p3: Location,
    step: Double = 0.05,
) : ParticleObject(p0) {
    private val locations: MutableList
    var p0: Location = p0
        set(value) {
            field = value
            resetLocations()
        }
    var p1: Location = p1
        set(value) {
            field = value
            resetLocations()
        }
    var p2: Location = p2
        set(value) {
            field = value
            resetLocations()
        }
    var p3: Location = p3
        set(value) {
            field = value
            resetLocations()
        }
    var step: Double = step
        set(value) {
            field = value
            resetLocations()
        }

    /** 构造一个三阶贝塞尔曲线 */
    init {
        locations = ArrayList()
        resetLocations()
    }

    override fun show() {
        locations.forEach(Consumer { loc: Location? -> loc?.let { spawnParticle(it) } })
    }

    /** 重新计算贝塞尔曲线上的点 */
    fun resetLocations() {
        locations.clear()
        // 算法
        // 算了我知道很蠢这个算法...
        var t = 0.0
        while (t < 1) {
            val v1 = p1.clone().subtract(p0).toVector()
            val t1 = p0.clone().add(v1.multiply(t))
            val v2 = p2.clone().subtract(p1).toVector()
            val t2 = p1.clone().add(v2.multiply(t))
            val v3 = p3.clone().subtract(p2).toVector()
            val t3 = p2.clone().add(v3.multiply(t))
            val dv1 = t2.clone().subtract(t1).toVector()
            val d1 = t1.clone().add(dv1.multiply(t))
            val dv2 = t3.clone().subtract(t2).toVector()
            val d2 = t2.clone().add(dv2.multiply(t))
            val f1 = d2.clone().subtract(d1).toVector()
            val destination = d1.clone().add(f1.multiply(t))
            locations.add(destination.clone())
            t += step
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy