From 1a8c972cf70cdf42d7a7107c24491672352a8378 Mon Sep 17 00:00:00 2001 From: notnotmelon Date: Sun, 14 Jan 2024 12:43:11 -0600 Subject: [PATCH] mounts part 3 --- locale/en/extras.cfg | 5 +- locale/en/items.cfg | 2 + prototypes/creatures/mecha-zungror.lua | 3 - prototypes/creatures/phadaisus.lua | 162 ++++++++++++++++++------- prototypes/items/items.lua | 4 +- 5 files changed, 128 insertions(+), 48 deletions(-) diff --git a/locale/en/extras.cfg b/locale/en/extras.cfg index 95566995..ade6a75a 100644 --- a/locale/en/extras.cfg +++ b/locale/en/extras.cfg @@ -66,4 +66,7 @@ wandering=An ocula was stranded! [gps=__1__, __2__] py-mount-generator=Biological engine [equipment-description] -py-mount-generator=This creature is able to generate energy from its own body. It can be used as a power source for equipment grid modules. \ No newline at end of file +py-mount-generator=This creature is able to generate energy from its own body. It can be used as a power source for equipment grid modules. + +[ammo-category-name] +dragon-breath=Dragon breath \ No newline at end of file diff --git a/locale/en/items.cfg b/locale/en/items.cfg index 2ecc054f..b5ca3ca2 100644 --- a/locale/en/items.cfg +++ b/locale/en/items.cfg @@ -1,4 +1,6 @@ [item-name] +dragon-breath=Dragon breath +dragon-breath-ammo=Phadaisus combustion fuel spidertron-remote=Mount remote moss=Moss moss-mk02=Moss MK 02 diff --git a/prototypes/creatures/mecha-zungror.lua b/prototypes/creatures/mecha-zungror.lua index 9da34f52..d58a9c3c 100644 --- a/prototypes/creatures/mecha-zungror.lua +++ b/prototypes/creatures/mecha-zungror.lua @@ -9,9 +9,6 @@ zungror.icon_tintable_mask = '__pyalienlifegraphics__/graphics/icons/mount-mask. data.raw['spidertron-remote']['spidertron-remote'].subgroup = 'py-alienlife-special-creatures' data.raw['spidertron-remote']['spidertron-remote'].order = 'z-c' -RECIPE('spidertron'):add_unlock('spidertron') -RECIPE('spidertron-remote'):add_unlock('mounts-mk01') - RECIPE('spidertron-remote').ingredients = { {mods.pyalternativeenergy and 'electronics-mk01' or 'copper-plate', 5}, {'electronic-circuit', 5} diff --git a/prototypes/creatures/phadaisus.lua b/prototypes/creatures/phadaisus.lua index b9806632..108a164f 100644 --- a/prototypes/creatures/phadaisus.lua +++ b/prototypes/creatures/phadaisus.lua @@ -1,47 +1,47 @@ local util = require('util') RECIPE { - type = 'recipe', - name = 'phadaisus', - energy_required = 60, - category = 'creature-chamber', - enabled = false, - ingredients = { - {type = 'item', name = 'py-shed-basic', amount = 1}, - {type = 'item', name = 'bioartificial-guts', amount = 1}, - {type = 'item', name = 'biomimetic-skin', amount = 1}, - {type = 'item', name = 'in-vitro-meat', amount = 1}, - {type = 'item', name = 'laboratory-grown-brain', amount = 1}, - {type = 'item', name = 'scafold-free-bones', amount = 1}, - {type = 'item', name = 'tissue-engineered-fat', amount = 1}, - {type = 'item', name = 'perfect-samples', amount = 10}, - {type = 'item', name = 'power-armor-mk2', amount = 1}, - {type = 'item', name = 'enzyme-pks', amount = 1}, - {type = 'item', name = 'zymogens', amount = 5}, - {type = 'item', name = mods.pyhightech and 'resilin' or 'lignin', amount = 5}, - {type = 'item', name = 'strorix-unknown-sample', amount = 5}, - {type = 'item', name = 'purine-analogues', amount = 15}, - {type = 'item', name = 'pheromones', amount = 100}, - {type = 'item', name = 'phadai-mk04', amount = 1}, - {type = 'item', name = mods.pyalternativeenergy and 'metastable-quasicrystal' or 'bio-sample', amount = 10}, - {type = 'item', name = 'phadai-codex-mk04', amount = 5}, - {type = 'item', name = 'earth-tiger-sample', amount = 4}, - {type = 'fluid', name = 'artificial-blood', amount = 400}, - {type = 'fluid', name = 'gta', amount = 500} - }, - result = 'phadaisus' + type = 'recipe', + name = 'phadaisus', + energy_required = 60, + category = 'creature-chamber', + enabled = false, + ingredients = { + {type = 'item', name = 'py-shed-basic', amount = 1}, + {type = 'item', name = 'bioartificial-guts', amount = 1}, + {type = 'item', name = 'biomimetic-skin', amount = 1}, + {type = 'item', name = 'in-vitro-meat', amount = 1}, + {type = 'item', name = 'laboratory-grown-brain', amount = 1}, + {type = 'item', name = 'scafold-free-bones', amount = 1}, + {type = 'item', name = 'tissue-engineered-fat', amount = 1}, + {type = 'item', name = 'perfect-samples', amount = 10}, + {type = 'item', name = 'power-armor-mk2', amount = 1}, + {type = 'item', name = 'enzyme-pks', amount = 1}, + {type = 'item', name = 'zymogens', amount = 5}, + {type = 'item', name = mods.pyhightech and 'resilin' or 'lignin', amount = 5}, + {type = 'item', name = 'strorix-unknown-sample', amount = 5}, + {type = 'item', name = 'purine-analogues', amount = 15}, + {type = 'item', name = 'pheromones', amount = 100}, + {type = 'item', name = 'phadai-mk04', amount = 1}, + {type = 'item', name = mods.pyalternativeenergy and 'metastable-quasicrystal' or 'bio-sample', amount = 10}, + {type = 'item', name = 'phadai-codex-mk04', amount = 5}, + {type = 'item', name = 'earth-tiger-sample', amount = 4}, + {type = 'fluid', name = 'artificial-blood', amount = 400}, + {type = 'fluid', name = 'gta', amount = 500} + }, + result = 'phadaisus' }:add_unlock('mounts-mk04') ITEM { - type = 'item-with-entity-data', - name = 'phadaisus', - icon = '__pyalienlifegraphics__/graphics/icons/phadaisus.png', - icon_tintable = '__pyalienlifegraphics__/graphics/icons/phadaisus.png', - icon_size = 64, - subgroup = 'py-alienlife-special-creatures', - order = 'x', - place_result = 'phadaisus', - stack_size = 10, + type = 'item-with-entity-data', + name = 'phadaisus', + icon = '__pyalienlifegraphics__/graphics/icons/phadaisus.png', + icon_tintable = '__pyalienlifegraphics__/graphics/icons/phadaisus.png', + icon_size = 64, + subgroup = 'py-alienlife-special-creatures', + order = 'x', + place_result = 'phadaisus', + stack_size = 10, icon_tintable_mask = '__pyalienlifegraphics__/graphics/icons/mount-mask.png', } @@ -215,11 +215,10 @@ data:extend{{ --tank_driving = true, weight = 6000, inventory_size = 200, - --guns = {'flamethrower'} render_layer = 'air-object', - automatic_weapon_cycling = false, + automatic_weapon_cycling = true, equipment_grid = 'mount-grid-10x10', - guns = {}, + guns = {'dragon-breath', 'dragon-breath', 'dragon-breath', 'dragon-breath'}, torso_rotation_speed = 0.01, chunk_exploration_radius = 4, chain_shooting_cooldown_modifier = 0.4, @@ -249,4 +248,83 @@ vehicle_leg.part_length = 0.3 vehicle_leg.movement_based_position_selection_distance = 0.7 vehicle_leg.initial_movement_speed = 0.01 vehicle_leg.movement_acceleration = 1.25 -data:extend{vehicle_leg} \ No newline at end of file +data:extend{vehicle_leg} + +local flamethrower = table.deepcopy(data.raw['gun']['tank-flamethrower']) +flamethrower.name = 'dragon-breath' +flamethrower.icon = '__pyalienlifegraphics__/graphics/icons/dragon-breath.png' +flamethrower.icon_size = 64 +flamethrower.icon_mipmaps = nil +flamethrower.attack_parameters.ammo_category = 'dragon-breath' +flamethrower.attack_parameters.gun_center_shift = {-0.17, -0.2} +flamethrower.attack_parameters.range = 20 +flamethrower.subgroup = 'py-alienlife-items' +data:extend{flamethrower} + +RECIPE { + name = 'dragon-breath-ammo', + type = 'recipe', + energy_required = 20, + enabled = false, + ingredients = { + {type = 'fluid', name = 'light-oil', amount = 250}, + {type = 'fluid', name = 'kerosene', amount = 1500}, + {type = 'fluid', name = 'aniline', amount = 500}, + }, + category = 'chemistry', + results = { + {type = 'item', name = 'dragon-breath-ammo', amount = 1}, + }, + crafting_machine_tint = table.deepcopy(data.raw['recipe']['flamethrower-ammo'].crafting_machine_tint), +}:add_unlock('mounts-mk04') + +ITEM { + name = 'dragon-breath-ammo', + type = 'ammo', + icon = '__pyalienlifegraphics__/graphics/icons/dragon-breath-ammo.png', + icon_size = 64, + ammo_type = { + action = { + action_delivery = { + stream = 'dragon-breath', + type = 'stream' + }, + type = 'direct' + }, + category = 'dragon-breath', + clamp_position = true, + consumption_modifier = 1, + source_type = 'vehicle', + target_type = 'position' + }, + magazine_size = 1000000, + flags = {'not-stackable'}, + stack_size = 1, + subgroup = 'py-alienlife-items', +} + +local stream = table.deepcopy(data.raw['stream']['tank-flamethrower-fire-stream']) +stream.name = 'dragon-breath' +stream.action = {{ + action_delivery = { + target_effects = { + { + apply_damage_to_trees = true, + damage = { + amount = 70, + type = 'fire' + }, + type = 'damage' + } + }, + type = 'instant' + }, + radius = 6, + type = 'area' +}} +data:extend{stream} + +data:extend{{ + type = 'ammo-category', + name = 'dragon-breath' +}} \ No newline at end of file diff --git a/prototypes/items/items.lua b/prototypes/items/items.lua index 7a9b2435..fa862429 100644 --- a/prototypes/items/items.lua +++ b/prototypes/items/items.lua @@ -2690,7 +2690,7 @@ ITEM { order = 'h', stack_size = 100, fuel_category = 'phadai-food', - fuel_value = '60MJ', + fuel_value = '120MJ', fuel_acceleration_multiplier = 1, fuel_top_speed_multiplier = 3 } @@ -2705,7 +2705,7 @@ ITEM { order = 'h', stack_size = 100, fuel_category = 'phadai-food', - fuel_value = '80MJ', + fuel_value = '160MJ', fuel_acceleration_multiplier = 1, fuel_top_speed_multiplier = 8 }