aboutsummaryrefslogtreecommitdiff
path: root/AppKit/GTMNSAnimation+Duration.m
diff options
context:
space:
mode:
authorGravatar gtm.daemon <gtm.daemon@7dc7ac4e-7543-0410-b95c-c1676fc8e2a3>2010-03-10 18:33:34 +0000
committerGravatar gtm.daemon <gtm.daemon@7dc7ac4e-7543-0410-b95c-c1676fc8e2a3>2010-03-10 18:33:34 +0000
commit332accd330b679f8ccb0ed0c8916439a39347711 (patch)
treeb2995f4995097fe875d6ac644782767eeeecc765 /AppKit/GTMNSAnimation+Duration.m
parent13b87870c8cf9d5445a1da6d20d142d43ac9c2e8 (diff)
[Author: dmaclach]
Change over animation so it will work with other event types than just mouse downs. R=thomasvl DELTA=33 (16 added, 1 deleted, 16 changed)
Diffstat (limited to 'AppKit/GTMNSAnimation+Duration.m')
-rw-r--r--AppKit/GTMNSAnimation+Duration.m39
1 files changed, 25 insertions, 14 deletions
diff --git a/AppKit/GTMNSAnimation+Duration.m b/AppKit/GTMNSAnimation+Duration.m
index 884cd32..c47772b 100644
--- a/AppKit/GTMNSAnimation+Duration.m
+++ b/AppKit/GTMNSAnimation+Duration.m
@@ -6,9 +6,9 @@
// Licensed under the Apache License, Version 2.0 (the "License"); you may not
// use this file except in compliance with the License. You may obtain a copy
// of the License at
-//
+//
// http://www.apache.org/licenses/LICENSE-2.0
-//
+//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
@@ -18,13 +18,16 @@
#import "GTMNSAnimation+Duration.h"
-NSTimeInterval GTMModifyDurationBasedOnCurrentState(NSTimeInterval duration) {
+const NSUInteger kGTMLeftMouseDownAndKeyDownMask
+ = NSLeftMouseDownMask | NSKeyDownMask;
+
+NSTimeInterval GTMModifyDurationBasedOnCurrentState(NSTimeInterval duration,
+ NSUInteger eventMask) {
NSEvent *event = [NSApp currentEvent];
- if ([event type] == NSLeftMouseUp) {
+ if (eventMask & NSEventMaskFromType([event type])) {
NSUInteger modifiers = [event modifierFlags];
if (!(modifiers & (NSAlternateKeyMask |
- NSCommandKeyMask |
- NSFunctionKeyMask))) {
+ NSCommandKeyMask))) {
if (modifiers & NSShiftKeyMask) {
duration *= 5.0;
}
@@ -39,14 +42,18 @@ NSTimeInterval GTMModifyDurationBasedOnCurrentState(NSTimeInterval duration) {
@implementation NSAnimation (GTMNSAnimationDurationAdditions)
-- (id)gtm_initWithDuration:(NSTimeInterval)duration
+- (id)gtm_initWithDuration:(NSTimeInterval)duration
+ eventMask:(NSUInteger)eventMask
animationCurve:(NSAnimationCurve)animationCurve {
- return [self initWithDuration:GTMModifyDurationBasedOnCurrentState(duration)
+ return [self initWithDuration:GTMModifyDurationBasedOnCurrentState(duration,
+ eventMask)
animationCurve:animationCurve];
}
-- (void)gtm_setDuration:(NSTimeInterval)duration {
- [self setDuration:GTMModifyDurationBasedOnCurrentState(duration)];
+- (void)gtm_setDuration:(NSTimeInterval)duration
+ eventMask:(NSUInteger)eventMask {
+ [self setDuration:GTMModifyDurationBasedOnCurrentState(duration,
+ eventMask)];
}
@end
@@ -55,16 +62,20 @@ NSTimeInterval GTMModifyDurationBasedOnCurrentState(NSTimeInterval duration) {
@implementation NSAnimationContext (GTMNSAnimationDurationAdditions)
-- (void)gtm_setDuration:(NSTimeInterval)duration {
- [self setDuration:GTMModifyDurationBasedOnCurrentState(duration)];
+- (void)gtm_setDuration:(NSTimeInterval)duration
+ eventMask:(NSUInteger)eventMask {
+ [self setDuration:GTMModifyDurationBasedOnCurrentState(duration,
+ eventMask)];
}
@end
@implementation CAAnimation (GTMCAAnimationDurationAdditions)
-- (void)gtm_setDuration:(CFTimeInterval)duration {
- [self setDuration:GTMModifyDurationBasedOnCurrentState(duration)];
+- (void)gtm_setDuration:(CFTimeInterval)duration
+ eventMask:(NSUInteger)eventMask {
+ [self setDuration:GTMModifyDurationBasedOnCurrentState(duration,
+ eventMask)];
}
@end