Fix crafting
This commit is contained in:
parent
b56635f6b1
commit
1ee935e406
6 changed files with 279 additions and 60 deletions
|
@ -3,6 +3,7 @@
|
||||||
<Configs name="configs">
|
<Configs name="configs">
|
||||||
<Config>Configs\Default</Config>
|
<Config>Configs\Default</Config>
|
||||||
</Configs>
|
</Configs>
|
||||||
|
<datafiles number="1" name="datafiles"/>
|
||||||
<NewExtensions/>
|
<NewExtensions/>
|
||||||
<sounds name="sound">
|
<sounds name="sound">
|
||||||
<sound>sound\snd_engine</sound>
|
<sound>sound\snd_engine</sound>
|
||||||
|
@ -13,7 +14,6 @@
|
||||||
<sprite>sprites\spr_player</sprite>
|
<sprite>sprites\spr_player</sprite>
|
||||||
<sprite>sprites\spr_bullets</sprite>
|
<sprite>sprites\spr_bullets</sprite>
|
||||||
<sprite>sprites\spr_blocks</sprite>
|
<sprite>sprites\spr_blocks</sprite>
|
||||||
<sprite>sprites\spr_blackhole</sprite>
|
|
||||||
<sprite>sprites\spr_broken_ship</sprite>
|
<sprite>sprites\spr_broken_ship</sprite>
|
||||||
<sprite>sprites\spr_asteroid</sprite>
|
<sprite>sprites\spr_asteroid</sprite>
|
||||||
<sprite>sprites\spr_boom</sprite>
|
<sprite>sprites\spr_boom</sprite>
|
||||||
|
@ -24,6 +24,7 @@
|
||||||
<sprite>sprites\spr_hotbar</sprite>
|
<sprite>sprites\spr_hotbar</sprite>
|
||||||
<sprite>sprites\spr_intentory</sprite>
|
<sprite>sprites\spr_intentory</sprite>
|
||||||
<sprite>sprites\spr_crafting</sprite>
|
<sprite>sprites\spr_crafting</sprite>
|
||||||
|
<sprite>sprites\spr_blackhole</sprite>
|
||||||
<sprite>sprites\spr_final</sprite>
|
<sprite>sprites\spr_final</sprite>
|
||||||
</sprites>
|
</sprites>
|
||||||
</sprites>
|
</sprites>
|
||||||
|
@ -61,6 +62,7 @@
|
||||||
<object>objects\obj_exit</object>
|
<object>objects\obj_exit</object>
|
||||||
<object>objects\obj_gameover_overlay</object>
|
<object>objects\obj_gameover_overlay</object>
|
||||||
<object>objects\obj_inventory</object>
|
<object>objects\obj_inventory</object>
|
||||||
|
<object>objects\obj_crafting</object>
|
||||||
<object>objects\obj_hotbar</object>
|
<object>objects\obj_hotbar</object>
|
||||||
</objects>
|
</objects>
|
||||||
<objects name="items">
|
<objects name="items">
|
||||||
|
|
|
@ -57,31 +57,6 @@ if(step_counter == 60*room_speed || instance_position(x,y,obj_chunk) == noone)
|
||||||
{
|
{
|
||||||
instance_destroy(self);
|
instance_destroy(self);
|
||||||
}
|
}
|
||||||
</string>
|
|
||||||
</argument>
|
|
||||||
</arguments>
|
|
||||||
</action>
|
|
||||||
</event>
|
|
||||||
<event eventtype="4" ename="obj_broken_ship">
|
|
||||||
<action>
|
|
||||||
<libid>1</libid>
|
|
||||||
<id>603</id>
|
|
||||||
<kind>7</kind>
|
|
||||||
<userelative>0</userelative>
|
|
||||||
<isquestion>0</isquestion>
|
|
||||||
<useapplyto>-1</useapplyto>
|
|
||||||
<exetype>2</exetype>
|
|
||||||
<functionname></functionname>
|
|
||||||
<codestring></codestring>
|
|
||||||
<whoName>self</whoName>
|
|
||||||
<relative>0</relative>
|
|
||||||
<isnot>0</isnot>
|
|
||||||
<arguments>
|
|
||||||
<argument>
|
|
||||||
<kind>1</kind>
|
|
||||||
<string>instance_destroy(other);
|
|
||||||
instance_create(other.x,other.y,obj_boom_fx)
|
|
||||||
instance_destroy(id);
|
|
||||||
</string>
|
</string>
|
||||||
</argument>
|
</argument>
|
||||||
</arguments>
|
</arguments>
|
||||||
|
@ -128,6 +103,31 @@ instance_destroy(id);
|
||||||
<isnot>0</isnot>
|
<isnot>0</isnot>
|
||||||
</action>
|
</action>
|
||||||
</event>
|
</event>
|
||||||
|
<event eventtype="4" ename="obj_broken_ship">
|
||||||
|
<action>
|
||||||
|
<libid>1</libid>
|
||||||
|
<id>603</id>
|
||||||
|
<kind>7</kind>
|
||||||
|
<userelative>0</userelative>
|
||||||
|
<isquestion>0</isquestion>
|
||||||
|
<useapplyto>-1</useapplyto>
|
||||||
|
<exetype>2</exetype>
|
||||||
|
<functionname></functionname>
|
||||||
|
<codestring></codestring>
|
||||||
|
<whoName>self</whoName>
|
||||||
|
<relative>0</relative>
|
||||||
|
<isnot>0</isnot>
|
||||||
|
<arguments>
|
||||||
|
<argument>
|
||||||
|
<kind>1</kind>
|
||||||
|
<string>instance_destroy(other);
|
||||||
|
instance_create(other.x,other.y,obj_boom_fx)
|
||||||
|
instance_destroy(id);
|
||||||
|
</string>
|
||||||
|
</argument>
|
||||||
|
</arguments>
|
||||||
|
</action>
|
||||||
|
</event>
|
||||||
<event eventtype="4" ename="obj_asteriod">
|
<event eventtype="4" ename="obj_asteriod">
|
||||||
<action>
|
<action>
|
||||||
<libid>1</libid>
|
<libid>1</libid>
|
||||||
|
|
191
objects/obj_crafting.object.gmx
Normal file
191
objects/obj_crafting.object.gmx
Normal file
|
@ -0,0 +1,191 @@
|
||||||
|
<!--This Document is generated by GameMaker, if you edit it by hand then you do so at your own risk!-->
|
||||||
|
<object>
|
||||||
|
<spriteName>spr_crafting</spriteName>
|
||||||
|
<solid>0</solid>
|
||||||
|
<visible>-1</visible>
|
||||||
|
<depth>-4000</depth>
|
||||||
|
<persistent>0</persistent>
|
||||||
|
<parentName><undefined></parentName>
|
||||||
|
<maskName><undefined></maskName>
|
||||||
|
<events>
|
||||||
|
<event eventtype="0" enumb="0">
|
||||||
|
<action>
|
||||||
|
<libid>1</libid>
|
||||||
|
<id>603</id>
|
||||||
|
<kind>7</kind>
|
||||||
|
<userelative>0</userelative>
|
||||||
|
<isquestion>0</isquestion>
|
||||||
|
<useapplyto>-1</useapplyto>
|
||||||
|
<exetype>2</exetype>
|
||||||
|
<functionname></functionname>
|
||||||
|
<codestring></codestring>
|
||||||
|
<whoName>self</whoName>
|
||||||
|
<relative>0</relative>
|
||||||
|
<isnot>0</isnot>
|
||||||
|
<arguments>
|
||||||
|
<argument>
|
||||||
|
<kind>1</kind>
|
||||||
|
<string>selected_slot = 0;
|
||||||
|
|
||||||
|
move_slot = false;
|
||||||
|
selected_item = 0;
|
||||||
|
selected_total = 0;
|
||||||
|
</string>
|
||||||
|
</argument>
|
||||||
|
</arguments>
|
||||||
|
</action>
|
||||||
|
</event>
|
||||||
|
<event eventtype="3" enumb="0">
|
||||||
|
<action>
|
||||||
|
<libid>1</libid>
|
||||||
|
<id>603</id>
|
||||||
|
<kind>7</kind>
|
||||||
|
<userelative>0</userelative>
|
||||||
|
<isquestion>0</isquestion>
|
||||||
|
<useapplyto>-1</useapplyto>
|
||||||
|
<exetype>2</exetype>
|
||||||
|
<functionname></functionname>
|
||||||
|
<codestring></codestring>
|
||||||
|
<whoName>self</whoName>
|
||||||
|
<relative>0</relative>
|
||||||
|
<isnot>0</isnot>
|
||||||
|
<arguments>
|
||||||
|
<argument>
|
||||||
|
<kind>1</kind>
|
||||||
|
<string>x = view_xview[0]+view_wview[0]/2 - (424/2);
|
||||||
|
y = view_yview[0]+view_hview[0]/2 - (254/2) - 200;
|
||||||
|
|
||||||
|
|
||||||
|
var i = 0;
|
||||||
|
if((mouse_x >= x && mouse_x <= x+140) && (mouse_y >= y && mouse_y <= y+140))
|
||||||
|
{
|
||||||
|
for(yy = 8; yy < (5*44); yy+=45)
|
||||||
|
{
|
||||||
|
for(xx = 6; xx < (9*45); xx+=45+1)
|
||||||
|
{
|
||||||
|
if((mouse_x >= x+xx && mouse_x <= x+xx+45) && (mouse_y >= y+yy && mouse_y <= y+yy+45))
|
||||||
|
{
|
||||||
|
selected_slot = i;
|
||||||
|
}
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
</string>
|
||||||
|
</argument>
|
||||||
|
</arguments>
|
||||||
|
</action>
|
||||||
|
</event>
|
||||||
|
<event eventtype="6" enumb="4">
|
||||||
|
<action>
|
||||||
|
<libid>1</libid>
|
||||||
|
<id>603</id>
|
||||||
|
<kind>7</kind>
|
||||||
|
<userelative>0</userelative>
|
||||||
|
<isquestion>0</isquestion>
|
||||||
|
<useapplyto>-1</useapplyto>
|
||||||
|
<exetype>2</exetype>
|
||||||
|
<functionname></functionname>
|
||||||
|
<codestring></codestring>
|
||||||
|
<whoName>self</whoName>
|
||||||
|
<relative>0</relative>
|
||||||
|
<isnot>0</isnot>
|
||||||
|
<arguments>
|
||||||
|
<argument>
|
||||||
|
<kind>1</kind>
|
||||||
|
<string>if(!move_slot)
|
||||||
|
{
|
||||||
|
selected_item = obj_inv_controller.inventory[selected_slot];
|
||||||
|
if(selected_item == 0)
|
||||||
|
return false;
|
||||||
|
selected_total = obj_inv_controller.inventoryCount[selected_slot];
|
||||||
|
obj_inv_controller.inventory[selected_slot] = 0;
|
||||||
|
obj_inv_controller.inventoryCount[selected_slot] = 0;
|
||||||
|
move_slot = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if(obj_inv_controller.inventory[selected_slot] == 0)
|
||||||
|
{
|
||||||
|
|
||||||
|
obj_inv_controller.inventory[selected_slot] = selected_item;
|
||||||
|
obj_inv_controller.inventoryCount[selected_slot] = selected_total;
|
||||||
|
|
||||||
|
move_slot = false;
|
||||||
|
selected_item = 0;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</string>
|
||||||
|
</argument>
|
||||||
|
</arguments>
|
||||||
|
</action>
|
||||||
|
</event>
|
||||||
|
<event eventtype="8" enumb="0">
|
||||||
|
<action>
|
||||||
|
<libid>1</libid>
|
||||||
|
<id>603</id>
|
||||||
|
<kind>7</kind>
|
||||||
|
<userelative>0</userelative>
|
||||||
|
<isquestion>0</isquestion>
|
||||||
|
<useapplyto>-1</useapplyto>
|
||||||
|
<exetype>2</exetype>
|
||||||
|
<functionname></functionname>
|
||||||
|
<codestring></codestring>
|
||||||
|
<whoName>self</whoName>
|
||||||
|
<relative>0</relative>
|
||||||
|
<isnot>0</isnot>
|
||||||
|
<arguments>
|
||||||
|
<argument>
|
||||||
|
<kind>1</kind>
|
||||||
|
<string>draw_self();
|
||||||
|
var xx = 6;
|
||||||
|
var yy = 8;
|
||||||
|
var i = 0;
|
||||||
|
for(yy = 8; yy < (5*44); yy+=45)
|
||||||
|
{
|
||||||
|
for(xx = 6; xx < (9*45); xx+=45+1)
|
||||||
|
{
|
||||||
|
if(i == selected_slot)
|
||||||
|
{
|
||||||
|
draw_set_color(make_colour_rgb(100,100,100));
|
||||||
|
draw_rectangle(x+xx,y+yy,x+xx+45,y+yy+44,false)
|
||||||
|
}
|
||||||
|
|
||||||
|
draw_sprite(spr_blocks,obj_inv_controller.inventory[i],x+xx+6,y+yy+7);
|
||||||
|
var count = obj_inv_controller.inventoryCount[i];
|
||||||
|
|
||||||
|
var xoffset = string_width(string(count))
|
||||||
|
if(count > 1)
|
||||||
|
{
|
||||||
|
draw_set_color(c_white);
|
||||||
|
draw_text(x+xx+45-xoffset,y+yy+30,string(count));
|
||||||
|
}
|
||||||
|
i++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(selected_item != 0)
|
||||||
|
{
|
||||||
|
draw_sprite(spr_blocks,selected_item,mouse_x-(TILE_SIZE/2),mouse_y-(TILE_SIZE/2));
|
||||||
|
}
|
||||||
|
</string>
|
||||||
|
</argument>
|
||||||
|
</arguments>
|
||||||
|
</action>
|
||||||
|
</event>
|
||||||
|
</events>
|
||||||
|
<PhysicsObject>0</PhysicsObject>
|
||||||
|
<PhysicsObjectSensor>0</PhysicsObjectSensor>
|
||||||
|
<PhysicsObjectShape>0</PhysicsObjectShape>
|
||||||
|
<PhysicsObjectDensity>0.5</PhysicsObjectDensity>
|
||||||
|
<PhysicsObjectRestitution>0.100000001490116</PhysicsObjectRestitution>
|
||||||
|
<PhysicsObjectGroup>0</PhysicsObjectGroup>
|
||||||
|
<PhysicsObjectLinearDamping>0.100000001490116</PhysicsObjectLinearDamping>
|
||||||
|
<PhysicsObjectAngularDamping>0.100000001490116</PhysicsObjectAngularDamping>
|
||||||
|
<PhysicsObjectFriction>0.200000002980232</PhysicsObjectFriction>
|
||||||
|
<PhysicsObjectAwake>-1</PhysicsObjectAwake>
|
||||||
|
<PhysicsObjectKinematic>0</PhysicsObjectKinematic>
|
||||||
|
<PhysicsShapePoints/>
|
||||||
|
</object>
|
|
@ -30,6 +30,32 @@
|
||||||
move_slot = false;
|
move_slot = false;
|
||||||
selected_item = 0;
|
selected_item = 0;
|
||||||
selected_total = 0;
|
selected_total = 0;
|
||||||
|
|
||||||
|
crafting_menu = instance_create(0,0,obj_crafting);
|
||||||
|
|
||||||
|
</string>
|
||||||
|
</argument>
|
||||||
|
</arguments>
|
||||||
|
</action>
|
||||||
|
</event>
|
||||||
|
<event eventtype="1" enumb="0">
|
||||||
|
<action>
|
||||||
|
<libid>1</libid>
|
||||||
|
<id>603</id>
|
||||||
|
<kind>7</kind>
|
||||||
|
<userelative>0</userelative>
|
||||||
|
<isquestion>0</isquestion>
|
||||||
|
<useapplyto>-1</useapplyto>
|
||||||
|
<exetype>2</exetype>
|
||||||
|
<functionname></functionname>
|
||||||
|
<codestring></codestring>
|
||||||
|
<whoName>self</whoName>
|
||||||
|
<relative>0</relative>
|
||||||
|
<isnot>0</isnot>
|
||||||
|
<arguments>
|
||||||
|
<argument>
|
||||||
|
<kind>1</kind>
|
||||||
|
<string>instance_destroy(crafting_menu);
|
||||||
</string>
|
</string>
|
||||||
</argument>
|
</argument>
|
||||||
</arguments>
|
</arguments>
|
||||||
|
|
|
@ -258,40 +258,6 @@ if((mouse_check_button_pressed(mb_left) && os_type != os_psvita) || game
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
</string>
|
|
||||||
</argument>
|
|
||||||
</arguments>
|
|
||||||
</action>
|
|
||||||
</event>
|
|
||||||
<event eventtype="4" ename="obj_broken_ship">
|
|
||||||
<action>
|
|
||||||
<libid>1</libid>
|
|
||||||
<id>603</id>
|
|
||||||
<kind>7</kind>
|
|
||||||
<userelative>0</userelative>
|
|
||||||
<isquestion>0</isquestion>
|
|
||||||
<useapplyto>-1</useapplyto>
|
|
||||||
<exetype>2</exetype>
|
|
||||||
<functionname></functionname>
|
|
||||||
<codestring></codestring>
|
|
||||||
<whoName>self</whoName>
|
|
||||||
<relative>0</relative>
|
|
||||||
<isnot>0</isnot>
|
|
||||||
<arguments>
|
|
||||||
<argument>
|
|
||||||
<kind>1</kind>
|
|
||||||
<string>damage_player(5);
|
|
||||||
|
|
||||||
instance_create(other.x,other.y,obj_boom_fx);
|
|
||||||
other.direction = direction;
|
|
||||||
other.image_angle = image_angle;
|
|
||||||
other.speed = 20;
|
|
||||||
|
|
||||||
speed = -20;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</string>
|
</string>
|
||||||
</argument>
|
</argument>
|
||||||
</arguments>
|
</arguments>
|
||||||
|
@ -370,6 +336,40 @@ if(didAdd)
|
||||||
<argument>
|
<argument>
|
||||||
<kind>1</kind>
|
<kind>1</kind>
|
||||||
<string>damage_player(hp_max);
|
<string>damage_player(hp_max);
|
||||||
|
</string>
|
||||||
|
</argument>
|
||||||
|
</arguments>
|
||||||
|
</action>
|
||||||
|
</event>
|
||||||
|
<event eventtype="4" ename="obj_broken_ship">
|
||||||
|
<action>
|
||||||
|
<libid>1</libid>
|
||||||
|
<id>603</id>
|
||||||
|
<kind>7</kind>
|
||||||
|
<userelative>0</userelative>
|
||||||
|
<isquestion>0</isquestion>
|
||||||
|
<useapplyto>-1</useapplyto>
|
||||||
|
<exetype>2</exetype>
|
||||||
|
<functionname></functionname>
|
||||||
|
<codestring></codestring>
|
||||||
|
<whoName>self</whoName>
|
||||||
|
<relative>0</relative>
|
||||||
|
<isnot>0</isnot>
|
||||||
|
<arguments>
|
||||||
|
<argument>
|
||||||
|
<kind>1</kind>
|
||||||
|
<string>damage_player(5);
|
||||||
|
|
||||||
|
instance_create(other.x,other.y,obj_boom_fx);
|
||||||
|
other.direction = direction;
|
||||||
|
other.image_angle = image_angle;
|
||||||
|
other.speed = 20;
|
||||||
|
|
||||||
|
speed = -20;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</string>
|
</string>
|
||||||
</argument>
|
</argument>
|
||||||
</arguments>
|
</arguments>
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 327 B After Width: | Height: | Size: 346 B |
Reference in a new issue