X-Git-Url: https://git.yukkurigames.com/?p=enjoyable.git;a=blobdiff_plain;f=TargetController.m;h=0119980ed97bbbae44d70a98e586f778b164ccdf;hp=9b075a15945ca851b8f5aa679d42952738cbd7ac;hb=3090f311c3406d9c157630bc9744b9b14aa42311;hpb=a71f9eae29ac9df72aa15c2de80f6a82b5aca44e diff --git a/TargetController.m b/TargetController.m index 9b075a1..0119980 100644 --- a/TargetController.m +++ b/TargetController.m @@ -5,159 +5,211 @@ // Created by Sam McCall on 5/05/09. // +#import "TargetController.h" + +#import "ConfigsController.h" +#import "Config.h" +#import "JSAction.h" +#import "JoystickController.h" +#import "KeyInputTextView.h" +#import "TargetConfig.h" +#import "TargetController.h" +#import "TargetKeyboard.h" +#import "TargetMouseBtn.h" +#import "TargetMouseMove.h" +#import "TargetMouseScroll.h" +#import "TargetToggleMouseScope.h" + @implementation TargetController --(void) keyChanged { - [radioButtons setState: 1 atRow: 1 column: 0 ]; +- (void)keyChanged { + [radioButtons setState:1 atRow:1 column:0 ]; [self commit]; } --(IBAction)radioChanged:(id)sender { - [[[NSApplication sharedApplication] mainWindow] makeFirstResponder: sender]; + +- (IBAction)radioChanged:(id)sender { + NSInteger row, col; + [radioButtons getRow:&row column:&col ofCell:sender]; + [[NSApplication sharedApplication].mainWindow makeFirstResponder:sender]; + + if (row != 1) + keyInput.vk = -1; + + if (row != 2) + [configPopup selectItemAtIndex:-1]; + else if (!configPopup.selectedItem) + [configPopup selectItemAtIndex:0]; + + if (row != 3) + mouseDirSelect.selectedSegment = -1; + else if (mouseDirSelect.selectedSegment == -1) + mouseDirSelect.selectedSegment = 0; + + if (row != 4) + mouseBtnSelect.selectedSegment = -1; + else if (mouseBtnSelect.selectedSegment == -1) + mouseBtnSelect.selectedSegment = 0; + + if (row != 5) + scrollDirSelect.selectedSegment = -1; + else if (scrollDirSelect.selectedSegment == -1) + scrollDirSelect.selectedSegment = 0; + [self commit]; } --(IBAction)mbtnChanged:(id)sender { - [radioButtons setState: 1 atRow: 5 column: 0]; - [[[NSApplication sharedApplication] mainWindow] makeFirstResponder: sender]; + +- (IBAction)mdirChanged:(id)sender { + [radioButtons setState:1 atRow:3 column:0]; + [[NSApplication sharedApplication].mainWindow makeFirstResponder:sender]; [self commit]; } +- (IBAction)mbtnChanged:(id)sender { + [radioButtons setState:1 atRow:4 column:0]; + [[NSApplication sharedApplication].mainWindow makeFirstResponder:sender]; + [self commit]; +} --(Target*) state { - switch([radioButtons selectedRow]) { - case 0: // none - return NULL; - case 1: // key - if([keyInput hasKey]) { +- (IBAction)sdirChanged:(id)sender { + [radioButtons setState:1 atRow:5 column:0]; + [[NSApplication sharedApplication].mainWindow makeFirstResponder:sender]; + [self commit]; +} + +- (Target *)makeTarget { + switch (radioButtons.selectedRow) { + case 0: + return nil; + case 1: + if (keyInput.hasKey) { TargetKeyboard* k = [[TargetKeyboard alloc] init]; - [k setVk: [keyInput vk]]; - [k setDescr: [keyInput descr]]; + k.vk = keyInput.vk; return k; - } + } else { + return nil; + } break; - case 2: - { - TargetConfig* c = [[TargetConfig alloc] init]; - [c setConfig: [[configsController configs] objectAtIndex: [configPopup indexOfSelectedItem]]]; + case 2: { + TargetConfig *c = [[TargetConfig alloc] init]; + if (!configPopup.selectedItem) + [configPopup selectItemAtIndex:0]; + c.config = configsController.configs[configPopup.indexOfSelectedItem]; return c; } case 3: { - // mouse X TargetMouseMove *mm = [[TargetMouseMove alloc] init]; - [mm setDir: 0]; + mm.dir = mouseDirSelect.selectedSegment; return mm; } case 4: { - // mouse Y - TargetMouseMove *mm = [[TargetMouseMove alloc] init]; - [mm setDir: 1]; - return mm; - } - case 5: { - // mouse button TargetMouseBtn *mb = [[TargetMouseBtn alloc] init]; - if ([mouseBtnSelect selectedSegment] == 0) { - [mb setWhich: kCGMouseButtonLeft]; - } - else { - [mb setWhich: kCGMouseButtonRight]; - } + mb.which = mouseBtnSelect.selectedSegment == 0 ? kCGMouseButtonLeft : kCGMouseButtonRight; return mb; } + case 5: { + TargetMouseScroll *ms = [[TargetMouseScroll alloc] init]; + ms.howMuch = scrollDirSelect.selectedSegment ? 1 : -1; + return ms; + } + case 6: { + TargetToggleMouseScope *tms = [[TargetToggleMouseScope alloc] init]; + return tms; + } + default: + return nil; } - return NULL; } -(void)configChosen:(id)sender { - [radioButtons setState: 1 atRow: 2 column: 0]; + [radioButtons setState:1 atRow:2 column:0]; [self commit]; } --(void) commit { - id action = [joystickController selectedAction]; - if(action) { - Target* target = [self state]; - [[configsController currentConfig] setTarget: target forAction: action]; - } +- (void)commit { + configsController.currentConfig[joystickController.selectedAction] = [self makeTarget]; } --(void) reset { +- (void)reset { [keyInput clear]; - [radioButtons setState: 1 atRow: 0 column: 0]; - [mouseBtnSelect setSelectedSegment: 0]; - [self refreshConfigsPreservingSelection: NO]; + [radioButtons setState:1 atRow:0 column:0]; + [self refreshConfigsPreservingSelection:NO]; } --(void) setEnabled: (BOOL) enabled { - [radioButtons setEnabled: enabled]; - [keyInput setEnabled: enabled]; - [configPopup setEnabled: enabled]; - [mouseBtnSelect setEnabled: enabled]; -} --(BOOL) enabled { +- (BOOL)enabled { return [radioButtons isEnabled]; } +- (void)setEnabled:(BOOL)enabled { + [radioButtons setEnabled:enabled]; + [keyInput setEnabled:enabled]; + [configPopup setEnabled:enabled]; + [mouseDirSelect setEnabled:enabled]; + [mouseBtnSelect setEnabled:enabled]; + [scrollDirSelect setEnabled:enabled]; +} -(void) load { - id jsaction = [joystickController selectedAction]; + id jsaction = joystickController.selectedAction; currentJsaction = jsaction; if(!jsaction) { - [self setEnabled: NO]; - [title setStringValue: @""]; + self.enabled = NO; + title.stringValue = @""; return; } else { - [self setEnabled: YES]; + self.enabled = YES; } - Target* target = [[configsController currentConfig] getTargetForAction: jsaction]; + Target *target = configsController.currentConfig[jsaction]; id act = jsaction; NSString* actFullName = [act name]; while([act base]) { act = [act base]; - actFullName = [[NSString alloc] initWithFormat: @"%@ > %@", [act name], actFullName]; + actFullName = [[NSString alloc] initWithFormat:@"%@ > %@", [act name], actFullName]; } - [title setStringValue: [[NSString alloc] initWithFormat: @"%@ > %@", [[configsController currentConfig] name], actFullName]]; + title.stringValue = [[NSString alloc] initWithFormat:@"%@ > %@", configsController.currentConfig.name, actFullName]; if(!target) { - // already reset - } else if([target isKindOfClass: [TargetKeyboard class]]) { - [radioButtons setState:1 atRow: 1 column: 0]; - [keyInput setVk: [(TargetKeyboard*)target vk]]; - } else if([target isKindOfClass: [TargetConfig class]]) { - [radioButtons setState:1 atRow: 2 column: 0]; - [configPopup selectItemAtIndex: [[configsController configs] indexOfObject: [(TargetConfig*)target config]]]; + [radioButtons setState:1 atRow:0 column:0]; + } else if([target isKindOfClass:[TargetKeyboard class]]) { + [radioButtons setState:1 atRow:1 column:0]; + keyInput.vk = [(TargetKeyboard*)target vk]; + } else if([target isKindOfClass:[TargetConfig class]]) { + [radioButtons setState:1 atRow:2 column:0]; + [configPopup selectItemAtIndex:[configsController.configs + indexOfObject:[(TargetConfig *)target config]]]; } - else if ([target isKindOfClass: [TargetMouseMove class]]) { - if ([(TargetMouseMove *)target dir] == 0) - [radioButtons setState:1 atRow: 3 column: 0]; - else - [radioButtons setState:1 atRow: 4 column: 0]; + else if ([target isKindOfClass:[TargetMouseMove class]]) { + [radioButtons setState:1 atRow:3 column:0]; + [mouseDirSelect setSelectedSegment:[(TargetMouseMove *)target dir]]; } - else if ([target isKindOfClass: [TargetMouseBtn class]]) { - [radioButtons setState: 1 atRow: 5 column: 0]; - if ([(TargetMouseBtn *)target which] == kCGMouseButtonLeft) - [mouseBtnSelect setSelectedSegment: 0]; - else - [mouseBtnSelect setSelectedSegment: 1]; + else if ([target isKindOfClass:[TargetMouseBtn class]]) { + [radioButtons setState:1 atRow:4 column:0]; + mouseBtnSelect.selectedSegment = [(TargetMouseBtn *)target which] == kCGMouseButtonLeft ? 0 : 1; + } + else if ([target isKindOfClass:[TargetMouseScroll class]]) { + [radioButtons setState:1 atRow:5 column:0]; + scrollDirSelect.selectedSegment = [(TargetMouseScroll *)target howMuch] > 0; + } + else if ([target isKindOfClass:[TargetToggleMouseScope class]]) { + [radioButtons setState:1 atRow:6 column:0]; } else { - [NSException raise:@"Unknown target subclass" format:@"Unknown target subclass"]; + NSLog(@"Unknown target type %@.", target.description); } } -(void) focusKey { - [[[NSApplication sharedApplication] mainWindow] makeFirstResponder: keyInput]; + Target *currentTarget = configsController.currentConfig[currentJsaction]; + if (!currentTarget || [currentTarget isKindOfClass:[TargetKeyboard class]]) + [[[NSApplication sharedApplication] mainWindow] makeFirstResponder:keyInput]; + else + [keyInput resignFirstResponder]; } --(void) refreshConfigsPreservingSelection: (BOOL) preserve { +- (void)refreshConfigsPreservingSelection:(BOOL)preserve { int initialIndex = [configPopup indexOfSelectedItem]; - - NSArray* configs = [configsController configs]; [configPopup removeAllItems]; - for(int i=0; i<[configs count]; i++) { - [configPopup addItemWithTitle: [[configs objectAtIndex:i]name]]; - } - if(preserve) - [configPopup selectItemAtIndex:initialIndex]; - + for (Config *config in configsController.configs) + [configPopup addItemWithTitle:config.name]; + [configPopup selectItemAtIndex:preserve ? initialIndex : -1]; } @end