Healthy kitties

Jokulhaups and Dragon just came back from the vet and they are very healthy! I have to get some of Dragon’s poop for a fecal test though, not looking forward to that.

The humane society suggested a vet that covers $200 of initial exam + shots within the first two weeks per kitty. So today I have like a -$260 balance after the two exams and pre-paying the fecal test. They both have one more vaccine to get that the humane society doesn’t cover and Jokulhaups’ is on Tuesday so we get it for free but Dragon needs hers the day after the two weeks… Nooooo

They need rabies shots from the humane society in a few months then they are set! They are both asleep right now, guess the car ride was exhausting. Dragon is stretched out in my lap and I snuck a round toy onto her leg, wonder if she’ll notice when she wakes up!

More pictures to come later, my netbook power cord broke so I’m on my phone.

Cats

Mine is the black one and is named Jokulhaups.
Brownish tabby one is Allison’s and is named Dragon.


I’m pretty sure I win the name competition.

E3 2011

Here’s my take on Microsoft, Sony, and Nintendo.

Sony
http://www.examiner.com/handheld-games-in-national/e3-2011-sony-press-conference-summary
Their game reveals were somewhat boring. I guess Uncharted 3 will probably be ok, but I got really bored of annoying cover based shooting where the game can’t differentiate between rolling and sticking your ass to the wall. I would consider picking up the God of War HD remake because I’ve always wanted to play that but didn’t want to bother with getting PS2 out. Otherwise, the rest of the games looked stupid.

The PSVita is probably the one thing that saved this from being an utter failure. There is probably a 0% chance of me buying it, but the $250 price point is amazing. When I first saw that Sony’s Next Gen Portable would have 2 touchscreens and all this other hardware, I was thinking “How expensive will this thing be?” Is this going to be like an ipad and be $500+? It really blew me away that Sony was able to release this at $250.

When I saw the Uncharted demo running on PSVita, I basically just laughed. There are 2 methods of control when climbing walls. You can use the control pads to actually navigate the handholds and make jumps. Or you can be pro and just tap on the screen where you want to go and Drake will automatically climb the wall and reach that point. Tap on another building and he will automatically run and jump across. I’m waiting for the day they just make it you tap on the enemy and Drake automatically shoots and kills him.

Nintendo
http://www.gamepro.com/article/news/220069/e3-nintendos-press-conference-the-roundup/

They announced a bunch of games that have been coming out like clockwork for the past 20 years. It always confuses me when people get excited about another Mario remake or another Zelda remake, particularly 3DS remakes which offer nothing new. You definitely need MORE Mario Kart versions that are all identical.

But really, all Nintendo had was the Wii U, their new console. So the selling point is that the controller has an inbuilt 6″ touch screen that can be streamed an image from the console. They then showed a bunch of concept videos of how you could use this touch screen to enhance your game experience.

There are 2 things I think this touchscreen could be useful for. The first is displaying HUD and additional game info, so that you can have a completely uncluttered screen on your TV. I guess that is kind of useful. The second thing is that it allows you to have more buttons, meaning you can have more complex interfaces. Instead of having to scroll through lists of abilities and such, you can just instantly press them. But I guess having a controller bigger than the original Xbox controller affords you the space to do that.

However, Nintendo seems to think this touchscreen shit is going to revolutionize how you play games. One of their selling points was that since it streams the game to the touchscreen, you don’t even need the TV to play. OH REALLY? Because I’m going to buy a full sized HD console and instead play on a shitty 6″ screen. Get a fucking PSVita and you can play on a tiny screen except also take it outside your living room.

Another selling point was that one person could play on the touch screen and other people could play on the TV. Then the touchscreen player would have a different role than the TV players. How is this any different from just a normal split screen, other than screen looking? It won’t matter for any online game because everyone gets their own screen anyway. It’s a party game gimmick. They should just bundle the Wii U with a free TV and they’d get the same result, except better.

All the unique control schemes and motion control is a big gimmick that doesn’t make games better. I don’t want to have to swipe the touchpad to shoot ninja stars. I don’t want to have to lift the controller and look “through” the touchscreen when I zoom in on a sniper rifle. I don’t want to have to wave it around to block fireballs being thrown at me. I’m calling it now that in the new Zelda game, you will come across some locked door with a puzzle on it. They will make you do some stupid minigame on the touchpad like outlining some secret shape in order to unlock the door. Those are gimmicky party game mechanics that don’t add anything to the game besides the fact that you have to perform some arbitrary action.

However, I’m sure it will outsell everything else because people have boners for touchscreens.

Microsoft
http://www.wpcentral.com/microsoft-s-e3-2011-keynote-summary

I briefly watched it and it had so much Kinect BS in it I stopped. Kinect is the king of stupid gimmicks.

Renoki: Making An Android Game (part 7)

Better Pausing

