Friday, October 16, 2009

Creating Internal Environments: Part 2 Catacombs


Detailed Catacombs

In "Creating Internal Environments: Part 1" I discussed how I developed all of the parts to make my Catacombs for my game "Lost Kingdom". Now its time to put everything together! First I had to make sure all of my parts fit together seamlessly and looked good. Fortunately all it took was five walls and one pillar repeated over and over.


Catacomb Wall Pieces

I also had to make a bunch of caskets to fit in the walls and to scatter around. The idea is that a necromancer took over the city's catacombs and made a big mess wile creating a legion of undead. So some of the caskets are broken or opened.


Big Mess of Caskets

With all of the pieces and major decor finished, I had to make the level out of all of it. First I put all of the walls up where I wanted them and then put the floor in. The floor is just a block underneath each room. It took a long time to find a good texture to put on the floor. Nothing seemed to go with the walls and decor, so I severely modified a decorative floor I had hiding away in my texture collection. Gimp did wonders with it and with color correction and contrast enhancement I had the floor that I wanted.


Catacomb Walls and Floor

With the level layout done, I had to put in more detail like all of the caskets that need to go into a crypt. I have more stuff to put in such as lights, candles, and dead bodies. But those are not done yet and the bodies may not be put into the level until I am ready to put in the monsters.


Catacomb with Caskets

Filling the level with caskets took about five hours. Some are pulled out of the walls and some are broken all over the floor. Im quite happy with their arrangement, some of the rooms are such a mess that a player would walk in and go "OMGWTF happened here? And where are all of the bodies!?!" And then run around the next corner and get swarmed with zombies and skeletons.



A Big Mess of coffins!

It looks like something out of a Silent Hill game. Extremely creepy and satisfyingly dark natured. What will really set it off is proper lighting and some good creepy sounds and music! Another thing I will likely look into is making some blood to splatter on the floors and walls. I also need to place the light fixtures and candles around the level, but I will do that in IRREdit.

Wings3D is spitting and sputtering trying to cope with the size and complexity of this level. It has 211,888 polygons when it is triangulated and this is only two thirds of the level. You won't have to worry about that being high in the game though, IRRLICHT can handle that like its nothing. The last third of the level I will have to make in its own load cell, fortunately this layout makes it easy for me to do that. Once you have completed the first part of the level and have found the key, just find the right door and enter the second part of the level.

This is the first time I have made an internal environment and there are a few things to remember when making one. Scope is important. I would love to make a HUGE level completely full of details, however I don't want to spend a month on one area. When I do make a gigantic level I will use simpler pieces where I don't have to go back and put caskets in every wall recess. The more you componentize things, the quicker and easier the level will be to make. If you have an entire room completely predone it is easy to copy it and paste it somewhere else, then mess around with the decor or replace one wall to make it look different. And lastly keeping the polygon count of all of your objects low allows the level to load quicker and your 3D Editor will have less of a problem handling all of the geometry.

Monday, October 12, 2009

Wings3D: Modeling a Ruin Entrance

An entrance to some ruins. The model may be used in my game later. Modelled by RemixedCat (me) in real time with no alterations.



This may be the entrance to the catacombs andrakon showed here on this blog. I did this in real time to the song that was playing in Windows Media Player 11. I used FRAPS to capture it while it also recorded the song. It was very hard to do that before the song was over! it was very fun to do this and I will feature more videos like this later on. I will make some more improvements to this. This was just a base design that I will improve and enhance later as we need it. I hope you enjoyed this! :)

Sunday, October 11, 2009

Wings3D: Modeling a 2 Story house

Time has not been altered in any way, the video is raw and unedited. Modeling done by Remixedcat (me). Porch columns were added later.



I did this in real time to the song that was playing in Windows Media Player 11. I used FRAPS to capture it while it also recorded the song. It was very hard to do that before the song was over! it was very fun to do this and I will feature more videos like this later on. Porch colums were added later as I could not decide the design, plus each porch with that house is going to be different to give the homes a custom touch! :)

Wings3D: Modeling a small Building

This building was modeled by RemixedCat (me) in about three and a half minutes.




I thought it would be very nice to show you that a small building can be done in as little as 3 minutes and 30 seconds in wings3d. I did this in real time to the song that was playing in Windows Media Player 11. I used FRAPS to capture it while it also recorded the song. It was very hard to do that before the song was over! it was very fun to do this and I will feature more videos like this later on.

