I want to add a view to my application that allows the user to change several (many) settings. It should look like the built in "Settings Application" (see here) but it has to be within my app itself. At the moment I just have a tableview and I manually add different cell objects (corresponding to switches, sliders, etc). Is there a smarter of doing that? I have the feeling that I'm reinventing the wheel.
views:
707answers:
4No, that's the way, returning individual cells in the tableView:cellForRowAtIndexPath:
method. Just remember that a UITableViewCell
has useful properties such an accessory mark (a detail discolsure button, a disclosure indicator or a checkmark) and an image at the left side.
Here's some code I used to set up a preferences page:
-(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
return 3;
}
-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
switch (section) {
case (0):
return 3;
break;
case (1):
return 2;
break;
case (2):
return 1;
break;
}
return 0;
}
-(NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section {
switch (section) {
case (0):
return @"Numbers";
break;
case (1):
return @"Randomize";
break;
case (2):
return @"About";
break;
}
return nil;
}
The switch statement sets up 3 sections: Numbers, Randomize, and Versions. You can fill in the sections with whatever controls you need
If you're really gung ho, you can simply use the same format Apple uses to describe settings that would normally go into the settings bundle - but instead parse them yourself, and dynamically build a table based on the settings types.
It's a lot of work, but then again half the work has already been done for you as Apple has a very well though out plist schema for how you define settings.
That also gives you the advantage of extending the settings format to include some extra abilities the Settings app would not have...
This is an old question by internet standards, but I've found an amazing way to do this that requires very little effort. I was pulling my hair out trying to build a 2nd table view in another nib before i found these guys: InAppSettingsKit
Basically they've got all the views and the backend stuff done, all you do is add the files to your project and implement a few delegate methods in the class you're calling the settings page from (along with a button in your UI to open the settings panel, etc), and it takes care of the NSUserDefaults stuff. The UI and the settings values and keys are all generated from the same Settings.bundle used for the real settings app, which means your settings can be altered by the user in both places, in the app AND in the settings app. I found this much easier than messing with the delegate methods for a custom table view, and now i don't actually have to choose between Settings.app and something in-app because it does both.
All that's left is to pull the values you need for each settings key later on in your app when you need them, with [[NSUserDefaults standardUserDefaults] objectForKey:@"key"].