CommitLog |
This commit is contained in:
parent
e74edd8841
commit
a9c35b6d6c
9 changed files with 128 additions and 60 deletions
|
@ -16,14 +16,13 @@
|
||||||
<sprite>sprites\spr_enemy</sprite>
|
<sprite>sprites\spr_enemy</sprite>
|
||||||
<sprite>sprites\spr_asteroid</sprite>
|
<sprite>sprites\spr_asteroid</sprite>
|
||||||
<sprite>sprites\spr_boom</sprite>
|
<sprite>sprites\spr_boom</sprite>
|
||||||
<sprite>sprites\spr_empty</sprite>
|
|
||||||
</sprites>
|
</sprites>
|
||||||
<backgrounds name="background">
|
<backgrounds name="background">
|
||||||
<background>background\bg_space</background>
|
<background>background\bg_space</background>
|
||||||
</backgrounds>
|
</backgrounds>
|
||||||
<paths name="paths"/>
|
<paths name="paths"/>
|
||||||
<scripts name="scripts">
|
<scripts name="scripts">
|
||||||
<script>scripts\generate_world.gml</script>
|
<script>scripts\load_chunk.gml</script>
|
||||||
</scripts>
|
</scripts>
|
||||||
<objects name="objects">
|
<objects name="objects">
|
||||||
<object>objects\obj_player</object>
|
<object>objects\obj_player</object>
|
||||||
|
@ -31,7 +30,6 @@
|
||||||
<object>objects\obj_controller</object>
|
<object>objects\obj_controller</object>
|
||||||
<object>objects\obj_bullet</object>
|
<object>objects\obj_bullet</object>
|
||||||
<object>objects\obj_asteriod</object>
|
<object>objects\obj_asteriod</object>
|
||||||
<object>objects\obj_air</object>
|
|
||||||
</objects>
|
</objects>
|
||||||
<rooms name="rooms">
|
<rooms name="rooms">
|
||||||
<room>rooms\rm_game</room>
|
<room>rooms\rm_game</room>
|
||||||
|
|
|
@ -1,23 +0,0 @@
|
||||||
<!--This Document is generated by GameMaker, if you edit it by hand then you do so at your own risk!-->
|
|
||||||
<object>
|
|
||||||
<spriteName>spr_empty</spriteName>
|
|
||||||
<solid>0</solid>
|
|
||||||
<visible>-1</visible>
|
|
||||||
<depth>0</depth>
|
|
||||||
<persistent>0</persistent>
|
|
||||||
<parentName><undefined></parentName>
|
|
||||||
<maskName><undefined></maskName>
|
|
||||||
<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>
|
|
|
@ -48,7 +48,43 @@
|
||||||
<arguments>
|
<arguments>
|
||||||
<argument>
|
<argument>
|
||||||
<kind>1</kind>
|
<kind>1</kind>
|
||||||
<string>step_counter++;
|
<string>/// Every Frame Global Code.
|
||||||
|
step_counter++;
|
||||||
|
</string>
|
||||||
|
</argument>
|
||||||
|
</arguments>
|
||||||
|
</action>
|
||||||
|
</event>
|
||||||
|
<event eventtype="8" enumb="64">
|
||||||
|
<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 Debug Screen
|
||||||
|
|
||||||
|
var chunkRelX = obj_player.x % 256
|
||||||
|
var chunkRelY = obj_player.y % 256
|
||||||
|
|
||||||
|
var chunkX = (obj_player.x - chunkRelX) / 256,;
|
||||||
|
var chunkY = (obj_player.y - chunkRelY) / 256;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
draw_text(10,10,"X: "+string(obj_player.x)+"#Y: "+string(obj_player.y));
|
||||||
|
draw_text(10,40,"CrX: "+string(chunkRelX)+"#CrY: "+string(chunkRelY));
|
||||||
|
draw_text(10,70,"CX: "+string(chunkX)+"#CY: "+string(chunkY));
|
||||||
</string>
|
</string>
|
||||||
</argument>
|
</argument>
|
||||||
</arguments>
|
</arguments>
|
||||||
|
@ -71,7 +107,8 @@
|
||||||
<arguments>
|
<arguments>
|
||||||
<argument>
|
<argument>
|
||||||
<kind>1</kind>
|
<kind>1</kind>
|
||||||
<string>if(window_get_fullscreen())
|
<string>/// Set fullscreen
|
||||||
|
if(window_get_fullscreen())
|
||||||
{
|
{
|
||||||
window_set_fullscreen(0);
|
window_set_fullscreen(0);
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,10 @@
|
||||||
<arguments>
|
<arguments>
|
||||||
<argument>
|
<argument>
|
||||||
<kind>1</kind>
|
<kind>1</kind>
|
||||||
<string></string>
|
<string>loaded_chunks[64] = 0;
|
||||||
|
//load_chunk(0,0);
|
||||||
|
|
||||||
|
</string>
|
||||||
</argument>
|
</argument>
|
||||||
</arguments>
|
</arguments>
|
||||||
</action>
|
</action>
|
||||||
|
@ -47,7 +50,15 @@
|
||||||
<arguments>
|
<arguments>
|
||||||
<argument>
|
<argument>
|
||||||
<kind>1</kind>
|
<kind>1</kind>
|
||||||
<string>generate_world();
|
<string>var chunkRelX = obj_player.x % 256
|
||||||
|
var chunkRelY = obj_player.y % 256
|
||||||
|
|
||||||
|
var chunkX = (obj_player.x - chunkRelX) / 256,;
|
||||||
|
var chunkY = (obj_player.y - chunkRelY) / 256;
|
||||||
|
|
||||||
|
if(loaded_chunks[0] == 0)
|
||||||
|
loaded_chunks[0] = load_chunk(chunkX,chunkY);
|
||||||
|
|
||||||
</string>
|
</string>
|
||||||
</argument>
|
</argument>
|
||||||
</arguments>
|
</arguments>
|
||||||
|
|
|
@ -25,8 +25,10 @@
|
||||||
<arguments>
|
<arguments>
|
||||||
<argument>
|
<argument>
|
||||||
<kind>1</kind>
|
<kind>1</kind>
|
||||||
<string>image_speed = 0;
|
<string>/// Player creation code.
|
||||||
|
image_speed = 0;
|
||||||
image_index = 1;
|
image_index = 1;
|
||||||
|
|
||||||
</string>
|
</string>
|
||||||
</argument>
|
</argument>
|
||||||
</arguments>
|
</arguments>
|
||||||
|
@ -49,7 +51,8 @@ image_index = 1;
|
||||||
<arguments>
|
<arguments>
|
||||||
<argument>
|
<argument>
|
||||||
<kind>1</kind>
|
<kind>1</kind>
|
||||||
<string>direction = image_angle
|
<string>/// Player per frame
|
||||||
|
direction = image_angle
|
||||||
if(speed > 0)
|
if(speed > 0)
|
||||||
speed -= 1
|
speed -= 1
|
||||||
|
|
||||||
|
@ -58,6 +61,7 @@ if(speed > 20)
|
||||||
|
|
||||||
view_xview[0] = x - view_wview[0]/2;
|
view_xview[0] = x - view_wview[0]/2;
|
||||||
view_yview[0] = y - view_hview[0]/2;
|
view_yview[0] = y - view_hview[0]/2;
|
||||||
|
|
||||||
</string>
|
</string>
|
||||||
</argument>
|
</argument>
|
||||||
</arguments>
|
</arguments>
|
||||||
|
|
20
scripts/generate_chunk.gml
Normal file
20
scripts/generate_chunk.gml
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
///generate_chunk()
|
||||||
|
|
||||||
|
var chunk_grid = ds_grid_create(128,128);
|
||||||
|
|
||||||
|
for(var xx = 0; xx < 128; xx++)
|
||||||
|
{
|
||||||
|
for(var yy = 0; yy < 128; yy++)
|
||||||
|
{
|
||||||
|
if(random_range(0,10) > 5)
|
||||||
|
{
|
||||||
|
chunk_grid = obj_asteriod;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
chunk_grid = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,9 +17,7 @@ for(var xx = startx; xx < xmax; xx+=32)
|
||||||
{
|
{
|
||||||
for(var yy = starty; yy < ymax;yy+=32)
|
for(var yy = starty; yy < ymax;yy+=32)
|
||||||
{
|
{
|
||||||
|
if(place_empty(xx,yy))
|
||||||
|
|
||||||
if(!place_free(xx,yy))
|
|
||||||
{
|
{
|
||||||
instance_create(xx,yy,obj_air);
|
instance_create(xx,yy,obj_air);
|
||||||
|
|
||||||
|
|
48
scripts/load_chunk.gml
Normal file
48
scripts/load_chunk.gml
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
///load_chunk(cx,cy);
|
||||||
|
|
||||||
|
var cx = argument0
|
||||||
|
var cy = argument1
|
||||||
|
|
||||||
|
var chunk_grid = ds_grid_create(256,256);
|
||||||
|
var filename = string(cx)+","+string(cy)+".spr";
|
||||||
|
if(file_exists(filename)) // Load Chunk
|
||||||
|
{
|
||||||
|
ini_open(filename);
|
||||||
|
for(var xx = 0; xx < 256; xx++)
|
||||||
|
{
|
||||||
|
for(var yy = 0; yy < 256; yy++)
|
||||||
|
{
|
||||||
|
var nm = string(xx)+string(yy);
|
||||||
|
var c = ini_read_real("XYV",nm,0);
|
||||||
|
chunk_grid[xx,yy] = c;
|
||||||
|
if(c != 0)
|
||||||
|
instance_create(xx,yy,c);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ini_close();
|
||||||
|
}
|
||||||
|
else // Generate Chunk
|
||||||
|
{
|
||||||
|
ini_open(filename);
|
||||||
|
for(var xx = 0; xx < 256; xx++)
|
||||||
|
{
|
||||||
|
for(var yy = 0; yy < 256; yy++)
|
||||||
|
{
|
||||||
|
var nm = string(xx)+string(yy);
|
||||||
|
if(random_range(0,10) > 5)
|
||||||
|
{
|
||||||
|
ini_write_real("XYV",nm,obj_asteriod);
|
||||||
|
chunk_grid[xx,yy] = obj_asteriod;
|
||||||
|
instance_create(cx+xx,cy+yy,obj_asteriod);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ini_write_real("XYV",nm,0);;
|
||||||
|
chunk_grid[xx,yy] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ini_close();
|
||||||
|
}
|
||||||
|
return chunk_grid;
|
||||||
|
|
|
@ -1,25 +0,0 @@
|
||||||
<!--This Document is generated by GameMaker, if you edit it by hand then you do so at your own risk!-->
|
|
||||||
<sprite>
|
|
||||||
<type>0</type>
|
|
||||||
<xorig>0</xorig>
|
|
||||||
<yorigin>0</yorigin>
|
|
||||||
<colkind>0</colkind>
|
|
||||||
<coltolerance>0</coltolerance>
|
|
||||||
<sepmasks>-1</sepmasks>
|
|
||||||
<bboxmode>1</bboxmode>
|
|
||||||
<bbox_left>0</bbox_left>
|
|
||||||
<bbox_right>31</bbox_right>
|
|
||||||
<bbox_top>0</bbox_top>
|
|
||||||
<bbox_bottom>31</bbox_bottom>
|
|
||||||
<HTile>0</HTile>
|
|
||||||
<VTile>0</VTile>
|
|
||||||
<TextureGroups>
|
|
||||||
<TextureGroup0>0</TextureGroup0>
|
|
||||||
</TextureGroups>
|
|
||||||
<For3D>0</For3D>
|
|
||||||
<width>32</width>
|
|
||||||
<height>32</height>
|
|
||||||
<frames>
|
|
||||||
<frame index="0">images\spr_empty_0.png</frame>
|
|
||||||
</frames>
|
|
||||||
</sprite>
|
|
Reference in a new issue