mirror of
https://github.com/CTCaer/RetroArch.git
synced 2025-01-11 13:26:34 +00:00
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:
parent
64673845dd
commit
be6b99b69a
@ -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;
|
||||||
|
@ -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"]];
|
||||||
|
@ -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]);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user