My name is Steve and I'm a part time game developer with a passion for tactical, turn based RPG's in a modern setting. This blog is about my experiences in overcoming many of the obstacles in pursuit of creating my first game for the pc and mac.
Saturday, December 15, 2012
Sticking with Blitzmax
In my last blog I talked about GameMaker and was thinking of switching to it. The only reason being is because making a game in GM allowed it to be packaged and exported to other platforms such, mainly IOs and Android. I have very little interest in Android, personally I love it and use it but there are different versions out there, different screen sizes, who needs it. That leaves the all empowering ipad. It's tempting but is it worth it?
I did some reading on what people thought of GM. Yes, it's been around forever no doubt. I read some of the reference manual to learn about GML (the scripting language it uses). The language seems pretty powerful and can probably do a lot of things that Blitzmax can do as well. I have no doubt GM can make great platform type games in a short amount of time as well as other genre's.
Then I started to get that feeling again. A long time ago I was trying to make a game using Torque2D. Same premise, it's a 2D engine that *can* be used to make any type of game you wanted. Even when I had a full handle on T2D and knew a lot about how it worked, it was a struggle to get things to work how I wanted. There were a lot of hurdles and it became exhausting after a while.
When I imported a bunch of sprites sheets into the editor, the editor memory usage spiked up to over a gig then crashed. This was a huge, huge problem. I talked to one of the dev's about it, it was kind of a bug or at the very least a shortcoming of the product. He emailed me a fix, which worked well but not great. I was able to bring in all the sprites without crashing but the editor slowed considerable. Clearly. T2D wasn't design for large levels and hundreds of sprites.
They released an update with a bunch of bug fixes and enhancements but to my surprise the unofficial patch that I received wasn't part of it so the memory problem happened all over again. Now don't get me wrong, T2D is a fine product if you are making a game on a smaller scale but it just wasn't suited to what I needed to do.
Now back to GameMaker. I'm sure it's a fine product but there are limitations. I read it has slow loading times and such would be a real pain to work with. I can see trying to get past coding hurdles just to make things work the way they should. I can see running into even more problems when I have lots of levels with lots of sprites. And for what? Just so I can sell my game on the Ipad?
So yea I'm over it. I also have to kick myself another kick in the ass to stop doing this to myself. There are a million products out there, all of them are good but the crucial point is if it's a right fit for what you are doing. I'm sticking with Blitzmax and my goal for 2013 is to make a damn good old school RPG!
Saturday, December 8, 2012
Toying with Switching to Game Maker Studio
Game Maker, I've known about it for a while but never paid it much mind. Game Maker was featured in one of the articles and what caught my eye is it can build a game on IOs and Android as well as PC and Mac. Hmmm. I know for a fact that Blitz will never have that capability ever. A few weeks ago I was reading up on XCode and just thinking to myself if I ever made a few games would I want to port it to the ipad? I would have to learn XCode which will require a lot of time and effort. For someone that isn't doing this full time and won't be doing this full time for a long time to come, if ever, it probably won't be worth it.
I know the developers of Blitz made a new product called Monkey but hear the syntax is horrible and overall it doesn't really interest me. On the other hand working with Game Maker will be confined to an editor of someone else's making. I'm adamant on not going with Unity, it's 3D orientated and I know I'll have to jump through a lot of hoops to get things to work for me. Using Blitzmax is still a viable option but it doesn't afford me to make a game past the pc and mac.
I'm probably going to do more research and maybe spend some time learning GM to see if it can do what I need. The prospect of making a game for traditional platforms as well as the mobile ones is hard to pass up.
Monday, November 26, 2012
Making an overhead map
I actually struggled with this for a while since I really had no idea how to code it. I posted in the Blitzmax forums asking for ideas and one of them (and a pretty good one) was to create a pixmap sprite. A pixmap sprite allows you to manipulate every pixel in it terms of color and what's the draw. One idea is each pixel would represent a single tile on a level and either draw that tile had or perhaps shade it so objects would be one color and the ground would be another.
After thinking a lot about it I think I have it figured out, in theory anyway. When I read in a level it populates several data structures. Basically, you have square at X and Y and I store the data. What coordinate does that square represent, what sprite gets drawn there, etc. When I render the screen I just loop through those arrays and draw it.
So why not pull in that same data but scale it! When I draw a level, I start at a fixed point for the first square at it's center, say X 0 and Y 0. The next square gets draw at X 32 and Y 8 and so on. If I wanted to draw a mini map of the entire level I could scale by size and coordinates. Let's say we have a 64x64 sprite. Zooming out by a factor of 1 would make it 32x32. Now, instead of drawing it at the same coordinates I will draw it at X 16 and Y 8. If I wanted to zoom out more I could keeping halving the numbers.
Of course this is all in theory. Fleshing it out in this post sounds like it should work but there is only one way to find out. Since I don't plan on constantly refreshing the map I would only have to loop through all the items only once so bigger maps shouldn't be a problem to draw. Once I get this coded and hopefully working I'll post more about it.
Sunday, November 25, 2012
Why a post-apocalyptic theme RPG
As a kid I played Dungeons and Dragons over the years, pen and paper style of course. In my early 20's we used to play every sunday afternoon. Don't get me wrong, I like fantasy just as much as the next guy... but there are only so many goblins and orcs someone can kill in their lifetime!
I always had a fetish for end of the world scenarios and sci-fiction, I love it. A mass disease that wipes out the human race, a nuclear war, the zombie apocalypse, love them all. I have zero interest in making yet another fantasy RPG about so and so magic user trying to find the kidnapped Princess in some dungeon somewhere.
Give me guns and bullets, they are fun to use, not crossbows and arrows. With a post-apoc RPG you can make it pretty gritty, read: not a "pg" family orientated game. I also think that if I make a deep story driven post-apoc RPG series I can create a niche market for myself. That remains to be seen but I want to be known as that post-apoc indie guy someday :)
Like I said my other passion is sci-fi. I can totally see cranking out some sci-fi rpg's taking place in a futuristic city with cool weapons and alien races. I think that would be received well since there aren't many turn based rpg's in a sci-fi setting out there. There could be all kinds of cool stuff I can do, evil corporations, a desert wasteland with some experiment gone wrong, alien races with various attributes. It would be pretty cool.
So in closing, no more magic spells and no more castles, let's fire off a few nukes and have some fun.
Tuesday, November 20, 2012
Turn based combat system: Building the classes
My girlfriend and I are currently vacationing in Florida for the Thanksgiving holiday so I haven't been coding at all. This does however give me time to think about the game mechanics and how it's all going to come together.
My combat system is all in spreadsheets with all the stats, skills and other character attributes. Of course this is a raw system that I made up on my own and completely unproven. I have no doubt once I see it in action there will be a lot adjustments.
Since my game isn't fantasy based upon I felt I was really restricted on making classes. For fantasy classes you can have a fighter, mage, cleric, thief, barbarian, paladin and so on. My game setting is post apocalyptic so I originally decided to not have classes at all and let the player build up the character stats as they saw fit, four characters in all. I also originally had it real old school with basic stats such as strength, endurance, etc in their own separate container that would receive their own points to upgrade with on each level up.
So I got to thinking and the more I thought about it the more I realized I wasn't really thinking outside of the box. The above system would still be fun but it's kind of one dimensional and doesn't allow for a lot of possibilities or tactical decisions in a firefight.
Here is what I came up with so far that I think will really open up the possibilities. The classes will be soldier, demolitions, sniper, heavy weapons, and locksmith.
The soldier would have bonuses for automatic weapons and be well rounded. Demolitions would have a love for explosive weapons and be able to set and disarm traps. Sniper would excel at longer range fire. Heavy weapons will be for heavy fire support but you would have to use those weapons wisely since ammo use will also be an issue. A locksmith will be a key master, able to hack terminals, open locks, steal, etc.
In addition to each class having their own specialities I'm also going to make certain upgrades available to only that class in leveling up. I can also see designing missions where you can pass them no matter what you have but a particular class would help a lot. It might also allow the player to build a party that is suited to their playing tastes. I also like the fact that if I create 6 classes but only allow four characters in the group it will force some decisions to be made. I plan on having a dozen or so characters that can be picked up along the way.
I'm confident that this new system, even though it's still only on paper, will allow much greater playing choices. I can't wait to see it in action.
Friday, November 16, 2012
Writing the perfect code, why do I torture myself?
Fast forward over an hour later, fixing things because I changed the type of inventory system. What did I gain from this? I'm not quite sure really, other then I'm using a Tlist instead of an array. So the question I'm going to ask out loud is why? If it works, leave it. There is no perfect code or structure, of course it's going to be a bit sloppy no matter what I do. No matter how I write it, a time difference of 2 milliseconds isn't really going to matter.
I need to tell myself to stop tinkering, stop going backwards and stop wasting time. Ok I think I'm done lecturing myself, next.
Thursday, November 15, 2012
To Blitzmax or not to Blitzmax
Given the pace that I'm making this game I always think there might be something better that I could be using, such as Unity 3D for example. Over a year ago when I took up Blitzmax I was confident it was what I was looking for and wanted and something I could stick with. I was using Torque Game Builder before that but it wasn't a good fit. Recently a thread was created on the Blitz forums about how there aren't any updates left to it and wondering of Blitz is going to be obsolete in the near future. I also read comments how Blitz is sorely lacking some essential features like AStar and items like that.
Now of course I read it and it fed the always present self doubt that I have about the time investment I'm making and if using Blitz is still the way to go. Maybe I should take up Unity 3D so I can eventually get my game published on the ipad really quickly and other platforms with one code base. Maybe Blitz could be a lot better and it's past it's life span.
I ran some searches on making a isometric rpg with Unity and found very little. I saw some posts asking if you "can" make an isometric rpg with Unity and the answer is the generic "you can make anything you want". I also read a blog of an indie that has actually made a few games and he is into Unity and he talked about how there are a lot of "tricks" to making a good rpg with Unity.
It took me about a day to realize I already had been down that road before and forgot the lesson I learned. I'm not a very good programmer by any means. I can't look at source files in an engine and figure out what's going on (or at least with any ease) or make any modifications to it. I had really struggled with the Torque engine because while it has a lot of great features a lot of the work I did was figuring out how make feature X work with design Y. It really did get exhausting after a while, always jumping hurdles to figure out how to make it work.
I'm sticking with Blitzmax and I'm not letting a few forum threads influence me. Just because something can be bigger and better it doesn't mean it's really for you. I remember reading that Cliff Harris still used I believe Directx 7.x to make his games until recently where he upgraded one version. And I also thought about people's comments how Blitz is lacking features like Pathfinding. I already made a pathfinding system in Blitz that works great and it's coded to exactly what I need.
So yea I'm sticking with what works for me and what I'm comfortable with and I'm not going to adopt the "grass is always greener on the other side" motto.
Tuesday, November 13, 2012
Capturing the essence of turn based combat
One of my goals is to create a combat system that relies on smarter decisions by the player, not just simply put guy in square X and fire at guy in square Y until combat is over. I can't help but be inspired by a childhood memory of playing Pool Of Radiance on the C64. I remember early in the game I discovered this island that had a castle full of kobolds. As soon as I went into the courtyard my party got attacked by a few dozen of them. I instantly fanned my party out thinking I can easily handle all of these low level creatures.
I quickly realized I was wrong. Each of my characters quickly got surrounded and overwhelmed. I tried again and again and kept losing, sometimes coming close to winning but the outcome was clear. Also a nice fireball spell, I think I only had one of them from my magic user, was only able to take out 2 or 3 kobolds. Not good.
But then I realized something. On the map there were these stone columns. Aha! I formed a defensive line with my party using the columns as anchors. Sure enough when my party got charged by the large wave of kobolds they had to stack up 2, 3 or even 4 deep waiting for a space to open up to attack. Now my party members were only getting one or two attack swings aimed at them instead of 4 or 5. After a few rounds I fired off a fireball right into the middle of the kobold pack. I remember killing 8 or 9 of them. Another round or two and they retreated and felt really good that I figured it out.
Ok granted, I'm not 12 years old anymore but I hope to capture that seem feeling of having to think things out and a bunch of little things have to be done right to add up to a win. I realize this is difficult and I'll probably never got it right but I'm going to try. I'm not ging to post my combat system because it's not even coded yet and I'm sure it will go through changes because there is a big difference between seeing it in a spreadsheet as opposed to playing it.
That is the advantage of a turn based combat system. You have to use resources and spaces carefully and think about your next move instead of just rushing and let the mathematics take care of the rest. It provides a chance for an overwhelped player party to win against superior numbers or firepower by using strategy.
It's probably going to take me a month to get the combat system into code, I hope to do it sooner. I hope it will come close to recreating soem of those fond memories I have.
Monday, November 12, 2012
Isometric Screen To World Coordinates
See the graphic below for an example.
Notice the blue square that is selected. Wrote some fairly involved code several different ways and just couldn't get this right. When I clicked near the middle of the tile I knew exactly which X and Y tile had been clicked, my code worked fine. However, when I clicked in the corner the problem became clear because my logic thought I had clicked in the next tile over. I looked at this 10 different ways and just couldn't get my head around it. How?
Then I found this article while searching for an answer and it became clear. If you scroll down the page you will see the author talk about a rectangle graphic that's 5 colors. It took me a little bit but I understood the logic behind it. In Blitzmax this was fairly easy to do. When I clicked with the mouse I calculated which of these rectangles I was clicking on (I didn't actually display the graphic). Once there I calculated where in the actual rectangle I was clicking on and then pulled the color out. If it was white, I was clicking on whatever row I had coded in the grid. However, if the color was red or green, I knew I had to subtract the row. It worked great and now my world selection worked 100%. Phew!
Friday, November 9, 2012
Blender, choking on it
I think I'm going to spend a few hours coding in Blitzmax and let all this new blender knowledge sink in a bit and start again either tonight or tomorrow.
Thursday, November 8, 2012
More Blender Goodness
I have no doubt when I start using it I'll stumble and forget the million keyboard shortcuts for it but I have to keep reminding myself I don't need complex objects so I can get by on the more simpler tasks. I'm also confident that after a few weeks of using it I'll be become more comfortable with it.
Hopefully I'll make it to the chapter on applying textures. I also have no idea how to correctly setup two cameras (I just know how to setup one camera), I assume that will be easier then rotating the object at both angles.
Wednesday, November 7, 2012
Blender 3D and Isometric Tiles
Enter Blender. I found a few tutorials on making Isometric tiles with Blender which was encouraging. When I first opened it, I stared at it for about 5 seconds and closed it. All I saw was numbers, lots of numbers, and panels and descriptions and so on. Not for me, way way too complicated.
Ok but I can't use SketchUp so I have to use something. I don't think it's going to be within my future undecided budget to outsource every piece of art. With a grand scale RPG that's going to add up fast. I bought Blender for Dummies. Slowly it's all starting to make sense to me when you take it apart. Granted, I'm not going to use 90% of what Blender has to offer. I don't care about the animation, skeleton rigging and so on. There are a ton of options that I have no idea what they do. Sometimes I have to reload Blender simply because I can't figure out how to undo something I did.
Where was I, oh yes. When you strip away the other stuff blender is shaping up to be exactly what I need it to do. I'm not making complex scenes with all sorts of light, people, animation, etc. I can output exactly the size tiles I want and I just need to manipulate shapes. I'm still reading through the dummies book on my Google Nexus 7 and haven't even reached the part on how to texture shapes but I'll get there.
The real hard part is going to be making some walls. Walls are easy, making walls that will interlock on a isometric grid is another story entirely.
Monday, November 5, 2012
I'm a newb indie dev and proud of it
Sunday, February 26, 2012
Textures and more textures
Then I talked to another indie developer, one that actually has games published and makes a living doing so. He said he never makes his own textures or rarely buys them, there are a ton of free texture websites out there.
Ok, so I went to searching around and I found the mecca of texture sites. It's a page with a bunch of links to texture websites. Some links are broken, some websites no longer exist, etc. I went through them one by one and found a good dozen sites with lots of free, detailed textures to use. http://freetexturesite.blogspot.com/ is the site.
I now have close to 20 bookmarks of sites that have various textures, lots of them, thousands of them. So it stands to reason why should I spend hundreds or more dollars on textures when there are so many available. Since I'm a artist newb, I found a tutorial on using Gimp to making textures seamless. I can see spending a day hunting through these websites and having a lot of high quality, usable textures that will be perfect for a RPG. Good stuff!
Saturday, February 25, 2012
Game Editor
Ok so first off, I know the grid is off and it needs to be adjusted. I just coded this a few days ago and it's not finished. The red buttons are navigation buttons to move in any direction around the map. The bottom pan are all of the properties I have for any given object. The left are the source graphics, I just select one and place it on the map. There is also the ability to group the source graphics into categories to keep everything organized.
There is more to it than that but that's the gist of it. It still needs work. For example, if I have a graphic in a level and I delete that graphic from the library the editor freezes on startup. There are other things on my list that I need to check or debug.
I am somewhat proud of my editor though :) If something isn't working, I know exactly where to go to fix it. If I need a new feature added, I can added pretty quickly and easily. The point is this is my editor and it's tailored for my use.
I decided I needed to invest a decent amount of time into making a solid, stable editor. Before it was a half ass editor, and I didn't get very far in coding my game before I discovered the editor lacked something, or crashed, or whatever. Once I'm done with the editor, it's stable, does everything I need it to do than I know I have a stable base to build upon. Hopefully I'll have the editor done in a few days than off to other, more fun things to do.
Wednesday, February 22, 2012
3D Modeling tools to create isometric artwork
What is the right tool for me? The perfect tool for someone else might be a terrible tool for me so here is a run down of things I looked at and my comments about them.
Blender - A good, solid solution to make isometric graphics. You can save camera angles, it has a large community, I've never heard anything bad about Blender. The only issue I had, and I heard this repeated a few times, Blender isn't the easiest 3D modeller to learn.
World Creator 2.5 - It's kind of obscure and the community is very small. It's been my limited experience that the creators are very passionate and very attentive to the user needs. This is a viable option for a non-artist a good way to create old school looking graphics. The drawbacks is the software, as far as I can tell, rarely gets updated and the community is very small. While in some respects it's a time saver to use it to create isometric graphics, from my limited knowledge, you have to hand edit (pixel by pixel) png files to create objects so in the long run it might be very time consuming.
Hexagon by Daz3D - I didn't do a lot of research into it but it doesn't appear to be a good tool for isometric art. I posted a few threads and it doesn't have much support in the way for isometric rendering.
Sketchup - Somewhat simple to use with not a lot of confusing options for someone not so smart such as myself. I explored this a while back and got some really screwed up isometric walls that didn't match and instantly dismissed it. Dumb on my part because I should have investigated it some more and posted on some forums. I discovered that with the isometric view you have to change the camera option. As a recent experiment, I created a couple of simple walls and they matched perfectly when placed side by side.
So I think I'm going to use Sketchup to create the graphics for my RPG. It has some built in isometric support, it doesn't have a mind numbing amount of options like Blender and it's free. For a while I was heavily leaning towards World Creator 2.5 but Sketchup offers one thing that WC doesn't - The ability to create a variety of objects quickly. With it I can create furniture, computers, doors, windows, rubble, sidewalks and any object I can imagine with a minimal time investment. Sure, I might be eating these words in a few months but we'll see! Also, a recent problem I ran into, the angle of some test walls and floors I created didn't match up. It was probably an error somewhere on my part but it bothered me.
I hope to create a isometric grid where one graphic fits snugly into one tile for AStar navigation purposes. When I created a test wall and floor with Sketchup the angles were a perfect match so it's alot easier to create a grid around that. This has been a pain in my gut for sometime now. It was either create the art mostly myself or outsource it, but let's face it, for some old school graphics why pay good money to have someone else make it?
Next up, the importance of starting game development with a good editor.
Thursday, February 9, 2012
Game Documentation
So to begin with I have virtually the entire game documented, in google spreadsheets. All of the PC traits, levels, missions, etc are all written up. What's left, and I admit it's a significant portion, is to write up two factions I have in mind for the overall plot, and game will have multiple endings.
Today I spent a lot of time tweaking the level editor. I already had a working level editor from a while ago but it needed a lot of polish. I still have some bugs to hunt down and some features to add but it's a little more robust not. Once I get the editor completed I'll feel like I have a more stable foundation to build the game.
Once the editor is completed, working and tested, I will go to work on the actual game. Where to being? I have about a 300 point to do list on all of the in game screens, that might be a good start.