Hard at work with the polygons, pixels, and programs. Introducing the cast:
You'll get names later.
Saturday, November 30, 2013
Tuesday, October 22, 2013
Actors
Lots of progress made... First up, basic actors.
For now, I just have a basic soul actor, a floating orb:
The soul actor also has a lightning attack:
Every actor has a path they walk:
So battle routines exist now, and the game controller vibrates a little when the player is hit, or when they player hits something.
However, I'm not entirely happy with the feedback and sounds associated with the battle routines.
This is an area where the player will be spending a lot of time, so it has to be perfect.
//ThGrk
For now, I just have a basic soul actor, a floating orb:
The soul actor also has a lightning attack:
Every actor has a path they walk:
So battle routines exist now, and the game controller vibrates a little when the player is hit, or when they player hits something.
However, I'm not entirely happy with the feedback and sounds associated with the battle routines.
This is an area where the player will be spending a lot of time, so it has to be perfect.
//ThGrk
Thursday, October 17, 2013
Editor Upgrade & Input
Work has been done to the level editor.
I've expanded it to include up to 72 buttons, and I added in a properties window that implements an input component that accepts keyboard input.
This allows me to change things for the levels in the editor, without having to manually change the level code.
This way, the editor handles all the code formatting for me, which reduces the work I have to do as well as the possibility of errors.
Here is a shot of the editor's new layout:
Here is a shot of a level's properties window:
The property window was required before destinations could be added, which must be written before actors can use them to traverse levels.
//ThGrk
I've expanded it to include up to 72 buttons, and I added in a properties window that implements an input component that accepts keyboard input.
This allows me to change things for the levels in the editor, without having to manually change the level code.
This way, the editor handles all the code formatting for me, which reduces the work I have to do as well as the possibility of errors.
Here is a shot of the editor's new layout:
Here is a shot of a level's properties window:
The property window was required before destinations could be added, which must be written before actors can use them to traverse levels.
//ThGrk
Tuesday, October 15, 2013
Level Editor - level up!
I just completed modifying the level editor so that I can create level faster. Much faster.
Here are 3 levels that I've completed in the last 3 hours, some were built from scratch, others were modified from existing level data:
The level editor held up quite well creating these levels.
Now I'm on to a very exciting part of the game - enemies, the battle system, and the fx manager.
//TheGrak
Here are 3 levels that I've completed in the last 3 hours, some were built from scratch, others were modified from existing level data:
The level editor held up quite well creating these levels.
Now I'm on to a very exciting part of the game - enemies, the battle system, and the fx manager.
//TheGrak
Sunday, October 13, 2013
Complex Housing
I also wanted to share a shot of how the level manager handles more complex housing structures.
For example:
For example:
Level Manager
Today I completed the cleaning and polishing routines for the level manager.
The level manager is in it's infancy now, but basically it's a class that - among many things - creates transition tiles and buildings from level data.
The transition tiles are the tiles between different land tiles that help to mask the tile grid.
The buildings include the building walls and ceilings, which are constructed from floor tiles.
So, I need only to provide basic land tiles and floor tiles (with doors for buildings), and the level generator takes care of the rest.
This also allows me to save levels in a 'compressed' format, and let the level manager 'decompress' the levels using the polishing routines.
I don't necessarily 'need' to save the levels in a compressed format, but I may do so just to get over a pesky xbox 360 bug with lists longer than 9000 items.
Here is an example of a compressed or barebones level:
Here is what that level looks like decompressed:
It's a difference of about a 1,000 sprites: compressed @5k, decompressed @6k.
Game objects have an ID now, so they can be grouped together and used in different ways.
For example, ceilings are grouped according to building now, so players only see into the building they occupy:
I'm really excited about the separation of polishing and cleaning a level from generating a level, because that means I only need to write routines to generate bare bones levels, then I can pass the bare bones level to the polishing routines.
//Grak
The level manager is in it's infancy now, but basically it's a class that - among many things - creates transition tiles and buildings from level data.
The transition tiles are the tiles between different land tiles that help to mask the tile grid.
The buildings include the building walls and ceilings, which are constructed from floor tiles.
So, I need only to provide basic land tiles and floor tiles (with doors for buildings), and the level generator takes care of the rest.
This also allows me to save levels in a 'compressed' format, and let the level manager 'decompress' the levels using the polishing routines.
I don't necessarily 'need' to save the levels in a compressed format, but I may do so just to get over a pesky xbox 360 bug with lists longer than 9000 items.
Here is an example of a compressed or barebones level:
Here is what that level looks like decompressed:
It's a difference of about a 1,000 sprites: compressed @5k, decompressed @6k.
Game objects have an ID now, so they can be grouped together and used in different ways.
For example, ceilings are grouped according to building now, so players only see into the building they occupy:
I'm really excited about the separation of polishing and cleaning a level from generating a level, because that means I only need to write routines to generate bare bones levels, then I can pass the bare bones level to the polishing routines.
//Grak
Saturday, October 12, 2013
Technical Success
Lots of technical advances in the last few days.
I started working on the building constructor, which will create buildings and destroyed buildings based on floor tiles.
Right now it removes duplicate floor tiles, and randomizes them.
The building sheet has also been planned out - there can be 14 different building types. I need 5.
Then I faced a challenge dealing with the tearing of tiled sprites, mentioned here.
I think I have resolved it, but we will have to check on others machines.
Then I changed one single line of code and the levels became persistent in RAM.
This is pretty cool, because you could destroy part of a town, leave for resources, then come back to find the townfolk repairing the damage.
So I stress tested it and put 55 persistent levels into RAM all at once. RAM is around 250mb.
I also figured out to simulate an actor of the game persistently in memory, so there could be autonomous NPCs roaming around causing events.
Then I transferred everything to the xbox 360 and watched as the code thrashed with the garbage collector, pausing the game noticeably every second or so.
In return I refactored several hundred lines to not create garbage. It's pretty easy if you subscribe to the simple rule of: do not create new instances outside of a field, or constructor/load method.
Then I battled with arrays and lists, and became aware of the difference between array.Count() and list.Count.
One is a slowish method, which returns a value. The other is a value of a list.
If you use .Count() in a loop, you can expect that loop to be very slow, because it's calling a slowish method every. single. time. through the loop.
Not realizing this, I spent a few hours with my game on my xbox 360 narrowing down what was blowing up the update and draw loops.
I ironed out several hundred more lines of code, switching from lists to arrays, then back to lists, then back to arrays.
After you code and recode a particular section 5 or 6 times, you start to get a feel for what works there.
The final touch was adding ceilings back into the buildings, which was slowing the xbox down terribly.
This newer routine is much faster, and the next step is to add and ID to each game object so I can group them.
Then only grouped ceiling tiles will become transparent, which means the player will only be able to see into the building they occupy.
I also reworked the zdepth sorting to allow for more specific layers, for example there are layers for clouds and atmospheric effects now.
So, not really any visual updates to show, but lots of fine tuning of the engine behind the scenes.
Here's a new screenshot!
I started working on the building constructor, which will create buildings and destroyed buildings based on floor tiles.
Right now it removes duplicate floor tiles, and randomizes them.
The building sheet has also been planned out - there can be 14 different building types. I need 5.
Then I faced a challenge dealing with the tearing of tiled sprites, mentioned here.
I think I have resolved it, but we will have to check on others machines.
Then I changed one single line of code and the levels became persistent in RAM.
This is pretty cool, because you could destroy part of a town, leave for resources, then come back to find the townfolk repairing the damage.
So I stress tested it and put 55 persistent levels into RAM all at once. RAM is around 250mb.
I also figured out to simulate an actor of the game persistently in memory, so there could be autonomous NPCs roaming around causing events.
Then I transferred everything to the xbox 360 and watched as the code thrashed with the garbage collector, pausing the game noticeably every second or so.
In return I refactored several hundred lines to not create garbage. It's pretty easy if you subscribe to the simple rule of: do not create new instances outside of a field, or constructor/load method.
Then I battled with arrays and lists, and became aware of the difference between array.Count() and list.Count.
One is a slowish method, which returns a value. The other is a value of a list.
If you use .Count() in a loop, you can expect that loop to be very slow, because it's calling a slowish method every. single. time. through the loop.
Not realizing this, I spent a few hours with my game on my xbox 360 narrowing down what was blowing up the update and draw loops.
I ironed out several hundred more lines of code, switching from lists to arrays, then back to lists, then back to arrays.
After you code and recode a particular section 5 or 6 times, you start to get a feel for what works there.
The final touch was adding ceilings back into the buildings, which was slowing the xbox down terribly.
This newer routine is much faster, and the next step is to add and ID to each game object so I can group them.
Then only grouped ceiling tiles will become transparent, which means the player will only be able to see into the building they occupy.
I also reworked the zdepth sorting to allow for more specific layers, for example there are layers for clouds and atmospheric effects now.
So, not really any visual updates to show, but lots of fine tuning of the engine behind the scenes.
Here's a new screenshot!
Wednesday, October 9, 2013
Editor and Building Work
Lots of progress.
First up, I switched out the main menu screen, so it looks a little nicer.
Then I added in buildings. But not just buildings, I added in destroyed buildings as well.
Buildings can be blown up partially, or completely. Specifically, walls can be blown up.
When a standing building collapses, the ceiling collapses as well, creating additional debris (not shown):
Ceilings automatically become transparent when you enter a building:
Finally, I worked on the editor a lot. I did many things, but one important thing I did was to add a shortcut to zoom out for a nice level screen shot:
You can also see the editor main menu items in the above screenshot. Glad I finally figured out what the main menu of the editor needs to be.
Now I can start filling in the missing sections and working towards a 'complete level'.
I also dissected how much RAM the game is currently using, and set estimates/projections on how much RAM the game will use when operating at peak.
Everything is within expectations, and the game should never dip below 60 fps.
Very soon I hope to have enemy and ally actors in the game, giving the player something to interact with.
I've also defined what the game's "Demo" is, which has helped me to put the game's main storyline in a better perspective.
The Demo will be free, the Game will cost a few dollars (less than $10) and be available for xbox 360 and PC, thru Steam.
I'm planning to use the Steam Greenlight feature, and publish on the xbox via the Xna Creator's Club.
Depending on how Xbox One and PS4 handle Indie development, I may port to those consoles.
However, after becoming familiar with the limitations of the xbox 360, I would probably prefer to scale the game up to match next-gen hardware.
We'll see where the road paved with good intentions takes us.
//Grak
First up, I switched out the main menu screen, so it looks a little nicer.
Then I added in buildings. But not just buildings, I added in destroyed buildings as well.
Buildings can be blown up partially, or completely. Specifically, walls can be blown up.
When a standing building collapses, the ceiling collapses as well, creating additional debris (not shown):
Ceilings automatically become transparent when you enter a building:
Finally, I worked on the editor a lot. I did many things, but one important thing I did was to add a shortcut to zoom out for a nice level screen shot:
You can also see the editor main menu items in the above screenshot. Glad I finally figured out what the main menu of the editor needs to be.
Now I can start filling in the missing sections and working towards a 'complete level'.
I also dissected how much RAM the game is currently using, and set estimates/projections on how much RAM the game will use when operating at peak.
Everything is within expectations, and the game should never dip below 60 fps.
Very soon I hope to have enemy and ally actors in the game, giving the player something to interact with.
I've also defined what the game's "Demo" is, which has helped me to put the game's main storyline in a better perspective.
The Demo will be free, the Game will cost a few dollars (less than $10) and be available for xbox 360 and PC, thru Steam.
I'm planning to use the Steam Greenlight feature, and publish on the xbox via the Xna Creator's Club.
Depending on how Xbox One and PS4 handle Indie development, I may port to those consoles.
However, after becoming familiar with the limitations of the xbox 360, I would probably prefer to scale the game up to match next-gen hardware.
We'll see where the road paved with good intentions takes us.
//Grak
Sunday, October 6, 2013
Lots of Progress
I've been very productive.
I've linked up levels through exit events, so players can travel from level to level - in many different ways.
When the player hits the edge of a map, a level will load. When a player enters a door, a level will load, etc...
I also added a fade in/out to make level loading less 'jumpy'.
Then I added in around 10-15 new game objects, ranging from bones to flowers to cacti, then placed them across several levels.
The game also features a non-blocking popup, that can display information such as which level was just loaded.
This popup does not interfere with any player input and operates on a timer, so the popup goes away automatically after a few seconds.
I'm going to revisit the dialog/window designs I've done so far because I'm not happy with them.
I added in destinations to levels, and support for creating/handling destinations in the editor.
Destinations are essentially positions in the level that can be used as nodes to traverse the level.
Algorithms such as A* can operate on this list of positions, figuring out which destinations to take to arrive at a location.
Destinations basically allow actors in the game to move around the level.
Up next is designing the building sheet, which will allow for the existence of entire towns and cities in the game.
And since I plan on making the building objects in a similar fashion to the game objects, there isn't really a reason why a building object couldn't collapse into a debris object, which would allow for the destruction of entire buildings/towns.
Here are some recent screenshots (I've taken to hiding the UI for now):
Can't wait to get some enemies in there and start figuring out the battle system/mechanics/gameplay!
I've linked up levels through exit events, so players can travel from level to level - in many different ways.
When the player hits the edge of a map, a level will load. When a player enters a door, a level will load, etc...
I also added a fade in/out to make level loading less 'jumpy'.
Then I added in around 10-15 new game objects, ranging from bones to flowers to cacti, then placed them across several levels.
The game also features a non-blocking popup, that can display information such as which level was just loaded.
This popup does not interfere with any player input and operates on a timer, so the popup goes away automatically after a few seconds.
I'm going to revisit the dialog/window designs I've done so far because I'm not happy with them.
I added in destinations to levels, and support for creating/handling destinations in the editor.
Destinations are essentially positions in the level that can be used as nodes to traverse the level.
Algorithms such as A* can operate on this list of positions, figuring out which destinations to take to arrive at a location.
Destinations basically allow actors in the game to move around the level.
Up next is designing the building sheet, which will allow for the existence of entire towns and cities in the game.
And since I plan on making the building objects in a similar fashion to the game objects, there isn't really a reason why a building object couldn't collapse into a debris object, which would allow for the destruction of entire buildings/towns.
Here are some recent screenshots (I've taken to hiding the UI for now):
Can't wait to get some enemies in there and start figuring out the battle system/mechanics/gameplay!
Wednesday, October 2, 2013
An installer that works
Theorem can be "installed" on a PC now. But it doesn't have to be. So to make things easy for testers, I'm going to release builds localized to a folder.
If you have the .Net 4.0 framework and XNA 4.0 framework installed, then you can run the game.
This separates the downloads into 3 items, with the only item containing updates being sized at 51mb. The full install is 101mb, but it doesn't make any sense to me to force a user to download 101mb every time there is an update to the game, when the total game is 51mb.
Now I can work on the really exciting part - adding trees, trunks, stumps, and move environment game objects to the levels.
If you have the .Net 4.0 framework and XNA 4.0 framework installed, then you can run the game.
This separates the downloads into 3 items, with the only item containing updates being sized at 51mb. The full install is 101mb, but it doesn't make any sense to me to force a user to download 101mb every time there is an update to the game, when the total game is 51mb.
Now I can work on the really exciting part - adding trees, trunks, stumps, and move environment game objects to the levels.
Tuesday, October 1, 2013
Levels and More Editor work
Levels are linked up and load very quickly.
The maximum level size is around 9000 tiles, which is due to an issue with the xbox loading a list larger than 9000 items.
I'm not sure if that is a fixable bug, but for now I'm just working around it.
I also completed some algorithms that complete building the transition tiles between dirt and other ground tiles, like grass and desert.
Essentially these algorithms create and place the diagonal, corner, and straight pieces around basic land tiles.
These algorithms reduce my amount of work to simply creating basic tiles over dirt tiles.
These algorithms also remove any duplicate tiles, allowing me to be very sloppy in the way in which I add tiles.
These routines basically cleanup and sanitize the level data before the level data is written to disk.
I also randomized the final placement of the collapsed bushes. I will need to create bush stumps now, so they should be missing in build 1.0.0.1.
I've got a bunch of game objects to be added next, so the environments should start looking more filled out.
Sunday, September 29, 2013
Alpha Release Build v1.0
Just finished adding in routines to control the destruction of bushes, so the player can attack the bushes and leaves will fall down.
Will probably refine falling leaf animation later.
Added in basic game sounds, a placeholder title theme, and a placeholder level song.
Removed the XML level definitions, now the editor just writes .CS file level definitions.
This reduced the amount of work, and the XML definitions were never really necessary.
Built a quick webpage for the game. Published the game with all the dependent libraries packaged into a single archive.
Posted said archive to said webpage to share with collaborative parties.
Posted the new Theorem logo to youTube:
Lots done, lots to do.
Will probably refine falling leaf animation later.
Added in basic game sounds, a placeholder title theme, and a placeholder level song.
Removed the XML level definitions, now the editor just writes .CS file level definitions.
This reduced the amount of work, and the XML definitions were never really necessary.
Built a quick webpage for the game. Published the game with all the dependent libraries packaged into a single archive.
Posted said archive to said webpage to share with collaborative parties.
Posted the new Theorem logo to youTube:
Lots done, lots to do.
Tuesday, September 24, 2013
Another long night
Some days are more productive than others.
Today was very productive:
I completed the zdepth sorting routines for player and game objects. This is based solely upon the Y position of the object. The player sorting routine is a simple example:
//Constantly sort player based on Y position
int zInt = (int)TheGame.Player1.Position.Y;
float zMinus = zInt * 0.000001f;
TheGame.Player1.zDepth = (0.899998f - zMinus);
0.899998f is the lowest layer that a game object can be drawn on. Below that are the ground tiles at 0.899999f and the dirt tiles at 0.9f. Everything is drawn ontop of these tiles, at a value less than 0.899998f.
I also completed integrating game objects into the level manager and the level class definition. I packed the environment game objects into the bkg sheet, which also contains the bkg tiles (grass, water, desert, dirt, etc...). There is still alot of space left, so I may not need an environment sheet at all.
I also recalculated the size of a 2k XNB (xbox binary file) to be about 16.5mb in memory. Before, I was working off the assumption that the XNB was about 23mb. This means I can load more textures into memory, and everything in the game is created from textures, so that means more enemies, allies, etc...
I also read alot about Hermeticism today, specifically about 40 pages from the Kybalion regarding Hermetic Axioms and Principles. These will be translated into dialog between characters and the player, deeply integrated into the story.
I was also refreshing myself on the 3 act story/screenplay structure, and considering rewriting the game's plot around this structure. However, I'm not exactly sure how to resolve the linear nature of the 3 act screenplay with the non-linear nature of the game. My initial thought regarding this is to keep act 1 and act 3 linear, while allowing many act 2s to exist in between. The player would always experience act 1 the same, but entering into act 2 the player can choose which town to visit, which dungeon, etc.. Act 2 is essentially free roam, but builds towards Act 3, in which the hero confronts the antagonist in climatic battle. I assume that once Act3 ends the player is left to free roam about the continent to discover it's secrets, etc...
I started the day awaking from a dream in which I witnessed a dark and foreboding storm form on the horizon. A man stood next to me, witnessing it too. I was silent in fear of the unknown storm approaching. He screamed out in pure terror and began to claw away the skin on his face. This chilling visual will certainly make it into a cinematic. The foreshadowing clouds are a nice motif as well.
Here is a screen shot showing game objects properly sorted with respect to the player:
Sidenote: this is the first screenshot of the actual game to make it onto the internets. More to come. Critical mass is approaching...
Today was very productive:
I completed the zdepth sorting routines for player and game objects. This is based solely upon the Y position of the object. The player sorting routine is a simple example:
//Constantly sort player based on Y position
int zInt = (int)TheGame.Player1.Position.Y;
float zMinus = zInt * 0.000001f;
TheGame.Player1.zDepth = (0.899998f - zMinus);
0.899998f is the lowest layer that a game object can be drawn on. Below that are the ground tiles at 0.899999f and the dirt tiles at 0.9f. Everything is drawn ontop of these tiles, at a value less than 0.899998f.
I also completed integrating game objects into the level manager and the level class definition. I packed the environment game objects into the bkg sheet, which also contains the bkg tiles (grass, water, desert, dirt, etc...). There is still alot of space left, so I may not need an environment sheet at all.
I also recalculated the size of a 2k XNB (xbox binary file) to be about 16.5mb in memory. Before, I was working off the assumption that the XNB was about 23mb. This means I can load more textures into memory, and everything in the game is created from textures, so that means more enemies, allies, etc...
I also read alot about Hermeticism today, specifically about 40 pages from the Kybalion regarding Hermetic Axioms and Principles. These will be translated into dialog between characters and the player, deeply integrated into the story.
I was also refreshing myself on the 3 act story/screenplay structure, and considering rewriting the game's plot around this structure. However, I'm not exactly sure how to resolve the linear nature of the 3 act screenplay with the non-linear nature of the game. My initial thought regarding this is to keep act 1 and act 3 linear, while allowing many act 2s to exist in between. The player would always experience act 1 the same, but entering into act 2 the player can choose which town to visit, which dungeon, etc.. Act 2 is essentially free roam, but builds towards Act 3, in which the hero confronts the antagonist in climatic battle. I assume that once Act3 ends the player is left to free roam about the continent to discover it's secrets, etc...
I started the day awaking from a dream in which I witnessed a dark and foreboding storm form on the horizon. A man stood next to me, witnessing it too. I was silent in fear of the unknown storm approaching. He screamed out in pure terror and began to claw away the skin on his face. This chilling visual will certainly make it into a cinematic. The foreshadowing clouds are a nice motif as well.
Here is a screen shot showing game objects properly sorted with respect to the player:
Sidenote: this is the first screenshot of the actual game to make it onto the internets. More to come. Critical mass is approaching...
Sunday, September 22, 2013
Theorem exists.
Today I begin a blog about the development of a game I am working on, titled 'Theorem'.
The game combines aspects of many other games that I have played, like Zelda 1&3 (LttP), and Final Fantasy 7.
It's 2D, top-down, tile & sprite based. Here is a screenshot to give you an idea about the visual style:
I'll have a page on my website up pretty soon with an alpha build of the game available for download. (PC only, for now).
The game combines aspects of many other games that I have played, like Zelda 1&3 (LttP), and Final Fantasy 7.
It's 2D, top-down, tile & sprite based. Here is a screenshot to give you an idea about the visual style:
I'll have a page on my website up pretty soon with an alpha build of the game available for download. (PC only, for now).
Subscribe to:
Posts (Atom)