mirror of
https://github.com/D00Med/scifi_nodes.git
synced 2025-07-17 15:30:20 +02:00
Compare commits
23 Commits
add-plastc
...
f79e84b92d
Author | SHA1 | Date | |
---|---|---|---|
f79e84b92d | |||
cc5f1bea5a | |||
e7864a4a86 | |||
c649c290ab | |||
4f2d2a304f | |||
8816db8ecf | |||
5b903a6e78 | |||
eb231d7ca7 | |||
2fd4de11c0 | |||
b88b7349a5 | |||
c30ae4b3bd | |||
6cf45fcd43 | |||
1ded358e04 | |||
ecfaa4714a | |||
c341cb8a20 | |||
d66e04f9b1 | |||
d3d6a7bf79 | |||
e34fdde795 | |||
1993068ed1 | |||
436f51ab0d | |||
749d59a530 | |||
bd58dbc48b | |||
4eaba4f6e1 |
17
.github/workflows/luacheck.yml
vendored
17
.github/workflows/luacheck.yml
vendored
@ -1,10 +1,17 @@
|
|||||||
name: luacheck
|
name: luacheck
|
||||||
|
|
||||||
on: [push, pull_request]
|
on: [push, pull_request]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
luacheck:
|
build:
|
||||||
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- uses: actions/checkout@v1
|
||||||
uses: actions/checkout@main
|
- name: apt
|
||||||
- name: Luacheck
|
run: sudo apt-get install -y luarocks
|
||||||
uses: lunarmodules/luacheck@master
|
- name: luacheck install
|
||||||
|
run: luarocks install --local luacheck
|
||||||
|
- name: luacheck run
|
||||||
|
run: $HOME/.luarocks/bin/luacheck ./
|
||||||
|
13
.luacheckrc
13
.luacheckrc
@ -1,14 +1,20 @@
|
|||||||
std = "min+minetest"
|
|
||||||
|
|
||||||
unused_args = false
|
unused_args = false
|
||||||
|
max_line_length = 180
|
||||||
|
|
||||||
globals = {
|
globals = {
|
||||||
"scifi_nodes"
|
"scifi_nodes"
|
||||||
}
|
}
|
||||||
|
|
||||||
read_globals = {
|
read_globals = {
|
||||||
|
-- Stdlib
|
||||||
|
string = {fields = {"split"}},
|
||||||
|
table = {fields = {"copy", "getn"}},
|
||||||
|
|
||||||
|
-- Minetest
|
||||||
|
"vector", "ItemStack",
|
||||||
|
"dump",
|
||||||
|
|
||||||
-- optional deps
|
-- optional deps
|
||||||
"advtrains",
|
|
||||||
"default",
|
"default",
|
||||||
"stairsplus",
|
"stairsplus",
|
||||||
"xpanes",
|
"xpanes",
|
||||||
@ -17,7 +23,6 @@ read_globals = {
|
|||||||
"mesecon",
|
"mesecon",
|
||||||
"unifieddyes",
|
"unifieddyes",
|
||||||
"letters",
|
"letters",
|
||||||
"signs_api",
|
|
||||||
"stealthnode",
|
"stealthnode",
|
||||||
"slats",
|
"slats",
|
||||||
"mtt"
|
"mtt"
|
||||||
|
@ -46,7 +46,6 @@ CC BY 3.0
|
|||||||
* scifi_nodes_grass_top.png https://github.com/minetest/minetest_game
|
* scifi_nodes_grass_top.png https://github.com/minetest/minetest_game
|
||||||
* scifi_nodes_grass_side.png https://github.com/minetest/minetest_game
|
* scifi_nodes_grass_side.png https://github.com/minetest/minetest_game
|
||||||
* scifi_nodes_wood.png https://github.com/minetest/minetest_game
|
* scifi_nodes_wood.png https://github.com/minetest/minetest_game
|
||||||
* scifi_nodes_plastcrete.png https://github.com/mt-mods/basic_materials
|
|
||||||
|
|
||||||
CC0
|
CC0
|
||||||
* scifi_nodes_digicode.ogg https://freesound.org/people/benjaminharveydesign/sounds/315921/
|
* scifi_nodes_digicode.ogg https://freesound.org/people/benjaminharveydesign/sounds/315921/
|
||||||
|
@ -14,7 +14,7 @@ local chest_formspec =
|
|||||||
|
|
||||||
-- Helper functions
|
-- Helper functions
|
||||||
local function drop_chest_stuff()
|
local function drop_chest_stuff()
|
||||||
return function(pos, _, oldmetadata)
|
return function(pos, oldnode, oldmetadata, digger)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
meta:from_table(oldmetadata)
|
meta:from_table(oldmetadata)
|
||||||
local inv = meta:get_inventory()
|
local inv = meta:get_inventory()
|
||||||
|
26
common.lua
26
common.lua
@ -1,5 +1,7 @@
|
|||||||
|
|
||||||
function scifi_nodes.get_switch_rules(param2)
|
|
||||||
|
scifi_nodes.get_switch_rules = function(param2)
|
||||||
|
|
||||||
-- param2 = 2
|
-- param2 = 2
|
||||||
local rules = {
|
local rules = {
|
||||||
{x=1, y=-1, z=-1},
|
{x=1, y=-1, z=-1},
|
||||||
@ -8,7 +10,7 @@ function scifi_nodes.get_switch_rules(param2)
|
|||||||
{x=0, y=-1, z=1},
|
{x=0, y=-1, z=1},
|
||||||
}
|
}
|
||||||
|
|
||||||
-- Left and right when looking to +y ?
|
-- Left and right when looking to +y ?
|
||||||
if param2 == 3 then
|
if param2 == 3 then
|
||||||
rules = mesecon.rotate_rules_right(mesecon.rotate_rules_right (rules))
|
rules = mesecon.rotate_rules_right(mesecon.rotate_rules_right (rules))
|
||||||
elseif param2 == 4 then
|
elseif param2 == 4 then
|
||||||
@ -18,23 +20,3 @@ function scifi_nodes.get_switch_rules(param2)
|
|||||||
end
|
end
|
||||||
return rules
|
return rules
|
||||||
end
|
end
|
||||||
|
|
||||||
scifi_nodes.slope_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-0.5, -0.5, -0.5, 0.5, -0.25, 0.5},
|
|
||||||
{-0.5, -0.25, -0.25, 0.5, 0, 0.5},
|
|
||||||
{-0.5, 0, 0, 0.5, 0.25, 0.5},
|
|
||||||
{-0.5, 0.25, 0.25, 0.5, 0.5, 0.5}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
scifi_nodes.slope_box_simple = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {
|
|
||||||
{-0.5, -0.5, -0.5, 0.5, -0.25, -0.25},
|
|
||||||
{-0.5, -0.25, -0.25, 0.5, 0, 0},
|
|
||||||
{-0.5, 0, 0, 0.5, 0.25, 0.25},
|
|
||||||
{-0.5, 0.25, 0.25, 0.5, 0.5, 0.5}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
@ -34,15 +34,6 @@ if not minetest.get_modpath("default") or not minetest.get_modpath("dye") then
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_craft({
|
|
||||||
output = "scifi_nodes:plastcrete 6",
|
|
||||||
recipe = {
|
|
||||||
{"scifi_nodes:white2", "default:gravel", "scifi_nodes:white2"},
|
|
||||||
{"default:gravel", "scifi_nodes:white2", "default:gravel"},
|
|
||||||
{"scifi_nodes:white2", "default:gravel", "scifi_nodes:white2"}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = "scifi_nodes:super_white",
|
output = "scifi_nodes:super_white",
|
||||||
recipe = {
|
recipe = {
|
||||||
|
@ -11,7 +11,7 @@ local digicode_context = {}
|
|||||||
|
|
||||||
-- after_place_node, use by digicode and palm_scanner
|
-- after_place_node, use by digicode and palm_scanner
|
||||||
-- placer is a player object
|
-- placer is a player object
|
||||||
local function set_owner(pos, placer)
|
local function set_owner(pos, placer, itemstack, pointed_thing)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
meta:set_string("owner", placer:get_player_name())
|
meta:set_string("owner", placer:get_player_name())
|
||||||
meta:set_string("code", secret_code)
|
meta:set_string("code", secret_code)
|
||||||
@ -48,7 +48,7 @@ local function update_code(pos, code)
|
|||||||
meta:set_string("code", code)
|
meta:set_string("code", code)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function show_digicode_formspec(pos, _, player)
|
local function show_digicode_formspec(pos, node, player, itemstack, pointed_thing)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local owner = meta:get_string("owner")
|
local owner = meta:get_string("owner")
|
||||||
local current_code = meta:get_string("code")
|
local current_code = meta:get_string("code")
|
||||||
|
@ -120,7 +120,7 @@ for _, current_door in ipairs(doors) do
|
|||||||
return itemstack;
|
return itemstack;
|
||||||
end
|
end
|
||||||
|
|
||||||
local function afterdestruct(pos)
|
local function afterdestruct(pos, oldnode)
|
||||||
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z},{name="air"})
|
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z},{name="air"})
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -173,12 +173,12 @@ for _, current_door in ipairs(doors) do
|
|||||||
timer:start(3)
|
timer:start(3)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function afterplace(pos)
|
local function afterplace(pos, placer, itemstack, pointed_thing)
|
||||||
local node = minetest.get_node(pos)
|
local node = minetest.get_node(pos)
|
||||||
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z},{name=opened_top,param2=node.param2})
|
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z},{name=opened_top,param2=node.param2})
|
||||||
end
|
end
|
||||||
|
|
||||||
local function ontimer(pos)
|
local function ontimer(pos, elapsed)
|
||||||
-- play sound
|
-- play sound
|
||||||
minetest.sound_play(sound,{
|
minetest.sound_play(sound,{
|
||||||
max_hear_distance = 16,
|
max_hear_distance = 16,
|
||||||
@ -218,7 +218,7 @@ for _, current_door in ipairs(doors) do
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
local function nodig()
|
local function nodig(pos, digger)
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
5
init.lua
5
init.lua
@ -30,7 +30,6 @@ dofile(MP.."/nodeboxes.lua")
|
|||||||
dofile(MP.."/palm_scanner.lua")
|
dofile(MP.."/palm_scanner.lua")
|
||||||
dofile(MP.."/digicode.lua")
|
dofile(MP.."/digicode.lua")
|
||||||
dofile(MP.."/octagon_panes.lua")
|
dofile(MP.."/octagon_panes.lua")
|
||||||
dofile(MP.."/octagon_glass.lua")
|
|
||||||
dofile(MP.."/forcefield.lua")
|
dofile(MP.."/forcefield.lua")
|
||||||
dofile(MP.."/crafts.lua")
|
dofile(MP.."/crafts.lua")
|
||||||
|
|
||||||
@ -46,4 +45,6 @@ end
|
|||||||
|
|
||||||
if minetest.get_modpath("mtt") and mtt.enabled then
|
if minetest.get_modpath("mtt") and mtt.enabled then
|
||||||
dofile(MP .. "/mtt.lua")
|
dofile(MP .. "/mtt.lua")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
minetest.log("action", "[scifi_nodes] loaded.")
|
||||||
|
4
mod.conf
4
mod.conf
@ -1,7 +1,6 @@
|
|||||||
name = scifi_nodes
|
name = scifi_nodes
|
||||||
description = Minetest mod that adds scifi themed blocks, doors, materials, plants and other assets.
|
description = Minetest mod that adds scifi themed blocks, doors, materials, plants and other assets.
|
||||||
optional_depends = """
|
optional_depends = """
|
||||||
advtrains,
|
|
||||||
default,
|
default,
|
||||||
xpanes,
|
xpanes,
|
||||||
mesecons,
|
mesecons,
|
||||||
@ -16,6 +15,5 @@ unifieddyes,
|
|||||||
letters,
|
letters,
|
||||||
mesecons_stealthnode,
|
mesecons_stealthnode,
|
||||||
mtt,
|
mtt,
|
||||||
slats,
|
slats
|
||||||
signs_api
|
|
||||||
"""
|
"""
|
||||||
|
22
models.lua
22
models.lua
@ -16,8 +16,24 @@ function scifi_nodes.register_slope(name, desc, texture, light, soundtype)
|
|||||||
drawtype = "mesh",
|
drawtype = "mesh",
|
||||||
mesh = "scifi_nodes_slope.obj",
|
mesh = "scifi_nodes_slope.obj",
|
||||||
tiles = texture,
|
tiles = texture,
|
||||||
selection_box = scifi_nodes.slope_box,
|
selection_box = {
|
||||||
collision_box = scifi_nodes.slope_box,
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{-0.5, -0.5, -0.5, 0.5, -0.25, 0.5},
|
||||||
|
{-0.5, -0.25, -0.25, 0.5, 0, 0.5},
|
||||||
|
{-0.5, 0, 0, 0.5, 0.25, 0.5},
|
||||||
|
{-0.5, 0.25, 0.25, 0.5, 0.5, 0.5}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
collision_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{-0.5, -0.5, -0.5, 0.5, -0.25, 0.5},
|
||||||
|
{-0.5, -0.25, -0.25, 0.5, 0, 0.5},
|
||||||
|
{-0.5, 0, 0, 0.5, 0.25, 0.5},
|
||||||
|
{-0.5, 0.25, 0.25, 0.5, 0.5, 0.5}
|
||||||
|
}
|
||||||
|
},
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
use_texture_alpha = "clip",
|
use_texture_alpha = "clip",
|
||||||
@ -32,7 +48,7 @@ end
|
|||||||
-- register some blocks in stairsplus if available (part of moreblocks)
|
-- register some blocks in stairsplus if available (part of moreblocks)
|
||||||
scifi_nodes.register_slope("white2", "Plastic", {"scifi_nodes_white2.png",}, 0, "stone")
|
scifi_nodes.register_slope("white2", "Plastic", {"scifi_nodes_white2.png",}, 0, "stone")
|
||||||
scifi_nodes.register_slope("super_white", "Super Plastic", {"scifi_nodes_super_white.png",}, 11, "stone")
|
scifi_nodes.register_slope("super_white", "Super Plastic", {"scifi_nodes_super_white.png",}, 11, "stone")
|
||||||
scifi_nodes.register_slope("ultra_white", "Super Plastic", {"scifi_nodes_ultra_white.png",},minetest.LIGHT_MAX, "stone")
|
scifi_nodes.register_slope("ultra_white", "Super Plastic", {"scifi_nodes_ultra_white.png",}, minetest.LIGHT_MAX, "stone")
|
||||||
scifi_nodes.register_slope("black", "Black", {"scifi_nodes_black.png",}, 0)
|
scifi_nodes.register_slope("black", "Black", {"scifi_nodes_black.png",}, 0)
|
||||||
scifi_nodes.register_slope("white", "White", {"scifi_nodes_white.png",}, 0)
|
scifi_nodes.register_slope("white", "White", {"scifi_nodes_white.png",}, 0)
|
||||||
scifi_nodes.register_slope("grey", "Grey", {"scifi_nodes_grey.png",}, 0)
|
scifi_nodes.register_slope("grey", "Grey", {"scifi_nodes_grey.png",}, 0)
|
||||||
|
@ -1,12 +0,0 @@
|
|||||||
g top
|
|
||||||
v 0.500000 0.500000 0.500000
|
|
||||||
v -0.500000 0.500000 0.500000
|
|
||||||
v -0.500000 -0.500000 -0.500000
|
|
||||||
v 0.500000 -0.500000 -0.500000
|
|
||||||
vt 1.0000 1.0000
|
|
||||||
vt 0.0000 1.0000
|
|
||||||
vt 0.0000 0.0000
|
|
||||||
vt 1.0000 0.0000
|
|
||||||
vn 0.0000 0.7071 -0.7071
|
|
||||||
s off
|
|
||||||
f 2/1/1 1/2/1 4/3/1 3/4/1
|
|
35
nodes.json
35
nodes.json
@ -8,21 +8,17 @@
|
|||||||
"white2": {
|
"white2": {
|
||||||
"description": "plastic",
|
"description": "plastic",
|
||||||
"colorable": true,
|
"colorable": true,
|
||||||
"sounds": "stone",
|
"sounds": "stone"
|
||||||
"signs_banner": true,
|
|
||||||
"signs_banner_color": "#000"
|
|
||||||
},
|
},
|
||||||
"super_white": {
|
"super_white": {
|
||||||
"description": "Super Plastic",
|
"description": "Super Plastic",
|
||||||
"light": 11,
|
"light": 11,
|
||||||
"sounds": "stone",
|
"sounds": "stone"
|
||||||
"texture_name": "white2"
|
|
||||||
},
|
},
|
||||||
"ultra_white": {
|
"ultra_white": {
|
||||||
"description": "Ultra Plastic",
|
"description": "Ultra Plastic",
|
||||||
"light": 14,
|
"light": 14,
|
||||||
"sounds": "stone",
|
"sounds": "stone"
|
||||||
"texture_name": "white2"
|
|
||||||
},
|
},
|
||||||
"engine": {
|
"engine": {
|
||||||
"description": "Engine"
|
"description": "Engine"
|
||||||
@ -62,8 +58,7 @@
|
|||||||
},
|
},
|
||||||
"stripes": {
|
"stripes": {
|
||||||
"description": "hazard stripes",
|
"description": "hazard stripes",
|
||||||
"slat": true,
|
"slat": true
|
||||||
"advtrains_platform": true
|
|
||||||
},
|
},
|
||||||
"rust": {
|
"rust": {
|
||||||
"description": "rusty metal"
|
"description": "rusty metal"
|
||||||
@ -72,8 +67,7 @@
|
|||||||
"description": "metal mesh"
|
"description": "metal mesh"
|
||||||
},
|
},
|
||||||
"black": {
|
"black": {
|
||||||
"description": "black wall",
|
"description": "black wall"
|
||||||
"signs_banner": true
|
|
||||||
},
|
},
|
||||||
"blackoct": {
|
"blackoct": {
|
||||||
"description": "black octagon"
|
"description": "black octagon"
|
||||||
@ -94,8 +88,7 @@
|
|||||||
"description": "blue bars"
|
"description": "blue bars"
|
||||||
},
|
},
|
||||||
"bluemetal": {
|
"bluemetal": {
|
||||||
"description": "blue metal",
|
"description": "blue metal"
|
||||||
"signs_banner": true
|
|
||||||
},
|
},
|
||||||
"bluetile": {
|
"bluetile": {
|
||||||
"description": "blue tile",
|
"description": "blue tile",
|
||||||
@ -154,8 +147,7 @@
|
|||||||
"colorable": true
|
"colorable": true
|
||||||
},
|
},
|
||||||
"greenmetal": {
|
"greenmetal": {
|
||||||
"description": "green metal wall",
|
"description": "green metal wall"
|
||||||
"signs_banner": true
|
|
||||||
},
|
},
|
||||||
"greenmetal2": {
|
"greenmetal2": {
|
||||||
"description": "green metal wall2"
|
"description": "green metal wall2"
|
||||||
@ -179,8 +171,7 @@
|
|||||||
"description": "green pipes"
|
"description": "green pipes"
|
||||||
},
|
},
|
||||||
"grey": {
|
"grey": {
|
||||||
"description": "grey wall",
|
"description": "grey wall"
|
||||||
"signs_banner": true
|
|
||||||
},
|
},
|
||||||
"greybolts": {
|
"greybolts": {
|
||||||
"description": "grey wall bolts"
|
"description": "grey wall bolts"
|
||||||
@ -284,8 +275,7 @@
|
|||||||
"slat": true
|
"slat": true
|
||||||
},
|
},
|
||||||
"purple": {
|
"purple": {
|
||||||
"description": "Purple node",
|
"description": "Purple node"
|
||||||
"signs_banner": true
|
|
||||||
},
|
},
|
||||||
"rock": {
|
"rock": {
|
||||||
"description": "Moonstone",
|
"description": "Moonstone",
|
||||||
@ -302,12 +292,5 @@
|
|||||||
},
|
},
|
||||||
"blackplate": {
|
"blackplate": {
|
||||||
"description": "Black plate"
|
"description": "Black plate"
|
||||||
},
|
|
||||||
"plastcrete": {
|
|
||||||
"description": "Plastcrete",
|
|
||||||
"sounds": "stone",
|
|
||||||
"colorable": true,
|
|
||||||
"moreblocks": false,
|
|
||||||
"paramtype2": "none"
|
|
||||||
}
|
}
|
||||||
}
|
}
|
115
nodes.lua
115
nodes.lua
@ -1,8 +1,6 @@
|
|||||||
local has_unifieddyes_mod = minetest.get_modpath("unifieddyes")
|
local has_unifieddyes_mod = minetest.get_modpath("unifieddyes")
|
||||||
local has_moreblocks_mod = minetest.get_modpath("moreblocks")
|
local has_moreblocks_mod = minetest.get_modpath("moreblocks")
|
||||||
local has_slats_mod = minetest.get_modpath("slats")
|
local has_slats_mod = minetest.get_modpath("slats")
|
||||||
local has_advtrains_mod = minetest.get_modpath("advtrains")
|
|
||||||
local has_signs_api_mod = minetest.get_modpath("signs_api")
|
|
||||||
|
|
||||||
--nodes
|
--nodes
|
||||||
|
|
||||||
@ -369,6 +367,95 @@ minetest.register_node("scifi_nodes:grnpipe2", {
|
|||||||
on_place = minetest.rotate_node
|
on_place = minetest.rotate_node
|
||||||
})
|
})
|
||||||
|
|
||||||
|
minetest.register_node("scifi_nodes:octrng", {
|
||||||
|
description = "Orange Octagon Glass",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
drawtype = "glasslike",
|
||||||
|
tiles = {
|
||||||
|
"scifi_nodes_octrng.png",
|
||||||
|
},
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
use_texture_alpha = "blend",
|
||||||
|
light_source = 10,
|
||||||
|
groups = {cracky=2, dig_generic = 3},
|
||||||
|
is_ground_content = false,
|
||||||
|
sounds = scifi_nodes.node_sound_glass_defaults(),
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_node("scifi_nodes:octgrn", {
|
||||||
|
description = "Green Octagon Glass",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
drawtype = "glasslike",
|
||||||
|
tiles = {
|
||||||
|
"scifi_nodes_octgrn.png",
|
||||||
|
},
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
use_texture_alpha = "blend",
|
||||||
|
light_source = 10,
|
||||||
|
groups = {cracky=2, dig_generic = 3},
|
||||||
|
is_ground_content = false,
|
||||||
|
sounds = scifi_nodes.node_sound_glass_defaults(),
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_node("scifi_nodes:octbl", {
|
||||||
|
description = "Blue Octagon Glass",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
drawtype = "glasslike",
|
||||||
|
tiles = {
|
||||||
|
"scifi_nodes_octbl.png",
|
||||||
|
},
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
use_texture_alpha = "blend",
|
||||||
|
light_source = 10,
|
||||||
|
groups = {cracky=2, dig_generic = 3},
|
||||||
|
is_ground_content = false,
|
||||||
|
sounds = scifi_nodes.node_sound_glass_defaults(),
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_node("scifi_nodes:octppl", {
|
||||||
|
description = "Purple Octagon Glass",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
drawtype = "glasslike",
|
||||||
|
tiles = {
|
||||||
|
"scifi_nodes_octppl.png",
|
||||||
|
},
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
use_texture_alpha = "blend",
|
||||||
|
light_source = 10,
|
||||||
|
groups = {cracky=2, dig_generic = 3},
|
||||||
|
is_ground_content = false,
|
||||||
|
sounds = scifi_nodes.node_sound_glass_defaults(),
|
||||||
|
})
|
||||||
|
|
||||||
|
if has_unifieddyes_mod then
|
||||||
|
minetest.register_node("scifi_nodes:octwht", {
|
||||||
|
description = "Octagon Glass",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
drawtype = "glasslike",
|
||||||
|
tiles = {
|
||||||
|
"scifi_nodes_octwht.png",
|
||||||
|
},
|
||||||
|
palette = "unifieddyes_palette_extended.png",
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "color",
|
||||||
|
use_texture_alpha = "blend",
|
||||||
|
light_source = 10,
|
||||||
|
groups = {
|
||||||
|
cracky = 2,
|
||||||
|
dig_generic = 3,
|
||||||
|
ud_param2_colorable = 1
|
||||||
|
},
|
||||||
|
is_ground_content = false,
|
||||||
|
sounds = scifi_nodes.node_sound_glass_defaults(),
|
||||||
|
on_construct = unifieddyes.on_construct,
|
||||||
|
on_dig = unifieddyes.on_dig
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
minetest.register_node("scifi_nodes:tower", {
|
minetest.register_node("scifi_nodes:tower", {
|
||||||
description = "Wind tower",
|
description = "Wind tower",
|
||||||
sunlight_propagates = false,
|
sunlight_propagates = false,
|
||||||
@ -574,30 +661,6 @@ for name, def in pairs(nodes) do
|
|||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
-- advtrains platform registration
|
|
||||||
if has_advtrains_mod and def.advtrains_platform then
|
|
||||||
advtrains.register_platform("scifi_nodes", "scifi_nodes:" .. name)
|
|
||||||
end
|
|
||||||
|
|
||||||
if has_signs_api_mod and def.signs_banner then
|
|
||||||
signs_api.register_sign("scifi_nodes", name .. "_banner", {
|
|
||||||
depth = 1/16,
|
|
||||||
width = 5,
|
|
||||||
height = 1,
|
|
||||||
entity_fields = {
|
|
||||||
maxlines = 1,
|
|
||||||
color = def.signs_banner_color or "#fff",
|
|
||||||
},
|
|
||||||
node_fields = {
|
|
||||||
visual_scale = 1,
|
|
||||||
description = name .. " banner",
|
|
||||||
tiles = tiles,
|
|
||||||
inventory_image = "scifi_nodes_" .. name .. ".png",
|
|
||||||
use_texture_alpha = "clip",
|
|
||||||
},
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
if has_slats_mod and def.slat then
|
if has_slats_mod and def.slat then
|
||||||
slats.register_slat(
|
slats.register_slat(
|
||||||
name,
|
name,
|
||||||
|
@ -1,53 +0,0 @@
|
|||||||
local has_unifieddyes_mod = minetest.get_modpath("unifieddyes")
|
|
||||||
|
|
||||||
local function register_glass(key, name)
|
|
||||||
local tiles = {"scifi_nodes_" .. key .. ".png"}
|
|
||||||
|
|
||||||
minetest.register_node("scifi_nodes:" .. key, {
|
|
||||||
description = name .. " Octagon Glass",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
drawtype = "glasslike",
|
|
||||||
tiles = tiles,
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
use_texture_alpha = "blend",
|
|
||||||
light_source = 10,
|
|
||||||
groups = {
|
|
||||||
cracky = 2,
|
|
||||||
dig_generic = 3
|
|
||||||
},
|
|
||||||
is_ground_content = false,
|
|
||||||
sounds = scifi_nodes.node_sound_glass_defaults(),
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
register_glass("octppl", "Purple")
|
|
||||||
register_glass("octbl", "Blue")
|
|
||||||
register_glass("octgrn", "Green")
|
|
||||||
register_glass("octrng", "Orange")
|
|
||||||
register_glass("octwht", "White")
|
|
||||||
|
|
||||||
if has_unifieddyes_mod then
|
|
||||||
minetest.register_node("scifi_nodes:octwht", {
|
|
||||||
description = "Octagon Glass",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
drawtype = "glasslike",
|
|
||||||
tiles = {
|
|
||||||
"scifi_nodes_octwht.png",
|
|
||||||
},
|
|
||||||
palette = "unifieddyes_palette_extended.png",
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "color",
|
|
||||||
use_texture_alpha = "blend",
|
|
||||||
light_source = 10,
|
|
||||||
groups = {
|
|
||||||
cracky = 2,
|
|
||||||
dig_generic = 3,
|
|
||||||
ud_param2_colorable = 1
|
|
||||||
},
|
|
||||||
is_ground_content = false,
|
|
||||||
sounds = scifi_nodes.node_sound_glass_defaults(),
|
|
||||||
on_construct = unifieddyes.on_construct,
|
|
||||||
on_dig = unifieddyes.on_dig
|
|
||||||
})
|
|
||||||
end
|
|
@ -1,15 +1,13 @@
|
|||||||
|
|
||||||
local function register(basename, color, texture)
|
local function register(basename, description, texture)
|
||||||
local nodename_single = "scifi_nodes:" .. basename .. "_pane"
|
local nodename_single = "scifi_nodes:" .. basename .. "_pane"
|
||||||
local nodename_double = "scifi_nodes:" .. basename .. "_pane_double"
|
local nodename_double = "scifi_nodes:" .. basename .. "_pane_double"
|
||||||
local nodename_offset = "scifi_nodes:" .. basename .. "_pane_offset"
|
local nodename_offset = "scifi_nodes:" .. basename .. "_pane_offset"
|
||||||
local nodename_slope = "scifi_nodes:" .. basename .. "_slope"
|
|
||||||
local recipe_ingredient = "scifi_nodes:" .. basename
|
local recipe_ingredient = "scifi_nodes:" .. basename
|
||||||
local base_decription = color .. " octagon glass"
|
|
||||||
|
|
||||||
-- single height
|
-- single height
|
||||||
minetest.register_node(nodename_single, {
|
minetest.register_node(nodename_single, {
|
||||||
description = base_decription .. " pane",
|
description = description,
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
tiles = {
|
tiles = {
|
||||||
texture
|
texture
|
||||||
@ -27,17 +25,14 @@ local function register(basename, color, texture)
|
|||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = {{-0.5, -0.5, -0.25, 0.5, 0.5, 0.25}},
|
fixed = {{-0.5, -0.5, -0.25, 0.5, 0.5, 0.25}},
|
||||||
},
|
},
|
||||||
groups = {
|
groups = {cracky = 3, oddly_breakable_by_hand = 3},
|
||||||
cracky = 3,
|
|
||||||
oddly_breakable_by_hand = 3
|
|
||||||
},
|
|
||||||
use_texture_alpha = "blend",
|
use_texture_alpha = "blend",
|
||||||
sounds = scifi_nodes.node_sound_glass_defaults()
|
sounds = scifi_nodes.node_sound_glass_defaults()
|
||||||
})
|
})
|
||||||
|
|
||||||
-- double height
|
-- double height
|
||||||
minetest.register_node(nodename_double, {
|
minetest.register_node(nodename_double, {
|
||||||
description = base_decription .. " pane (double)",
|
description = description,
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
tiles = {
|
tiles = {
|
||||||
texture
|
texture
|
||||||
@ -55,17 +50,14 @@ local function register(basename, color, texture)
|
|||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = {{-0.5, -0.5, -0.25, 0.5, 1.5, 0.25}},
|
fixed = {{-0.5, -0.5, -0.25, 0.5, 1.5, 0.25}},
|
||||||
},
|
},
|
||||||
groups = {
|
groups = {cracky = 3, oddly_breakable_by_hand = 3},
|
||||||
cracky = 3,
|
|
||||||
oddly_breakable_by_hand = 3
|
|
||||||
},
|
|
||||||
use_texture_alpha = "blend",
|
use_texture_alpha = "blend",
|
||||||
sounds = scifi_nodes.node_sound_glass_defaults()
|
sounds = scifi_nodes.node_sound_glass_defaults()
|
||||||
})
|
})
|
||||||
|
|
||||||
-- single height with offset
|
-- single height with offset
|
||||||
minetest.register_node(nodename_offset, {
|
minetest.register_node(nodename_offset, {
|
||||||
description = base_decription .. " pane (offset)",
|
description = description,
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
tiles = {
|
tiles = {
|
||||||
texture
|
texture
|
||||||
@ -83,37 +75,11 @@ local function register(basename, color, texture)
|
|||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = {{-0.5, -0.5, 0.75, 0.5, 0.5, 1.25}},
|
fixed = {{-0.5, -0.5, 0.75, 0.5, 0.5, 1.25}},
|
||||||
},
|
},
|
||||||
groups = {
|
groups = {cracky = 3, oddly_breakable_by_hand = 3},
|
||||||
cracky = 3,
|
|
||||||
oddly_breakable_by_hand = 3,
|
|
||||||
not_blocking_trains = 1
|
|
||||||
},
|
|
||||||
use_texture_alpha = "blend",
|
use_texture_alpha = "blend",
|
||||||
sounds = scifi_nodes.node_sound_glass_defaults()
|
sounds = scifi_nodes.node_sound_glass_defaults()
|
||||||
})
|
})
|
||||||
|
|
||||||
-- slope pane
|
|
||||||
minetest.register_node(nodename_slope, {
|
|
||||||
description = base_decription .. " pane (slope)",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
drawtype = "mesh",
|
|
||||||
mesh = "scifi_nodes_slope_simple.obj",
|
|
||||||
tiles = {
|
|
||||||
texture
|
|
||||||
},
|
|
||||||
paramtype = "light",
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
use_texture_alpha = "blend",
|
|
||||||
light_source = 10,
|
|
||||||
groups = {
|
|
||||||
cracky = 2,
|
|
||||||
dig_generic = 3
|
|
||||||
},
|
|
||||||
selection_box = scifi_nodes.slope_box_simple,
|
|
||||||
collision_box = scifi_nodes.slope_box_simple,
|
|
||||||
is_ground_content = false,
|
|
||||||
sounds = scifi_nodes.node_sound_glass_defaults()
|
|
||||||
})
|
|
||||||
-- register recipes
|
-- register recipes
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
@ -123,15 +89,6 @@ local function register(basename, color, texture)
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craft({
|
|
||||||
output = nodename_slope .. " 16",
|
|
||||||
recipe = {
|
|
||||||
{"", "", recipe_ingredient},
|
|
||||||
{"", recipe_ingredient, ""},
|
|
||||||
{recipe_ingredient, "", ""}
|
|
||||||
},
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = nodename_double .. " 16",
|
output = nodename_double .. " 16",
|
||||||
recipe = {
|
recipe = {
|
||||||
@ -147,9 +104,8 @@ local function register(basename, color, texture)
|
|||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
register("octrng", "Orange", "scifi_nodes_octrng.png")
|
register("octrng", "Orange Octagon Glass pane", "scifi_nodes_octrng.png")
|
||||||
register("octgrn", "Green", "scifi_nodes_octgrn.png")
|
register("octgrn", "Green Octagon Glass pane", "scifi_nodes_octgrn.png")
|
||||||
register("octbl", "Blue", "scifi_nodes_octbl.png")
|
register("octbl", "Blue Octagon Glass pane", "scifi_nodes_octbl.png")
|
||||||
register("octppl", "Purple", "scifi_nodes_octppl.png")
|
register("octppl", "Purple Octagon Glass pane", "scifi_nodes_octppl.png")
|
||||||
register("octwht", "White", "scifi_nodes_octwht.png")
|
|
||||||
register("glass", "Dark Glass pane", "scifi_nodes_glass.png")
|
register("glass", "Dark Glass pane", "scifi_nodes_glass.png")
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 5.1 KiB |
BIN
textures/scifi_nodes_super_white.png
Normal file
BIN
textures/scifi_nodes_super_white.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 83 B |
BIN
textures/scifi_nodes_ultra_white.png
Normal file
BIN
textures/scifi_nodes_ultra_white.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 83 B |
Reference in New Issue
Block a user