Sunday, September 26, 2010

Using UITableViewController #1: Swipe to Delete

This article among other articles about iOS development can be found on my new blog.



this is just a quick tutorial for those like me who didn't implement this before. Luckily this is one of the nice UI features that can be implemented without much hassle.

You only have to do a few things to get this working.

1) Tell your UITableViewDelegate that your rows have a delete editing style:


- (UITableViewCellEditingStyle) tableView:(UITableView*)tableView editingStyleForRowAtIndexPath:(NSIndexPath*)indexPath {
return UITableViewCellEditingStyleDelete;
}



2) Implement commitEditingStyle: in your UITableViewDataSource. In order to get the delete button displayed it is enough to just have the function implemented without doing anything:


- (void)tableView:(UITableView*)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath*)indexPath {
// delete your data for this row from here
}



3) Now if you actually want to delete that row visually you have to add more to commitEditingStyle. And before you do that visual delete, you have to change your data beforehand so that
numberOfRowsInSection: returns less rows than before:


- (NSInteger)tableView:(UITableView*)aTableView numberOfRowsInSection:(NSInteger)section {
return numRows;
}

- (void)tableView:(UITableView *)tableView commitEditingStyle:(UITableViewCellEditingStyle)editingStyle forRowAtIndexPath:(NSIndexPath*)indexPath {
numRows--;
[self.tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade];
}




And that's it!

Sunday, September 12, 2010

Simple but nice

Todays post tells a story that follows the lead of the last post on my path to more simplicity in the games i create.

The Story
Once a year or so i meet with a friend in the evening and do some painting. Everytime i paint, i try to paint something with a lot of detail. Usually the result is mediocre. The detail i want to achieve doesn't come out right or i don't have enough time/patience to finish it. In the end i'm just unhappy and have the feeling that i wasted my time. (It takes about a year to recover from this evening and try again.)

Yesterday i bought some ultra widescreen canvases with my girlfriend and instead of going for something detailed again i chose to just paint something simple but nice.

I love gradients so i chose to stick to that and imagined just horizontal stripes in black, a blue gradient, black again and red/orangy gradients.
Since i try to be a good indie citizen i started with a prototype.
I painted the gradients quickly on A5 format to see if i would actually like it. And i did. I asked myself if i should make another prototype which is even better but in the end of the evening i wanted to have a finished painting - not just prototypes. So i went ahead and painted the canvas and was finished by end of the evening. And here it is:






The Result

I must say i'm really pleased with the results. Probably because A) i'm not an artist and B) my former paintings were crap . What strikes me is that even though i worked fewer hours on it - and it doesn't have the complexity of my former paintings - it has much more to it. Let me stress that i'm not saying "this is an amazing painting" - i just say that i finished something in the time i had and i'm happy with the results and especially with the process of painting something i like in one evening.


Walter: “The beauty of this is its simplicity."



Conclusion

Painting is not game design. They are two different things and can't be compared that easily. But if i would draw the line to game design, i experienced a lot of the benefits i discussed in my earlier blog post. Due to the simplicity of the idea i could prototype it quickly and then execute it in the time i had. I even had plenty of time in the end to fix and polish a few things.
If my painting was an iPhone app, i probably would give it away for free since it is a bit too simplistic. But in the end i achieved something and feel that it is easier to build on top of that experience to make something slightly more complex next time.

To end this post i'd like to add a quote from an interview with Adam Saltsman i read a few days ago since i feel it fits well to this (and the last) post:

What do you contribute to your success as an independent game developer and what advice do you have for others who want to live the dream?
Make small games! Make little polished demos or prototypes and share them with everybody. This is not necessarily the route to financial success but in my experience it is the best and fastest way to learn how to design games. I’ve made maybe a dozen or so 1-week games and I’m just beginning to feel really comfortable with my design process.

Friday, September 3, 2010

Why developing smaller games is great

A few days ago I read about "Size Doesn’t Matter" in the #idevblogaday blog roll. Since i feel infected by the idea of small scope games at the moment i'd like to share my thoughts on why it can be a great catch for indie developers - especially newcomers like me. This is my first article on indie (iPhone) game development so please bear with me here ;-).




















We all know that developing small games usually takes less time than bigger ones and that there are plenty games out there that work great with just little scope. I asked myself what benefits there actually are to develop smaller games.
This is what i came up with:

  1. Be more creative and have more fun creating games.
    If you have worked on a lengthy title before, you know what i mean, it just gets less fun the longer you work on it. With smaller games you still have to do your polish work but you'll be working on the next title or prototype sooner than later.

  2. Release more.
    Releasing a new title brings that great feeling with it. You put it out there, people are playing it and you get some feedback for you work and feel that you accomplished something. Working on small titles willl give you that feeling more often because you'll just release more often.

  3. Quicker Prototyping.
    This might not be true for every concept but usually if you have a smaller game you should be able to prototype it quicker because there are less questions that need be answered.

  4. Good for your wallet.
    Since it takes less time to create that game you can keep the costs low. Less designer work, less sound work or purchases, less development, less testing, less concept work, less changes, less ...

  5. Better Cross-Promotion.
    By having more but smaller titles you have more power to cross promote your own games
    and have one of your games free for a while. In my opinion NimbleBit shows this in perfection.

  6. Faster Feedback.
    If you are a newcomer or new to a certain game genre it's good to get some feedback if you are on the right track. My first title took 5 months to release and all that happened was that i learned about 4 months too late what went right and what wrong. Although the game turned out well, the time i spent on the game didn't get into my pockets just yet. After all i rather would have created two or even three games in that time.

  7. Day-Job Compatibility.
    Another reason for smaller games is that it works better with your dayjob. With a bigger project you might get into a state where you just feel it's dragging on and will probably never finish. And you might be right, you might just not have the time or patience to finish it. Think smaller.

  8. Make it shiny.
    With less content that needs to be in the game you'll have more time (and patience) to polish your game and make it a better user experience as you would be able to working on a larger game.

  9. Easier to grasp.
    By having a smaller game with less content you're likely to have less that needs explaining. The game will be easier to grasp and might not need any explanation at all.

  10. Better for your nerves.
    Since you have a smaller scope, there's less to worry about and your game has should have less bugs. Also it might be easier to test. Less testing and bugfixing is not only time-saving, it also doesn't interfere as much with the work you actually wanted to get done and leaves you in a happier state of mind.

Despite all the advantages of smaller games i still don't think it's that easy to make a well working game with just little content. If the idea isn't good enough it won't stand all that cutting away of features. In the end it might just miss that extra mode or a bunch of levels to make it work.