Positioning Fixes. The window might still do some weirdness if you change its positi...
[ITKit.git] / ITPivotWindowEffect.m
index 2c87f68..373c5f3 100755 (executable)
@@ -6,30 +6,69 @@
 @interface ITPivotWindowEffect (Private)
 - (void)setPivot:(float)angle;
 - (void)performAppearFromProgress:(float)progress effectTime:(float)time;
-- (void)performVanishFromProgress:(float)progress effectTime:(float)time;
+- (void)appearStep;
 - (void)appearFinish;
+- (void)performVanishFromProgress:(float)progress effectTime:(float)time;
+- (void)vanishStep;
 - (void)vanishFinish;
 @end
 
 
 @implementation ITPivotWindowEffect
 
+
++ (NSString *)effectName
+{
+    return @"Pivot";
+}
+
++ (NSDictionary *)supportedPositions
+{
+    return [NSDictionary dictionaryWithObjectsAndKeys:
+        [NSDictionary dictionaryWithObjectsAndKeys:
+            [NSNumber numberWithBool:YES], @"Left",
+            [NSNumber numberWithBool:NO], @"Center",
+            [NSNumber numberWithBool:YES], @"Right", nil] , @"Top" ,
+        [NSDictionary dictionaryWithObjectsAndKeys:
+            [NSNumber numberWithBool:NO], @"Left",
+            [NSNumber numberWithBool:NO], @"Center",
+            [NSNumber numberWithBool:NO], @"Right", nil] , @"Middle" ,
+        [NSDictionary dictionaryWithObjectsAndKeys:
+            [NSNumber numberWithBool:YES], @"Left",
+            [NSNumber numberWithBool:NO], @"Center",
+            [NSNumber numberWithBool:YES], @"Right", nil] , @"Bottom" , nil];
+}
+
+
++ (unsigned int)listOrder
+{
+    return 500;
+}
+
+
+/*************************************************************************/
+#pragma mark -
+#pragma mark APPEAR METHODS
+/*************************************************************************/
+
 - (void)performAppear
 {
-    [self setWindowVisibility:ITTransientStatusWindowAppearingState];
+    __idle = NO;
+    
+    [self setWindowVisibility:ITWindowAppearingState];
     [self performAppearFromProgress:0.0 effectTime:_effectTime];
 }
 
 - (void)performAppearFromProgress:(float)progress effectTime:(float)time
 {
-    _effectProgress = progress;
+    [_window setEffectProgress:progress];
     _effectSpeed = (1.0 / (EFFECT_FPS * time));
     
     if ( progress == 0.0 ) {
         [self setPivot:315.0];
         [_window setAlphaValue:0.0];
     }
-
+    
     [_window orderFront:self];
     _effectTimer = [NSTimer scheduledTimerWithTimeInterval:(1.0 / EFFECT_FPS)
                                                     target:self
                                                    repeats:YES];
 }
 
-- (void)performVanish
+- (void)appearStep
 {
-    [self setWindowVisibility:ITTransientStatusWindowVanishingState];
-    [self performVanishFromProgress:1.0 effectTime:_effectTime];
+    float interPivot = 0.0;
+    float progress   = ([_window effectProgress] + _effectSpeed);
+    
+    progress = ( (progress < 1.0) ? progress : 1.0 );
+    
+    [_window setEffectProgress:progress];
+    
+    interPivot = (( sin((progress * pi) - (pi / 2)) + 1 ) / 2);
+    [self setPivot:(315 + (interPivot * 45))];
+    [_window setAlphaValue:interPivot];
+    
+    if ( progress >= 1.0 ) {
+        [self appearFinish];
+    }
 }
 
-- (void)performVanishFromProgress:(float)progress effectTime:(float)time
+- (void)appearFinish
 {
-    _effectProgress = progress;
-    _effectSpeed = (1.0 / (EFFECT_FPS * time));
-    if ( progress == 1.0 ) {
-        [self setPivot:0.0];
-        [_window setAlphaValue:1.0];
+    [_effectTimer invalidate];
+    _effectTimer = nil;
+    [self setWindowVisibility:ITWindowVisibleState];
+    
+    __idle = YES;
+    
+    if ( __shouldReleaseWhenIdle ) {
+        [self release];
     }
-
-    [_window orderFront:self];
-    _effectTimer = [NSTimer scheduledTimerWithTimeInterval:(1.0 / EFFECT_FPS)
-                                                    target:self
-                                                  selector:@selector(vanishStep)
-                                                  userInfo:nil
-                                                   repeats:YES];
 }
 
 - (void)cancelAppear
 {
-    [self setWindowVisibility:ITTransientStatusWindowVanishingState];
+    [self setWindowVisibility:ITWindowVanishingState];
     
     [_effectTimer invalidate];
     _effectTimer = nil;
     
-    [self performVanishFromProgress:_effectProgress effectTime:(_effectTime / 3.5)];
+    [self performVanishFromProgress:[_window effectProgress] effectTime:(_effectTime / 3.5)];
 }
 
-- (void)cancelVanish
-{
-    [self setWindowVisibility:ITTransientStatusWindowAppearingState];
 
-    [_effectTimer invalidate];
-    _effectTimer = nil;
+/*************************************************************************/
+#pragma mark -
+#pragma mark VANISH METHODS
+/*************************************************************************/
 
-    [self performAppearFromProgress:_effectProgress effectTime:(_effectTime / 3.5)];
+- (void)performVanish
+{
+    __idle = NO;
+    
+    [self setWindowVisibility:ITWindowVanishingState];
+    [self performVanishFromProgress:1.0 effectTime:_effectTime];
 }
 
-- (void)appearStep
+- (void)performVanishFromProgress:(float)progress effectTime:(float)time
 {
-    float interPivot = 0.0;
-    _effectProgress += _effectSpeed;
-    _effectProgress = (_effectProgress < 1.0 ? _effectProgress : 1.0);
-    interPivot = (( sin((_effectProgress * pi) - (pi / 2)) + 1 ) / 2);
-    [self setPivot:((interPivot * 45) + 315)];
-    [_window setAlphaValue:interPivot];
-
-    if ( _effectProgress >= 1.0 ) {
-        [self appearFinish];
+    [_window setEffectProgress:progress];
+    _effectSpeed = (1.0 / (EFFECT_FPS * time));
+    if ( progress == 1.0 ) {
+        [self setPivot:0.0];
+        [_window setAlphaValue:1.0];
     }
+    
+    [_window orderFront:self];
+    _effectTimer = [NSTimer scheduledTimerWithTimeInterval:(1.0 / EFFECT_FPS)
+                                                    target:self
+                                                  selector:@selector(vanishStep)
+                                                  userInfo:nil
+                                                   repeats:YES];
 }
 
 - (void)vanishStep
 {
     float interPivot = 1.0;
-    _effectProgress -= _effectSpeed;
-    _effectProgress = (_effectProgress > 0.0 ? _effectProgress : 0.0);
-    interPivot = (( sin((_effectProgress * pi) - (pi / 2)) + 1 ) / 2);
-    [self setPivot:((interPivot * 45) + 315)];
+    float progress   = ([_window effectProgress] - _effectSpeed);
+    
+    progress = ( (progress > 0.0) ? progress : 0.0);
+    
+    [_window setEffectProgress:progress];
+    
+    interPivot = (( sin(([_window effectProgress] * pi) - (pi / 2)) + 1 ) / 2);
+    [self setPivot:(315 + (interPivot * 45))];
     [_window setAlphaValue:interPivot];
-
-    if ( _effectProgress <= 0.0 ) {
+    
+    if ( progress <= 0.0 ) {
         [self vanishFinish];
     }
 }
 
-- (void)appearFinish
+- (void)vanishFinish
 {
     [_effectTimer invalidate];
     _effectTimer = nil;
-    [self setWindowVisibility:ITTransientStatusWindowVisibleState];
+    [_window orderOut:self];
+    [_window setAlphaValue:1.0];
+    [self setPivot:0.0];
+    [self setWindowVisibility:ITWindowHiddenState];
+    
+    __idle = YES;
+    
+    if ( __shouldReleaseWhenIdle ) {
+        [self release];
+    }
 }
 
-- (void)vanishFinish
+- (void)cancelVanish
 {
+    [self setWindowVisibility:ITWindowAppearingState];
+    
     [_effectTimer invalidate];
     _effectTimer = nil;
-    [self setWindowVisibility:ITTransientStatusWindowHiddenState];
+    
+    [self performAppearFromProgress:[_window effectProgress] effectTime:(_effectTime / 3.5)];
 }
 
+
+/*************************************************************************/
+#pragma mark -
+#pragma mark PRIVATE METHOD IMPLEMENTATIONS
+/*************************************************************************/
+
 - (void)setPivot:(float)angle
 {
-    float degAngle = (angle * (pi / 180));
+    int hPos = [_window horizontalPosition];
+    int vPos = [_window verticalPosition];
 
-    CGAffineTransform transform = CGAffineTransformMakeRotation(degAngle);
+    if ( (hPos == ITWindowPositionCenter) || (vPos == ITWindowPositionMiddle) ) {
     
- // Set pivot rotation point
-    transform.tx = -32.0;
-    transform.ty = [_window frame].size.height + 32.0;
+        CGAffineTransform transform;
+        NSPoint translation;
+        
+        translation.x = ( -([_window frame].origin.x) ) ;
+        translation.y = -( [[_window screen] frame].size.height - [_window frame].origin.y - [_window frame].size.height );
 
-    CGSSetWindowTransform([NSApp contextID],
-                          (CGSWindowID)[_window windowNumber],
-                          CGAffineTransformTranslate(transform,
-                                                     (([_window frame].origin.x - 32.0) * -1),
-                                                     (([[_window screen] frame].size.height - ([_window frame].origin.y) + 32.0) * -1) ));
+        transform = CGAffineTransformMakeTranslation( translation.x, translation.y );
+        
+        CGSSetWindowTransform([NSApp contextID],
+                              (CGSWindowID)[_window windowNumber],
+                              transform);
+    } else {
+        
+        float  degAngle;
+        NSRect windowFrame = [_window frame];
+        NSRect screenFrame = [[_window screen] frame];
+        float  translateX;
+        float  translateY;
+        CGAffineTransform transform;
+        
+        if ( vPos == ITWindowPositionBottom ) {
+            if ( hPos == ITWindowPositionLeft ) {
+                angle = angle;
+            } else if ( hPos == ITWindowPositionRight ) {
+                angle = ( 45 - -(315 - angle) );
+            }
+        } else if ( vPos == ITWindowPositionTop ) {
+            if ( hPos == ITWindowPositionLeft ) {
+                angle = ( 45 - -(315 - angle) );
+            } else if ( hPos == ITWindowPositionRight ) {
+                angle = angle;
+            }
+        }
+        
+        degAngle  = (angle * (pi / 180));
+        transform = CGAffineTransformMakeRotation(degAngle);
+        
+        if ( vPos == ITWindowPositionBottom ) {
+            transform.ty = ( windowFrame.size.height + windowFrame.origin.y);
+            translateY   = -(screenFrame.size.height);
+        } else if ( vPos == ITWindowPositionTop ) {
+            transform.ty = -( screenFrame.size.height - windowFrame.origin.y - windowFrame.size.height );
+            translateY   = 0;
+        }
+        
+        if ( hPos == ITWindowPositionLeft ) {
+            transform.tx = -( windowFrame.origin.x );
+            translateX   = 0;
+        } else if ( hPos == ITWindowPositionRight ) {
+            transform.tx = ( screenFrame.size.width - windowFrame.origin.x );
+            translateX   = -(screenFrame.size.width);
+        }
+        
+        CGSSetWindowTransform([NSApp contextID],
+                              (CGSWindowID)[_window windowNumber],
+                              CGAffineTransformTranslate( transform,
+                                                          translateX,
+                                                          translateY ) );
+    }
 }