March 7th, 2011 § § permalink
Flixel is a free, open source 2D game engine built in ActionScript 3, from Adam Atomic, creator of Canabalt and other games. I became especially curious about Flixel ever since the iOS version of Canabalt went open source at the end of 2010. Both the Flash and iOS versions of Canabalt use Flixel. I understand that the iOS port of Flixel is still early, and from what I can tell, documentation for the iOS port is essentially nonexistent as of yet.
Regardless, here is my plan:
- Learn Flixel and create a game
- Port it to iOS [EDIT: that is, port my game to iOS, using the Flixel iOS port that is in the Canabalt source]
- ???
- PROFIT!!!
…all while blogging about the experience, of course. At least, that’s the idea — no promises that I’ll actually get very far! If I get really ambitious I might even write a tutorial at some point.
First experiences
Getting started with Flixel was pretty easy, thanks to the “Hello, World” tutorials available on the Flash Game Dojo wiki (which appears to be the main documentation hub for Flixel). After that I wasn’t sure where to go next, since the documentation is a bit scattered and disorganized. I did find some great info on the Github project page and wiki, which oddly is not linked to from the Flixel home page (as I said, a bit scattered). Perhaps Flash Game Dojo is where all the action is supposed to be now? I’m not really sure.
What I’m finding most helpful right now are the very simple example games, complete with source code, provided by Adam Atomic, which are a great help to see how the framework expects things to be set up. The FlxTeroids source code is instructive, as well as EZPlatformer (which has a nice tutorial with it).
Despite the disorganization, there is a lot of good information out there, including the very active forums (which I’ve not yet explored).
A question of units
One bit of info I couldn’t find was what units the FlxObject class uses for velocity and acceleration. I did a quick experiment, and it turns out that velocity is in pixels per second, and acceleration is in pixels per second per second — all very sensible, but it wasn’t explicitly stated anywhere I could find. Similarly, the angle and angularVelocity members are in degrees (not radians) and degrees per second.
What’s next?
This has been a bit of a rambling blog post (I, too, am a bit scattered!). Next I decide on what kind of game to make (something very simple) and start making it! Along the way I will share what I’ve learned.
Stay tuned…!
February 21st, 2011 § § permalink
It’s a black art… if you can even get it to work.
February 14th, 2011 § § permalink
Back in the iPhone OS 3.x days, I would stare longingly at the Settings bundles in Apple’s built-in iPhone apps:
If an app wanted explanatory text in the Settings app, you pretty much had to make do with Titles and Group titles. Ugly.
It turns out that in iOS 4.0 and higher, Apple allowed for third-party apps to have descriptive text too. And I only found out about this last week (I noticed its use in the Ladidude app).
The longer descriptive text is called “Footer text” in Apple’s nomenclature, and can be attached to any Group. To add your own, do the following:
- Open your Settings.bundle Root.plist in Xcode
- Go to the group you want footer text attached to.
- Add a new Item to the Group and edit the key to be “FooterText” (you’ll have to type “FooterText” in manually):
- The set the value to whatever text you want to show up. If you need to insert linefeeds, type option-Enter.
- Now you can visit your app’s settings in the Settings app. It should look something like this:
If your app is compatible with iPhone OS 3.x as well, not to worry: the extra FooterText key is simply ignored on pre-iOS4 devices.
February 7th, 2011 § § permalink
iOS 4.0 came with the ability to distribute your ad hoc apps over the air, which is very convenient for testers. More details are available on Apple’s website. Unfortunately, doing this manually can be a bit of a hassle, partly because the everything in the XML manifest requires absolute URLs.
I’ve created a PHP script that makes this task somewhat easier.
Requirements:
A web server that runs PHP 5 with the following extensions:
- ZIP
- either MBString or Iconv
- either BC or GMP or phpseclib
Installation/usage:
-
Download and unzip the files into a new directory on your web server.
- Create a directory for each app you want to deploy (the directory cannot have any spaces in its name!).
- In this directory, put:
- the
.IPA
file of your app, built using Xcode’s “Build & Archive” command (no spaces in the filename)
- the
.mobileprovision
file (again, no spaces in the filename)
- a 512×512 PNG file named
iTunesArtwork.png
(case-sensitive)
- a 72×72 PNG file named
Icon.png
(case-sensitive)
The directory structure should look like this:
- Now visit the web page that corresponds to the directory where you unzipped the files. You should see something like this:
with one entry for each directory.
- Visit the same page on an iOS device running iOS 4.0 or higher. You should be able to install the app simply by tapping on the corresponding “app” link. You shouldn’t need to install the provisioning profile separately, but if you do, it can also be installed via the web site by tapping on the “provisioning profile” link.
That’s it. I admit the code is a bit of a mess, as it was hacked together relatively quickly. I haven’t been able to get it working when there are spaces in the names of the files or directories. Perhaps someone else can fix that :)
This code uses the very useful CFPropertyList PHP library by Rodney Rehm to parse the Info.plist file that’s in the IPA, to extract all the info required by the XML manifest. That’s how the magic happens.
Download the files here.
November 3rd, 2010 § Comments Off on Generating certificates for push notifications? Don’t use Chrome! § permalink
Thank you again Stack Overflow, for telling me why the Apple Push Notification service SSL Certificate Assistant (on the iOS Provisioning Portal) kept rejecting my certificate signing request.
It turns out that for whatever reason, if you try uploading your certificate signing request using Chrome, it will fail with an error (Chrome bug? site bug?). So: use Safari (or Firefox, apparently, based on the comments)!
October 25th, 2010 § Comments Off on Plague: 1; bunnyhero: 0 § permalink
So after almost 3 weeks I’m finally feeling close to normal. Whiskey tango foxtrot! Plague from hell.
That means there’s no way I could get anything approved for the app store before October ends. I suppose, in theory, I could get something ready to at least submit by then, but that means completing a whole game in a week’s time. It’s possible, but to be honest I’m not sure if I’m up to it.
October 8th, 2010 § Comments Off on October challenge week 1: ha! :( § permalink
I’m off to a terrible start, unfortunately :( This month started off very busy, with little time for me to work on the challenge, and now I’ve been struck down with some kind of plague that makes it very difficult to concentrate on anything for any length of time.
All I’ve got so far are two rectangles on the screen. In theory, this will become a gameplay prototype. In practice… it’s two rectangles on the screen.
I sure hope I get better quick. Not going to give up just yet. In the meantime, I think I’ll just go and have a little lie down somewhere.
October 1st, 2010 § Comments Off on October Challenge § permalink
I have decided to try my hand at the October Challenge, AKA PoV’s Challenge. It’s a personal challenge to create and sell at least one copy of a game before the end of October.
I’ve been meaning to participate in one of these game-making challenges for a while (like Ludum Dare, or Toronto Game Jam), but never have, partly because those 2- or 3-day sprints are a little too easy to procrastinate about (blink and they’re over! and I am a master procrastinator), and partly because they seem a little too intensive for me in my advancing age (I like sleep!).
This one seems like something I could actually do and yet still be a kick-in-the-pants challenge. I like that PoV references NaNoWriMo in his post :)
Since I plan to make an iOS game, fulfilling the last part of the challenge (sell a copy) is partly at the mercy of Apple’s app review process, but I’m going to give it my best shot anyway. And of course I plan to blog about it all here.
Wish me [good] luck! And let me know if you’ll be participating too.
August 31st, 2010 § Comments Off on iOS4 multitasking: subtle UIViewController change § permalink
UIApplicationDelegate
changed a lot with the introduction of multitasking in iOS4 (see Dr. Touch’s post and charts [although there are still some small omissions and inaccuracies there]).
But UIApplicationDelegate
was not the only class affected. UIViewController
‘s behaviour is slightly changed in the presence of multitasking: namely the view(Will|Did)Disappear:
methods.
If your iOS4-built app is running on iPhone OS 3, or if UIApplicationExitsOnSuspend
is set to true
, then when the user presses the Home button, the frontmost view controller’s viewWillDisappear:
and viewDidDisappear:
methods will be called before the app exits. However, if UIApplicationExitsOnSuspend
is false
and you’re running on a multitasking-enabled device (iPhone 3GS or higher; iPod touch 3rd generation), viewWillDisappear:
and viewDidDisappear:
are not called as it enters the background.
That was a messy couple of sentences so here’s a chart!
UIApplicationExitsOnSuspend? |
multitasking-capable device and OS? |
When Home button is pressed: |
false |
true |
viewWill/DidDisappear: NOT called |
false |
false |
viewWill/DidDisappear: IS called |
true |
true |
viewWill/DidDisappear: IS called |
true |
false |
viewWill/DidDisappear: IS called |
It’s subtle, but it might make a difference to your code.
August 22nd, 2010 § Comments Off on The Sparrow Framework § permalink
When I first started iPhone programming last year, I decided I wanted to stay away from third-party frameworks at first, so I could learn as much of the native environment as possible. My first animation-based project used CALayers, but I later converted it to use OpenGL for better performance.
I am definitely not opposed to using third-party frameworks. When I’m not trying to wring the last bit of performance out of a device, I’d rather deal with higher-level abstractions than directly with OpenGL.
Cocos2D-iPhone is a very popular open source framework for 2D games and graphics applications. It seems very feature-rich, including things like visual effects, particle systems and even integrated physics engines!
But I was immediately drawn to the Sparrow Framework when I first heard about it. It, too, is an open source 2D graphics/game framework for iOS. It has far fewer features than Cocos2D (possibly a boon, depending on your outlookโless code to add to your app) but its main attraction (to me) is that it is modelled after the ActionScript 3 API. For someone like myself who has used Flash for many years, this is a definite plus.
When I was writing the Vampire simulator, I needed to make the vampire sparkle. I figured that this simple animation task would be well suited for my first exploration of the Sparrow framework.
Creating a new Sparrow app is very simple. Just duplicate the “scaffold” folder and rename the Xcode project within. You will have to do a one-time Xcode settings change: adding a SPARROW_SRC folder reference to point to where the Sparrow source files are on your hard drive.
The documentation that is available for Sparrow is minimal but very, very clearly written. Also, the source code is easy to follow. If you have any background with the ActionScript 3 class library, the learning curve is practically zero. I was shocked at how quickly I was making things happen with it.
Here’s a simple example from the vampire app. This snippet places the image “vampire.png” at the centre of the screen:
SPImage *image = [SPImage imageWithContentsOfFile:@"vampire.png"];
image.x = (self.width - image.width) / 2;
image.y = (self.height - image.height) / 2;
[self addChild:image]; |
SPImage *image = [SPImage imageWithContentsOfFile:@"vampire.png"];
image.x = (self.width - image.width) / 2;
image.y = (self.height - image.height) / 2;
[self addChild:image];
Responding to events (touch events, or timing) will be familiar to you if you’ve used ActionScript (or JavaScript, for that matter), using the addEventListener
method:
[self addEventListener:@selector(onEnterFrame:) atObject:self forType:SP_EVENT_TYPE_ENTER_FRAME]; |
[self addEventListener:@selector(onEnterFrame:) atObject:self forType:SP_EVENT_TYPE_ENTER_FRAME];
This will cause the onEnterFrame:
method on self
to be called on every frame of the animation.
Refugees from Flash should note: while Sparrow is modelled after the ActionScript 3 libraries, it is only a small, small subset of it. For example, it does not include any of drawing API (on the other hand, if you want to do any custom drawing, you can subclass SPDisplayObject
and draw with OpenGL directly).
I definitely plan to use Sparrow for whatever my next game project might be. I’ll likely have more to say about it then. I’ll be interested to see how performance holds up if a lot of elements are flying around the screen.