Monday, October 5, 2009

Growing Skills: 3D Modeling

Have you ever sat down with a bucket full of legos and made a small town or tower? Its a lot of fun! I spent a whole summer just building things out of legos with my friends. We made a bunch of boats, buildings, robots, and airplanes and played around with them for hours! Its really not too much different from making 3D models. The biggest differences are that you can't run out of pieces and you decide how all of the pieces are shaped. Oh and your fiendish friends won't recycle them for parts when your not around.

My first experience with 3D modeling was actually in a game called Blockland. Its a game where you and a bunch of people online can create a game room and build anything you want in it with a bunch of lego like blocks. After you make a scene you all can go to war in it too if you want. Blow up everything and everyone with missile launchers and watch the blocks fly! Honestly this game has seriously improved since I played it. It now has physics plus more weapons, bricks, and options for game play. I played it when it was still in a free beta stage, but now you can play the demo or buy a key for $20.



Totally Awesome Blockland Gameplay Video

Some time after playing Blockland I wondered into someones project for improving upon some old 2D game called Crossfire. The new and improved version was called Deliantra and it was fairly fun and interesting. I never played for too long but it did have some unique gameplay mechanics for an older game being remade and revamped with better 2D graphics. I talked a wile with Deliantra's creator Schmorp, after a wile he described how they were improving the graphics. What they were doing was creating 3D models of all of the items and buildings, taking a picture of them from the correct angle, and replacing the old sprites with higher resolution images. I thought it was a neat idea so I whipped out Blender and made a building, then it crashed and burned my house down. After a little research I found K3D and remade my building, and it turned out great! I exported it in the right format and emailed it to Schmorp. A few days later my building was in the game! You can see it in the picture below, it is yellow with a white roof and shows up twice in the left hand side.


Deliantra

Generally this inspired me to set out on a journey to get some more experience in 3D modeling. I was inspired to make something more and improve my skills. The next game I got into was Sauerbraten, the sequel to Cube. In Sauerbraten several people could get together on a map and have a fragfest, otherwise known as a death match. Or everyone could collaborate on making a new map togeather. Every map in Sauerbraten was made completely within the game with its own editing tools. It was usually done by pulling new geometry out of existing geometry and then moving the faces of it around to get the shape you want. Its kind of like how Wings3D works, except Wings3D isn't as restrictive. After spending a couple weeks on maps with a bunch of noobs building random stuff, I learned enough to make my own map from scratch. RemixedCat and I spent a week working on our own map called Joro's Retreat. Co-operative editing really made it easier to make the map, but my biggest complaint at the time was there was no way to copy my geometry and paste it somewhere else. I think that was fixed since I played though. Anyway I submitted Joro's Retreat to Quadropolis, Sauerbraten's 3rd party map site. To my suprise it hit #1 of their top 10 list and stayed there for several months! The map still works with the latest version of Sauerbraten, but there are a couple textures missing out of the library because the bookcase texture and a rug texture was later removed from Sauerbraten.


A Great Map, Completely Full of Details

I spent most of the next year deciding what to do with myself and I didn't do too much 3D Modeling. I did occasionally look into different game engines and 3D software looking for a good process to make a game with. I eventually decided to make a game after I found all of the tools I needed. Look at my first post "Making a Game: Tools of the Trade" to see what software I decided apon. And after about 3 months of making a few models a week, my modeling and my project is coming right along!

Really the best way to learn how to make 3D models is sit down and start making a bunch of stuff. Expect everything you make for the first week to be junk, or if it does turn out good, it will probably have too many polygons to use in a game. That awesome looking reptilian head in my first post was one of my first models. It looks great but I used the smooth tool on it a couple times to make it look good. Now when I make things in 3D I try to make it without using the smooth tool at all. The reason? Because the smooth tool just about doubles the number of polygons in your model every time you use it.

After playing around in my preferred 3D modeler for a month or two I knew what just about all of the tools were used for. Plus in Wings3D they add new stuff to it a lot. In the experimental version they have a new tool called Ambient Occlusion. Its their version of a technique often used in games these days. It darkens wherever there is an area on your model that is always going to be in shadow. It makes the lighting look more realistic and it does a pretty good job. I used it on the Georgian Townhouse in my earlier post, and on the pillar in my last post. Oh speaking of my last post, here is a picture of my current progress.


Catacombs, still missing a floor...

