/* |
File: SlideshowView.h |
Abstract: A SlideshowView displays a single NSImage at a time, and can transition to a new image using any of the Core Animation / Core Image supported transition effects. |
|
Version: 1.5 |
|
Disclaimer: IMPORTANT: This Apple software is supplied to you by Apple |
Inc. ("Apple") in consideration of your agreement to the following |
terms, and your use, installation, modification or redistribution of |
this Apple software constitutes acceptance of these terms. If you do |
not agree with these terms, please do not use, install, modify or |
redistribute this Apple software. |
|
In consideration of your agreement to abide by the following terms, and |
subject to these terms, Apple grants you a personal, non-exclusive |
license, under Apple's copyrights in this original Apple software (the |
"Apple Software"), to use, reproduce, modify and redistribute the Apple |
Software, with or without modifications, in source and/or binary forms; |
provided that if you redistribute the Apple Software in its entirety and |
without modifications, you must retain this notice and the following |
text and disclaimers in all such redistributions of the Apple Software. |
Neither the name, trademarks, service marks or logos of Apple Inc. may |
be used to endorse or promote products derived from the Apple Software |
without specific prior written permission from Apple. Except as |
expressly stated in this notice, no other rights or licenses, express or |
implied, are granted by Apple herein, including but not limited to any |
patent rights that may be infringed by your derivative works or by other |
works in which the Apple Software may be incorporated. |
|
The Apple Software is provided by Apple on an "AS IS" basis. APPLE |
MAKES NO WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION |
THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY AND FITNESS |
FOR A PARTICULAR PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND |
OPERATION ALONE OR IN COMBINATION WITH YOUR PRODUCTS. |
|
IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL |
OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, |
MODIFICATION AND/OR DISTRIBUTION OF THE APPLE SOFTWARE, HOWEVER CAUSED |
AND WHETHER UNDER THEORY OF CONTRACT, TORT (INCLUDING NEGLIGENCE), |
STRICT LIABILITY OR OTHERWISE, EVEN IF APPLE HAS BEEN ADVISED OF THE |
POSSIBILITY OF SUCH DAMAGE. |
|
Copyright (C) 2013 Apple Inc. All Rights Reserved. |
|
*/ |
|
#import <Cocoa/Cocoa.h> |
|
@class CIImage; |
@class CATransition; |
|
// SlideshowView demonstrates the use of CATransition animations with a layer-backed view subtree. |
// A SlideshowView displays a single NSImage at a time, and can be asked to switch to a |
// different NSImage via the -transitionToImage: method. |
|
// Following is the set of transition styles that SlideshowView supports. Some map to |
// Core Animation's built-in transition types; the rest are implemented using Core Image's |
// standard set of transition filters. |
|
typedef enum { |
// Core Animation's four built-in transition types |
SlideshowViewFadeTransitionStyle, |
SlideshowViewMoveInTransitionStyle, |
SlideshowViewPushTransitionStyle, |
SlideshowViewRevealTransitionStyle, |
|
// Core Image's standard set of transition filters |
SlideshowViewCopyMachineTransitionStyle, |
SlideshowViewDisintegrateWithMaskTransitionStyle, |
SlideshowViewDissolveTransitionStyle, |
SlideshowViewFlashTransitionStyle, |
SlideshowViewModTransitionStyle, |
SlideshowViewPageCurlTransitionStyle, |
SlideshowViewRippleTransitionStyle, |
SlideshowViewSwipeTransitionStyle, |
|
NumberOfSlideshowViewTransitionStyles |
} SlideshowViewTransitionStyle; |
|
@interface SlideshowView : NSView { |
|
NSImageView *currentImageView; // an NSImageView that displays the current image, as a subview of the SlideshowView |
NSInteger transitionStyle; // the style of transition to use; one of the SlideshowViewTransitionStyle values enumerated above |
BOOL autoCyclesTransitionStyle; // set if we should automatically cycle our transitionStyle |
CIImage *inputShadingImage; // an environment-map image that the transition filter may use in generating the transition effect |
CIImage *inputMaskImage; // a mask image that the transition filter may use in generating the transition effect |
} |
|
- (id)initWithFrame:(NSRect)newFrame; |
|
- (SlideshowViewTransitionStyle)transitionStyle; |
- (void)setTransitionStyle:(SlideshowViewTransitionStyle)newTransitionStyle; |
|
- (BOOL)autoCyclesTransitionStyle; |
- (void)setAutoCyclesTransitionStyle:(BOOL)flag; |
|
- (void)transitionToImage:(NSImage *)newImage; |
|
@end |