Skip to content

Tree Packs: Species

supermassimo edited this page Apr 11, 2023 · 16 revisions

What is it

Properties

The following properties MUST be included:

  • "family": The family of trees this species belongs to. It will define the trunk block and other global behaviors. It must first be defined in the Families folder.

The following properties can be included:

  • General
    • "type": Allows for custom behavior beyond these properties. The options are {nether_fungus, swamp_oak, palm}. More can be added by addons. (Default is none)
    • "always_show_on_waila": On true, will always show species under the block indicator (when waila, hwyla or similar is installed). On false, it will never show up. On null it will only show up when the species is not the family's common species. (Default: null)
    • "transformable": Whether transformation potions can be used on this species (Default: true)
    • "leaves_properties": What leaves properties will be used. They must first be defined in the Leaves Properties folder. (By default it will be the family's common leaves)
    • "mega_species": The species' mega variant, if it has one. (Default: none)
    • "can_bone_meal_tree": Whether bonemeal can be used to grow the tree. (Default: true)
    • "acceptable_soils": A list of the soil tags this tree can be planted on. (Default: ["dirt_like"])
    • "features": An array of the generation features of this species.
    • "does_rot": Whether the tree branches decay when the conditions aren't feasible. (Default: true)
  • Growth properties
    • "tapering": How much the tree thickens per block from the branches to the base.
    • "up_probability": When calculating the probability maps, the chance for a branch to prefer to go upwards.
    • "signal_energy": The energy that each growth signal starts with. It defines the max size of the tree from trunk to tips.
    • "soil_longevity": The number of pulses in average that it takes to lower the soil's fertility.
    • "growth_rate": A multiplier of how fast the tree grows. (Default: 1.0)
    • "lowest_branch_height": The lowest block height branches will start growing away from the trunk.
    • "max_branch_radius": The maximum radius of any branch of this species. Must be equal or lower to the Family's max radius. (Default: 8)
    • "growth_logic_kit": The custom logic kit used to shape the tree as it grows. By default options are {null, dark_oak, conifer, jungle, nether_fungus, palm}. More can be added by addons. (Default: null)
    • "environment_factors": The environmental factor multipliers of the species.
    • "acceptable_growth_blocks": An array of blocks that the tree can only grow on. When left empty it will not have this requirement. (Default: none)
    • "seasonal_growth_offset": [When a season mod is installed] The offset from summer that the species is on season for growth. Affects growth speed. (Min: 0.0, Max: 4.0, Default: 0.0)
  • Seed and saplings
    • "seed": The seed item, if a custom one is being used. (By default its generated on its own)
    • "generate_seed": Whether a seed should be created for this species. (Default: true)
    • "generate_sapling": Whether a sapling block should be created for this species. (Default: true)
    • "sapling_name": The name of the generated sapling block. (By default its [species]_sapling)
    • "seed_name": The name of the generated sapling block. (By default its [species]_seed)
    • "sapling_sound": The sound type of the generated sapling block. (Default: GRASS)
    • "sapling_shape": The hitbox and collision box for the genrated sapling block. By default options are {"empty", "block", "sapling", "slim_sapling", "flat_mushroom", "round_mushroom", "round_mushroom_rim"}. More can be added by addons (Default: sapling)
    • "seed_composter_chance": The chance for the composter level to raise when the seed is composted. (Default: 0.3)
    • "sapling_grows_naturally": Whether the sapling can grow on its own without using bonemeal. (Default: true)
    • "primitive_sapling": A sapling recipe to obtain the seed from the sapling or vice-versa.
    • "primitive_saplings": An array of sapling recipes to obtain the seed from the sapling or vice-versa.
    • "seasonal_seed_drop_offset": [When a season mod is installed] The offset from summer that the species is on season for voluntarily dropping seeds. Affects expansion of forests. (Min: 0.0, Max: 4.0, Default: 0.0)
  • Fruits and pods
    • "fruits": A list of all the fruits assigned to this species. The fruit feature must still be added for fruit to generate. (Default: none)
    • "pods": A list of all the pods assigned to this species. The pod feature must still be added for pods to generate. (Default: none)
    • "seasonal_fruiting_offset": [When a season mod is installed] The offset from summer that the species is on season for generating fruit. Affects fruit/pod production. (Min: 0.0, Max: 4.0, Default: 0.0)
    • "inherit_fruiting_offset_to_fruits": If set to true, the "seasonal_fruiting_offset" will be inherited to the fruits' "season_offset". (Default: false)
    • "inherit_fruiting_offset_to_pods": If set to true, the "seasonal_fruiting_offset" will be inherited to the pods' "season_offset". (Default: false)
  • Generation
    • "world_gen_leaf_map_height": The maximum height for which leaves will be placed during world gen. Must be increased for huge trees. (Default: 32)
    • "world_gen_acceptable_soils": A list of soil tags that will be checked for world gen instead of "acceptable_soils". (Default: none)
    • "common_override": A list of biomes for which this species will override the family's common species configuration. All trees planted in this biome will automatically become this species instead. (Default: none)
    • "perfect_biomes": A list of biomes for which suitability will always be 1.0 (the max value), despite the environmental factors. (Default: none)

Gen Features

Generation features are additional things added to trees either during world generation or when growing naturally.

Features can be further configured by modifying their properties. Each feature has its own configuration, and some properties must be included for it to work properly. If no property needs to be modified the feature with its default configuration can be added by including the name directly instead of using an object.

Including default properties without configuring them
    "features" : [
        "bottom_flare",
        "mound",
        "roots"
    ]
Using a configured feature
    "features" : [
        {
            "name": "rot_soil",
            "properties": {
                "rotten_soil": "podzol"
            }
        },
        "mushroom_rot",
        "bee_nest"
    ]

Dynamic Trees includes a vast array of these features: (Addons can add their own custom features)

  • "fruit": This feature generates a specified fruit under the tree's leaves. The "fruit" property is required.
    properties:
    • "fruit": The fruit that will generated. It must first be defined in the fruits folder.
    • "quantity": The amount of attempts during growth on every tree pulse. (Default: 4)
    • "fruiting_radius": The minimum radius for the base of the trunk before fruit start to grow. (Default: 8)
    • "place_chance": The chance on every attempt that a fruit block will be placed. (Default 1.0)
  • "pod": This feature generates a specified pod on the tree's branches. The "pod" property is required.
    properties:
    • "pod": The pod that will generated. It must first be defined in the pods folder.
    • "place_chance": The chance on every attempt that a pod block will be placed. (Default: 0.125)
  • "vines": Generates vines on the leaves, like in jungle trees.
    properties:
    • "vine_type": The type of vine. Can be {side, ceiling, floor}. (Default: side)
    • "block": The vine block used. (Default: minecraft:vines)
    • "tip_block": When using ceiling or floor type, the block at the tips. (Default: none)
    • "quantity": The amount of vines that will be attempted to place (Default 4)
    • "max_length": The maximum length of the vine column. (Default: 8)
    • "vertical_spread": The variation in angle (degrees) for the ray used to place the vines. (Default: 60)
    • "ray_distance": The max distance from the ray used to place the vines. (Default: 5)
    • "fruiting_radius": The minimum radius for the base of the trunk before fruit start to grow. (Default: -1, meaning no vines generate during growth)
  • "bee_nest":
    properties:
  • "shroomlight":
    properties:
  • "conifer_topper":
    properties:
  • "mound":
    properties:
  • "roots":
    properties:
  • "clear_volume":
    properties:
  • "bottom_flare":
    properties:
  • "undergrowth":
    properties:
  • "podzol":
    properties:
  • "bush":
    properties:
  • "huge_mushroom":
    properties:
  • "huge_mushrooms":
    properties:
  • "mushroom_rot":
    properties:
  • "rot_soil":
    properties:
  • "biome_predicate":
    properties:
  • "random_predicate":
    properties:
  • "alt_leaves": Makes a percentage of the tree's leaves change into another type of leaves. Either "alt_leaves" or "alt_leaves_block" is required.
    properties:
    • "alt_leaves": The leaves properties that will be used. They must first be defined in the leaves properties folder.
    • "alt_leaves_block": Alternatively, instead of using leaves properties a simple block can be used.
    • "place_chance": The chance on every attempt that random leaf block will be swapped for the alt leaves. (Default: 0.5)
    • "quantity": The amount of leaves that will be attempted to be swapped on every pulse. (Default: 5)

Sapling Recipes

//to-do

Environment Factors

//to-do

Loot Tables

Drops from the species' leaves when felled must be defined through loot tables. When working on an addon the runData task can be setup to generate them automatically, otherwise when working on a treepack they must be defined manually.

The following properties are only useful for generating Loot Tables through the runData task:

  • "drop_seeds": Whether the species' seeds are dropped from the tree when chopped down. (Default: true)