I have about half of the level done. Fortunately my idea of modeling several walls and putting those together like this works quite well! I still have to put floors in yet but I'll do that after I get all the walls up. Also the black parts of the walls are supposed to be black. The background is going to be black and I will have large black blocks put up between the walls so the player can't see further than the room they are in. It should create a good view for the player when I'm done.

Friday, October 2, 2009

Creating Internal Environments: Part 1

Its getting closer to that time of year again! One of my favorites! HALLOWEEN!! So to keep with the holiday spirit I thought I would make a Catacombs for all kinds of undead to hobble around in. I'll be documenting my process to reveal it to you as your trick or treat candy! Enjoy!

First I started with an idea and a simple story for it. The idea is a Catacombs behind the Church in my first city I'm making. The story for it is a Necromancer broke in and started making undead from all of the corpses laying around inside. Your job? You guessed it! Go slaughter some zombies and skeletons, and kick out that Necromancer! So before the player gets to bash in their great great grandparents' skulls, I have to make the level.

First I sketched out an idea for a layout. Because its easier for me to model in standard sizes and re-use parts, I thought it would be best if I made the level out of several of the same size parts. I color coded which rooms are the same size and labeled a few things.


Catacombs Layout Sketch

After the sketch is done I decided I should refine the idea and make it with squares of equal size. So in Wings 3d I made a 32x32 grid and colored where I wanted the floors. I then refined the layout and added some elements to enhance flow. Things like locked doors and closed gates are different colors and labeled in their material names. I then extruded all of the walls to make it look 3D.


Catacomb Layout in Wings3D

At this point I have a layout and an Idea but I needed to refine the idea and decide what style I wanted to make the catacombs in. I spent some time looking at pictures of real catacombs to get some ideas. I decided apon the look of all of my pieces such as columns and recesses based off of those pictures. To make sure I kept true to those selected elements and to make sure they looked alright together, I drew a quick sketch of all of the parts I wanted in it. I did this for each different wall. This is the wall with three casket recesses in it.


Extremely poor sketch of a wall full of caskets, scary!

Armed with a sketch of all of the elements I needed to render, I am now ready to battle my way into Wings3D! I will be putting the dungeon together in pieces, so to make things easier I proceeded to make a plain empty square wall to make all of the various walls and doorways from. This way, once I have modeled and textured all of the different walls and doorways, I can say a room is three walls by three walls wide and everything will fit together.


Untextured Model of a Catacombs Wall

Staying true to the elements I drew out, I easily completed a few walls and doorways. I had also drew out some of the things you would find within the catacombs like coffins and light fixtures. I modeled these as well and made several variations such as broken coffins or coffins with their lids off. With that done I had to go on to the hardest part of making my catacombs, texturing! Usually when you see a picture of a catacombs, the walls and decor is worn off and the place is falling apart. Thats usually because its several hundred years old. But this catacombs is a bit newer because the game is supposed to take place in a past setting, those several hundred years haven't happened yet.


Textured Model of a Catacombs Wall

At this point I'm pretty well tired out for the day. I modeled five different walls, an arched doorway, a gate, several caskets, and some light fixtures. I still need to texture most of the items but at least I textured all of the walls. It took me at least two hours to decide what textures to use on them and I had to make a couple new ones too. Fortunately since the game has more of an overhead view I do not need to make any ceilings.

I will show you the rest of the process in Part 2 once I have gotten that far. Mostly it will be about putting all of the pieces together and adding in more fine detail. Part 3 will be about importing the scene into IRREdit and adding proper lighting and lightmaps!

Tuesday, September 29, 2009

Early in game editor screenshots!

This in an early screenshot in IRREdit. I took this wile I was trying to figure out what kind of terrain I wanted and if I wanted the town to be placed right on it or within its own area. The terrain was made within an terrain editor called Terragen and modified by hand from within it. The textures were made within a program called T2 which is apparently a dead project. It can't make the terrain as good looking as I want it so I will have to apply textures to the terrain from within the Irrlicht engine. Fortunately the code for that has already been written, and the quality will be much better.


IRREdit early screenshot

As for the town, I decided to make it within its own area. There are three good reasons for this however. I can more easily create the town terrain from within wings3D than making a hightmap for it. I don't have the control I want of the terrain from within Terragen, and I have a specific layout in mind. And I will not have to worry so much about showing too many polygons and bogging down the players system from seeing the town too much from the distance.

