// Enjoy
//
// Created by Yifeng Huang on 7/26/12.
-// Copyright (c) 2012 __MyCompanyName__. All rights reserved.
//
#import "TargetMouseMove.h"
-@implementation TargetMouseMove
+#import "JoystickController.h"
--(BOOL) isContinuous {
- return true;
+@implementation TargetMouseMove {
+ int sign;
}
-@synthesize dir;
-
--(NSString*) stringify {
- return [[NSString alloc] initWithFormat: @"mmove~%d", dir];
+-(BOOL) isContinuous {
+ return YES;
}
-+(TargetMouseMove*) unstringifyImpl: (NSArray*) comps {
- NSParameterAssert([comps count] == 2);
- TargetMouseMove* target = [[TargetMouseMove alloc] init];
- [target setDir: [[comps objectAtIndex:1] integerValue]];
- return target;
++ (NSString *)serializationCode {
+ return @"mmove";
}
--(void) trigger: (JoystickController *)jc {
- return;
+- (NSDictionary *)serialize {
+ return @{ @"type": @"mmove", @"axis": @(_axis) };
}
--(void) untrigger: (JoystickController *)jc {
- return;
++ (Target *)targetDeserialize:(NSDictionary *)serialization
+ withConfigs:(NSArray *)configs {
+ TargetMouseMove *target = [[TargetMouseMove alloc] init];
+ target.axis = [serialization[@"axis"] intValue];
+ return target;
}
--(void) update: (JoystickController *)jc {
- //printf("Dir %d inputValue %f\n", [self dir], [self inputValue]);
- if (fabs([self inputValue]) < 0.01)
- return; // dead zone
+- (BOOL)update:(JoystickController *)jc {
+ if (fabsf(self.magnitude) < 0.01) {
+ sign = 0;
+ return NO; // dead zone
+ }
+
+ // If the action crossed over High/Low, this target is done.
+ if (!sign)
+ sign = self.magnitude < 0 ? -1 : 1;
+ else if (sign / self.magnitude < 0) {
+ sign = 0;
+ return NO;
+ }
- NSRect screenRect = [[NSScreen mainScreen] frame];
- NSInteger height = screenRect.size.height;
+ CGFloat height = NSScreen.mainScreen.frame.size.height;
// TODO
- double speed = 4.0;
- if ([jc frontWindowOnly])
- speed = 12.0;
- double dx = 0.0, dy = 0.0;
- if ([self dir] == 0)
- dx = [self inputValue] * speed;
+ float speed = 4.f;
+ if (jc.frontWindowOnly)
+ speed = 12.f;
+ float dx = 0.f, dy = 0.f;
+ if (_axis == 0)
+ dx = self.magnitude * speed;
else
- dy = [self inputValue] * speed;
- NSPoint *mouseLoc = &jc->mouseLoc;
- mouseLoc->x += dx;
- mouseLoc->y -= dy;
+ dy = self.magnitude * speed;
+ NSPoint mouseLoc = jc.mouseLoc;
+ mouseLoc.x += dx;
+ mouseLoc.y -= dy;
+ jc.mouseLoc = mouseLoc;
CGEventRef move = CGEventCreateMouseEvent(NULL, kCGEventMouseMoved,
- CGPointMake(mouseLoc->x, height - mouseLoc->y),
+ CGPointMake(mouseLoc.x, height - mouseLoc.y),
0);
CGEventSetType(move, kCGEventMouseMoved);
- CGEventSetIntegerValueField(move, kCGMouseEventDeltaX, dx);
- CGEventSetIntegerValueField(move, kCGMouseEventDeltaY, dy);
+ CGEventSetIntegerValueField(move, kCGMouseEventDeltaX, (int)dx);
+ CGEventSetIntegerValueField(move, kCGMouseEventDeltaY, (int)dy);
- if ([jc frontWindowOnly]) {
+ if (jc.frontWindowOnly) {
ProcessSerialNumber psn;
GetFrontProcess(&psn);
CGEventPostToPSN(&psn, move);
}
CFRelease(move);
+ return YES;
}
@end