/usr/include/GNUstep/GNUstepGUI/GSAnimator.h is in libgnustep-gui-dev 0.22.0-1ubuntu2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 | /*
GSAnimator.h
Author: Xavier Glattard (xgl) <xavier.glattard@online.fr>
Copyright (c) 2007 Free Software Foundation, Inc.
This file is part of the GNUstep GUI Library.
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; see the file COPYING.LIB.
If not, see <http://www.gnu.org/licenses/> or write to the
Free Software Foundation, 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#ifndef _GNUstep_H_GSAnimator_
#define _GNUstep_H_GSAnimator_
#import <Foundation/NSDate.h>
#import <Foundation/NSObject.h>
#import <Foundation/NSZone.h>
@class NSArray;
@class NSEvent;
@class NSRunLoop;
@class NSString;
@class NSTimer;
/**
* Protocol that needs to be adopted by classes that want to
* be animated by a GSAnimator.
*/
@protocol GSAnimation
/** Call back method indicating that the GSAnimator did start the
* animation loop. */
- (void) animatorDidStart;
/** Call back method indicating that the GSAnimator did stop the
* animation loop. */
- (void) animatorDidStop;
/** Call back method called for each animation loop. */
- (void) animatorStep: (NSTimeInterval)elapsedTime;
@end
/**
* GSAnimator is the front of a class cluster. Instances of a subclass of
* GSAnimator manage the timing of an animation.
*/
@interface GSAnimator : NSObject
{
id<GSAnimation> _animation; // The Object to be animated
BOOL _running; // Indicates that the animator is looping
NSTimeInterval _elapsed; // Elapsed time since the animator started
NSTimeInterval _lastFrame; // The time of the last animation loop
unsigned int _frameCount; // The number of loops since the start
NSArray *_runLoopModes;
NSTimer *_timer; // Timer used for looping
NSTimeInterval _timerInterval;
}
/** Returns a GSAnimator object initialized with the specified object
* to be animated as fast as possible. */
+ (GSAnimator*) animatorWithAnimation: (id<GSAnimation>)anAnimation;
/** Returns a GSAnimator object initialized with the specified object
* to be animated. */
+ (GSAnimator*) animatorWithAnimation: (id<GSAnimation>)anAnimation
frameRate: (float)fps;
/** Returns a GSAnimator object allocated in the given NSZone and
* initialized with the specified object to be animated. */
+ (GSAnimator*) animatorWithAnimation: (id<GSAnimation>)anAnimation
frameRate: (float)fps
zone: (NSZone*)aZone;
/** Returns a GSAnimator object initialized with the specified object
* to be animated. The given NSRunLoop is used in NSDefaultRunLoopMode.*/
- (GSAnimator*) initWithAnimation: (id<GSAnimation>)anAnimation
frameRate: (float)aFrameRate;
- (GSAnimator*) initWithAnimation: (id<GSAnimation>)anAnimation;
- (unsigned int) frameCount;
- (void) resetCounters;
- (float) frameRate;
- (NSArray*) runLoopModesForAnimating;
- (void) setRunLoopModesForAnimating: (NSArray*)modes;
- (void) startAnimation;
- (void) stopAnimation;
- (BOOL) isAnimationRunning;
- (void) startStopAnimation;
- (void) stepAnimation;
@end
#endif /* _GNUstep_H_GSAnimator_ */
|