So here is a screenshot of what I have done so far of the main town. The terrain is mostly untextured as of yet, and I do not have all of the buildings done yet. However I was able to obtain a very unique terrain and city layout by modeling it within wings3D rather than using a greyscale image hightmap.


IRREdit early town screenshot

I used a neat trick to help me out with placing the buildings. I took a screenshot of the terrain from above and edited it from within SAI, my drawing pad program. I then drew where I wanted the buildings and roads and labeled what each of the buildings were. I then reapplied that screenshot to the terrain. This allows me to see where I want the buildings exactly, rather then guessing where I want them.

I have a lot more buildings left to make and texture, however this allows me to see what I need more easily. After I finish with all of the buildings I will model the streets and then put in details like trees, bushes, and street lights. One neat trick is the windmills already turn!

Monday, September 28, 2009

Wings3d: Texturing a model with the Snap Image tool

Here is a time lapse video of a small tudor style apartment building being textured in Wings3d. Each video is a little over 7:30 mins long. This took about an hour however.

Part 1


Part 2


In the video I am texturing in Wings3D by using the Snap Image command in the tools menu. I used 7 different textures on this building. Most of them are 256x256px but the two wood textures are 128x128px and the iron texture is 64x64px. This method is a bit unusual but yields great results. I will be using the same textures all over my town for most of the buildings so this should be more efficient than using one 1024x1024px texture for each building. With the snap image tool I can get a very high quality look because I can scale the image to be as small as I want. It does take a wile to do however.

The trick is getting the correct camera angle. This is especially tricky when your wood texture is horizontal and the wood beams are vertical, this is why I sometimes tilt the building on its side. Also to ensure the texture is applied uniformly, it is best done in Orthogonal view.

You can change the color of the images after you have applied them too. You can see this done at about 7:00 mins into the second movie. It is done by editing the material the image is linked to and changing the diffuse color. This shows me making the chimney bricks slightly more red.

Sunday, September 27, 2009

Realistic 3D Rendering

Sometimes I like to see the final product of my work. Wings3d does not have realistic lighting built in, but I can get photo realistic lighting and affects by rendering my model and a scene in a rendering application like Kerkythea.


Georgian Townhouse

Hey that looks very realistic! This is a Georgian style townhouse I made wile trying to emulate the 1700's Georgian style. It is actually one of the first buildings I made. My goal for that model was to see how realistic I could make it, and I needed to figure out a good work flow and process to make buildings. It was made in several pieces on purpose so I could fit them together to make a two story or two window wide version. I also made it so I could easily switch out the front door for some variation. A funny feature in this model is that you can actually open the windows!

Honestly the features of this model are overkill. It took me an entire week to make correctly but I learned a lot from it. A modular design is often used in games nowadays but it is very difficult to get the pieces to fit together. The hardest part is to get the textures to line up so it does not look like there is a seam. If I made this two stories I would likely have to reapply the brick to make it seamless. Fortunately Wings3d has a Snap Image feature that makes it easy to re texture a model like this.

When I made the Georgian Townhouse I reapplied the texture several times throughout the modeling process. Every time I changed something I reapplied the texture to see if it worked right. That was the reason it took so long for me to make it. I now complete the model entirely before I texture it at all.

I no longer use this process for the most part. Sometimes I will reuse windows or doors across several models but beyond that I make the rest of the building in one piece each time. The models I am making now for my first town are made with my own version of the Tudor style. They are architecturally fairly realistic, however I do not plan to make the next super realistic game like Crysis or Oblivion. Usually they take about an hour to make and an hour to texture. I plan to make a slightly stylized game that is intentionally slightly unrealistic, that way its not unusual to see crazy environments or neat and fun looking towns.

Saturday, September 26, 2009

Growing Skills: Overview

If you are new to the gaming industry as am I, you will have to grow some skills. If you are lucky enough to have a partner then you can divvy up the work load. Fortunately RemixedCat is a graphics artist and handles making all of my textures.

3D modeling is where I started. I whipped out Wings3D and started playing around, messing with all of the menus and options. It takes a wile to get good at 3D modeling but its a lot of fun. I started with a lot of simple objects that I can still use in my game such as plates, cups, tables, and dressers.

Once you have some models made you will need to learn how to texture them. There are a couple ways to do it but getting it right can take longer than making the model itself if you are new to it. RemixedCat spent a lot of time making textures for me to use. Mostly stuff for buildings and terrain though. Most of them are cut right out of pictures of objects and then processed to make them seamless. We had to make sure our source images were open source or free to use, this avoids any later legal trouble.

