increment

master
dhunt 2013-10-09 17:37:19 -07:00
parent fcc9cb9ca1
commit d08ae2bec5
6 changed files with 278 additions and 10 deletions

1
containers.lua Normal file
View File

@ -0,0 +1 @@

68
craftitems.lua Normal file
View File

@ -0,0 +1,68 @@
minetest.register_craftitem(":bitumen:bitumen", {
description = "Bitumen",
inventory_image = "bitumen_bitumen.png",
on_place_on_ground = minetest.craftitem_place_item,
})
minetest.register_craftitem(":bitumen:synthetic_crude", {
description = "Synthetic Crude Oil",
inventory_image = "bitumen_synthetic_crude.png",
on_place_on_ground = minetest.craftitem_place_item,
})
minetest.register_craftitem(":bitumen:lube_oil", {
description = "Heavy Lubricating Oil",
inventory_image = "bitumen_lube_oil.png",
on_place_on_ground = minetest.craftitem_place_item,
})
minetest.register_craftitem(":bitumen:fuel_oil", {
description = "Fuel Oil",
inventory_image = "bitumen_fuel_oil.png",
on_place_on_ground = minetest.craftitem_place_item,
})
minetest.register_craftitem(":bitumen:diesel", {
description = "Diesel",
inventory_image = "bitumen_diesel.png",
on_place_on_ground = minetest.craftitem_place_item,
})
minetest.register_craftitem(":bitumen:kerosene", {
description = "Kerosene",
inventory_image = "bitumen_kerosene.png",
on_place_on_ground = minetest.craftitem_place_item,
})
minetest.register_craftitem(":bitumen:gasoline", {
description = "Gasoline",
inventory_image = "bitumen_gasoline.png",
on_place_on_ground = minetest.craftitem_place_item,
})
minetest.register_craftitem(":bitumen:jet_fuel", {
description = "Jet Fuel",
inventory_image = "bitumen_jet_fuel.png",
on_place_on_ground = minetest.craftitem_place_item,
})
minetest.register_craftitem(":bitumen:lpg", {
description = "LPG",
inventory_image = "bitumen_lpg.png",
on_place_on_ground = minetest.craftitem_place_item,
})

View File

@ -1,6 +1,9 @@
local modpath = minetest.get_modpath("bitumen")
-- dofile(modpath.."/plastic.lua")
dofile(modpath.."/craftitems.lua")
dofile(modpath.."/containers.lua")
dofile(modpath.."/tarsands.lua")
dofile(modpath.."/oilshale.lua")
dofile(modpath.."/refinery.lua")

200
refinery.lua Normal file
View File

