mirror of
git://repo.or.cz/rocks.git
synced 2025-01-01 14:00:30 +01:00
Deduplication, param cleanup. Veins.
This commit is contained in:
parent
f9d6fbdcea
commit
16a9a079d9
@ -15,7 +15,7 @@ l.OnInit={}
|
|||||||
l.ToResolve={}
|
l.ToResolve={}
|
||||||
|
|
||||||
local includes={
|
local includes={
|
||||||
"pipes","veins"
|
"utils","pipes","veins"
|
||||||
}
|
}
|
||||||
|
|
||||||
minetest.register_on_generated(function(minp,maxp,seed)
|
minetest.register_on_generated(function(minp,maxp,seed)
|
||||||
@ -23,9 +23,12 @@ minetest.register_on_generated(function(minp,maxp,seed)
|
|||||||
local vm, emin, emax = minetest.get_mapgen_object("voxelmanip")
|
local vm, emin, emax = minetest.get_mapgen_object("voxelmanip")
|
||||||
local area = VoxelArea:new{MinEdge=emin, MaxEdge=emax}
|
local area = VoxelArea:new{MinEdge=emin, MaxEdge=emax}
|
||||||
local pr=PseudoRandom(seed)
|
local pr=PseudoRandom(seed)
|
||||||
|
local data=vm:get_data()
|
||||||
|
local mgc={minp=minp,maxp=maxp,pr=pr,data=data,area=area}
|
||||||
for i=1, #l.OnGenerate do
|
for i=1, #l.OnGenerate do
|
||||||
l.OnGenerate[i](minp,maxp,pr,vm,area)
|
l.OnGenerate[i](mgc)
|
||||||
end
|
end
|
||||||
|
vm:set_data(data)
|
||||||
vm:write_to_map()
|
vm:write_to_map()
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
@ -44,24 +44,26 @@ end
|
|||||||
|
|
||||||
depositgen.l.ToResolve.air={name="air"}
|
depositgen.l.ToResolve.air={name="air"}
|
||||||
|
|
||||||
local function generate(minp,maxp,pr,vm,area)
|
local function generate(mgc)
|
||||||
local t1 = os.clock()
|
local t1 = os.clock()
|
||||||
|
|
||||||
local data = vm:get_data()
|
local data = mgc.data
|
||||||
|
local area = mgc.area
|
||||||
|
local pr=mgc.pr
|
||||||
|
local minp,maxp=mgc.minp,mgc.maxp
|
||||||
local chunksizer = maxp.x - minp.x + 1
|
local chunksizer = maxp.x - minp.x + 1
|
||||||
local chunksize = chunksizer + 1
|
local chunksize = chunksizer + 1
|
||||||
local pmapsize = {x = chunksize, y = chunksize, z = chunksize}
|
local pmapsize = {x = chunksize, y = chunksize, z = chunksize}
|
||||||
local minpxz = {x = minp.x, y = minp.z}
|
local minpxz = {x = minp.x, y = minp.z}
|
||||||
|
|
||||||
for _,descr in pairs(regs) do
|
for _,descr in pairs(regs) do
|
||||||
--local orepr=PseudoRandom(pr:next())
|
|
||||||
local numpipes_raw=(chunksize/descr.scarcity)
|
local numpipes_raw=(chunksize/descr.scarcity)
|
||||||
local numpipes = math.floor(numpipes_raw + (pr:next(0,99)/100))
|
local numpipes = math.floor(numpipes_raw + (pr:next(0,99)/100))
|
||||||
|
|
||||||
for vc=1, numpipes do
|
for vc=1, numpipes do
|
||||||
local pointA=vector.new(pr:next(0,chunksizer)+minp.x,pr:next(0,chunksizer)+minp.y,pr:next(0,chunksizer)+minp.z)
|
local pointA=l.rndvector(mgc)
|
||||||
local pointB=vector.new(pr:next(0,chunksizer)+minp.x,pr:next(0,chunksizer)+minp.y,pr:next(0,chunksizer)+minp.z)
|
local pointB=l.rndvector(mgc)
|
||||||
local pointC=vector.new(pr:next(0,chunksizer)+minp.x,pr:next(0,chunksizer)+minp.y,pr:next(0,chunksizer)+minp.z)
|
local pointC=l.rndvector(mgc)
|
||||||
local step=(1.8)/(vector.distance(pointA,pointB)+vector.distance(pointB,pointC))
|
local step=(1.8)/(vector.distance(pointA,pointB)+vector.distance(pointB,pointC))
|
||||||
|
|
||||||
for t=0, 1, step do
|
for t=0, 1, step do
|
||||||
@ -107,7 +109,6 @@ local function generate(minp,maxp,pr,vm,area)
|
|||||||
|
|
||||||
end --</apipe>
|
end --</apipe>
|
||||||
|
|
||||||
vm:set_data(data)
|
|
||||||
l.print("pipes "..math.ceil((os.clock() - t1) * 1000).." ms ")
|
l.print("pipes "..math.ceil((os.clock() - t1) * 1000).." ms ")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
16
depositgen/utils.lua
Normal file
16
depositgen/utils.lua
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
function depositgen.l.SpawnCluster(mgc,pos,wherein,size,content,density)
|
||||||
|
for y=pos.y-size, pos.y+size do
|
||||||
|
for x=pos.x-size, pos.x+size do
|
||||||
|
for z=pos.z-size, pos.z+size do
|
||||||
|
if mgc.pr:next(0,density)==0 then
|
||||||
|
di=mgc.area:index(x,y,z)
|
||||||
|
if mgc.data[di]==wherein then
|
||||||
|
mgc.data[di]=content
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end end end
|
||||||
|
end
|
||||||
|
function depositgen.l.rndvector(mgc)
|
||||||
|
local chunksizer = mgc.maxp.x - mgc.minp.x + 1
|
||||||
|
return vector.new(mgc.pr:next(0,chunksizer)+mgc.minp.x,mgc.pr:next(0,chunksizer)+mgc.minp.y,mgc.pr:next(0,chunksizer)+mgc.minp.z)
|
||||||
|
end
|
@ -35,34 +35,34 @@ local sample_vein_def={
|
|||||||
scarcity=80,
|
scarcity=80,
|
||||||
content="default:dirt",
|
content="default:dirt",
|
||||||
scatter={
|
scatter={
|
||||||
--{ scarcity=7, density=4, content="default:mese", size=2 }
|
{ scarcity=7, density=4, content="default:mese", size=2 }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
depositgen.register_vein(sample_vein_def)
|
depositgen.register_vein(sample_vein_def)
|
||||||
end
|
end
|
||||||
|
|
||||||
local function generate(minp,maxp,pr,vm,area)
|
local function generate(mgc)
|
||||||
local t1 = os.clock()
|
local t1 = os.clock()
|
||||||
local data = vm:get_data()
|
local data = mgc.data
|
||||||
|
local area = mgc.area
|
||||||
|
local pr=mgc.pr
|
||||||
|
|
||||||
local chunksizer = maxp.x - minp.x + 1
|
local chunksizer = mgc.maxp.x - mgc.minp.x + 1
|
||||||
local chunksize = chunksizer + 1
|
local chunksize = chunksizer + 1
|
||||||
local pmapsize = {x = chunksize, y = chunksize, z = chunksize}
|
local pmapsize = {x = chunksize, y = chunksize, z = chunksize}
|
||||||
local minpxz = {x = minp.x, y = minp.z}
|
local minpxz = {x = mgc.minp.x, y = mgc.minp.z}
|
||||||
|
|
||||||
for _,descr in pairs(regs) do
|
for _,descr in pairs(regs) do
|
||||||
local num = math.floor( (chunksize/descr.scarcity) + (pr:next(0,99)/100) )
|
local num = math.floor( (chunksize/descr.scarcity) + (pr:next(0,99)/100) )
|
||||||
for vc=1, num do
|
for vc=1, num do
|
||||||
|
|
||||||
local A=vector.new(pr:next(0,chunksizer)+minp.x,pr:next(0,chunksizer)+minp.y,pr:next(0,chunksizer)+minp.z)
|
local A=l.rndvector(mgc)
|
||||||
local B=vector.new(pr:next(0,chunksizer)+minp.x,pr:next(0,chunksizer)+minp.y,pr:next(0,chunksizer)+minp.z)
|
local B=l.rndvector(mgc)
|
||||||
local C=vector.new(pr:next(0,chunksizer)+minp.x,pr:next(0,chunksizer)+minp.y,pr:next(0,chunksizer)+minp.z)
|
local C=l.rndvector(mgc)
|
||||||
local D=vector.new(pr:next(0,chunksizer)+minp.x,pr:next(0,chunksizer)+minp.y,pr:next(0,chunksizer)+minp.z)
|
local D=l.rndvector(mgc)
|
||||||
local l1=vector.distance(A,C)+vector.distance(C,B)
|
local l1=vector.distance(A,C)+vector.distance(C,B)
|
||||||
local l2=vector.distance(A,D)+vector.distance(D,B)
|
local l2=vector.distance(A,D)+vector.distance(D,B)
|
||||||
local step=2/math.max(l1,l2)
|
local step=2/math.max(l1,l2)
|
||||||
local scarcity=6
|
|
||||||
local ocn=pr:next(0,scarcity)+(scarcity/2)
|
|
||||||
for t=0, 1, step do
|
for t=0, 1, step do
|
||||||
local P=vector.multiply(A,(1-t)^2)
|
local P=vector.multiply(A,(1-t)^2)
|
||||||
P=vector.add(P, vector.multiply(B,t*t) )
|
P=vector.add(P, vector.multiply(B,t*t) )
|
||||||
@ -79,10 +79,22 @@ local function generate(minp,maxp,pr,vm,area)
|
|||||||
--</brush>
|
--</brush>
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
--<ores>
|
||||||
|
local cluster=descr.scatter[1]
|
||||||
|
for xxx=1, 5 do
|
||||||
|
local t=pr:next(0,100)/100
|
||||||
|
local u=pr:next(0,100)/100
|
||||||
|
local P=vector.multiply(A,(1-t)^2)
|
||||||
|
P=vector.add(P, vector.multiply(B,t*t) )
|
||||||
|
local Q=vector.add(P, vector.multiply(D,2*t*(1-t)) )
|
||||||
|
P=vector.add(P, vector.multiply(C,2*t*(1-t)) )
|
||||||
|
local R=vector.add(vector.multiply(P,(1-u)), vector.multiply(Q,u) )
|
||||||
|
l.SpawnCluster(mgc,vector.round(R),l.ToResolve.air.id,cluster.size,cluster.content.id,cluster.density)
|
||||||
|
end
|
||||||
|
--</ores>
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
vm:set_data(data)
|
|
||||||
print("vein "..math.ceil((os.clock() - t1) * 1000).." ms ")
|
print("vein "..math.ceil((os.clock() - t1) * 1000).." ms ")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user