Categories
Game Design Game Development Geek / Technical Linux Game Development Personal Development

LD18: Stop That Hero! Slowly Progressing

Screen shot in progress

What you see is a working UI. The hero’s status is running off of live data, which means that he’s at full health, has 10 lives left, and has no weapon.

Also, the number of resources you have is running on live data.

The world is rendering 16×16 tiles of grass and tree right now, but I don’t have real data for it yet. I’m going to have to create the world, and at first, I’m fine with it being a bit smaller just so I can test out the AI when I finally get to it.

We’re nearing the 24-hour mark, though. I feel like I’ve been working non-stop and have been quite focused, but so many things still need to be finished. I might not sleep well tonight. B-\

Categories
Game Design Game Development Geek / Technical Linux Game Development Personal Development

LD18: And So It Was Named

My game has a title screen with working GUI elements. And with a title screen comes a title.

The game has a title!

It’s “Stop That Hero!”, the game where you throw everything you have at that pesky heroic figure bent on stopping you from doing whatever evil things you are doing. What are you doing, anyway? Kidnapping princesses? Destroying the world? Littering?

Categories
Game Design Game Development Geek / Technical Linux Game Development Personal Development

Progress and Lunch

Ok, I have a window that opens and closes. It’s not that amazing, but it is a lot of boiler-plate code. I probably should have declared that I will be using some existing code to, you know, render a window.

Anyway, on to lunch. That’s right! It’s time for my award-winning peanut butter and pickle sandwich!

The award-winning peanut butter pickle sandwich!

I also had carrots, broccoli, grapes, and a peach.

Also, my cats are dealing with my LD-induced schedule fairly well:

Cats are cuddly

Categories
Game Design Game Development Geek / Technical Linux Game Development Personal Development

LD18: Let’s Be Agile!

I took some time to figure out what features I’ll need to implement, what art and sound I’ll need to create, and what the complexity of it all will be, and I’ve come up with a backlog of 103 Agile story points.

Agile backlog

First iteration

Now, iterations are going to be kind of loosely based on “Whenever I get it done” as opposed to time-bound sprints. Still, having all of the work figured out up front helped me figure out that I was missing some features. For instance, an instruction screen! Also, I feel that the rest of LD will be much more focused. I’ll always have a piece of functionality assigned to me that I should be working on.

Categories
Game Design Game Development Geek / Technical Linux Game Development Personal Development

LD18: Time for Breakfast!

I started my day right: with a banana!

A banana to start the day!

After reading for a bit, catching up on LD posts, and awarding some trophies, I finally made myself a full breakfast!

Scrambled eggs, buttered toast with cinnamon, and OJ

As you can see, I had scrambled eggs, buttered toast with some cinnamon sprinkled on top, and a glass of orange juice! I also have my unread “Artificial Intelligence for Games” book handy. I have a feeling I’m going to need it.

But first, a quick shower! Then I can get back to working on my game in earnest. In the meantime, I’ve realized that my hero is going to need to know how to fight an enemy. I had a couple of states as Fight or Flee, but what does Fight mean? I think I’ll change them to Chase/Evade, and Attack is a completely different state.

My plan: when the hero is chasing an enemy, it tries to get adjacent to it. Then it can attack. The attack occurs, damage is calculated, and then the hero has to wait a few moments before he can attack again. Hmm…maybe the hero should be put into another state after an attack: rest mode. This way, he can’t attack and flee immediately. He has to stick around long enough to be attacked himself.

Ok, Self, don’t panic. I’m sure the AI isn’t going to be THAT overwhelming.

Categories
Game Design Game Development Geek / Technical Linux Game Development Personal Development

LD18: Digital Mock Up

Another mock up!

Mock Up

I still don’t have code, but I’ve decided that the individual squares/tiles of the game will be 16×16. It’s tiny, but that means the graphics don’t have to look terribly great. The hero is 8×11.