The reason I was obsessing so much over behavior when you press Home, is I was afraid my app would be consuming so many resources while theoretically “closed”. It would be hanging onto a ton of memory from loaded bitmaps, music, data structures, etc. In addition, my original design would have the game loop continue to spinlock until the user resumed the game. This would drain battery and result in people getting all pissy.

I had wanted to use myThread.wait() and myThread.notify() in the beginning, but I couldn’t seem to get it to work right. It was only after I realized that calling myThread.wait() does not actually make myThread pause. It makes whatever thread you’re currently in pause. So the way to actually make my game loop pause is to make my main Activity set a pause flag in the game loop thread. Then the game loop will check that flag and pause itself with wait(). Then later on, you can do myThread.notify() to start the thread again and make the thread disable the pause flag immediately after waking up.

[insert witty Combo Breaker title]

I’m back from Beijing, and more bored than before, despite having some projects to work on. At the moment I’m trying to figure out what Jack’s done on Renoki so I can add a menu, but I still don’t really know Android programming…

Not much other than staying at home and playing games, reading, working on my ONiB doc, and now trying to figure out Renoki.Β  Just looking forward to moving at the end of June!

Renoki: Making An Android Game (part 6)

The Home Button

I decided my next step was to implement player state information (lives, items acquired, gold, points, etc). I realized that by adding these, I would also have to handle saving state between closing and opening of my app. This is where I ran into some annoying issues.

The lifetime of your Android app can be modeled by this:

http://developer.android.com/images/activity_lifecycle.png

What’s annoying is that pressing “Back” and pressing “Home” are completely different things. Pressing “Back” will cause the kernel to destroy your app, effectively closing it and freeing all the resources your app has allocated. Originally, I had planned that when a user resumes playing my app, they would always begin at the start of whatever level they were last at. This would save me the trouble of saving tons of game state variables, like what monsters are in the game board at the time they last exited. Instead, I just need to save the level. If the user exits my app with “Back”, then all of this works as planned.

The problem occurs when the user exits my app by pressing “Home”. The Home key will immediately return to the homescreen, but will NOT destroy your app. It will call the onStop() method and then your app will continue to run in the background. Interestingly enough, this is the exact same behavior that will occur if you receive a phone call while playing your app, or any other activity interrupts your app. This is where I have two choices, which are implemented very nicely by Plants vs Zombies and Angry Birds.

If Plants vs Zombies gets interrupted, either by Home Key or phone call, when you restart it you will see a loading bar. Once loading is complete, it will place you in the exact state you were in except the game is paused. This implies that they are manually freeing memory or something of the sort, and when you resume they have to spend the time to reload it. On the other hand, when Angry Birds gets interrupted, restarting it is instant. There is zero loading time and you immediately return to the exact moment but paused. This implies that the Angry Birds pause screen is still running at full capacity in the background of your phone.

So for my game, I’m probably going to take the Angry Birds approach and just have my game continue to run in the pause screen whenever users press Home. The game loop will continue to run, just each iteration will do nothing. All the graphics and music will remain in memory and resuming the game will be pretty much instant. Luckily, I can still use my original plan of starting the game at the beginning of the level when the user exits correctly with the “back” button. Since everything is always running in the background, I will not need to save any player state when the user exits with “Home”.

Renoki: Making An Android Game (part 5)

I worked a little bit today. Added hammer swing animation and logic to handle hitting monsters.

And yes, the hammer swings will queue up if you hit before the previous swing animation is done. It’s a simple queue that accepts up to 3 hits. After that, it just disregards future touches until the queue frees up a space. Hitting pause will always enter into the queue.

At first I thought I was going to need some synchronization because the hammer hits are independent of all the gameboard logic. Then I realized that instead of making the hammer swings asynchronous and needing locks, I can just make the hammers occur on the game clock.

Basically when you tap, you insert the location into the hit queue. On the update part of the game loop, you first check whether a swinging flag is true (animation already going). If not, then you remove from the queue and do a hit on that location and set swinging flag to 1. In the draw part of the game loop, you draw as long as the swinging flag is true. The only synchronization I need is around the queue.

Renoki: Making An Android Game (part 4)

My First Big Step

I worked on Renoki a lot this weekend. This was a combination of Allison being gone and the HoN servers being under attack from a DDOS making games unstable. Regardless, I managed to get a monster loaded and the door animations working. And yes you can faintly hear the radio station playing annoying Miku Hatsune in the background.

Anyway, I set up my framework exactly how I described it in one of the earlier parts. There is a loop that runs continuously that continually draws sprites to a screen and also updates their state. There is an array of sprites, with each index corresponding to one of the nine locations on the game board. For now, it just inserts sprites at constant rate, whereas in the future it will be random and dependent on the level speed.

The animations are done by using sprite sheets. This is where I take five frames of an animations and just paste them one after another onto one big image. After you load the combined image, you create a viewable rectangle that only shows one of the frames. Then, you just shift the rectangle over 1 frame at a time and that creates the moving animation.

