ios: Add a shader option on the settings page (put them in shaders directory just inside RetroArch.app)

Add a 'None' option to both the shader and overlay settings sub pages to allow them to be disabled.
This commit is contained in:
meancoot 2013-02-10 12:11:37 -05:00
parent 64673845dd
commit be6b99b69a
3 changed files with 18 additions and 11 deletions

View File

@ -14,7 +14,6 @@
@property (strong, nonatomic) UIWindow *window; @property (strong, nonatomic) UIWindow *window;
@property (strong, nonatomic) NSString *module_path; @property (strong, nonatomic) NSString *module_path;
@property (strong, nonatomic) NSString *overlay_path;
@property (strong, nonatomic) UINavigationController *navigator; @property (strong, nonatomic) UINavigationController *navigator;
@property (strong, nonatomic) UIImage* file_icon; @property (strong, nonatomic) UIImage* file_icon;
@property (strong, nonatomic) UIImage* folder_icon; @property (strong, nonatomic) UIImage* folder_icon;

View File

@ -30,9 +30,7 @@ extern uint32_t ios_current_touch_count ;
// TODO: Relocate this! // TODO: Relocate this!
self.system_directory = "/var/mobile/Library/RetroArch/"; self.system_directory = "/var/mobile/Library/RetroArch/";
mkdir(self.system_directory, 0755); mkdir(self.system_directory, 0755);
self.overlay_path = [[[NSBundle mainBundle] bundlePath] stringByAppendingString:@"/overlays"];
// Load icons // Load icons
self.file_icon = [UIImage imageWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"ic_file" ofType:@"png"]]; self.file_icon = [UIImage imageWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"ic_file" ofType:@"png"]];
self.folder_icon = [UIImage imageWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"ic_dir" ofType:@"png"]]; self.folder_icon = [UIImage imageWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"ic_dir" ofType:@"png"]];

View File

@ -59,7 +59,7 @@ static NSMutableDictionary* subpath_setting(config_file_t* config, NSString* nam
NSString* value = get_value_from_config(config, name, defaultValue); NSString* value = get_value_from_config(config, name, defaultValue);
value = [value stringByReplacingOccurrencesOfString:path withString:@""]; value = [value stringByReplacingOccurrencesOfString:path withString:@""];
NSArray* values = [[NSFileManager defaultManager] subpathsOfDirectoryAtPath:[RetroArch_iOS get].overlay_path error:nil]; NSArray* values = [[NSFileManager defaultManager] subpathsOfDirectoryAtPath:path error:nil];
values = [values pathsMatchingExtensions:[NSArray arrayWithObject:extension]]; values = [values pathsMatchingExtensions:[NSArray arrayWithObject:extension]];
return [[NSMutableDictionary alloc] initWithObjectsAndKeys: return [[NSMutableDictionary alloc] initWithObjectsAndKeys:
@ -93,12 +93,12 @@ static NSMutableDictionary* subpath_setting(config_file_t* config, NSString* nam
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{ {
return 1; return 2;
} }
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{ {
return [[value objectForKey:@"VALUES"] count]; return (section == 1) ? [[value objectForKey:@"VALUES"] count] : 1;
} }
- (UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath - (UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
@ -106,14 +106,20 @@ static NSMutableDictionary* subpath_setting(config_file_t* config, NSString* nam
UITableViewCell* cell = [self.tableView dequeueReusableCellWithIdentifier:@"option"]; UITableViewCell* cell = [self.tableView dequeueReusableCellWithIdentifier:@"option"];
cell = cell ? cell : [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"option"]; cell = cell ? cell : [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"option"];
cell.textLabel.text = [[value objectForKey:@"VALUES"] objectAtIndex:indexPath.row]; if (indexPath.section == 1)
cell.textLabel.text = [[value objectForKey:@"VALUES"] objectAtIndex:indexPath.row];
else
cell.textLabel.text = @"None";
return cell; return cell;
} }
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{ {
[value setObject:[[value objectForKey:@"VALUES"] objectAtIndex:indexPath.row] forKey:@"VALUE"]; if (indexPath.section == 1)
[value setObject:[[value objectForKey:@"VALUES"] objectAtIndex:indexPath.row] forKey:@"VALUE"];
else
[value setObject:@"" forKey:@"VALUE"];
[view reloadData]; [view reloadData];
[[RetroArch_iOS get].navigator popViewControllerAnimated:YES]; [[RetroArch_iOS get].navigator popViewControllerAnimated:YES];
@ -139,10 +145,14 @@ static NSMutableDictionary* subpath_setting(config_file_t* config, NSString* nam
config = config_file_new(config_path); config = config_file_new(config_path);
if (!config) config = config_file_new(0); if (!config) config = config_file_new(0);
NSString* overlay_path = [[[NSBundle mainBundle] bundlePath] stringByAppendingString:@"/overlays/"];
NSString* shader_path = [[[NSBundle mainBundle] bundlePath] stringByAppendingString:@"/shaders/"];
settings = [NSArray arrayWithObjects: settings = [NSArray arrayWithObjects:
[NSArray arrayWithObjects:@"Video", [NSArray arrayWithObjects:@"Video",
boolean_setting(config, @"video_smooth", @"Smooth Video", @"true"), boolean_setting(config, @"video_smooth", @"Smooth Video", @"true"),
boolean_setting(config, @"video_crop_overscan", @"Crop Overscan", @"false"), boolean_setting(config, @"video_crop_overscan", @"Crop Overscan", @"false"),
subpath_setting(config, @"video_bsnes_shader", @"Shader", @"", shader_path, @"shader"),
nil], nil],
[NSArray arrayWithObjects:@"Audio", [NSArray arrayWithObjects:@"Audio",
@ -152,7 +162,7 @@ static NSMutableDictionary* subpath_setting(config_file_t* config, NSString* nam
nil], nil],
[NSArray arrayWithObjects:@"Input", [NSArray arrayWithObjects:@"Input",
subpath_setting(config, @"input_overlay", @"Input Overlay", @"", [RetroArch_iOS get].overlay_path, @"cfg"), subpath_setting(config, @"input_overlay", @"Input Overlay", @"", overlay_path, @"cfg"),
nil], nil],
[NSArray arrayWithObjects:@"Save States", [NSArray arrayWithObjects:@"Save States",
@ -186,7 +196,7 @@ static NSMutableDictionary* subpath_setting(config_file_t* config, NSString* nam
NSString* name = [setting objectForKey:@"NAME"]; NSString* name = [setting objectForKey:@"NAME"];
NSString* value = [setting objectForKey:@"VALUE"]; NSString* value = [setting objectForKey:@"VALUE"];
if ([[setting objectForKey:@"TYPE"] isEqualToString:@"F"]) if ([[setting objectForKey:@"TYPE"] isEqualToString:@"F"] && [value length] > 0)
value = [[setting objectForKey:@"PATH"] stringByAppendingPathComponent:value]; value = [[setting objectForKey:@"PATH"] stringByAppendingPathComponent:value];
config_set_string(config, [name UTF8String], [value UTF8String]); config_set_string(config, [name UTF8String], [value UTF8String]);