@ -0,0 +1,200 @@
-- need:
-- boiler
-- distillation column
-- bottler?
minetest.register_craft({
output = 'bitumen:cracking_boiler',
recipe = {
{'default:steel_ingot', '', 'default:steel_ingot'},
{'pipeworks:steel_pipe', 'technic:lv_electric_furnace', 'pipeworks:steel_pipe'},
{'', 'technic:lv_cable0', ''},
}
})
minetest.register_craft({
output = 'bitumen:cracking_column',
recipe = {
{'default:steel_ingot', '', 'default:steel_ingot'},
{'default:steel_ingot', '', 'pipeworks:steel_pipe'},
{'default:steel_ingot', '', 'default:steel_ingot'},
}
})
-- technic.extractor_recipes ={}
--[[
technic.register_extractor_recipe = function(src, src_count, dst, dst_count)
technic.extractor_recipes[src] = {src_count = src_count, dst_name = dst, dst_count = dst_count}
if unified_inventory then
unified_inventory.register_craft({
type = "extracting",
output = dst.." "..dst_count,
items = {src.." "..src_count},
width = 0,
})
end
end
-- Receive an ItemStack of result by an ItemStack input
technic.get_extractor_recipe = function(item)
if technic.extractor_recipes[item.name] and
item.count >= technic.extractor_recipes[item.name].src_count then
return technic.extractor_recipes[item.name]
else
return nil
end
end]]
-- technic.register_extractor_recipe("technic:coal_dust", 1, "dye:black", 2)
-- technic.register_extractor_recipe("default:cactus", 1, "dye:green", 2)
local extractor_formspec =
"invsize[8,9;]"..
"label[0,0;Extractor]"..
"list[current_name;src;3,1;1,1;]"..
"list[current_name;dst;5,1;2,2;]"..
"list[current_player;main;0,5;8,4;]"
--need pipeworks integration
minetest.register_node("bitumen:cracking_column", {
description = "Cracking Column Segment",
tiles = {"technic_lv_grinder_top.png", "technic_lv_grinder_bottom.png", "technic_lv_grinder_side.png",
"technic_lv_grinder_side.png", "technic_lv_grinder_side.png", "technic_lv_grinder_front.png"},
paramtype2 = "facedir",
groups = {cracky=2},
legacy_facedir_simple = true,
sounds = default.node_sound_wood_defaults(),
})
minetest.register_node("bitumen:cracking_boiler", {
description = "Cracking Column Boiler",
tiles = {"technic_lv_grinder_top.png", "technic_lv_grinder_bottom.png", "technic_lv_grinder_side.png",
"technic_lv_grinder_side.png", "technic_lv_grinder_side.png", "technic_lv_grinder_front.png"},
paramtype2 = "facedir",
groups = {cracky=2},
legacy_facedir_simple = true,
sounds = default.node_sound_wood_defaults(),
on_construct = function(pos)
local meta = minetest.get_meta(pos)
meta:set_string("infotext", "Extractor")
meta:set_string("formspec", extractor_formspec)
local inv = meta:get_inventory()
inv:set_size("src", 1)
inv:set_size("dst", 4)
end,
can_dig = function(pos,player)
local meta = minetest.get_meta(pos);
local inv = meta:get_inventory()
if not inv:is_empty("src") or not inv:is_empty("dst") then
minetest.chat_send_player(player:get_player_name(),
"Machine cannot be removed because it is not empty");
return false
else
return true
end
end,
})
minetest.register_node("bitumen:cracking_boiler_active", {
description = "Cracking Column Boiler",
tiles = {"technic_lv_grinder_top.png", "technic_lv_grinder_bottom.png",
"technic_lv_grinder_side.png", "technic_lv_grinder_side.png",
"technic_lv_grinder_side.png", "technic_lv_grinder_front_active.png"},
paramtype2 = "facedir",
groups = {cracky=2, not_in_creative_inventory=1},
legacy_facedir_simple = true,
sounds = default.node_sound_wood_defaults(),
can_dig = function(pos,player)
local meta = minetest.get_meta(pos);
local inv = meta:get_inventory()
if not inv:is_empty("src") or not inv:is_empty("dst") then
minetest.chat_send_player(player:get_player_name(),
"Machine cannot be removed because it is not empty");
return false
else
return true
end
end,
})
minetest.register_abm({
nodenames = {"bitumen:cracking_boiler", "bitumen:cracking_boiler_active"},
interval = 1,
chance = 1,
action = function(pos, node, active_object_count, active_object_count_wider)
-- The machine will automatically shut down if disconnected from power in some fashion.
local meta = minetest.get_meta(pos)
local inv = meta:get_inventory()
local srcstack = inv:get_stack("src", 1)
local eu_input = meta:get_int("LV_EU_input")
-- Machine information
local machine_name = "Cracking Boiler"
local machine_node = "bitumen:cracking_boiler"
local demand = 1000
-- Setup meta data if it does not exist.
if not eu_input then
meta:set_int("LV_EU_demand", demand)
meta:set_int("LV_EU_input", 0)
return
end
-- Power off automatically if no longer connected to a switching station
technic.switching_station_timeout_count(pos, "LV")
if srcstack then
src_item = srcstack:to_table()
end
if src_item then
recipe = technic.get_extractor_recipe(src_item)
end
if recipe then
result = {name=recipe.dst_name, count=recipe.dst_count}
end
if inv:is_empty("src") or (not recipe) or (not result) or
(not inv:room_for_item("dst", result)) then
hacky_swap_node(pos, machine_node)
meta:set_string("infotext", machine_name.." Idle")
meta:set_int("LV_EU_demand", 0)
return
end
if eu_input < demand then
-- unpowered - go idle
hacky_swap_node(pos, machine_node)
meta:set_string("infotext", machine_name.." Unpowered")
elseif eu_input >= demand then
-- Powered
hacky_swap_node(pos, machine_node.."_active")
meta:set_string("infotext", machine_name.." Active")
meta:set_int("src_time", meta:get_int("src_time") + 1)
if meta:get_int("src_time") >= 4 then -- 4 ticks per output
meta:set_int("src_time", 0)
srcstack:take_item(recipe.src_count)
inv:set_stack("src", 1, srcstack)
inv:add_item("dst", result)
end
end
meta:set_int("LV_EU_demand", demand)
end
})
technic.register_machine("LV", "bitumen:cracking_boiler", technic.receiver)
technic.register_machine("LV", "bitumen:cracking_boiler_active", technic.receiver)
energy_density = {
lpg = { 26 },
jet_fuel = { 31 },
gasoline = { 34 },
diesel = { 37 },
fuel_oil = { 40 },
lube_oil = { 43 },
synth_crude = { 50 }
}

View File

@ -13,26 +13,21 @@
-- "sucker"/"fetcher" that will pull an item from the connected system
-- need to get the info for sand-type things
minetest.register_node( "atomic:tar_sand", {
minetest.register_node( "bitumen:tar_sand", {
description = "Tar Sand",
tiles = { "bitumen_tar_sand.png" },
is_ground_content = true,
groups = {choppy=2},
sounds = default.node_sound_wood_defaults(),
drop = 'craft "atomic:bitumen" 1',
drop = 'craft "bitumen:bitumen" 1',
})
minetest.register_craftitem(":atomic:bitumen", {
description = "Bitumen",
inventory_image = "bitumen_bitumen.png",
on_place_on_ground = minetest.craftitem_place_item,
})
-- upper layer
minetest.register_ore({
ore_type = "sheet",
ore = "atomic:tar_sand",
ore = "bitumen:tar_sand",
wherein = "default:desertstone",
clust_scarcity = 1,
clust_num_ores = 1,
@ -47,7 +42,7 @@ minetest.register_ore({
-- lower layer
minetest.register_ore({
ore_type = "sheet",
ore = "atomic:tar_sand",
ore = "bitumen:tar_sand",
wherein = "default:stone",
clust_scarcity = 1,
clust_num_ores = 1,

View File

@ -4,7 +4,8 @@ function normalMap()
{
gimp -i -b "(define (normalMap-fbx-conversion fileName newFileName nscale) (let* ((image (car (gimp-file-load RUN-NONINTERACTIVE fileName fileName))) (drawable (car (gimp-image-get-active-layer image)))) (plug-in-normalmap RUN-NONINTERACTIVE image drawable 7 0.0 nscale 0 0 0 0 0 0 0 0 0.0 drawable ) (gimp-file-save RUN-NONINTERACTIVE image drawable newFileName newFileName) (gimp-image-delete image))) (normalMap-fbx-conversion \"$1\" \"$2\" $3)" -b '(gimp-quit 0)'
}
# ignore normal files. hacky, but it works
for file in `ls *.png | grep -v _normal`
do
normalMap $file `echo $file | sed 's/.png/_normal.png/'` 8