home *** CD-ROM | disk | FTP | other *** search
/ Celestin Apprentice 2 / Apprentice-Release2.iso / Source Code / Libraries / SAT 2.3a1 / SAT Think Lib ƒ / SAT.h next >
Encoding:
Text File  |  1994-11-17  |  8.6 KB  |  245 lines  |  [TEXT/KAHL]

  1. /* #include file for the C interface to SAT */
  2.  
  3. /* Comment out under TC5: */
  4. /*#include <Color.h>*/
  5. /*#include <WindowMgr.h>*/
  6. /*#include <DialogMgr.h>*/
  7.  
  8. // Will it work with C++ if I do like this?
  9. #pragma once
  10. #ifdef _cplusplus
  11. extern "C" {
  12. #endif
  13.  
  14. #ifndef true
  15. #define true 1
  16. #endif
  17.  
  18. #ifndef false
  19. #define false 0
  20. #endif
  21.  
  22. #ifndef nil
  23. #define nil 0L
  24. #endif
  25.  
  26.     typedef struct Face {
  27.         char            *colorData;
  28.         short            resNum;
  29.         BitMap        iconMask;
  30.         short            rowBytes; /* Note! No flags in the highest bits!*/
  31.         struct face    *next;
  32.         RgnHandle        maskRgn;
  33.         } Face, *FacePtr;
  34.  
  35.     typedef struct Sprite {
  36. /* Variables that you should change as appropriate */
  37.         short            kind;
  38.         Point            position;
  39.         Rect            hotRect, hotRect2;    // Only change hotRect, SAT handles hotRect2
  40.         FacePtr            face;
  41.         pascal void        (*task) (struct Sprite *);
  42.         pascal void        (*hitTask) (struct Sprite *, struct Sprite *);
  43.         pascal void        (*destructTask) (struct Sprite *);
  44.         RgnHandle        clip; /* Clip region to be used when this sprite is drawn. */
  45. /* SAT variables that you shouldn't change: */
  46.         Point            oldpos;
  47.         struct Sprite    *next, *prev;
  48.         Rect            r, oldr;
  49.         FacePtr        oldFace;            //Used by RunSAT2
  50.         Boolean        dirty;        //Used by RunSAT2
  51. /* Variables for free use by the application: */
  52.         short        layer;
  53.         Point            speed;
  54.         short        mode;
  55.         Ptr            appPtr;
  56.         long            appLong;
  57.         } Sprite, *SpritePtr;
  58.  
  59. typedef struct{
  60.         short    patternType;     /* 1 = Pattern, PatHandle, 2 = PixPat, PixPatHandle */
  61.         PixPatHandle    thePat;         /* or PatHandle */
  62.         }    SATPattern, *SATPatPtr, **SATPatHandle;
  63.  
  64. #define    UpdatePtr    Ptr
  65.  
  66. typedef struct {
  67.         WindowPtr    wind;
  68.         short        offSizeH, offSizeV;
  69.         GrafPtr        offScreen, backScreen;
  70.         GDHandle        offScreenGD, backScreenGD;
  71.         long            ox, oy;
  72.         short        pict, bwpict;
  73.         Boolean        fitThePICTs;
  74.         short        sorting, collision, searchWidth;
  75.         GDHandle        device;
  76.         PixMapHandle    screen;
  77.         Rect            bounds;
  78.         short        initDepth;
  79.         pascal Boolean    (*synchHook) ();
  80.         SpritePtr        sRoot;
  81.         UpdatePtr        updateRoot;
  82.         Boolean        anyMonsters;
  83.  
  84.         CGrafPtr        ditherOff;
  85.         GDHandle        ditherOffGD;
  86.         CGrafPtr        iconPort;
  87.         GDHandle        iconPortGD;
  88.         CGrafPtr        iconPort2;
  89.         GDHandle        iconPort2GD;
  90.         GrafPtr            bwIconPort;
  91.  
  92. /* Environment-independent globals: */
  93.         FacePtr            faceRoot;    /* Face list */
  94.         Boolean            colorFlag; /* Is this Mac color capable? */
  95.         } SATglobalsRec;
  96.  
  97. /* Constants for SATConfigure */
  98.     enum{kVPositionSort=0, kLayerSort, kNoSort};
  99.     enum{kKindCollision=0, kForwardCollision, kBackwardCollision, kNoCollision, kForwardOneCollision};
  100.  
  101. /* Global variables */
  102.     extern SATglobalsRec    gSAT;    /* Most globals */
  103.     extern pascal void        (*gSoundErrorProc)(OSErr); /* Sound errors reported here */
  104.  
  105. /* SAT routines */
  106.  
  107.     typedef pascal void (*TaskPtr)(SpritePtr);
  108.     typedef pascal Boolean (*SynchPtr)(void);
  109.     typedef pascal void (*EmergencyPtr)(void);
  110.  
  111. /* Initialization */
  112.     pascal void SATConfigure(Boolean, short, short, short);
  113.     pascal void SATInit (short, short, short, short);
  114.     pascal void SATCustomInit (short, short, Rect *, WindowPtr, GDHandle, Boolean, Boolean, Boolean, Boolean, Boolean);
  115. /* Maintainance, background manipulation etc. */
  116.     pascal Boolean SATDepthChangeTest(void);
  117.     pascal void SATDrawPICTs (short, short);
  118.     pascal void SATRedraw(void);
  119. /* Drawing */
  120.     pascal void SATPlotFace(FacePtr, GrafPtr, GDHandle, Point, Boolean); /*Draw a Face (icon).*/
  121.     pascal void SATPlotFaceToScreen(FacePtr, Point, Boolean);
  122.     pascal void SATCopyBits(GrafPtr, GrafPtr, GDHandle, Rect*, Rect*, Boolean);
  123.     pascal void SATCopyBitsToScreen(GrafPtr, Rect, Rect, Boolean);
  124.     pascal void SATBackChanged (Rect *); /*Tell SAT about changes in BackScreen*/
  125. /* SetPort replacements */
  126.     pascal void SATGetPort (GrafPtr*,  GDHandle*);
  127.     pascal void SATSetPort (GrafPtr, GDHandle);
  128.     pascal void SATSetPortOffScreen(void); /*Use before Quick-Drawing on offScreen*/
  129.     pascal void SATSetPortBackScreen(void); /*Use before Quick-Drawing on BackScreen*/
  130.     pascal void SATSetPortScreen(void); /*Use to restore after drawing off/backscreen*/
  131. /* Sprite handling */
  132.     pascal FacePtr SATGetFace (short);
  133.     pascal void SATDisposeFace (FacePtr);
  134.     pascal SpritePtr SATNewSprite (short,short,short, TaskPtr); // (*void)(SpritePtr));
  135.     pascal SpritePtr SATNewSpriteAfter (SpritePtr,short,short,short, TaskPtr);
  136.     pascal void SATKillSprite (SpritePtr);
  137. /* Animating */
  138.     pascal void SATRun (Boolean);
  139.     pascal void    SATRun2 (Boolean); //Alternate routine for allowing resting sprites}
  140. /* Advanced special-purpose calls */
  141.     pascal void SATInstallSynch (SynchPtr);
  142.     pascal void SATInstallEmergency (EmergencyPtr);
  143.     pascal void SATSetSpriteRecSize (long);
  144.     pascal void SATSkip(void);
  145.     pascal void SATKill(void); /*Dispose of offscreen buffers to allow re-init*/
  146. /* Offscreen - use only if you need an *extra* offscreen buffer. These calls are likely to change in the future!*/
  147.     pascal void SATMakeOffscreen (GrafPtr*, Rect*, GDHandle*);    /*Make offscreen buffer in current screen depth and CLUT.*/
  148.     pascal void SATDisposeOffScreen (GrafPtr*, GDHandle);        /*Get rid of offscreen*/
  149.     pascal OSErr CreateOffScreen (Rect*, short, CTabHandle, CGrafPtr*, GDHandle*); /*From Principia Offscreen*/
  150.     pascal void DisposeOffScreen (CGrafPtr, GDHandle);            /*From Principia Offscreen*/
  151. /* Face manipulation */
  152.     pascal void SATSetPortMask (FacePtr);
  153.     pascal void SATSetPortFace (FacePtr);
  154.     pascal void SATSetPortFace2 (FacePtr);
  155.     pascal FacePtr SATNewFace (Rect*);
  156.     pascal void SATChangedFace (FacePtr);
  157.  
  158. /* Most common old names, uncomment for compatibility with old programs */
  159. // #define ConfigureSAT        SATConfigure
  160. // #define InitSAT            SATInit
  161. // #define CustomInitSAT    SATCustomInit
  162. // #define KillSAT            SATKill
  163. // #define RunSAT            SATRun
  164. // #define SkipSAT            SATSkip
  165. // #define GetFace            SATGetFace
  166. // #define DisposeFace        SATDisposeFace
  167. // #define NewSprite        SATNewSprite
  168. // #define NewSpriteAfter    SATNewSpriteAfter
  169. // #define KillSprite        SATKillSprite
  170. // #define NewFace            SATNewFace
  171. // #define ChangedFace        SATChangedFace
  172. // #define PeekOffscreen    SATRedraw
  173.  
  174. /* New procedures, EXPERIMENTAL, intended for making a C++ interface */
  175.     pascal SpritePtr SATNewSpritePP(SpritePtr, Ptr, short, short, short, TaskPtr);
  176.     pascal void SATCopySprite(SpritePtr, SpritePtr);
  177.     pascal FacePtr SATNewFacePP(Rect*, Ptr);
  178.     pascal FacePtr SATGetFacePP (short, Ptr);
  179.     pascal void SATCopyFace(FacePtr, FacePtr);
  180.     pascal void SATDisposeFacePP (FacePtr);
  181.  
  182. /* Cicn utilities */
  183.     pascal CIconHandle SATGetCicn (short);
  184.     pascal void SATPlotCicn (CIconHandle, GrafPtr, GDHandle, Rect*);
  185.     pascal void SATDisposeCicn (CIconHandle);
  186.  
  187. /*Utilities*/
  188.     pascal void SATSetStrings (Str255, Str255, Str255, Str255, Str255, Str255, Str255, Str255);
  189.     pascal Boolean SATTrapAvailable (short);
  190.     pascal void DrawInt (short);
  191.     pascal void DrawLong (long);
  192.     pascal short Rand (short);
  193.     pascal short Rand10(void);
  194.     pascal short Rand100(void);
  195.     pascal void ReportStr (Str255);
  196.     pascal Boolean QuestionStr(Str255);
  197.     pascal void CheckNoMem (Ptr); /*If the Ptr is nil, out of memory emergency exit*/
  198.     pascal short SATFakeAlert (Str255, Str255, Str255, Str255, short, short, short, Str255, Str255, Str255);
  199.     pascal void SetMouse (Point);
  200. /* Pattern utilities */
  201.     pascal void SATPenPat (SATPatHandle);
  202.     pascal void SATBackPat (SATPatHandle);
  203.     pascal SATPatHandle SATGetPat (short);
  204.     pascal void SATDisposePat (SATPatHandle);
  205. /* Menu bar utilities */
  206.     pascal void SATShowMBar(void);
  207.     pascal void SATHideMBar(WindowPtr);
  208. /* PICT utilities */
  209.     pascal void SATGetandDrawPICTRes (short id);
  210.     pascal void SATGetandDrawPICTResInRect (short id, Rect *frame);
  211.     pascal void SATGetandCenterPICTResInRect (short id, Rect *frame);
  212. /*Sound*/
  213.     pascal void InitSATSound(void);            /* No longer necessary */
  214.     pascal void SATSoundPlay (Handle, short, Boolean);    /* Play sounds with priority handling */
  215.     pascal void SATSoundShutup(void);        /*Silence, dispose of sound channel*/
  216.     pascal void SATSoundEvents(void);        /* Call this once in a while when not calling RunSAT often */
  217.     pascal Boolean SATSoundDone(void);    /* Any sound going on?*/
  218.     pascal Handle SATGetSound (short);
  219.     pascal Handle SATGetNamedSound (Str255);
  220.     pascal void SATDisposeSound (Handle);
  221.     pascal void SATSoundOn(void);
  222.     pascal void SATSoundOff(void);
  223. /* Multi-channel sound routines */
  224.     pascal short SATSoundInitChannels (short);
  225.     pascal Boolean SATSoundDoneChannel (short);
  226.     pascal void SATSoundPlayChannel (Handle, short);
  227.     pascal void SATSoundReserveChannel (short, Boolean);
  228.     pascal void SATSoundShutupChannel (short);
  229.     pascal void SATPreloadChannels(void);
  230. /* Experimental, likely to be renamed/removed/changed: */
  231.     pascal void SATSoundPlay2 (Handle, short, Boolean,Boolean);
  232.     pascal void SATSoundPlayEasy (Handle, Boolean);
  233. /* More multi-channel: */
  234.     pascal int SATGetNumChannels(void);
  235.     pascal Ptr SATGetChannel (int);
  236. /* Customization */
  237.     pascal void SATSetSoundInitParams (long);
  238.  
  239.  
  240. // Will it work with C++ if I do like this?
  241. #ifdef _cplusplus
  242. }
  243. #endif
  244.  
  245.