HyCodeYourTale
classpublicPriority 3

EllipsoidDensityAsset

com.hypixel.hytale.builtin.hytalegenerator.assets.density.EllipsoidDensityAsset

extends DensityAsset

2

Methods

2

Public Methods

1

Fields

1

Constructors

Constants

BuilderCodec<EllipsoidDensityAsset>CODEC= BuilderCodec.builder( EllipsoidDensityAsset.class, EllipsoidDensityAsset::new, DensityAs...

Constructors

public
EllipsoidDensityAsset()

Methods

Public Methods (2)

public
Density build(DensityAsset.Argument argument)
@Nonnull@Override
public
void cleanUp()
@Override

Fields

Private/Package Fields (1)

privatedouble spinAngle

Inheritance

Parent
Current
Interface
Child

Use mouse wheel to zoom, drag to pan. Click nodes to navigate.

Related Classes

Source Code

package com.hypixel.hytale.builtin.hytalegenerator.assets.density;

import com.hypixel.hytale.builtin.hytalegenerator.assets.curves.ConstantCurveAsset;
import com.hypixel.hytale.builtin.hytalegenerator.assets.curves.CurveAsset;
import com.hypixel.hytale.builtin.hytalegenerator.density.Density;
import com.hypixel.hytale.builtin.hytalegenerator.density.nodes.ConstantValueDensity;
import com.hypixel.hytale.builtin.hytalegenerator.density.nodes.DistanceDensity;
import com.hypixel.hytale.builtin.hytalegenerator.density.nodes.RotatorDensity;
import com.hypixel.hytale.builtin.hytalegenerator.density.nodes.ScaleDensity;
import com.hypixel.hytale.codec.Codec;
import com.hypixel.hytale.codec.KeyedCodec;
import com.hypixel.hytale.codec.builder.BuilderCodec;
import com.hypixel.hytale.codec.validation.LegacyValidator;
import com.hypixel.hytale.math.vector.Vector3d;
import javax.annotation.Nonnull;

public class EllipsoidDensityAsset extends DensityAsset {
   public static final BuilderCodec<EllipsoidDensityAsset> CODEC = BuilderCodec.builder(
         EllipsoidDensityAsset.class, EllipsoidDensityAsset::new, DensityAsset.ABSTRACT_CODEC
      )
      .append(new KeyedCodec<>("Curve", CurveAsset.CODEC, true), (t, k) -> t.densityCurveAsset = k, k -> k.densityCurveAsset)
      .add()
      .<Vector3d>append(new KeyedCodec<>("Scale", Vector3d.CODEC, false), (t, k) -> t.scaleVector = k, k -> k.scaleVector)
      .addValidator((LegacyValidator<? super Vector3d>)((v, r) -> {
         if (v.x == 0.0 || v.y == 0.0 || v.z == 0.0) {
            r.fail("scale vector contains 0.0");
         }
      }))
      .add()
      .append(new KeyedCodec<>("NewYAxis", Vector3d.CODEC, false), (t, k) -> {
         if (k.length() != 0.0) {
            t.newYAxis = k;
         }
      }, k -> k.newYAxis)
      .add()
      .append(new KeyedCodec<>("Spin", Codec.DOUBLE, false), (t, k) -> t.spinAngle = k, k -> k.spinAngle)
      .add()
      .build();
   private CurveAsset densityCurveAsset = new ConstantCurveAsset();
   private Vector3d scaleVector = new Vector3d(1.0, 1.0, 1.0);
   @Nonnull
   private Vector3d newYAxis = new Vector3d(0.0, 1.0, 0.0);
   private double spinAngle = 0.0;

   public EllipsoidDensityAsset() {
   }

   @Nonnull
   @Override
   public Density build(@Nonnull DensityAsset.Argument argument) {
      if (!this.isSkipped() && this.densityCurveAsset != null) {
         DistanceDensity sphere = new DistanceDensity(this.densityCurveAsset.build());
         ScaleDensity scale = new ScaleDensity(this.scaleVector.x, this.scaleVector.y, this.scaleVector.z, sphere);
         return new RotatorDensity(scale, this.newYAxis, this.spinAngle);
      } else {
         return new ConstantValueDensity(0.0);
      }
   }

   @Override
   public void cleanUp() {
      this.cleanUpInputs();
      this.densityCurveAsset.cleanUp();
   }
}