My favourite WordPress plugins

One of my favourite things about WordPress is its extendibility. It's very easy to add new functionality with the plugin system, and it makes for a really powerful application. Here are a few of my favourite WordPress plugins:

  • Akismet – If it wasn't for Akismet, I would have turned comments off a long time ago. I've been running it on this blog for about three weeks, and it's caught nearly 400 spam comments. That's a lot of spam for a small blog like this, and it was a major time consumer before I installed Akismet.
  • WP-PageNavi – This manages the navigation between pages at the bottom of each page. I find it a lot easier to navigate sites that use this as opposed to the default WordPress "Next Page / Previous Page" setup.
  • Related Posts – Shows the related posts at the bottom of each page. It's almost essential for any blog that has more than a handful of posts, as it allows readers to find a lot of older posts that may have remained hidden to them.
  • Smart Archives – Used in conjunction with "Exec-PHP", it produces the archives I use on this blog. It's another "must have" for anyone with more than a few posts.
  • StatTraq – Shows me where people are visiting from, and what they're reading. It's not particularly heavy duty, but it gives a good overview of what's happening.

You can find plenty more plugins at http://wp-plugins.net/.


Five things I wish I'd known when I started programming

I've been programming since I was able to use a keyboard, and it's one of the best skills I ever learnt. Like any skill, it has to be constantly fine-tuned, and I'm always on the lookout for ways to improve. Here's a few important things I've learnt over the years, most of them from my (very) early days.

1. "Funny" comments aren't funny at all

The first large game I wrote was a text adventure for the Atari ST. Instead of commenting each section of code with something useful, they had "funny" comments instead. For example, the code that handled eating had a comment saying "Bite me" above it. How witty.

2. I suffer from Premature Optimisation

I always find it satisfying to squeeze a bit more speed out of any routine, but sometimes it's difficult to wait until the code is actually functioning how it's supposed to. Some of these optimisations can leave code very difficult to read, especially if they're using functions I wouldn't normally touch.

Naturally, I'd leave these obscure changes uncommented as a challenge to my future self.

3. The compiler doesn't care how my code looks

Source code is for people to read, and compilers to translate. It really doesn't care if my braces start on a new line or not, so I don't worry about it. If the formatting of the code is a problem for me when I'm reading it, then I'll change it.

Incidentally, I once read someone else's source code that controlled a ball, and they'd arranged the code to look like a ball. I thought that was awesome, especially because it wasn't an entry for the code obfuscation competition.

One of the few things I managed to get right in my early code is indentation. It's one of the simplest changes you can make to any source file, and it really affects how readable things are.

4. Languages support comments for a reason

Somewhat similar to number 1. The only thing worse than looking at a source file and thinking "Why didn't this idiot comment their code?" is realising that it's yours.

Good commenting is an art form in itself, but it's a highly valuable skill. Good comments explain why something is happening, not what is happening. Nowadays I use PDL as often as I can, and I find it makes code much more readable. Not only does it mean code is commented well, but it means I have to think about things before I start typing.

5. Use decent variable names

In BASIC, "$" often represents a string. I used to think it was funny to use the variable name G$. If I'd already used it, I might call it G2$, or even GG$. As you can probably imagine, anything that used more than about five variables turned into a completely unreadable mess.

I know I was young and reckless, but it's no excuse for such horrible, horrible variable names.

Oh dear

So there we have it - a collection of some of the scariest code ever written. There's plenty of other lessons I've learnt, such as "Use functions instead of copying and pasting code" and "Use good function names instead of 'print2' and 'print3' ", but these are the pick of the bunch. Sometimes you only realise how important some of these things are when you do them badly.


Changing the header image every month

One of the things I did with the old design of this blog was to change the header image every month, and it's something I use on my other website (philnewton.net). I could have done this by uploading a new image every month, but being a programmer I decided to do it a different way.

Using mod_rewrite to change the image

If you're using an Apache server, you can use something called mod_rewrite to rewrite URLs and do other nifty tricks. I used this to change the image the user saw every month.

I keep all the images in my images folder, and name them according to the month I want them to show. For example, the March image will be called "03-header.jpg", and the December image "12-header.jpg". I then use a little mod_rewrite trickery to redirect requests to the correct location. The code looks something like the following:

<ifmodule mod_rewrite.c>
  RewriteEngine on
  RewriteRule ^images/header.jpg$ /images/%{TIME_MON}-header.jpg
</ifmodule>

This code is placed in a ".htaccess" file that resides in the html root folder on the server. This is the folder where all the other folders and files are kept. I put it here instead of in the blog folder because WordPress has its own ".htaccess" file which sometimes changed and removed my tweaks.

Using it in the template

You don't have to make any changes to your html templates, just make sure you link to the image as "header.jpg" and not something like "12-header.jpg". The server will take care of all the redirection all on its own, and it won't disturb anyone's browsing experience.


Happy Birthday Sonic!

sonic-large.gif

Today marks the 15th birthday of everybody's favourite blue hedgehog, Sonic!

Although his more recent games haven't been so great, the original Sonic games still stand out because of their speed, appearance and general "pick up and play" style gameplay. He's spawned countless games, TV shows and plenty of merchandise too. He's even had a gene named after him!

Happy birthday, you spikey ball of fun!


Game Design Lessons - Shining Force III

Introduction

This article is half of an in-depth look at the videogame "Shining Force III" for the Sega Saturn. This is a project between me and my brother at Prosody.co.uk. We'll regularly be examining games to see what makes them tick, and what lessons game developers can learn from them. My articles will take a more analytical approach, whereas his will focus on the game from a player's point of view.

You can read the other half of this article at: Player POV – Shining Force III.

What makes it great?

Simple Mechanics

The statistics in the game are simplified so that the player isn't blinded by reams of numbers. A lot of the more complex elements are hidden from the player, which allows the player to get on with enjoying the game.

Data hiding like this allows the more "hardcore" players to experiment with the inner workings of the game. Layering helps to keep casual and hardcore players interested in the game, and can be a reward for the "hacker" type of game player that likes to learn the game inside and out.

Simple Interface

The overall interface is very simple, and consists of a menu containing four icons organised in a diamond formation. This is optimised for the controller, as the player only has to press one direction to choose an action.

There's often a temptation to map commands to every button on a controller, and with a keyboard, this becomes especially tempting. Try to keep things as simple as possible. Remember – if in doubt, leave it out.

The rest of the GUI is simple too. Hovering over a player shows their current health, level and any adverse status effects. The screen is generally free of clutter, which lets the player get on with actually playing the game instead of fighting with the interface.

Keep it simple! This is difficult for developers, and interface design is an art as well as a science, but spending quality time designing and testing your interface will really pay off in the end.

Subtle graphics

sf3-screen-1.jpg

SF3 is old, but still retains an interesting charm to its graphics, in a similar way that the 16-bit SNES RPGs still look attractive today. It's all too easy to be caught up in the graphical arms race, but it can be a real hindrance to progress. You don't have to look far to find projects that are still caught in the "make a 3D engine" phase. Concentrate on making the graphics functional and subtly beautiful, and you'll have a more charming game.

We all know that gameplay is the important element, but it's a lie to think that graphics aren't important. They don't have to be spectacular, but they do have to be interesting and complimentary to the experience.

What's bad about it?

It's linear

Like nearly every RPG, SF3 suffers from being quite a linear experience. Although you can explore towns at your own pace and use any strategy in battles, the game is still a very linear progression from one story point to the other.

Relatively poor replay value

Because the game is linear, there something of a lack of replay value. Once you've played a battle, you know the surprises and can adjust your tactics for the next time you play it.

The developers have tried to combat this problem by including secret characters and a variety of interesting weapons and items.

The main reason the game is still playable after the game is complete is the fact that every battle plays differently. Even though you'll know some of the surprises, you can still experiment with different tactics and different team members.

So what can we learn?

What lessons can be learnt from this? What can we learn to improve our own games with?

There's a TONNE of work involved in making an RPG!

It's a shame that RPGs are so popular with indie developers, because there's a tonne of work involved in creating them! It's not just the quantity, but also the quality that's important. Music needs to stir the right emotions, graphics need to convey the right mood and the little details need to be added to sew the game world together. It's a big job, that's for sure.

Focus on the fun parts of the gameplay.

RPGs generally have two modes: exploration and fighting. It's important to pick a few elements that make the gameplay fun, and work on optimising them as much as possible.

The main element of the battle system is finding a strategy to outwit the AI opponents. Do you rush into the battle and attempt to take out the key enemies, or do you draw them out into the field and attack them from the sides?

For example, the battle terrain in SF3 has a "land effect", which means certain characters can move quicker or slower on different terrain. It also affects their defence stat, so sometimes it's better to attack via a forest as it provides a higher land effect and thus increases your defence, giving you an advantage over your opponent. This simple, easily overlooked element can add an extra layer of strategy to your game plan.

Instead of weighing the game down with a tonne of different features, the developers concentrated on making the battle mode as immersive and appealing as possible. Like chess, every game plays differently and every opponent requires a different strategy to beat. It's easy to add hundreds of features to make your game sound more appealing, but refining the core elements of the game are far more rewarding.

Use details to immerse the players

Even simple things, such as washing lines in towns and vases on tables help to capture the player's interest, and make them want to spend more time exploring the game world. This can be difficult in a large scale game such as an RPG, but for a smaller indie project, more attention can be spent on getting the details right. This is the layer of "polish" that helps make your game stand out, and is really an area where the developer can let their creative side shine through.

Concentrate on the useful features

I know it's difficult, but always concentrate on the useful features of the game before moving on to the "exciting" ones. Stick to what's useful when it comes to designing the User Interface, and don't be tempted to add superfluous "cool" features. If in doubt, ask your audience. In fact, ask your audience anyway because they'll almost certainly tell you what parts of the interface could be improved.

Progressive Rewards

sf3-screen-2.jpg

As the player progresses through the game, reward them! SF3 does this by gradually adding more powerful and interesting weapons to the player's arsenal. New enemies and spells are also provided to keep interest, and by the final stages of the game there is a really diverse range of weapons and spells for the player to use in battles.

Characters learn new "special" moves, and the appearance of magic changes as it increases in level. This can drive the player forward, as they want to see what new things lie in store for them. Although the story is the driving factor behind the entire game, these extra bonuses drive the player through the actual game play experience.

Let the players take risks

One of the interesting areas of SF3 is the Smithy. You find chunks of "Mithril" and "Dark Matter" lying around the world, and a smithy can craft these elements into weapons and armour. However, you don't know what item you'll get, so you may get something new and cool, or you might get something you've seen before. This kind of risk taking helps to create interest.

The other interesting element is "cursed" weapons. These weapons are generally much more powerful than regular weapons, but they have some nasty side effects. They may sap your health when you attack, or you may be paralysed by them and unable to attack at all. This feature lets the player take the risk – do they think a sky high attack value is worth the risk of being paralysed for a turn?

Risk taking is part of human nature and can make the experience far more compelling (just look at gambling) so make sure your players have ample opportunities to take a risk to reap big rewards.

Ease players into the experience

Complex games often come with a "tutorial mode" or a "training level" to help the player get used to the experience. It's important to handle this correctly, as it can create a barrier between the player and the game. Will you really believe you're a gallant knight slaying a goblin if the screen is constantly filled with tips like "Press X to attack" and "Use the mouse to swing your sword"?

SF3 starts with a simple "explore the town" stage, which gets the player used to the exploration aspect of the game. It then shifts to a quick (and easy) battle to allow them to experiment with the battle mode.

Indie games can often swamp the player with hints as new elements are added, sometimes to the detriment of the gameplay experience. Think carefully when creating your training mode, and make sure it doesn't detract from the game play. Indie games have a difficult time, because they generally don't come with a printed manual, which makes it harder to tell the player about the game without dragging them through a tutorial.

If you want to be really smart, try and work out if the player is struggling for a while before showing a tip. For example, if they haven't reloaded for a while, show a tip that tells them how to reload. One thing – be very careful about modal dialogs. These require the user to perform an additional action to remove them, and they can become VERY ANNOYING, VERY FAST. You have been warned.

Want the player's point of view?

You can read the other half of this article at: Player POV – Shining Force III. It takes a look at the game from the player's perspective, and looks at how the different game elements fit together to create an immersive RPG.