X-Git-Url: https://git.yukkurigames.com/?p=enjoyable.git;a=blobdiff_plain;f=TargetMouseScroll.m;h=6595628002913477619858d8264a941826ab34ad;hp=6986004b4b7bac8c6f4e43c4cb2bca48a1f56452;hb=1bb3f553caac2b6b74380bd20ddc4bb1ff22abb2;hpb=15a3aec049658f4a1c3c6e8c9f8a549fb8de0782 diff --git a/TargetMouseScroll.m b/TargetMouseScroll.m index 6986004..6595628 100644 --- a/TargetMouseScroll.m +++ b/TargetMouseScroll.m @@ -3,12 +3,13 @@ // Enjoy // // Created by Yifeng Huang on 7/28/12. -// Copyright (c) 2012 __MyCompanyName__. All rights reserved. // #import "TargetMouseScroll.h" -@implementation TargetMouseScroll +@implementation TargetMouseScroll { + int sign; +} + (NSString *)serializationCode { return @"mscroll"; @@ -24,13 +25,45 @@ target.amount = [serialization[@"amount"] intValue]; return target; } --(void) trigger { + +- (void)trigger { + if (!self.magnitude) { + CGEventRef scroll = CGEventCreateScrollWheelEvent(NULL, + kCGScrollEventUnitLine, + 1, + _amount); + CGEventPost(kCGHIDEventTap, scroll); + CFRelease(scroll); + } +} + +- (BOOL)update:(JoystickController *)jc { + if (fabsf(self.magnitude) < 0.01f) { + 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; + } + + int amount = (int)(16.f * fabsf(self.magnitude) * _amount); CGEventRef scroll = CGEventCreateScrollWheelEvent(NULL, - kCGScrollEventUnitLine, + kCGScrollEventUnitPixel, 1, - _amount); + amount); CGEventPost(kCGHIDEventTap, scroll); CFRelease(scroll); + + return YES; +} + +- (BOOL)isContinuous { + return YES; } @end