Monday, 1 July 2013

Boxes: Sneaky Buggers

Last year I wrote at fair length about the hidden dangers of Monkey's auto-boxing:
http://pointlessdiversions.blogspot.co.nz/2012_03_01_archive.html

You'd think that having spent some time explaining it all that I'd be proofed against the schemes of evil boxes. Unfortunately not. Heed my tale of woe.

Cubic Bastards

I have a class "Path" that deals with, well... paths. For convenience I give each path a human-readable string identifier and this gets passed in on construction:

Method New ( id:String )

This has been in place for quite a while with no problems, which you'd expect, because there's nothing really wrong with it. Then, the other day I wrote some code that contained a simple error. I had a couple of fields in a class that manipulated paths, let's call it PathManipulator for the purposes of this post:

Class PathManipulator
    Field currPath:Path
    Field currPathID:String
    ...

The separate path and path id field were to allow the path to be set via the ID string and retrieved from a map if desired. In addition I wrote a setter method:

Method SetCurrPath:Void( id:String )
    currPath = id
End

And there's the error. I accidentally set the path reference rather than the string reference.

So, I wrote this and some more code and compiled and it all ran okay. Then after adding some more code I started getting an Array Out Of Bounds exception crash. The crash was in the Path class, not in my PathManipulator code and looked like something was somehow clearing the internal points array. Cutting a long story short I spent several hours trying to trace where this array clear was occurring before working out that the source of the problem was the setter method above.

This was my fault though, right? Well, yes and no. It's an error, no doubt, but an error that maybe shouldn't be so difficult to spot. In the setter I'm assigning a String to a Path reference. Why does that even compile? It compiles because I provided a constructor for my Path class that takes a String value as input. Monkey's compiler sees this and helpfully converts the line:

currPath = id

becomes

currPath = New Path(id)

So, no compile error, just a silent replacement of the currPath reference with an uninitialised path instance that has an empty points array resulting in me looking in completely the wrong place for the problem. The boxes got me again.

They're out to get you. To get all of us.

The ability to define your own classes with auto-boxing is certainly a handy thing, but this incident just further convinces me that it's too easy to be caught out by the way it currently functions. I feel like it should require some explicit notice to the compiler that you intend for a class to be auto-boxing rather than have any constructor that takes a primitive assumed to be for that purpose.

Be careful out there.

Friday, 8 March 2013

Update On Box2D Performance vs. libGDX


A while back I posted a quick performance comparison between my Monkey port of Box2D and libGDX's JNI version. At the time the libGDX version was about twice as fast.

Since then I've done a bit of optimisation work and I thought it would be worth posting to note that I've just uploaded 1.0.12 of the port and to update the figures.

The Monkey performance on the same domino stack benchmark from the previous post is now ~88ms on average. Assuming that libGDX's Box2D implementation remains the same at ~75ms that means the performance gap has narrowed from 100% to under 20%. The variability of performance with the Monkey version is still higher, with spikes to >160ms where libGDX keeps it under 100ms but it's a much closer race now. Note that this is just a headline figure on a very collision/contact intensive example that is intentionally chosen for being slow on Android, performance in general is likely indistinguishable for the most part.

The performance improvements are significant enough to enable Monkey devs to target lower powered devices and/or create more physics intensive games. So, if you shelved something because the framerate wasn't quite there then it might be worth grabbing the newer module version and taking another look.

Thursday, 7 March 2013

Games and the Mundane

Yesterday I had a Twitter back and forth with Rob Fearon, that started from this tweet where he implied that "the mundane" is less represented in games than it was in the past.



 Feel free to have a read of the conversation but the summary is that I suggested that there are a fair number of games that deal in mundane things and we then swapped Spectrum game references in an effort to hash out what boundaries are being drawn around "mundane". It's probably a deathly dull conversation to most but for Twitter it's not bad. Anyway, Rob used the conversation to gather fuel for a subsequent blog post, which you can find here.

To be honest the initial tweet is the sort of thing that I can't leave alone. Firstly, pretty much any claim that games don't do something or include something is usually hard to defend. There are so many games out there that the claim is generally coming from a place of ignorance about what exists or is excluding categories of games for some unspoken reason. Secondly, it smelled a bit of the kind of snobbery that you often hear from people who eschew genre fiction because only writing about normality is literature (unless its "magical realism"). I doubted that Rob meant the second thing but the button was pressed anyway.

Having read the post I'm further convinced that any disagreement was primarily around what Rob meant by mundane in the first place. I took it to mean games that put the player in unexceptional roles/jobs/circumstances, which the casual game market has many examples of. Rob appears to to dismiss games like Diner Dash because they offer aspirational fantasies of achieving great success in these roles. However, leaving that aside, Rob's post really seems to be talking about several different themes that involve mundanity but aren't just about representing the mundane.

