projects
/
enjoyable.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix memory leak.
[enjoyable.git]
/
TargetMouseMove.m
diff --git
a/TargetMouseMove.m
b/TargetMouseMove.m
index
8eeae88
..
893bbb6
100644
(file)
--- a/
TargetMouseMove.m
+++ b/
TargetMouseMove.m
@@
-10,43
+10,54
@@
#import "JoystickController.h"
#import "JoystickController.h"
-@implementation TargetMouseMove
+@implementation TargetMouseMove {
+ int sign;
+}
-(BOOL) isContinuous {
-(BOOL) isContinuous {
- return
true
;
+ return
YES
;
}
}
-@synthesize
dir
;
+@synthesize
axis
;
+ (NSString *)serializationCode {
return @"mmove";
}
- (NSDictionary *)serialize {
+ (NSString *)serializationCode {
return @"mmove";
}
- (NSDictionary *)serialize {
- return @{ @"type": @"mmove", @"
dir": @(self.dir
) };
+ return @{ @"type": @"mmove", @"
axis": @(self.axis
) };
}
+ (Target *)targetDeserialize:(NSDictionary *)serialization
withConfigs:(NSArray *)configs {
TargetMouseMove *target = [[TargetMouseMove alloc] init];
}
+ (Target *)targetDeserialize:(NSDictionary *)serialization
withConfigs:(NSArray *)configs {
TargetMouseMove *target = [[TargetMouseMove alloc] init];
- target.
dir = [serialization[@"dir
"] intValue];
+ target.
axis = [serialization[@"axis
"] intValue];
return target;
}
- (BOOL)update:(JoystickController *)jc {
return target;
}
- (BOOL)update:(JoystickController *)jc {
- //printf("Dir %d inputValue %f\n", [self dir], [self inputValue]);
- if (fabs(self.magnitude) < 0.01)
+ if (fabsf(self.magnitude) < 0.01) {
+ sign = 0;
return NO; // dead zone
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;
// TODO
NSRect screenRect = [[NSScreen mainScreen] frame];
NSInteger height = screenRect.size.height;
// TODO
- float speed = 4.
0
;
+ float speed = 4.
f
;
if ([jc frontWindowOnly])
if ([jc frontWindowOnly])
- speed = 12.
0
;
- float dx = 0.
0, dy = 0.0
;
- if (
[self dir]
== 0)
+ speed = 12.
f
;
+ float dx = 0.
f, dy = 0.f
;
+ if (
axis
== 0)
dx = self.magnitude * speed;
else
dy = self.magnitude * speed;
dx = self.magnitude * speed;
else
dy = self.magnitude * speed;
@@
-72,7
+83,7
@@
}
CFRelease(move);
}
CFRelease(move);
- return
dx || dy
;
+ return
YES
;
}
@end
}
@end