The monster object is completely independent of the rest of the framework. By this, I mean that the monster controls the door open and close animation and how long it stays on the gameboard. Once the monster decides it is dead or retreats, it sets a flag and the loop will remove it from the array.

Renoki: Making An Android Game (part 3)

Dealing with Multiple Resolutions

Something that had originally confused me was how I was going to set the game board to support multiple resolutions. As of Android 1.6, you can basically have any resolution you want, ranging from the original Android G1 phone 480×320 to my Thunderbolt with 800×480. The way Renoki is going to be made is to have a static background image (the game board) and the monsters, doors and hammer swings would be sprites I animate on top of it. The question is: How do I take a static back ground image and make it look right on two phones, where one is almost double the resolution of the other?

http://developer.android.com/guide/practices/screens_support.html
Turns out Android handles this by just lumping everything into small, medium and large categories (and extra large categories for tablets). They also use two terms to describe this: “size” and “pixel density”.

http://developer.android.com/images/screens_support/screens-ranges.png

Size is the physical dimensions of your device, across the diagonal. So anything that is less than maybe 2-3 inches is small, 4-5 is medium, 5-7 is large, anything bigger is extra large. Even if two phones have slightly different physical dimensions, they would still get lumped into the same category. Thus, most phones tend to fall into the medium size, and since I’m developing Renoki only for phones, I don’t need to really concern myself with size.

Pixel density is the number of pixels per inch. Now the Thunderbolt has absolute pixel (px) dimensions of 800×480, but Android has another unit called density pixels (px). If you query the screen height and width from within your app on the Thunderbolt, it will return 533x320dp. If you did the same for the G1, you get 480x320dp. The reason is that the Thunderbolt has a high pixel density while the G1 only has a medium pixel density. On the Thunderbolt, 1 density pixel is the equivalent of 1.5 absolute pixels. On the G1, 1 density pixel is 1 absolute pixel.

Thus, you can pretend the Thunderbolt has a 533×320 resolution when specifying the X and Y coordinate of the sprites. As long as you always use dp for your units, Android will automatically rescale everything for you. Therefore, putting a sprite at position (50,50) will be the same relative location on both the G1 and the Thunderbolt. If there are other phones with other strange resolutions, 1 dp might equal 1.33 px and so on.

There are still 2 different things to worry about. Firstly, although Android will automatically rescale everything for you, this does not prevent them from becoming warped or distorted when scaling. Just like when you blow up a tiny image it looks blurry, the same thing would happen if you provided an image for a mdpi phone and viewed it on a hdpi phone (enhance…enhance…enhance). Android solves this problem by allowing you to provide multiple versions of the same images, resized for different pixel densities. In the ‘res/drawable’ directories, there is a ‘res/drawable-ldpi’, a ‘res/drawable-mdpi’ and a ‘res/drawable-hdpi’. You might put a 48x48px image for mdpi, and a 72x72px image for hdpi. You give all the images the same name and place them in the appropriate directory in your Eclipse project. Android will automatically pick the image depending on the device you are running your app on.

http://developer.android.com/images/screens_support/screens-densities.png

The last thing to take into account is when you have screens with different aspect ratios. The G1 is 480×320 or 1.5. The Thunderbolt is 533×320 or 1.66 (repeating of course). This means the Thunderbolt screen is a little bit longer (or taller, depending on how you want to say it) than the G1. When I display an image like the game board, you will see “more” of the image on the Thunderbolt than the G1. The only way to really handle this is to design for the smallest aspect ratio and to only put non-essential things outside of that.

I will make my main game board (the doors, the score, your hammer, your gold, etc) all fit into a 480×320 box. I will then extend the image another 53 pixels underneath with some non-essential image or just plain color. On the G1, everything under that red line won’t even show up. On the Thunderbolt, maybe I would put an image of a monster waving at you or something else stupid. Regardless, the game board is the same size and nothing essential is cut off. Unfortunately, I don’t think there is a better solution than this other than just not supporting certain aspect ratios.

Renoki: Making An Android Game (part 2)

I’ve been somewhat busy recently with CMU graduation one weekend and apartment hunting the next. However, I did manage to do some learning.

I sat down and watched this long tutorial which gives a good background of Android graphics.

I’ve also begun to look at several tutorials on how to setup a game loop.
http://p-xr.com/android-tutorial-how-to-make-a-basic-game-loop-and-fps-counter/

Finally, I am taking a look at a tutorial on animating sprites
http://p-xr.com/android-tutorial-how-to-paint-animate-loop-and-remove-a-sprite/

The basic structure of the code will be simple. You have a loop running that continually updates the screen depending on a state. The state will follow the below Finite State Machine. Depending on the state, you will have various sprites or other actions appear on the screen.