I had to come up with a good game idea and fun game play. I borrowed a few themes and elements from some of my favorite Super Nintendo games and computer games and mashed them together to make a unique idea for an RPG. It won't be anything like Oblivion though, more like a less linear final fantasy game with real time game play and attacks. Play Hinterland for a general idea of the attack system, extra party members included.


Screenshot of Hinterland

The story line can take a wile to come up with too. The general theme for Lost Kingdoms is an invading army takes over the country you live in. You help the king escape and take asylum in a neighboring country. Most of the game you will be trying to help the king get the country back, too bad he is more like Gandhi than Genghis Khan. Once you have a setting and general idea of where your game is going it is a lot easier to make content for it.

Programing your game can be easy if you know exactly what you want in it. It can be imposable if you have not learned how to program however. I suggest grabbing a good book or two about the language your engine was written in and read them over. Afterwards its easy to learn from looking at the engines example programs. IRRLICHT has a good number of well documented examples to get you started with. Just don't forget to read the API documentation if you don't know how to use something.

It took me a wile to acquire all of these skills but I took them one at a time. As with any skill, they will improve with use. There is a lot of assets to make before the game is done. I only have a hill of them done, and I need a mountain!

Thursday, September 24, 2009

Making a Game: Tools of the Trade

You can't make a game with just your bare hands, you have to have the right tools! It can take a long time to decide what programs you need if you have never made a game before. Sometimes they are incompatible with each other and will not save files in a usable format. Or sometimes they just don't have the features you need.


If you want to make a 3D game you will need a 3d modeler, a photo editing program to make textures, a scene editor, and a game engine or graphics engine of your preferred programing language. Sometimes the 3D modeler you choose will not have all of the features you need and you will need to use a separate program for texturing or animating. The scene editor may come with the game engine or you could place all of the models in the game within the games code. Sometimes you can use the 3d modeler as a scene editor too. Also the game engine or graphics engine you choose may not have everything in it you want so you will have to program it in yourself.

These are the programs I will be using to make my game "Lost Kingdoms":
You have a lot of options when it comes to the 3d modeler. There are a lot of other professional packages available such as Maya, 3ds Max, and ZBrush. Many of them can handle everything with the 3d model including lighting, animation, and handling the scene. Wings3D and Blender are the two major free 3D modelers. A lot of people swear by Blender, however if you are just learning 3D modeling, I would suggest choosing something else. It is a potentially great program that suffers from having a seriously steep learning curve, and in my experience is very buggy. Wings3D Benefits from being one of the easiest to use 3D modelers out there, and is my favorite. Sure it does not do everything, but what it does do, it does great!


The choice of a graphics editor is easy. Go with whatever you have access to and are comfortable with. If you have not chosen one yet then try Gimp. Ive used Photoshop and Gimp and they have a lot of the same features. Im running on a tight budget so I tend to go with the free alternative. You may also want to use a repeating texture generating program such as Genetica or something similar. There are several to choose from, some free, some not. I also use a drawing program called SAI when I use my graphics tablet. It has some great tools and features that are absolutely invaluable to drawing.

A scene editor helps you put your game together. Once you have all of the 3D models done for a town for instance, the scene editor will let you place the models where you want them. IRREdit also allows me to place lights, terrain, primitives, and can do some simple animations like allowing a windmill to turn. IRREdit was written specifically for IRRLICHT so if you choose a different game engine you would need to find a different scene editor.

The game engine took me the longest to decide upon. I nearly went with the JMonkey Engine instead, and it would have been a good choice too. But there are a lot of major factors to decide upon when choosing a game engine. You have to find one written in your preferred programing language. If you do not have a preferred language then you would have to learn one. Fortunately IRRLICHT and JMonkey are good engines to get your feet wet with. IRRLICHT is written in C++ and JMonkey is written in Java. Ultimately it came down to one factor for me, it is easier to find reusable code and modules written in C++. I can easily plug in a physics engine like ODE Open Dynamics Engine into IRRLICHT, but I would have a hard time finding something similar written in Java.

Other concerns with a game engine choice is what kind of stuff does it support? Does it have a good community? Is it well documented? Is it up to date and support newer features and graphics shaders? Is it still being developed? Is it easy to modify or expand? Does it have networking support? With all of these questions it took me several months to research and find the right engine for me.

Now that I have all of that done, I better get started on my game! I have a long road ahead of me. Fortunately I'm not alone.