I wish I knew a better color scheme to use, though. Colorblind players, let me know if you can’t see anything because the greens, blues, and reds blend in together. B-(

My next task is to actually create real tiles and sprites, and then I can get started on some code to render it correctly.

But first, I think I’ll go to sleep. Good night, LD!

Categories
Game Design Game Development Geek / Technical Linux Game Development Personal Development

LD18: Prototyping Goodness

After thinking about ways to play as the hero and using enemies as weapons, I decided that I would make the player a villain who summons and sends out minions to attack the AI-controlled hero.

I created a mock-up of the UI:

UI layout

You can see that the hero’s status is listed at the top, and the player can see how many resources are currently available, along with what minion types can be produced. They will have different costs and varying abilities. Or, at least I’m planning that they will now. When the deadline looms, I might have to limit the variety.

You can also see the world map. I didn’t spend too much time drawing out everything, but the basics are there. The hero is visible and moving around the world, searching for weapons, health, dungeons, and your castle. There will be obstacles, such as trees, mountains, and water. There will be towers/dungeons. Whenever a tower/dungeon is cleared, the hero gains access to new areas. Eventually, the hero will find your castle, and you’re done for.

Unless, of course, you can get your minions to do their job, hunt down the hero, and kill him first!

I mocked up a close-up of that first area as well:

More prototyping

The star is a weapon upgrade. The heart is health. The barrel/spindle thing is supposed to be the tower. Circles are obstacles. I moved the man around, imitating what I expect the AI should look like. In doing so, I realized that I needed to figure out what visibility the hero will have. It wouldn’t be right for him to make a direct line to the castle. He’d have to explore, so I think he’ll have a fog of war to deal with. He’ll normally be in exploration mode and can see a few squares around him in any direction. If he spots a location with a weapon, health, dungeon, or castle, he’ll switch to “Move me there in the fastest way possible” mode. If he encounters an enemy, he’ll go into Fight mode, unless he has low health, in which case he’ll be in Flee mode.

I also realized that I needed to decide what happens if he sees a target, starts moving toward it, but spots a new target on the way. Should he move to the new target? Should he ignore new targets? I decided he should have a queue of targets, and then I realized a prioritized queue would be best. If he sees a weapon upgrade, he’s going for it first. If he spots health, he’ll only go to it first if his health is low. If he has perfect health, he’ll ignore it. Towers/dungeons/castles will be the last targets he’ll go for. This way, if he has low health, sees a weapon upgrade and a tower, he will head towards the weapon. If he then sees a health upgrade, he’ll go to the health upgrade first, then go back to the weapon, then head to the tower.

But what should the player be doing? I want the player’s main action to be clicking on locations to place enemies for the hero. At the top of the screen, you’d click on the enemy you want to purchase, then you’d click on the world map to place the enemy. Obviously you shouldn’t be able to overwhelm the hero with enemies right away, so your limited resources would stop you. Also, do I want the player to be able to place enemies anywhere, or should they only be placed in specific areas/spawn points? If the player can place the enemies anywhere, then the hero is simply going to be fighting them right away. If, however, there are going to be specific spawn points, such as the tower/dungeons, then the enemies will need to explore and find the hero, and it gives more importance to the fact that the hero is not only getting to new areas but also eliminating your spawn points whenever a tower/dungeon is cleared.

With a few hours of prototyping, I think I understand my game design that much better.

Categories
Game Design Game Development Games Geek / Technical Linux Game Development Personal Development

LD18: Prototyping and Ideas

It’s time to prototype some ideas! I have a chance to play with my new barrels and hearts!

Prototyping!

But let’s take a step back and try to come up with some ideas. Assuming you play as the hero in the game, what are the various ways you could use enemies as weapons?

1) You could use the enemy’s body as a projectile. Your attack might send Enemy A flying, but when A hits B, B is hurt. Maybe A is immobile, especially if they are somehow stuck together now, as below:

Enemy's body is a projectile

2) You could force the enemy to use its own projectiles, which happen to be damaging to all entities in the game, including other enemies. Somehow, you have to provoke the enemy into attacking. In this example, you can see that the enemy throws out its spines, leaving it naked and vulnerable. It would probably need to head home to reload, and the other enemies in the vicinity were killed.

Force enemy to use projectiles

3) You could pick up the enemy, causing it to panic and flail. Until it can get itself free from your grasp, you can move it close to other enemies and let it destroy them.

Pick up enemy and let it flail

4) You could use bait to lure enemies into combat with each other. When they see the steak in this example, the two enemies can’t help themselves. They love steak! Unfortunately, only one of them can have it, so they end up in a dust cloud. Only one will survive. And get steak.

Force enemies to fight over bait

5) You could take control of the enemy in various ways. First, you could attack an enemy, bring it under submission, and train it to fight for you. It’s kind of like a Pokemon or the monsters in Rune Factory, if you’ve played that one. Second, you might have the ability to control an individual enemy’s mind or take possession of it’s body. It’s kind of like the game Space Station Silicon Valley for the N64. Third, maybe the enemies all follow whoever holds a certain token or item, like a wand or staff. If you are in control, now the enemies are yours to command! Fourth, you can find a way to mount and ride an enemy. If you can do so, you can then use it to ram into other enemies.

Take Control

So these are some of the ideas I have running through my head. Even though I’ve been thinking about sending enemies after an AI hero for much longer, I’m starting to like the mechanics listed here. Any thoughts?

Categories
Game Design Game Development Geek / Technical Linux Game Development Personal Development

LD18: Theme Is Enemies As Weapons

I was hoping that “Enemies as Weapons” would be the theme. I normally do not think about game ideas or concepts before the compo starts, but this time, I couldn’t help but think about how I would approach this one.

In Super Mario Bros, it’s common to use Koopa shells to take out enemies, so I tried to think about how the hero could somehow change the state of a foe to make it harmful to its allies. Could you pick them up, which causes them to lash out? Could you simply hit one, which makes it do something to protect itself instinctively, but its defensive weapons happen to be harmful to enemies as well?

But then I thought: what if I allowed the player to generate enemies for an AI hero? Imagine having a bird’s eye view of a world, and you can see the hero approaching your domain, but you can select an appropriate type of enemy, create it, and send it to meet the hero. At first it might be easy, but the hero has multiple lives, so you’d have to send more and varied enemies to stop him/her.

I liked the idea of generating enemies to go after an AI hero. I’ve never had very interesting AI in my previous games, but I’ve recently been reading “AI for Game Developers” and was getting a bit inspired. Ludum Dare is usually a chance for me to learn something new, so maybe this time around I’ll be learning how to implement some AI capable of avoiding obstacles, evading other entities, and figuring out how to get through the world.

Or, I should realize I only have 48 hours to implement the entire game and I might not want to spend too much time figuring out something as huge as advanced artificial intelligence. Simple AI is sometimes good enough.

Categories
Game Design Game Development Games Geek / Technical

LD18: My Previous Ludum Dare Montage

Ludum Dare Montage

I did five Ludum Dare competitions in a row, starting with LD #11. I missed out on a couple, but now I’m back for #18!

I’m excited! Only a couple more hours to go.