So, because I'm a bit like that, I've broken down the mundane elements that Rob fondly remembers from the 80s and blathered at length about each one below.

Street-level Politics


Rob uses the word politics on its own but I think he's specifically referring to the space where policy meets the man in the street and not politics from the perspective of the powerful. Presumably it's obvious that high-level geopolitics remains a fascination in games of war, conquest and competition for resources and games like SimCity let people scratch their top-down urban planning and social-engineering itches in ways that exceed what the 80s could offer.

Taking the "politics in the small" reading I can see why it might seem true that there was more of it in games back then. A game like Hampstead, where you play an unemployed person attempting to climb the social ladder, seems overtly political in a way that's rare now. Indeed if the benchmark is that sort of spotlighted social commentary then I'd probably agree, but for fairly specific environmental reasons.

The enticing intro to Hampstead

I think a big part of it isn't about games but about a general shift in the political climate. Current domestic politics are low-contrast compared to the UK in the early 80s. Back then the class divides were more sharply felt, the left/right political divide was far wider and mass unemployment was a shocking new development rather than just part of the scenery. (Also both Rob and I were considerably younger and stuff just feels more vivid in your youth anyway). As such it was a more attractive and tractable target than we have now. The political references in games of the time mirrored the knockabout anti-establishment wave of alternative comedy and the likes of Spitting Image. This stuff was in mainstream games because it was in mainstream culture and games could at least emulate the broad-stroke cartoonish veneer of that output.

Spitting Image from 1984. Completely impenetrable if you weren't there.

In the round though I'm not sure I agree that current games feature a relative lack of that sort of politics. For a start, politics is implicit in any game that purports to represent social environments and that's something that games continue to try to do with increasing fidelity. When GTA includes homeless NPCs that beg for money, that's politics right there. Of course, the idea that it's a deep commentary on the homeless problem is silly, but I would argue that GTA with its satirical talk radio stations and narratives on crime, race relations, corruption etc. can lay claim to carrying more political weight than Monty Mole or Hampstead even if its scope means that the politics isn't front and centre.

The Everyman Character.


With politics out of the way so is much of my disagreement with what Rob says in his post. When he talks about the loss of the mundane player character I think he's broadly right. Rob's examples of Trashman and Technician Ted and the ones I mentioned in the Twitter conversation: Tapper, Paperboy, Pedro, Wally Week, are just the tip of the iceberg. The early 80s game scene featured a mad explosion of character IP and a huge number of those were working class/average blokes (Yes, pretty much all blokes I'm afraid. Let's deal with one axis of representation at a time.).

