kpoppel
2013-06-03 ceb8a71f27b45c304ce2626cc4f939a52323b192
commit | author | age
64207b 1 HV_machines = {}
R 2
3 registered_HV_machines_count=0
4
5 function register_HV_machine (string1,string2)
6 registered_HV_machines_count=registered_HV_machines_count+1
7 HV_machines[registered_HV_machines_count]={}
8 HV_machines[registered_HV_machines_count].machine_name=string1
9 HV_machines[registered_HV_machines_count].machine_type=string2
10 end
11
12 minetest.register_craft({
13     output = 'technic:hv_battery_box 1',
14     recipe = {
15         {'technic:mv_battery_box', 'technic:mv_battery_box', 'mv_technic:battery_box'},
ede397 16         {'technic:mv_battery_box', 'technic:hv_transformer', 'mv_technic:battery_box'},
64207b 17         {'', 'technic:hv_cable', ''},
R 18     }
19 }) 
20
21 hv_battery_box_formspec =
22     "invsize[8,9;]"..
23     "image[1,1;1,2;technic_power_meter_bg.png]"..
24     "list[current_name;src;3,1;1,1;]"..
25     "image[4,1;1,1;technic_battery_reload.png]"..
26     "list[current_name;dst;5,1;1,1;]"..
27     "label[0,0;HV Battery Box]"..
28     "label[3,0;Charge]"..
29     "label[5,0;Discharge]"..
30     "label[1,3;Power level]"..
31     "list[current_player;main;0,5;8,4;]"
32
33 minetest.register_node("technic:hv_battery_box", {
34     description = "HV Battery Box",
35     tiles = {"technic_hv_battery_box_top.png", "technic_hv_battery_box_bottom.png", "technic_hv_battery_box_side0.png",
36         "technic_hv_battery_box_side0.png", "technic_hv_battery_box_side0.png", "technic_hv_battery_box_side0.png"},
37     groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2},
38     sounds = default.node_sound_wood_defaults(),
39     technic_mv_power_machine=1,
40     last_side_shown=0,
41     drop="technic:hv_battery_box",
42     on_construct = function(pos)
43         local meta = minetest.env:get_meta(pos)
44         meta:set_string("infotext", "HV Battery Box")
45         meta:set_float("technic_hv_power_machine", 1)
46         meta:set_string("formspec", battery_box_formspec)
47         local inv = meta:get_inventory()
48         inv:set_size("src", 1)
49         inv:set_size("dst", 1)
50         battery_charge = 0
51         max_charge = 1500000
52         last_side_shown=0
53         end,    
54     can_dig = function(pos,player)
55         local meta = minetest.env:get_meta(pos);
56         local inv = meta:get_inventory()
57         if not inv:is_empty("dst") then
58             return false
59         elseif not inv:is_empty("src") then
60             return false
61         end
62         return true
63     end,
64 })
65
66
67 for i=1,8,1 do
68 minetest.register_node("technic:hv_battery_box"..i, {
69     description = "HV Battery Box",
70     tiles = {"technic_hv_battery_box_top.png", "technic_hv_battery_box_bottom.png", "technic_hv_battery_box_side0.png^technic_power_meter"..i..".png",
71         "technic_hv_battery_box_side0.png^technic_power_meter"..i..".png", "technic_hv_battery_box_side0.png^technic_power_meter"..i..".png", "technic_hv_battery_box_side0.png^technic_power_meter"..i..".png"},
72     groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2,not_in_creative_inventory=1},
73     sounds = default.node_sound_wood_defaults(),
74     paramtype="light",
75     light_source=9,
76     technic_power_machine=1,
77     last_side_shown=0,
78     drop="technic:hv_battery_box",
79     on_construct = function(pos)
80         local meta = minetest.env:get_meta(pos)
ede397 81         meta:set_string("infotext", "HV Battery box")
64207b 82         meta:set_float("technic_hv_power_machine", 1)
R 83         meta:set_string("formspec", battery_box_formspec)
84         local inv = meta:get_inventory()
85         inv:set_size("src", 1)
86         inv:set_size("dst", 1)
87         battery_charge = 0
88         max_charge = 1500000
89         last_side_shown=0
90         end,
91     can_dig = function(pos,player)
92         local meta = minetest.env:get_meta(pos);
93         local inv = meta:get_inventory()
94         if not inv:is_empty("dst") then
95             return false
96         elseif not inv:is_empty("src") then
97             return false
98         end
99         return true
100     end,
101 })
102 end
103
104
105 HV_nodes_visited = {}
106
107
108 minetest.register_abm({
109     nodenames = {"technic:hv_battery_box","technic:hv_battery_box1","technic:hv_battery_box2","technic:hv_battery_box3","technic:hv_battery_box4",
110              "technic:hv_battery_box5","technic:hv_battery_box6","technic:hv_battery_box7","technic:hv_battery_box8"
111             },
112     interval = 1,
113     chance = 1,
114     action = function(pos, node, active_object_count, active_object_count_wider)
115     local meta = minetest.env:get_meta(pos)
116     charge= meta:get_int("battery_charge")
117     max_charge= 1500000
118     local i=math.ceil((charge/max_charge)*8)
119     if i>8 then i=8 end
120     j=meta:get_float("last_side_shown")
121     if i~=j then
122     if i>0 then hacky_swap_node(pos,"technic:hv_battery_box"..i)  
123     elseif i==0 then hacky_swap_node(pos,"technic:hv_battery_box") end 
124     meta:set_float("last_side_shown",i)
125     end
126
127 --loading registered power tools
128     local inv = meta:get_inventory()
129     if inv:is_empty("src")==false  then 
130         local srcstack = inv:get_stack("src", 1)
131         local src_item=srcstack:to_table()
132         local src_meta=get_item_meta(src_item["metadata"])
133
134         local item_max_charge=nil
135         for i=1,registered_power_tools_count,1 do
136             if power_tools[i].tool_name==src_item["name"] then
137                 src_meta=get_item_meta(src_item["metadata"])
138                 if src_meta==nil then 
139                     src_meta={}
140                     src_meta["technic_power_tool"]=true
141                     src_meta["charge"]=0
142                 else 
143                     if src_meta["technic_power_tool"]==nil then
144                         src_meta["technic_power_tool"]=true
145                         src_meta["charge"]=0
146                     end
147                 end
148                 item_max_charge=power_tools[i].max_charge
149             end
150         end
151         
152         if item_max_charge then
153             load1=src_meta["charge"] 
154             load_step=16000
155             if load1<item_max_charge and charge>0 then 
156                 if charge-load_step<0 then load_step=charge end
157                 if load1+load_step>item_max_charge then load_step=item_max_charge-load1 end
158                 load1=load1+load_step
159                 charge=charge-load_step
160                 set_RE_wear(src_item,load1,item_max_charge)
161                 src_meta["charge"]=load1
162                 src_item["metadata"]=set_item_meta(src_meta)
163                 inv:set_stack("src", 1, src_item)
164             end
165             meta:set_int("battery_charge",charge)
166         end    
167     end
168     
169 -- dischargin registered power tools
170         if inv:is_empty("dst") == false then 
171         srcstack = inv:get_stack("dst", 1)
172         src_item=srcstack:to_table()
173         local src_meta=get_item_meta(src_item["metadata"])
174         local item_max_charge=nil
175         for i=1,registered_power_tools_count,1 do
176             if power_tools[i].tool_name==src_item["name"] then
177                 src_meta=get_item_meta(src_item["metadata"])
178                 if src_meta==nil then 
179                     src_meta={}
180                     src_meta["technic_power_tool"]=true
181                     src_meta["charge"]=0
182                 else 
183                     if src_meta["technic_power_tool"]==nil then
184                         src_meta["technic_power_tool"]=true
185                         src_meta["charge"]=0
186                     end
187                 end
188                 item_max_charge=power_tools[i].max_charge
189             end
190         end
191
192         if item_max_charge then
193         local load1=src_meta["charge"] 
194         load_step=16000
195         if load1>0 and charge<max_charge then 
196              if charge+load_step>max_charge then load_step=max_charge-charge end
197                if load1-load_step<0 then load_step=load1 end
198         load1=load1-load_step
199         charge=charge+load_step
200         set_RE_wear(src_item,load1,item_max_charge)
201         src_meta["charge"]=load1
202         src_item["metadata"]=set_item_meta(src_meta)
203         inv:set_stack("dst", 1, src_item)
204         end        
205         end
206         end
207         
208     meta:set_int("battery_charge",charge)
209
210     local load = math.floor((charge/1500000) * 100)
211     meta:set_string("formspec",
212                 hv_battery_box_formspec..
213                 "image[1,1;1,2;technic_power_meter_bg.png^[lowpart:"..
214                         (load)..":technic_power_meter_fg.png]"
215                 )
216         
217     local pos1={}
218
219     pos1.y=pos.y-1
220     pos1.x=pos.x
221     pos1.z=pos.z
222
223
224     meta1 = minetest.env:get_meta(pos1)
225     if meta1:get_float("hv_cablelike")~=1 then return end
226
227         local HV_nodes = {}
228         local PR_nodes = {}
229         local RE_nodes = {}
230
231         HV_nodes[1]={}
232         HV_nodes[1].x=pos1.x
233         HV_nodes[1].y=pos1.y
234         HV_nodes[1].z=pos1.z
235         HV_nodes[1].visited=false
236     
237 table_index=1
238     repeat
239     check_HV_node (PR_nodes,RE_nodes,HV_nodes,table_index)
240     table_index=table_index+1
241     if HV_nodes[table_index]==nil then break end
242     until false
243
244
245 local pos1={}
246 i=1
247     repeat
248     if PR_nodes[i]==nil then break end -- gettin power from all connected producers
249         pos1.x=PR_nodes[i].x
250         pos1.y=PR_nodes[i].y
251         pos1.z=PR_nodes[i].z
252     local meta1 = minetest.env:get_meta(pos1)
253     local internal_EU_buffer=meta1:get_float("internal_EU_buffer")
254     if charge<max_charge then 
255     charge_to_take=4000
256     if internal_EU_buffer-charge_to_take<=0 then
257         charge_to_take=internal_EU_buffer
258     end
259     if charge_to_take>0 then 
260     charge=charge+charge_to_take 
261     internal_EU_buffer=internal_EU_buffer-charge_to_take
262     meta1:set_float("internal_EU_buffer",internal_EU_buffer)
263     end
264     end
265     i=i+1
266     until false
267
268 if charge>max_charge then charge=max_charge end
269
270 i=1
271     repeat
272     if RE_nodes[i]==nil then break end
273         pos1.x=RE_nodes[i].x         -- loading all conected machines buffers
274         pos1.y=RE_nodes[i].y
275         pos1.z=RE_nodes[i].z
276     local meta1 = minetest.env:get_meta(pos1)
277     local internal_EU_buffer=meta1:get_float("internal_EU_buffer")
278     local internal_EU_buffer_size=meta1:get_float("internal_EU_buffer_size")
279
280     local charge_to_give=4000
281     if internal_EU_buffer+charge_to_give>internal_EU_buffer_size then
282         charge_to_give=internal_EU_buffer_size-internal_EU_buffer
283     end
284     if charge-charge_to_give<0 then charge_to_give=charge end
285
286     internal_EU_buffer=internal_EU_buffer+charge_to_give
287     meta1:set_float("internal_EU_buffer",internal_EU_buffer)
288     charge=charge-charge_to_give;
289     
290     i=i+1
291     until false
292     charge=math.floor(charge)
293     charge_string=tostring(charge)
294     meta:set_string("infotext", "HV Battery Box: \n"..charge_string.."/"..max_charge);
295     meta:set_int("battery_charge",charge)
296
297 end
298 })
299
300 function add_new_HVcable_node (HV_nodes,pos1)
301 local i=1
302     repeat
303         if HV_nodes[i]==nil then break end
304         if pos1.x==HV_nodes[i].x and pos1.y==HV_nodes[i].y and pos1.z==HV_nodes[i].z then return false end
305         i=i+1
306     until false
307 HV_nodes[i]={}
308 HV_nodes[i].x=pos1.x
309 HV_nodes[i].y=pos1.y
310 HV_nodes[i].z=pos1.z
311 HV_nodes[i].visited=false
312 return true
313 end
314
315 function check_HV_node (PR_nodes,RE_nodes,HV_nodes,i)
316         local pos1={}
317         pos1.x=HV_nodes[i].x
318         pos1.y=HV_nodes[i].y
319         pos1.z=HV_nodes[i].z
320         HV_nodes[i].visited=true
321         new_node_added=false
322     
323         pos1.x=pos1.x+1
324         check_HV_node_subp (PR_nodes,RE_nodes,HV_nodes,pos1)
325         pos1.x=pos1.x-2
326         check_HV_node_subp (PR_nodes,RE_nodes,HV_nodes,pos1)
327         pos1.x=pos1.x+1
328         
329         pos1.y=pos1.y+1
330         check_HV_node_subp (PR_nodes,RE_nodes,HV_nodes,pos1)
331         pos1.y=pos1.y-2
332         check_HV_node_subp (PR_nodes,RE_nodes,HV_nodes,pos1)
333         pos1.y=pos1.y+1
334
335         pos1.z=pos1.z+1
336         check_HV_node_subp (PR_nodes,RE_nodes,HV_nodes,pos1)
337         pos1.z=pos1.z-2
338         check_HV_node_subp (PR_nodes,RE_nodes,HV_nodes,pos1)
339         pos1.z=pos1.z+1
340 return new_node_added
341 end
342
343 function check_HV_node_subp (PR_nodes,RE_nodes,HV_nodes,pos1)
344 meta = minetest.env:get_meta(pos1)
ede397 345 if meta:get_float("hv_cablelike")==1 then new_node_added=add_new_HVcable_node(HV_nodes,pos1) end
64207b 346 for i in ipairs(HV_machines) do
R 347     if minetest.env:get_node(pos1).name == HV_machines[i].machine_name then 
348         if HV_machines[i].machine_type == "PR" then
349             new_node_added=add_new_HVcable_node(PR_nodes,pos1) 
350             end
351         if HV_machines[i].machine_type == "RE" then
352             new_node_added=add_new_HVcable_node(RE_nodes,pos1) 
353             end
354     end
355 end
356 end
357