From 8acd3832e36eab8ac46e50d45bc9ccbd3121f1bc Mon Sep 17 00:00:00 2001 From: jshipsey Date: Tue, 25 May 2021 03:27:34 -0400 Subject: [PATCH] more loot tables, overworld ores, more items --- assets/common/cave_scatter/deep.ron | 6 +- assets/common/cave_scatter/shallow.ron | 9 +-- assets/common/item_price_calculation.ron | 1 - .../animal_misc/phoenix_feather.ron | 9 +++ .../{ => animal_misc}/viscous_ooze.ron | 0 assets/common/items/food/meat/bird_cooked.ron | 22 ++++++ .../items/food/meat/bird_large_cooked.ron | 22 ++++++ .../common/items/food/meat/bird_large_raw.ron | 22 ++++++ assets/common/items/food/meat/bird_raw.ron | 22 ++++++ .../items/npc_armor/biped_large/harvester.ron | 4 ++ .../items/npc_armor/biped_large/minotaur.ron | 4 ++ .../npc_armor/biped_large/tidal_warrior.ron | 4 ++ .../items/npc_armor/biped_large/yeti.ron | 4 ++ .../items/weapons/hammer/burnt_drumstick.ron | 18 +++++ assets/common/loot_tables/armor/steel.ron | 8 --- .../creature/bird_large/cockatrice.ron | 4 ++ .../creature/bird_large/phoenix.ron | 5 ++ .../loot_tables/creature/bird_medium.ron | 2 +- assets/common/loot_tables/creature/golem.ron | 1 - .../creature/quad_low/deadwood.ron | 4 ++ .../loot_tables/creature/quad_low/fanged.ron | 2 +- .../creature/quad_low/venemous.ron | 1 + .../creature/quad_medium/carapace.ron | 6 ++ .../creature/quad_medium/catoblepas.ron | 5 ++ .../quad_medium/{default.ron => clawed.ron} | 1 + .../creature/quad_medium/dreadhorn.ron | 6 ++ .../creature/quad_medium/fanged.ron | 5 ++ .../creature/quad_medium/gentle.ron | 5 ++ .../loot_tables/creature/quad_small/fur.ron | 5 ++ .../creature/quad_small/mushroom.ron | 3 + .../loot_tables/creature/quad_small/ooze.ron | 3 + .../loot_tables/creature/quad_small/sheep.ron | 3 + .../loot_tables/creature/theropod/horned.ron | 4 ++ .../loot_tables/creature/theropod/raptor.ron | 1 + .../loot_tables/dungeon/tier-3/enemy.ron | 1 - .../loot_tables/dungeon/tier-4/enemy.ron | 1 - .../loot_tables/dungeon/tier-4/miniboss.ron | 2 - .../loot_tables/dungeon/tier-5/enemy.ron | 1 - assets/common/recipe_book.ron | 21 ++++++ assets/voxygen/item_image_manifest.ron | 34 ++++++++- .../voxygen/voxel/biped_weapon_manifest.ron | 4 ++ assets/voxygen/voxel/object/tanning_rack.vox | 3 + .../crafting_ing/{ => animal_misc}/claw.vox | 0 .../sprite/crafting_ing/animal_misc/fur.vox | 3 + .../animal_misc/phoenix_feather.vox | 3 + .../viscous_ooze.vox} | 0 .../sprite/crafting_ing/hide/rugged_hide.vox | 3 + .../sprite/crafting_ing/hide/tough_hide.vox | 4 +- .../crafting_ing/leather/rigid_leather.vox | 3 + .../sprite/food/meat/bird_large_cooked.vox | 3 + .../voxel/sprite/food/meat/bird_large_raw.vox | 3 + .../voxel/weapon/hammer/burnt_drumstick.vox | 3 + assets/world/style/colors.ron | 2 +- server/src/events/entity_manipulation.rs | 71 +++++++++++++++++-- world/src/layer/mod.rs | 18 ++++- world/src/layer/scatter.rs | 6 ++ 56 files changed, 371 insertions(+), 39 deletions(-) create mode 100644 assets/common/items/crafting_ing/animal_misc/phoenix_feather.ron rename assets/common/items/crafting_ing/{ => animal_misc}/viscous_ooze.ron (100%) create mode 100644 assets/common/items/food/meat/bird_cooked.ron create mode 100644 assets/common/items/food/meat/bird_large_cooked.ron create mode 100644 assets/common/items/food/meat/bird_large_raw.ron create mode 100644 assets/common/items/food/meat/bird_raw.ron create mode 100644 assets/common/items/weapons/hammer/burnt_drumstick.ron delete mode 100644 assets/common/loot_tables/armor/steel.ron create mode 100644 assets/common/loot_tables/creature/bird_large/cockatrice.ron create mode 100644 assets/common/loot_tables/creature/bird_large/phoenix.ron create mode 100644 assets/common/loot_tables/creature/quad_low/deadwood.ron create mode 100644 assets/common/loot_tables/creature/quad_medium/carapace.ron create mode 100644 assets/common/loot_tables/creature/quad_medium/catoblepas.ron rename assets/common/loot_tables/creature/quad_medium/{default.ron => clawed.ron} (73%) create mode 100644 assets/common/loot_tables/creature/quad_medium/dreadhorn.ron create mode 100644 assets/common/loot_tables/creature/quad_medium/fanged.ron create mode 100644 assets/common/loot_tables/creature/quad_medium/gentle.ron create mode 100644 assets/common/loot_tables/creature/quad_small/fur.ron create mode 100644 assets/common/loot_tables/creature/quad_small/mushroom.ron create mode 100644 assets/common/loot_tables/creature/quad_small/ooze.ron create mode 100644 assets/common/loot_tables/creature/quad_small/sheep.ron create mode 100644 assets/common/loot_tables/creature/theropod/horned.ron create mode 100644 assets/voxygen/voxel/object/tanning_rack.vox rename assets/voxygen/voxel/sprite/crafting_ing/{ => animal_misc}/claw.vox (100%) create mode 100644 assets/voxygen/voxel/sprite/crafting_ing/animal_misc/fur.vox create mode 100644 assets/voxygen/voxel/sprite/crafting_ing/animal_misc/phoenix_feather.vox rename assets/voxygen/voxel/sprite/crafting_ing/{ooze.vox => animal_misc/viscous_ooze.vox} (100%) create mode 100644 assets/voxygen/voxel/sprite/crafting_ing/hide/rugged_hide.vox create mode 100644 assets/voxygen/voxel/sprite/crafting_ing/leather/rigid_leather.vox create mode 100644 assets/voxygen/voxel/sprite/food/meat/bird_large_cooked.vox create mode 100644 assets/voxygen/voxel/sprite/food/meat/bird_large_raw.vox create mode 100644 assets/voxygen/voxel/weapon/hammer/burnt_drumstick.vox diff --git a/assets/common/cave_scatter/deep.ron b/assets/common/cave_scatter/deep.ron index f53f17e766..98ff622ab4 100644 --- a/assets/common/cave_scatter/deep.ron +++ b/assets/common/cave_scatter/deep.ron @@ -1,7 +1,7 @@ [ - (10, Velorite), - (15, VeloriteFrag), - (100, ShortGrass), + (30, Velorite), + (40, VeloriteFrag), + (70, ShortGrass), (10, CaveMushroom), (10, AmethystSmall), (10, TopazSmall), diff --git a/assets/common/cave_scatter/shallow.ron b/assets/common/cave_scatter/shallow.ron index 9aeec991e9..b7d348cfb9 100644 --- a/assets/common/cave_scatter/shallow.ron +++ b/assets/common/cave_scatter/shallow.ron @@ -1,15 +1,12 @@ [ - (10, Velorite), - (15, VeloriteFrag), (110, Stones), (150, ShortGrass), (120, CaveMushroom), (30, AmethystSmall), (15, TopazSmall), - (20, Tin), - (16, Copper), - (5, Coal), - (8, Iron), + (15, Tin), + (12, Copper), + (15, Iron), (5, Chest), (15, Crate), ] diff --git a/assets/common/item_price_calculation.ron b/assets/common/item_price_calculation.ron index 0748d14fbe..090523abcf 100644 --- a/assets/common/item_price_calculation.ron +++ b/assets/common/item_price_calculation.ron @@ -19,7 +19,6 @@ loot_tables: [ (1.0, true, "common.loot_tables.armor.twigs"), (1.0, true, "common.loot_tables.armor.twigsflowers"), (1.0, true, "common.loot_tables.armor.twigsleaves"), - (0.25, false, "common.loot_tables.armor.steel"), (0.075, false, "common.loot_tables.armor.cultist"), // Materials (7.5, true, "common.loot_tables.materials.common"), diff --git a/assets/common/items/crafting_ing/animal_misc/phoenix_feather.ron b/assets/common/items/crafting_ing/animal_misc/phoenix_feather.ron new file mode 100644 index 0000000000..bf6a1fcba1 --- /dev/null +++ b/assets/common/items/crafting_ing/animal_misc/phoenix_feather.ron @@ -0,0 +1,9 @@ +ItemDef( + name: "Phoenix Feather", + description: "Said to have magical properties.", + kind: Ingredient( + kind: "PhoenixFeather", + ), + quality: Common, + tags: [], +) \ No newline at end of file diff --git a/assets/common/items/crafting_ing/viscous_ooze.ron b/assets/common/items/crafting_ing/animal_misc/viscous_ooze.ron similarity index 100% rename from assets/common/items/crafting_ing/viscous_ooze.ron rename to assets/common/items/crafting_ing/animal_misc/viscous_ooze.ron diff --git a/assets/common/items/food/meat/bird_cooked.ron b/assets/common/items/food/meat/bird_cooked.ron new file mode 100644 index 0000000000..d6ebe34157 --- /dev/null +++ b/assets/common/items/food/meat/bird_cooked.ron @@ -0,0 +1,22 @@ +ItemDef( + name: "Cooked Bird Meat", + description: "Best enjoyed with one in each hand.", + kind: Consumable( + kind: "BirdCooked", + effect: [ + Buff(( + kind: Saturation, + data: ( + strength: 25.0, + duration: Some(( + secs: 10, + nanos: 0, + )), + ), + cat_ids: [Natural], + )), + ] + ), + quality: Common, + tags: [Food], +) diff --git a/assets/common/items/food/meat/bird_large_cooked.ron b/assets/common/items/food/meat/bird_large_cooked.ron new file mode 100644 index 0000000000..a1c94aa038 --- /dev/null +++ b/assets/common/items/food/meat/bird_large_cooked.ron @@ -0,0 +1,22 @@ +ItemDef( + name: "Huge Cooked Drumstick", + description: "Makes for a legendary meal.", + kind: Consumable( + kind: "BirdLargeCooked", + effect: [ + Buff(( + kind: Saturation, + data: ( + strength: 80.0, + duration: Some(( + secs: 10, + nanos: 0, + )), + ), + cat_ids: [Natural], + )), + ] + ), + quality: Common, + tags: [Food], +) diff --git a/assets/common/items/food/meat/bird_large_raw.ron b/assets/common/items/food/meat/bird_large_raw.ron new file mode 100644 index 0000000000..2bd8afc6d1 --- /dev/null +++ b/assets/common/items/food/meat/bird_large_raw.ron @@ -0,0 +1,22 @@ +ItemDef( + name: "Huge Raw Drumstick", + description: "It's magificent.", + kind: Consumable( + kind: "BirdLargeRaw", + effect: [ + Buff(( + kind: Saturation, + data: ( + strength: 30.0, + duration: Some(( + secs: 3, + nanos: 0, + )), + ), + cat_ids: [Natural], + )), + ] + ), + quality: Common, + tags: [Food], +) diff --git a/assets/common/items/food/meat/bird_raw.ron b/assets/common/items/food/meat/bird_raw.ron new file mode 100644 index 0000000000..252cb1fd63 --- /dev/null +++ b/assets/common/items/food/meat/bird_raw.ron @@ -0,0 +1,22 @@ +ItemDef( + name: "Raw Bird Meat", + description: "A hefty drumstick.", + kind: Consumable( + kind: "BirdRaw", + effect: [ + Buff(( + kind: Saturation, + data: ( + strength: 15.0, + duration: Some(( + secs: 3, + nanos: 0, + )), + ), + cat_ids: [Natural], + )), + ] + ), + quality: Common, + tags: [Food], +) diff --git a/assets/common/items/npc_armor/biped_large/harvester.ron b/assets/common/items/npc_armor/biped_large/harvester.ron index d2aa76d312..524c5d041f 100644 --- a/assets/common/items/npc_armor/biped_large/harvester.ron +++ b/assets/common/items/npc_armor/biped_large/harvester.ron @@ -6,6 +6,10 @@ ItemDef( stats: ( protection: Normal(0.0), poise_resilience: Normal(0.0), + energy_max: 0, + energy_recovery: 0.0, + crit_power: 0.0, + stealth: 0.0, ), )), quality: Legendary, diff --git a/assets/common/items/npc_armor/biped_large/minotaur.ron b/assets/common/items/npc_armor/biped_large/minotaur.ron index f57629d868..df7543c2c7 100644 --- a/assets/common/items/npc_armor/biped_large/minotaur.ron +++ b/assets/common/items/npc_armor/biped_large/minotaur.ron @@ -6,6 +6,10 @@ ItemDef( stats: ( protection: Normal(0.0), poise_resilience: Normal(0.0), + energy_max: 0, + energy_recovery: 0.0, + crit_power: 0.0, + stealth: 0.0, ), )), quality: Legendary, diff --git a/assets/common/items/npc_armor/biped_large/tidal_warrior.ron b/assets/common/items/npc_armor/biped_large/tidal_warrior.ron index 2e7980bbac..a46c1f0fe4 100644 --- a/assets/common/items/npc_armor/biped_large/tidal_warrior.ron +++ b/assets/common/items/npc_armor/biped_large/tidal_warrior.ron @@ -6,6 +6,10 @@ ItemDef( stats: ( protection: Normal(20.0), poise_resilience: Normal(0.0), + energy_max: 0, + energy_recovery: 0.0, + crit_power: 0.0, + stealth: 0.0, ), )), quality: Legendary, diff --git a/assets/common/items/npc_armor/biped_large/yeti.ron b/assets/common/items/npc_armor/biped_large/yeti.ron index 65918a3686..f3639ddfc4 100644 --- a/assets/common/items/npc_armor/biped_large/yeti.ron +++ b/assets/common/items/npc_armor/biped_large/yeti.ron @@ -6,6 +6,10 @@ ItemDef( stats: ( protection: Normal(0.0), poise_resilience: Normal(0.0), + energy_max: 0, + energy_recovery: 0.0, + crit_power: 0.0, + stealth: 0.0, ), )), quality: Legendary, diff --git a/assets/common/items/weapons/hammer/burnt_drumstick.ron b/assets/common/items/weapons/hammer/burnt_drumstick.ron new file mode 100644 index 0000000000..237fd4c51c --- /dev/null +++ b/assets/common/items/weapons/hammer/burnt_drumstick.ron @@ -0,0 +1,18 @@ +ItemDef( + name: "Burnt Drumstick", + description: "Might need more practice...", + kind: Tool(( + kind: Hammer, + hands: Two, + stats: Direct(( + equip_time_secs: 0.5, + power: 0.5, + poise_strength: 1.0, + speed: 1.0, + crit_chance: 0.09375, + crit_mult: 2.2190475, + )), + )), + quality: Low, + tags: [], +) \ No newline at end of file diff --git a/assets/common/loot_tables/armor/steel.ron b/assets/common/loot_tables/armor/steel.ron deleted file mode 100644 index 5d0060f9c3..0000000000 --- a/assets/common/loot_tables/armor/steel.ron +++ /dev/null @@ -1,8 +0,0 @@ -[ - (1.0, Item("common.items.armor.mail.steel.belt")), - (1.0, Item("common.items.armor.mail.steel.chest")), - (1.0, Item("common.items.armor.mail.steel.foot")), - (1.0, Item("common.items.armor.mail.steel.hand")), - (1.0, Item("common.items.armor.mail.steel.pants")), - (1.0, Item("common.items.armor.mail.steel.shoulder")), -] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/bird_large/cockatrice.ron b/assets/common/loot_tables/creature/bird_large/cockatrice.ron new file mode 100644 index 0000000000..12debee315 --- /dev/null +++ b/assets/common/loot_tables/creature/bird_large/cockatrice.ron @@ -0,0 +1,4 @@ +[ + (1.0, Item("common.items.food.meat.bird_raw")), + (1.0, Item("common.items.crafting_ing.hide.scales")), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/bird_large/phoenix.ron b/assets/common/loot_tables/creature/bird_large/phoenix.ron new file mode 100644 index 0000000000..705dc8f853 --- /dev/null +++ b/assets/common/loot_tables/creature/bird_large/phoenix.ron @@ -0,0 +1,5 @@ +[ + (0.1, Item("common.items.food.meat.bird_large_raw")), + (1.0, Item("common.items.crafting_ing.animal_misc.phoenix_feather")), + +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/bird_medium.ron b/assets/common/loot_tables/creature/bird_medium.ron index 650aba53c3..5734d81385 100644 --- a/assets/common/loot_tables/creature/bird_medium.ron +++ b/assets/common/loot_tables/creature/bird_medium.ron @@ -1,3 +1,3 @@ [ - (1.0, Item("common.items.crafting_ing.hide.animal_hide")), + (1.0, Item("common.items.food.meat.bird_raw")), ] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/golem.ron b/assets/common/loot_tables/creature/golem.ron index 1caabc59f8..a20e4a076c 100644 --- a/assets/common/loot_tables/creature/golem.ron +++ b/assets/common/loot_tables/creature/golem.ron @@ -1,6 +1,5 @@ [ (1.0, LootTable("common.loot_tables.food.prepared")), - (1.0, LootTable("common.loot_tables.armor.steel")), (1.0, LootTable("common.loot_tables.weapons.tier-1")), (1.0, LootTable("common.loot_tables.weapons.tier-2")), (1.0, LootTable("common.loot_tables.weapons.tier-3")), diff --git a/assets/common/loot_tables/creature/quad_low/deadwood.ron b/assets/common/loot_tables/creature/quad_low/deadwood.ron new file mode 100644 index 0000000000..ac925c7b9e --- /dev/null +++ b/assets/common/loot_tables/creature/quad_low/deadwood.ron @@ -0,0 +1,4 @@ +[ + (1.0, Item("common.items.crafting_ing.animal_misc.lively_vine")), + (1.0, Item("common.items.crafting_ing.animal_misc.grim_eyeball")), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_low/fanged.ron b/assets/common/loot_tables/creature/quad_low/fanged.ron index f0fcba6209..42302fe9cc 100644 --- a/assets/common/loot_tables/creature/quad_low/fanged.ron +++ b/assets/common/loot_tables/creature/quad_low/fanged.ron @@ -1,6 +1,6 @@ [ (1.0, Item("common.items.food.meat.tough_raw")), (2.0, Item("common.items.crafting_ing.hide.scales")), - (2.0, Item("common.items.crafting_ing.animal_misc.fang")), + (2.0, Item("common.items.crafting_ing.animal_misc.sharp_fang")), ] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_low/venemous.ron b/assets/common/loot_tables/creature/quad_low/venemous.ron index 152ac87559..9627092481 100644 --- a/assets/common/loot_tables/creature/quad_low/venemous.ron +++ b/assets/common/loot_tables/creature/quad_low/venemous.ron @@ -1,5 +1,6 @@ [ (1.0, Item("common.items.food.meat.tough_raw")), + (1.0, Item("common.items.crafting_ing.animal_misc.sharp_fang")), (2.0, Item("common.items.crafting_ing.animal_misc.venom_sac")), (2.0, Item("common.items.crafting_ing.hide.scales")), ] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_medium/carapace.ron b/assets/common/loot_tables/creature/quad_medium/carapace.ron new file mode 100644 index 0000000000..432f820da5 --- /dev/null +++ b/assets/common/loot_tables/creature/quad_medium/carapace.ron @@ -0,0 +1,6 @@ +[ + (1.5, Item("common.items.food.meat.beast_small_raw")), + (0.5, Item("common.items.food.meat.beast_large_raw")), + (2.0, Item("common.items.crafting_ing.animal_misc.sharp_fang")), + (3.0, Item("common.items.crafting_ing.hide.carapace")), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_medium/catoblepas.ron b/assets/common/loot_tables/creature/quad_medium/catoblepas.ron new file mode 100644 index 0000000000..d825eed067 --- /dev/null +++ b/assets/common/loot_tables/creature/quad_medium/catoblepas.ron @@ -0,0 +1,5 @@ +[ + (1.5, Item("common.items.crafting_ing.animal_misc.grim_eyeball")), + (0.5, Item("common.items.food.meat.beast_large_raw")), + (3.0, Item("common.items.crafting_ing.hide.tough_hide")), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_medium/default.ron b/assets/common/loot_tables/creature/quad_medium/clawed.ron similarity index 73% rename from assets/common/loot_tables/creature/quad_medium/default.ron rename to assets/common/loot_tables/creature/quad_medium/clawed.ron index 3cf402cc04..778ce5ae20 100644 --- a/assets/common/loot_tables/creature/quad_medium/default.ron +++ b/assets/common/loot_tables/creature/quad_medium/clawed.ron @@ -1,5 +1,6 @@ [ (1.5, Item("common.items.food.meat.beast_small_raw")), (0.5, Item("common.items.food.meat.beast_large_raw")), + (2.0, Item("common.items.crafting_ing.animal_misc.claw")), (3.0, Item("common.items.crafting_ing.hide.tough_hide")), ] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_medium/dreadhorn.ron b/assets/common/loot_tables/creature/quad_medium/dreadhorn.ron new file mode 100644 index 0000000000..74c79cede6 --- /dev/null +++ b/assets/common/loot_tables/creature/quad_medium/dreadhorn.ron @@ -0,0 +1,6 @@ +[ + (1.5, Item("common.items.food.meat.beast_small_raw")), + (0.5, Item("common.items.food.meat.beast_large_raw")), + (2.0, Item("common.items.crafting_ing.animal_misc.large_horn")), + (3.0, Item("common.items.crafting_ing.hide.carapace")), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_medium/fanged.ron b/assets/common/loot_tables/creature/quad_medium/fanged.ron new file mode 100644 index 0000000000..a39d5a76a2 --- /dev/null +++ b/assets/common/loot_tables/creature/quad_medium/fanged.ron @@ -0,0 +1,5 @@ +[ + (0.5, Item("common.items.food.meat.beast_large_raw")), + (2.0, Item("common.items.crafting_ing.animal_misc.sharp_fang")), + (3.0, Item("common.items.crafting_ing.hide.tough_hide")), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_medium/gentle.ron b/assets/common/loot_tables/creature/quad_medium/gentle.ron new file mode 100644 index 0000000000..a11ac921f4 --- /dev/null +++ b/assets/common/loot_tables/creature/quad_medium/gentle.ron @@ -0,0 +1,5 @@ +[ + (1.5, Item("common.items.food.meat.beast_small_raw")), + (0.5, Item("common.items.food.meat.beast_large_raw")), + (3.0, Item("common.items.crafting_ing.hide.animal_hide")), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_small/fur.ron b/assets/common/loot_tables/creature/quad_small/fur.ron new file mode 100644 index 0000000000..0575051c86 --- /dev/null +++ b/assets/common/loot_tables/creature/quad_small/fur.ron @@ -0,0 +1,5 @@ +[ + (1.0, ItemQuantity("common.items.crafting_ing.animal_misc.fur", 1, 3)), + (1.0, Item("common.items.crafting_ing.hide.animal_hide")), + +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_small/mushroom.ron b/assets/common/loot_tables/creature/quad_small/mushroom.ron new file mode 100644 index 0000000000..ab6c680d5f --- /dev/null +++ b/assets/common/loot_tables/creature/quad_small/mushroom.ron @@ -0,0 +1,3 @@ +[ + (1.0, Item("common.items.food.mushroom")), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_small/ooze.ron b/assets/common/loot_tables/creature/quad_small/ooze.ron new file mode 100644 index 0000000000..a5d0ae5191 --- /dev/null +++ b/assets/common/loot_tables/creature/quad_small/ooze.ron @@ -0,0 +1,3 @@ +[ + (1.0, Item("common.items.crafting_ing.hide.viscous_ooze")), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/quad_small/sheep.ron b/assets/common/loot_tables/creature/quad_small/sheep.ron new file mode 100644 index 0000000000..a510623b8c --- /dev/null +++ b/assets/common/loot_tables/creature/quad_small/sheep.ron @@ -0,0 +1,3 @@ +[ + (1.0, Item("common.items.crafting_ing.cloth.wool", 2, 5)), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/theropod/horned.ron b/assets/common/loot_tables/creature/theropod/horned.ron new file mode 100644 index 0000000000..ebbad7c6d8 --- /dev/null +++ b/assets/common/loot_tables/creature/theropod/horned.ron @@ -0,0 +1,4 @@ +[ + (1.0, Item("common.items.crafting_ing.hide.plate")), + (1.0, Item("common.items.crafting_ing.animal_misc.large_horn")), +] \ No newline at end of file diff --git a/assets/common/loot_tables/creature/theropod/raptor.ron b/assets/common/loot_tables/creature/theropod/raptor.ron index 15a31e312a..2cd8de953f 100644 --- a/assets/common/loot_tables/creature/theropod/raptor.ron +++ b/assets/common/loot_tables/creature/theropod/raptor.ron @@ -1,4 +1,5 @@ [ + (0.5, Item("common.items.food.meat.beast_large_raw")), (1.0, Item("common.items.crafting_ing.hide.tough_hide")), (1.0, Item("common.items.crafting_ing.animal_misc.raptor_feather")), ] \ No newline at end of file diff --git a/assets/common/loot_tables/dungeon/tier-3/enemy.ron b/assets/common/loot_tables/dungeon/tier-3/enemy.ron index 0efcda9998..9a6f17240e 100644 --- a/assets/common/loot_tables/dungeon/tier-3/enemy.ron +++ b/assets/common/loot_tables/dungeon/tier-3/enemy.ron @@ -1,5 +1,4 @@ [ (1.0, LootTable("common.loot_tables.humanoids")), - (1.0, LootTable("common.loot_tables.armor.steel")), (1.0, LootTable("common.loot_tables.weapons.tier-3")), ] diff --git a/assets/common/loot_tables/dungeon/tier-4/enemy.ron b/assets/common/loot_tables/dungeon/tier-4/enemy.ron index 696bef6900..c41fd9819e 100644 --- a/assets/common/loot_tables/dungeon/tier-4/enemy.ron +++ b/assets/common/loot_tables/dungeon/tier-4/enemy.ron @@ -1,5 +1,4 @@ [ (1.0, LootTable("common.loot_tables.humanoids")), - (1.0, LootTable("common.loot_tables.armor.steel")), (1.0, LootTable("common.loot_tables.weapons.tier-4")), ] diff --git a/assets/common/loot_tables/dungeon/tier-4/miniboss.ron b/assets/common/loot_tables/dungeon/tier-4/miniboss.ron index e51e0c7b7a..81239f6e8d 100644 --- a/assets/common/loot_tables/dungeon/tier-4/miniboss.ron +++ b/assets/common/loot_tables/dungeon/tier-4/miniboss.ron @@ -1,6 +1,4 @@ [ - // armor - (6.0, LootTable("common.loot_tables.armor.steel")), // weapons (3.0, LootTable("common.loot_tables.weapons.tier-4")), // lantern diff --git a/assets/common/loot_tables/dungeon/tier-5/enemy.ron b/assets/common/loot_tables/dungeon/tier-5/enemy.ron index 88530ec0c6..37620ba3af 100644 --- a/assets/common/loot_tables/dungeon/tier-5/enemy.ron +++ b/assets/common/loot_tables/dungeon/tier-5/enemy.ron @@ -6,7 +6,6 @@ (5.0, Item("common.items.food.cheese")), // Gear (3.0, LootTable("common.loot_tables.weapons.tier-5")), - (2.0, LootTable("common.loot_tables.armor.steel")), (0.25, Item("common.items.armor.misc.neck.plain_1")), (0.5, Item("common.items.armor.misc.ring.gold")), (0.25, Item("common.items.armor.misc.ring.skull")), diff --git a/assets/common/recipe_book.ron b/assets/common/recipe_book.ron index 3e5f592c48..eb1fe812a2 100644 --- a/assets/common/recipe_book.ron +++ b/assets/common/recipe_book.ron @@ -149,6 +149,20 @@ ], craft_sprite: Some(CookingPot), ), + "bird_cooked": ( + output: ("common.items.food.meat.bird_cooked", 1), + inputs: [ + (Item("common.items.food.meat.bird_raw"), 1), + ], + craft_sprite: Some(CookingPot), + ), + "bird_large_cooked": ( + output: ("common.items.food.meat.bird_large_cooked", 1), + inputs: [ + (Item("common.items.food.meat.bird_large_raw"), 1), + ], + craft_sprite: Some(CookingPot), + ), "beast_small_cooked": ( output: ("common.items.food.meat.beast_small_cooked", 1), inputs: [ @@ -443,6 +457,13 @@ ], craft_sprite: Some(Anvil), ), + "Burnt Drumstick": ( + output: ("common.items.weapons.hammer.burnt_drumstick", 1), + inputs: [ + (Item("common.items.food.meat.bird_large_cooked"), 1), + ], + craft_sprite: Some(CookingPot), + ), //ARMOR/HIDE/RAWHIDE "rawhide back": ( output: ("common.items.armor.hide.rawhide.back", 1), diff --git a/assets/voxygen/item_image_manifest.ron b/assets/voxygen/item_image_manifest.ron index b1809d510d..dcc4629fa9 100644 --- a/assets/voxygen/item_image_manifest.ron +++ b/assets/voxygen/item_image_manifest.ron @@ -792,6 +792,10 @@ "voxel.weapon.hammer.cult_purp-0", (2.0, -1.0, 0.0), (-135.0, 90.0, 0.0), 1.1, ), + Tool("common.items.weapons.hammer.burnt_drumstick"): VoxTrans( + "voxel.weapon.hammer.burnt_drumstick", + (2.0, -1.0, 0.0), (-135.0, 90.0, 0.0), 1.1, + ), // 1h Hammers Tool("common.items.weapons.hammer_1h.bloodsteel-0"): VoxTrans( "voxel.weapon.hammer_1h.bloodsteel-0", @@ -2327,6 +2331,22 @@ "voxel.sprite.food.meat.fish_cooked", (0.0, 0.0, 0.0), (-20.0, 10.0, 20.0), 0.9, ), + Consumable("BirdRaw"): VoxTrans( + "voxel.sprite.food.meat.bird_raw", + (0.0, 0.0, 0.0), (-20.0, 10.0, 20.0), 0.9, + ), + Consumable("BirdCooked"): VoxTrans( + "voxel.sprite.food.meat.bird_cooked", + (0.0, 0.0, 0.0), (-20.0, 10.0, 20.0), 0.9, + ), + Consumable("BirdLargeRaw"): VoxTrans( + "voxel.sprite.food.meat.bird_large_raw", + (0.0, 0.0, 0.0), (-20.0, 10.0, 20.0), 0.9, + ), + Consumable("BirdLargeCooked"): VoxTrans( + "voxel.sprite.food.meat.bird_large_cooked", + (0.0, 0.0, 0.0), (-20.0, 10.0, 20.0), 0.9, + ), Consumable("BeastSmallRaw"): VoxTrans( "voxel.sprite.food.meat.beast_small_raw", (0.0, 0.0, 0.0), (-50.0, 10.0, 0.0), 1.0, @@ -2474,7 +2494,7 @@ (0.0, 0.0, 0.0), (-20.0, 10.0, 20.0), 0.9, ), Ingredient("Claw"): VoxTrans( - "voxel.sprite.crafting_ing.claw", + "voxel.sprite.crafting_ing.animal_misc.claw", (0.0, 0.0, 0.0), (-20.0, 10.0, 20.0), 0.9, ), Ingredient("VenomSac"): VoxTrans( @@ -2487,7 +2507,11 @@ ), Ingredient("SharpFang"): VoxTrans( "voxel.sprite.crafting_ing.animal_misc.sharp_fang", - (0.0, 0.0, 0.0), (-20.0, 10.0, 20.0), 0.9, + (0.0, 0.0, 0.0), (-20.0, 10.0, 20.0), 1.0, + ), + Ingredient("Fur"): VoxTrans( + "voxel.sprite.crafting_ing.animal_misc.fur", + (0.0, 0.0, 0.0), (-40.0, -10.0, 10.0), 1.0, ), Ingredient("LargeHorn"): VoxTrans( "voxel.sprite.crafting_ing.animal_misc.large_horn", @@ -2645,7 +2669,11 @@ (0.0, 0.0, 0.0), (-50.0, 30.0, 20.0), 0.8, ), Ingredient("ViscousOoze"): VoxTrans( - "voxel.sprite.crafting_ing.ooze", + "voxel.sprite.crafting_ing.animal_misc.ooze", + (0.0, 0.0, 0.0), (-50.0, 30.0, 20.0), 0.8, + ), + Ingredient("PhoenixFeather"): VoxTrans( + "voxel.sprite.crafting_ing.animal_misc.phoenix_feather", (0.0, 0.0, 0.0), (-50.0, 30.0, 20.0), 0.8, ), // Gliders diff --git a/assets/voxygen/voxel/biped_weapon_manifest.ron b/assets/voxygen/voxel/biped_weapon_manifest.ron index 831bec2328..68db974f4a 100644 --- a/assets/voxygen/voxel/biped_weapon_manifest.ron +++ b/assets/voxygen/voxel/biped_weapon_manifest.ron @@ -571,6 +571,10 @@ vox_spec: ("weapon.hammer.cult_purp-0", (-3.5, -4.5, -5.0)), color: None ), + "common.items.weapons.hammer.burnt_drumstick": ( + vox_spec: ("weapon.hammer.burnt_drumstick", (-3.0, -6.0, -5.0)), + color: None + ), /*"Craftsman": ( //TODO This should be a 1h hammer! vox_spec: ("weapon.hammer.craftsman", (-2.0, -5.0, -5.5)), color: None diff --git a/assets/voxygen/voxel/object/tanning_rack.vox b/assets/voxygen/voxel/object/tanning_rack.vox new file mode 100644 index 0000000000..d5ef422428 --- /dev/null +++ b/assets/voxygen/voxel/object/tanning_rack.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:ce5dc46fd29daf46769e367a6fb944dece6ee63ca55d3375697968a7334f5867 +size 1904 diff --git a/assets/voxygen/voxel/sprite/crafting_ing/claw.vox b/assets/voxygen/voxel/sprite/crafting_ing/animal_misc/claw.vox similarity index 100% rename from assets/voxygen/voxel/sprite/crafting_ing/claw.vox rename to assets/voxygen/voxel/sprite/crafting_ing/animal_misc/claw.vox diff --git a/assets/voxygen/voxel/sprite/crafting_ing/animal_misc/fur.vox b/assets/voxygen/voxel/sprite/crafting_ing/animal_misc/fur.vox new file mode 100644 index 0000000000..cbfe7e29ef --- /dev/null +++ b/assets/voxygen/voxel/sprite/crafting_ing/animal_misc/fur.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:a7235059619f726a7c462dfe457978c78f548a98247c192bb72fdc2d8410bee6 +size 1580 diff --git a/assets/voxygen/voxel/sprite/crafting_ing/animal_misc/phoenix_feather.vox b/assets/voxygen/voxel/sprite/crafting_ing/animal_misc/phoenix_feather.vox new file mode 100644 index 0000000000..4a7108527d --- /dev/null +++ b/assets/voxygen/voxel/sprite/crafting_ing/animal_misc/phoenix_feather.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:99fed9a0ffb2ad95cf394a4d97cf2aa8a3b1b956637c43d5c0ea0633060d08e8 +size 1652 diff --git a/assets/voxygen/voxel/sprite/crafting_ing/ooze.vox b/assets/voxygen/voxel/sprite/crafting_ing/animal_misc/viscous_ooze.vox similarity index 100% rename from assets/voxygen/voxel/sprite/crafting_ing/ooze.vox rename to assets/voxygen/voxel/sprite/crafting_ing/animal_misc/viscous_ooze.vox diff --git a/assets/voxygen/voxel/sprite/crafting_ing/hide/rugged_hide.vox b/assets/voxygen/voxel/sprite/crafting_ing/hide/rugged_hide.vox new file mode 100644 index 0000000000..16683c1c58 --- /dev/null +++ b/assets/voxygen/voxel/sprite/crafting_ing/hide/rugged_hide.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:a27f4ffd19f3fc06290ac6a960c526254fd36e1f0fa3a977f84c32fc23fcb700 +size 56508 diff --git a/assets/voxygen/voxel/sprite/crafting_ing/hide/tough_hide.vox b/assets/voxygen/voxel/sprite/crafting_ing/hide/tough_hide.vox index a722ad6a47..f8a7fe8a9f 100644 --- a/assets/voxygen/voxel/sprite/crafting_ing/hide/tough_hide.vox +++ b/assets/voxygen/voxel/sprite/crafting_ing/hide/tough_hide.vox @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:32c5d831561e7ccc3e9238a3a3566a3729b5c86b01909e6ea73e46261f1cba95 -size 1872 +oid sha256:00cf96424deb37bc40fc3c0fdefd90ef2647f12d56eec10afb377cc99ab3383f +size 2000 diff --git a/assets/voxygen/voxel/sprite/crafting_ing/leather/rigid_leather.vox b/assets/voxygen/voxel/sprite/crafting_ing/leather/rigid_leather.vox new file mode 100644 index 0000000000..eb5cac1923 --- /dev/null +++ b/assets/voxygen/voxel/sprite/crafting_ing/leather/rigid_leather.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:9f371ca2d5d2d72e6a4739ff9534bd55081b6caafc914ab535c21a975eb602c4 +size 56252 diff --git a/assets/voxygen/voxel/sprite/food/meat/bird_large_cooked.vox b/assets/voxygen/voxel/sprite/food/meat/bird_large_cooked.vox new file mode 100644 index 0000000000..d15d3e3bd6 --- /dev/null +++ b/assets/voxygen/voxel/sprite/food/meat/bird_large_cooked.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:01af9135fe8f5fd0fd021844bce8be96255680c466338d519c52ebef8cd5ed71 +size 4980 diff --git a/assets/voxygen/voxel/sprite/food/meat/bird_large_raw.vox b/assets/voxygen/voxel/sprite/food/meat/bird_large_raw.vox new file mode 100644 index 0000000000..0cd51ab9d9 --- /dev/null +++ b/assets/voxygen/voxel/sprite/food/meat/bird_large_raw.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:aa265eff64b3152d40138672b4cee54c9341f508e5a82a668aca24c963bac82c +size 4980 diff --git a/assets/voxygen/voxel/weapon/hammer/burnt_drumstick.vox b/assets/voxygen/voxel/weapon/hammer/burnt_drumstick.vox new file mode 100644 index 0000000000..5526b6ae0a --- /dev/null +++ b/assets/voxygen/voxel/weapon/hammer/burnt_drumstick.vox @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:f2f0082554bd24263cbdc39b5f06b74699e015bf7c01857f9412b9b596246340 +size 4980 diff --git a/assets/world/style/colors.ron b/assets/world/style/colors.ron index 3f56568c85..72dab6e5d9 100644 --- a/assets/world/style/colors.ron +++ b/assets/world/style/colors.ron @@ -59,7 +59,7 @@ deep_stone_color: (125, 120, 130), layer: ( bridge: (80, 80, 100), - stalagtite: (140, 150, 200), + stalagtite: (77, 91, 161), ), site: ( castle: (), diff --git a/server/src/events/entity_manipulation.rs b/server/src/events/entity_manipulation.rs index 7f3514ce98..80b9389d3b 100644 --- a/server/src/events/entity_manipulation.rs +++ b/server/src/events/entity_manipulation.rs @@ -2,7 +2,7 @@ use crate::{ client::Client, comp::{ agent::{Sound, SoundKind}, - biped_large, quadruped_low, quadruped_medium, quadruped_small, + biped_large, bird_large, quadruped_low, quadruped_medium, quadruped_small, skills::SkillGroupKind, theropod, PhysicsState, }, @@ -358,6 +358,25 @@ pub fn handle_destroy(server: &mut Server, entity: EcsEntity, cause: HealthSourc quadruped_small::Species::Dodarock => { "common.loot_tables.creature.quad_small.dodarock" }, + quadruped_small::Species::Truffler | quadruped_small::Species::Fungome => { + "common.loot_tables.creature.quad_small.mushroom" + }, + quadruped_small::Species::Sheep => { + "common.loot_tables.creature.quad_small.sheep" + }, + quadruped_small::Species::Skunk + | quadruped_small::Species::Quokka + | quadruped_small::Species::Beaver + | quadruped_small::Species::Jackalope + | quadruped_small::Species::Hare => { + "common.loot_tables.creature.quad_small.fur" + }, + quadruped_small::Species::Frog + | quadruped_small::Species::Axolotl + | quadruped_small::Species::Gecko + | quadruped_small::Species::Turtle => { + "common.loot_tables.creature.quad_small.ooze" + }, _ => "common.loot_tables.creature.quad_small.default", } }, @@ -365,12 +384,47 @@ pub fn handle_destroy(server: &mut Server, entity: EcsEntity, cause: HealthSourc quadruped_medium::Species::Frostfang | quadruped_medium::Species::Roshwalr => { "common.loot_tables.creature.quad_medium.ice" }, - _ => "common.loot_tables.creature.quad_medium.default", + quadruped_medium::Species::Catoblepas => { + "common.loot_tables.creature.quad_medium.catoblepas" + }, + quadruped_medium::Species::Bear + | quadruped_medium::Species::Snowleopard + | quadruped_medium::Species::Tiger + | quadruped_medium::Species::Lion => { + "common.loot_tables.creature.quad_medium.clawed" + }, + quadruped_medium::Species::Tarasque + | quadruped_medium::Species::Bonerattler => { + "common.loot_tables.creature.quad_medium.carapace" + }, + quadruped_medium::Species::Dreadhorn => { + "common.loot_tables.creature.quad_medium.dreadhorn" + }, + quadruped_medium::Species::Mouflon + | quadruped_medium::Species::Camel + | quadruped_medium::Species::Deer + | quadruped_medium::Species::Hirdrasil + | quadruped_medium::Species::Horse + | quadruped_medium::Species::Highland + | quadruped_medium::Species::Zebra + | quadruped_medium::Species::Donkey + | quadruped_medium::Species::Antelope + | quadruped_medium::Species::Kelpie + | quadruped_medium::Species::Cattle + | quadruped_medium::Species::Yak => { + "common.loot_tables.creature.quad_medium.gentle" + }, + _ => "common.loot_tables.creature.quad_medium.fanged", }, Some(common::comp::Body::BirdMedium(_)) => { "common.loot_tables.creature.bird_medium" }, - Some(common::comp::Body::BirdLarge(_)) => "common.loot_tables.creature.bird_medium", + Some(common::comp::Body::BirdLarge(bird_large)) => match bird_large.species { + bird_large::Species::Cockatrice => { + "common.loot_tables.creature.bird_large.cockatrice" + }, + _ => "common.loot_tables.creature.bird_large.phoenix", + }, Some(common::comp::Body::FishMedium(_)) => "common.loot_tables.creature.fish", Some(common::comp::Body::FishSmall(_)) => "common.loot_tables.creature.fish", Some(common::comp::Body::BipedLarge(biped_large)) => match biped_large.species { @@ -389,8 +443,10 @@ pub fn handle_destroy(server: &mut Server, entity: EcsEntity, cause: HealthSourc Some(common::comp::Body::Theropod(theropod)) => match theropod.species { theropod::Species::Sandraptor | theropod::Species::Snowraptor - | theropod::Species::Woodraptor => { - "common.loot_tables.creature.theropod.raptor" + | theropod::Species::Woodraptor + | theropod::Species::Sunlizard => "common.loot_tables.creature.theropod.raptor", + theropod::Species::Archaeos | theropod::Species::Ntouka => { + "common.loot_tables.creature.theropod.horned" }, _ => "common.loot_tables.creature.theropod.default", }, @@ -403,7 +459,7 @@ pub fn handle_destroy(server: &mut Server, entity: EcsEntity, cause: HealthSourc quadruped_low::Species::Lavadrake => { "common.loot_tables.creature.quad_low.carapace" }, - quadruped_low::Species::Rocksnapper => { + quadruped_low::Species::Rocksnapper | quadruped_low::Species::Sandshark => { "common.loot_tables.creature.quad_low.carapace" }, quadruped_low::Species::Asp => { @@ -412,6 +468,9 @@ pub fn handle_destroy(server: &mut Server, entity: EcsEntity, cause: HealthSourc quadruped_low::Species::Hakulaq => { "common.loot_tables.creature.quad_low.fanged" }, + quadruped_low::Species::Deadwood => { + "common.loot_tables.creature.quad_low.deadwood" + }, quadruped_low::Species::Basilisk => { "common.loot_tables.creature.quad_low.basilisk" }, diff --git a/world/src/layer/mod.rs b/world/src/layer/mod.rs index d86e1f60a1..363dc6444f 100644 --- a/world/src/layer/mod.rs +++ b/world/src/layer/mod.rs @@ -150,7 +150,7 @@ pub fn apply_caves_to(canvas: &mut Canvas, rng: &mut impl Rng) { .index() .noise .cave_nz - .get(wpos2d.map(|e| e as f64 * 0.125).into_array()) + .get(wpos2d.map(|e| e as f64 * 0.18).into_array()) .sub(0.5) .max(0.0) .mul( @@ -191,6 +191,12 @@ pub fn apply_caves_to(canvas: &mut Canvas, rng: &mut impl Rng) { canvas.map(Vec3::new(wpos2d.x, wpos2d.y, cave_base), |block| { block.with_sprite(kind) }); + let kind2 = *Lottery::::load_expect("common.cave_scatter.shallow") + .read() + .choose(); + canvas.map(Vec3::new(wpos2d.x, wpos2d.y, cave_roof - 1), |block| { + block.with_sprite(kind2) + }); } } else { if rng.gen::() @@ -204,6 +210,16 @@ pub fn apply_caves_to(canvas: &mut Canvas, rng: &mut impl Rng) { block.with_sprite(kind) }); } + if rng.gen::() < 0.3 * (difficulty / 3.0).powf(2.5) + && cave_base < surface_z as i32 - 25 + { + let kind = *Lottery::::load_expect("common.cave_scatter.deep") + .read() + .choose(); + canvas.map(Vec3::new(wpos2d.x, wpos2d.y, cave_roof - 1), |block| { + block.with_sprite(kind) + }); + } }; } }); diff --git a/world/src/layer/scatter.rs b/world/src/layer/scatter.rs index ce8a0d241a..82cbc83a78 100644 --- a/world/src/layer/scatter.rs +++ b/world/src/layer/scatter.rs @@ -153,6 +153,12 @@ pub fn apply_scatter_to(canvas: &mut Canvas, rng: &mut impl Rng) { (Stones, false, |c, _| { ((c.rockiness - 0.5).max(0.025) * 1.0e-3, None) }), + (Copper, false, |c, _| { + ((c.rockiness - 0.5).max(0.025) * 1.5e-3, None) + }), + (Tin, false, |c, _| { + ((c.rockiness - 0.5).max(0.025) * 1.5e-3, None) + }), // Don't spawn Mushrooms in snowy regions (Mushroom, false, |c, _| { (