Maybe we can thank Mario (not that Mario's character stuck with "just a plumber") for popularising this character theme in games or maybe Mario's success was a result of pre-existing cultural desire that the others were also trying to tap into. Looking at popular culture outside of games I tend to think the latter is true. From Charlie Chaplin through George Formby and Coronation Street to Boys from the Blackstuff (forgive the UK-centric examples, but we are talking about the UK games scene primarily), Joe and Jemima Ordinary had characters to connect with. They were commercially successful ventures too, particularly in post WWII cinema and TV. There's no reason why someone designing a game character wouldn't try to target the same market.

George Formby, singing about real work.

It's not an argument without wrinkles though. Average people are in modern commercial games. The ubiquitous modern realistic military combat games that get so much stick often feature soldiers that are average, working class guys. I'm sure Rob would counter that a soldier in a combat situation is outside of "mundane" but then how is he wrapping that same concept around the surreal craziness of Technician Ted's factory? Another criticism might be that such games tend to exaggerate the influence of the player (you won WWII!) and imbue them with super-powers such as the ability to absorb multiple bullet wounds. I'd accept that but I think several games have made efforts to portray the limited agency of a soldier in an overall conflict and their mortality within the bounds of creating a playable game.

But I said I'd stopped disagreeing with Rob, right? Well, to disentangle this I think we have to put soldiers (and cops, secret service etc.) to one side as characters. They're average people in mundane jobs but the situations they're trained to deal with aren't what we deal with every day (hopefully). I'd still argue that games can treat them in ways that embrace their mundane nature but can't deny that it is more often abandoned in favour of allowing players to raise the character's inherent combat agency to the point of situational mastery.
Just an average guy doing my job.

We also have to separate mundane themes and characters from mundane representations and scenarios. As Rob says, you can put Tapper in space with aliens at the tables but he's still just serving drinks. To coin an example from fiction: Arthur Dent doesn't become extraordinary by being beamed into space -- he remains resolutely ordinary while the universe does extraordinary things to him.

So what we're talking about is not just an ordinariness of character that makes them empathetic but an ordinariness of skills, goals and possible rewards. I still baulk at Rob including the goal/ability of saving a small business in the realm of hyper-agency but I understand the line even if I disagree about where it should be drawn. I also agree that it's a line that modern games mostly don't recognise at all.

Unfortunately it's not difficult to see why that's the case. There are huge trade-offs with this sort of ordinary. There's a big audience that enjoys the power fantasies and escapism available in games. From a marketing perspective it's more attractive to insert little touches of romance or an emotional backstory to excuse or soften an escapist fantasy character than it is to abandon the fantasy. I doubt that Max Payne started with a desire to make a game about losing a child and had the slow-mo gun-fighting added after. We shouldn't confuse which part is decoration and which part is the game.

It seems unlikely to me that we'll see a resurgence of games about mechanics, postmen, plasterers and shelf-stackers struggling to achieve little more than getting to the end of another day. For the most part I don't think it's much of a loss either. A good 70+% of those games in the 80s were just Jet Set Willy remixes, including Technician Ted. I'd certainly like to see more ordinariness in games but I can't pretend that much of the 80s output could be used as an example of how to do it.

Skool Daze - better than Rob's examples.

Just as an aside, my pick for the 1984 example of how great a game can be made out of this viewpoint would be Skool Daze. It puts the player in the shoes of an ordinary character (Eric, a schoolboy),  a very ordinary but punishing environment over which they have little control (a school), gives them a very small goal (steal your report card) and then gives them just enough agency to have fun and play out minor fantasies of bad behaviour.

Un-Mundaning


Final bit, honest.

Rob brings up Frankie Goes To Hollywood. With this one I think he's off on another tangent. Now we're not talking about games including mundane reflections of reality, we're talking about games taking the mundane and making it not mundane.

When other forms do this sort of thing it can run towards escapist fantasy or towards a kind of celebratory metaphor. I imagine that Rob's really on about the celebratory end, taking the weirdness and magic of ordinary human life and expressing it as "real" magic in the game world. To be honest, I don't much care either way, I just like the idea of mixing humdrum reality with fantasy and think games are very well placed to do it. Fantasy, magical realism and dream logic are all workable within games.

So I'd like more of that, definitely. Do I think there was more of it in the 80s? Yep. However, much as with the other facets of mundane, I don't think it was really done with any great artistic intent or merit for the most part. When Matthew Smith put man-sized perambulating toilets and hovering telephones into Manic Miner the scene was kind of set for normal things to behave in very abnormal ways. FGTH was a standout game in its use of the banal mixed with surreal imagery but it stood out because nearly everything else in that vein consisted of toothbrushes bouncing around in yet another arcade adventure platformer.

Pyjamarama - Self-Inception

Besides FGTH I have to put forward Pyjamarama as an example of un-mundaning done well and in a way that could be relevant today. In it you play Wally Week's disembodied dream spirit in his nightmare. You have to explore a house and work out how to get your body to wake up so you can get to your job on time, which you hate.


*I'm not ignoring the fact that plenty of us live unable to achieve such aspirations. I'm just saying that being the owner-operator of a coffee shop isn't a life beyond the realms of everyday reality.

Friday, 1 March 2013

F2P, IAP, Micro-transactions and DLC

The news that EA is planning to put micro-transactions into their games has brought the simmering discussion surrounding IAP back to a boil. For many it represents a new offensive on the "core" gaming territory by a business model that had been mostly confined to mobile and Facebook casual.

I think gamers are right to be very suspicious of how this will play out. If this review of the EA published Real Racing 3 on iOS is anything to go by then they're willing to try putting frequent and high tariffs on gameplay. On the other hand Real Racing 3 is still a free-to-play iOS game. How they'll incorporate micro-transactions into PC or mainstream console titles has yet to be seen.

There is a strong argument that consumers have a choice to buy or not buy whatever is offered  (as voiced by CliffyB while I was writing this post). I can't deny the truth in that but it doesn't mitigate the valid concerns of fans of existing games titles. EA owns many well-loved brands and fans of those brands are now faced with the possibility that future iterations will be warped to conform to a business model that needs to generate ongoing payments. It's not just a matter of the games being less fun, or even more expensive, it's the possibility that the very nature of those franchises will be changed. SimCity, Command and Conquer or Mirror's Edge wrapped round a micro-transaction model may well not be SimCity, C&C or Mirror's Edge as we know them. There won't be a choice to buy or not buy the games we want -- those games will simply not exist any more.

Maybe, Just Maybe, It'll Be Okay


There is, as always, a middle ground. It's the zone in which we can imagine games that incorporate micro-transactions in non-destructive ways. Unfortunately, a position that recognises the danger in applying free-to-play models to the traditional games market but also holds that it's not uniformly evil is too grey to be attractive. Nuanced opinions don't get heard much in a debate that exists between corporate spin-drone press-releases and hyperbolic teenaged gamers in comment sections.

Despite the lack of vocal recognition the reality is that IAP just means "stuff" you can buy from within the game. DLC is just "stuff" you can buy to add to your existing game whether from inside or outside that game. "Micro-transactions" is just code for virtual currency to buy "stuff"*. F2P just means it's free to install and play at least some of it or for some period of time and you'll have to buy "stuff" to play more.

None of these things are inherently evil concepts. My local coffee shop is F2P in that you can walk in and hang around for free. They have IAP coffee and cakes and a micro-transaction currency involving gift vouchers and reward stamps. If I stretch a bit I can even say they have DLC ground coffee that you can order for use at home. I doubt that many people would compare them to Hitler for doing any of that.

The debate needs to move from blanket "this thing good"/"this thing bad" to being about the specific behaviours. People need to express what is not okay and what is okay. Not all DLC is horse armour. Not all F2P is Real Racing 3.

If EA sells me a full-price Tomb Raider and then offers extra hats, clothes, hairstyles for more further payment then that's fine. If they want to sell me ammo or "Lara Energy" needed to play freely then it's not. I'll be honest, I probably won't buy the hats but some people will and I don't mind them being available.

If EA sells me a full-price Need For Speed and then offers extra cars, paint jobs, decals for further payment then that's fine. If they only offer the "best" car as an added extra then it's not. It's really, really not okay to do this if a game contains multiplayer competitive elements.

If EA sells me a full-price Mirror's Edge and then offers extra missions for further payment that's fine. If those missions are actually required to bring a narrative close to the story in the game I paid for then it's not.

If EA creates a franchise specifically for F2P then I reserve the right to hate it, but it's really no skin off my nose. If they take a franchise that I enjoy and subvert its nature to fit F2P then they're not just making something I dislike but they're destroying something I liked. It's not illegal but certainly a dick move.

If EA creates micro-transactions that are proxy subscription fees for ongoing services, that's fine by me. You can justify selling the ability to play if the game has a significant ongoing running cost. Justification goes out of the window if you've manufactured the need for that cost (always-connected DRM, unwanted social/multiplayer features). 

If EA introduces micro-transactions to create an on-ramp between demo/piracy and  full purchase then that could be acceptable. I'm okay with free to install and pay-to-play purchases for single-player games as long as I can get off the treadmill with a single purchase (infinite coins/fuel/whatever) that is in line with traditional game pricing. We also need to be able to release games from IAP treadmills in instances where the payment mechanism ceases to exist.

But Probably Not


I'm afraid that my instinct and experience tells me that we're in for a bad time no matter what arguments are made and heard. I foresee the inclusion of payment models that don't seek to increase revenue by upselling or extending the market but rather by getting people to pay more for less. I foresee micro-transactions shoe-horned into games and game designs broken to include them. I foresee a proliferation of virtual currencies as consumer "company scrip" and we'll have to collect EAbucks, Ubibeans, and Acticredits to play their games.

Ultimately it's just too tempting for publishers to ignore. F2P/IAP aren't just the kind of buzzwords that business types feel they must add to their CV. The massive numbers coming out of the top mobile freemium games are real. If you add to that the possibility that micro-transactions can be used to open a new front in the digital shop-front battle (Can't spend $EA on non-EA titles and no-one else gets a cut) then it becomes inevitable that the big boys are going to try it on.

I also frankly doubt that it's going to go away. Even if gamers vote with their wallets as CliffyB suggests and we see some big franchise releases bomb due to bad micro-transaction implementation once the systems are in place they will be used. We can only hope that market forces result in tolerable usage to most of us.

If there's a silver lining to this looming cloud it's that, by moving to payment models that are unpopular with large numbers of gamers, the big players will make space for others to offer alternatives. "Pay once, play forever" might just become a selling point in itself that indies can exploit.


*Micro-transactions were once touted as a mechanism for monetising web content and literally meant "small value transactions". The idea was that you could charge 0.5c or whatever for reading a blog post. These transactions were enabled via virtual currency (to avoid the overhead of real currency transactions). The meaning in games has taken great liberties with the interpretation of "small value" and now it really just means the use of in-game currency to buy stuff, whether for 10c or $10.

Wednesday, 27 February 2013

Game Camera Work

My on-off dev schedule has been on again recently and with it I may as well resurrect this neglected blog space.

I did a bit of work on the camera for one of my game projects and thought the progression of the solution lent itself to a post. Then I remembered that I'd been wanting to try my hand at creating one of those dev video things and so I tried that.

The creation of the video was a whole adventure in finding a workable capture solution, a working microphone, working video-editing software and getting my mouth to produce coherent sentences but I'll save you the long story.

Here's the video: