MYAnimatingSplitView.h
changeset 32 222393534845
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/MYAnimatingSplitView.h	Wed May 20 08:34:04 2009 -0700
     1.3 @@ -0,0 +1,43 @@
     1.4 +//
     1.5 +//  MYAnimatingSplitView.h
     1.6 +//  Cloudy
     1.7 +//
     1.8 +//  Created by Jens Alfke on 7/10/08.
     1.9 +//  Copyright 2008 Jens Alfke. All rights reserved.
    1.10 +//
    1.11 +
    1.12 +#import <AppKit/NSSplitView.h>
    1.13 +
    1.14 +
    1.15 +@interface MYAnimatingSplitView : NSSplitView
    1.16 +{
    1.17 +    NSTimeInterval _animationTime;
    1.18 +    BOOL _isLiveResizing;
    1.19 +}
    1.20 +
    1.21 +
    1.22 +/** The maximum time it will take to animate the divider. (Actual time depends on distance moved.) */
    1.23 +@property NSTimeInterval animationTime;
    1.24 +
    1.25 +/** Pixel position of the divider (in the splitview's bounds' coordinate system.)
    1.26 +    Setting this property animates the divider to the new position. */
    1.27 +@property float dividerPosition;
    1.28 +
    1.29 +/** Position of the divider, scaled to the range [0..1]. */
    1.30 +@property float dividerFractionalPosition;
    1.31 +
    1.32 +- (void) collapseSubviewAtIndex: (int)index;
    1.33 +- (void) collapseSubviewAtIndex: (int)index animate: (BOOL)animate;
    1.34 +
    1.35 +/** Returns YES while the splitview itself is being resized (i.e. while the window
    1.36 +    is resizing, or a parent splitview is moving its divider.) */
    1.37 +@property (readonly) BOOL isLiveResizing;
    1.38 +
    1.39 +@end
    1.40 +
    1.41 +
    1.42 +@interface NSObject (MYAnimatingSplitViewDelegate)
    1.43 +/** If the delegate implements this method, it will be called when the splitview
    1.44 +    begins and ends live resizing. */
    1.45 +- (void)splitView: (NSSplitView*)splitView inLiveResize: (BOOL)inLiveResize;
    1.46 +@end