home *** CD-ROM | disk | FTP | other *** search
Text File | 1991-10-16 | 100.9 KB | 2,295 lines |
- Autodesk Animator Windows Player
-
- AAPLAY.DLL - AA Play Library
-
- AAPLAY.DLL is a dynamic link library which will play Autodesk An-
- imator animation files and Windows device independent bitmap
- files.
-
- Using AAPLAY.DLL, applications can load, play and control anima-
- tions under windows. AAPLAY can use Autodesk Animator Files, or
- Windows Device Independent Bitmap Files. AAPLAY.DLL can play an
- animation inside of a window, or it will take over the entire
- screen for animation playing.
-
- AAPLAY.DLL can play MIDI music, digitized sound, or Compact Disk
- Redbook Audio with animations.
-
- AAPLAY.DLL can also manage animation scripts. Scripts are text
- files which contain animations to be played in a given order.
- AAPLAY.DLL can be used to create, edit and play animation
- scripts.
-
- When using full screen animations, the display can no longer be
- shared. AAPLAY.DLL will not allow any other animations to play
- while a full screen animation is playing. Their status will be
- playing, but no action will actually be taking place. When the
- current full screen animation is stopped, the next full screen
- animation is selected for playing. If there are no full screen
- animations to be played, AAPLAY.DLL will return the screen to
- windowed mode.
-
- The C language header file aaplay.h makes all of the declarations
- needed for using the AA Play Library. This document also includes
- the C language names, and the actual values of constants needed
- for the AA Play Library. In the following description, TRUE rep-
- resents a non-zero value, and FALSE is a zero value.
-
- A smaller version of the library is available with the sound and
- scripting features removed. A library call can be made to deter-
- mine the capabilities of the player. Features not in the limited
- version are indicated in this document.
- Windows Initialization - WIN.INI, and SYSTEM.INI
- The Windows player uses some entries in the Windows initializa-
- tion file, WIN.INI. These values are kept in the section named,
- [AAPLAY Animation]. The values are:
-
- FullScreen=driver
-
- Gives the driver used for full screen animation.
- Currently only the VGA is supported. The driver
- for the VGA is AAVGA.DLL. If this value is miss-
- ing, full screen animations can not be done.
-
- DualScreen=value
- Value indicates whether the full screen anima-
- tions are run on the same display as Windows. The
- player assumes the display is shared by Windows
- and full screen animation, unless this line is
- present and value is yes, true, on, or a non-zero
- number.
-
- If you are planning to run Windows on a display different from
- the VGA and run full screen animations, you must add the follow-
- ing line to the [386enh] section of the file SYSTEM.INI. This
- line will prevent Windows from attempting to place the VGA ad-
- dress space in the page frame for expanded memory.
-
- EMMExclude=A000-AFFF
- Special Considerations
- There are several differences between running animations in the
- Windows environment and the DOS environment. The following con-
- siderations should be made when authoring for Windows.
-
- Colors Under Windows
-
- The following discussion of color is not applicable when running
- animations in full screen mode under Windows.
-
- Colors must be considered for animations that are to be run in a
- window under the Windows Environment. Two color problems can
- arise. Windows on the standard VGA uses the 640 by 480 16 color
- mode. Animations that use many colors will not be displayed cor-
- rectly, in this case. If you are make animations to be played in
- a window on a standard VGA, you should limit your color selec-
- tion. The 640 by 480 16 color mode also does not support changing
- colors in an animation.
-
- For displays with more colors, a mechanism for managing color
- palettes was implemented in Windows 3.0. This mechanism is used
- by the player to display animations in a window. There are some
- unpleasant side effects that can occur when animation palettes do
- not conform to the Windows palette management.
-
- First, Windows reserves twenty colors for its own use, so only
- 236 colors are available for the animation. However, if the col-
- ors in an animation do not change, Windows will match colors in
- the animation and animations using 256 colors will display cor-
- rectly.
-
- Normally, when Windows changes the palette, a message is sent to
- every window begin displayed, informing the window that the
- palette has been changed. While these messages are being sent,
- other activity in the system is suspended, including playing
- other frames of the animation. So palette changes, either within
- an animation or between to successive animations in a script, can
- cause pauses while the animation is playing. When the palette is
- changed, Windows also may change the colors being used on the
- display. This means that the animation really needs to be re gen-
- erated in order to correctly display. If the color change is be-
- tween animation in a script, the first frame of the new animation
- will correct the colors. But, if the color change is within an
- animation, Windows can fix up the colors pretty well, but not
- completely accurately. So some colors in the animation may
- change.
-
- If color palette effects are desired, the player can reserve
- palette entries to be used for the effects. Three options are
- provided, no color entries are ever reserved, the color entries
- are reserved when the player finds that the colors are changing,
- or all of the color entries are reserved. When color palette en-
- tries are reserved, they are not available for color matching,
- and so if more then 236 colors are used, some colors will be
- lost. Windows reserves the color in the order they appear in the
- palette, so the twenty entries at the end of the palette are gen-
- erally the ones that are lost.
- To overcome these effects you should use color judiciously. If at
- all possible, don't use more than 236 colors in any frame and
- make these the first 236 colors in the palette. This limitation
- allows all of the palette entries to be reserved. Use a common
- palette for as many frames as possible. If animations are to be
- sequenced in a script, the palette of the last frame and the
- palette of the first frame of the following animation should be
- the same.
-
- Playback Speed
-
- Frame timing depends on whether the Multimedia extensions are in-
- stalled on a system. If these extensions are not installed, ani-
- mations can only be played at integral divisors of eighteen
- frames per second (18, 9, 6, 4.5, etc.). The player will round
- the speed so the playback time is as close as possible to the
- time desired (12 frames per second rounds to 9, 13 to 18). When
- the Multimedia extensions are installed, frame timing can be made
- to millisecond accuracy.
-
- When playing animations in a window, the player must convert the
- Animator format to Windows format and then generate the display
- from the converted image. This costs time. Animations can not be
- played in a window as quickly as on the full VGA screen.
-
- Playback speed can be improved, by loading the animation into
- memory before playing it. Of course, some amount of time is used
- in loading the animation, but it is possible to hide this by us-
- ing a still frame, or pre-loading the animation when the applica-
- tion begins.
-
- Sound With Animations
-
- The player can play sounds with animations, but the player cannot
- guarantee frame synchronization between the sounds and the anima-
- tion. The player will only begin sounds at the beginning of an
- animation, but in scripts sounds can play through more than one
- animation. Sounds can also be set to repeat after they have fin-
- ished. Repeating can be set to a specific number of times or un-
- til the animation ends. The animation can also be repeated until
- the sound is finished if you want to build a trailer. The player
- can not change the playing position within sounds, except to
- reposition the sound to the starting point. If an application
- uses aaSetParm, or aaSetParmIndirect to change the position of an
- animation, the sound position is not changed. When using the Test
- buttons in the user dialogs, sounds will start from the beginning
- of the sound.
-
- The player attempts to support any sound supported by the Media
- Control Interface. Sounds are divided into two classes, sounds
- which play from files on the computer, and sounds which play from
- independent media. The waveaudio and sequencer sounds are exam-
- ples of sounds that play from files, and cdaudio, videodisc, au-
- diotape, and videotape are examples of sounds that play through
- independent media.
-
- Sounds from files start at the beginning of the sound and con-
- tinue until the end of the sound. The player assumes a sound file
- contains exactly one sound that is played. Sounds for these de-
- vices are specified by giving the file name of the sound. The de-
- vice name can also be given, or if it is not given, the MCI ex-
- tensions section of system.ini is used to match the sound file to
- the proper device.
-
- For sounds from independent media this is not true. Additional
- parameters may be needed to indicate where the sound begins and
- ends on the media. Since these device do not require file names,
- the player will accept a string specifying the play command pa-
- rameters. These parameters are used each time the sound is
- played. The parameters allowed for specific devices are:
-
- cdaudio from pos
- to pos
-
- Pos gives the position on the compact disk in
- frames. If from is not given, the sound will
- start from its current position.
-
-
- Positions are given in minutes, seconds, and
- frames in the format t:m:s:f. The first frame is
- frame 1. So the first frame of a track is 0:0:1.
- So in order to play a song 4 minutes 63 seconds
- long on track 5 of a CDROM, the parameters used
- would be:
-
- from 5 to 5:4:63
-
-
- videodisc from pos
- to pos
-
- Pos gives the position on the videodisc in
- frames. Always give the to argument to insure
- that the end of the sound is known. If from is
- not given, the sound starts from the current
- position.
-
- In this case, position is a time in hh:mm:ss
- format. Your videodisc player may display
- position in this format, or it may display
- position as a frame number. To convert from frame
- numbers to time, divide by 30 to get seconds, and
- then convert to hh:mm:ss format. The from
- position must be at least 1 second. For example,
- enter
-
- from 0:0:1 to 0:4:0
-
- to play 4 minutes on the disc.
- User Dialogs
- The library has several dialogs that it will display when re-
- quested by an application. The library will also display some er-
- ror messages in message boxes.
-
- Prompts for File Names
-
- Dialogs are provided to ask the user for the names of animations
- or sounds. These dialogs are produced when the function aaGetFile
- is called and when a user saves a modified script that is begin
- unloaded using aaUnload. The limited version of the player will
- not present the dialog for sound names. If this dialog is re-
- quested, the player will indicate that CANCEL was pressed in the
- dialog.
-
- Both of these dialogs are like standard file open dialogs of most
- applications. An edit control is provided for entering a file
- name, and two list boxes list files matching the file specifica-
- tion, and directories. An additional list box is added when the
- name of a sound file is entered. This box contains a list of de-
- vices from the [MCI] section of system.ini, and is used to supply
- the device used to play the sound.
-
- When selecting a sound, the dialog recognizes device which re-
- quire a file name and devices that do not. If the device does not
- require a file name, the list boxes for the directory are dis-
- abled. The user can type in the play parameters string in the
- edit control.
-
- Edit Script Dialog
-
- This dialog is produced when aaPrompt is called for an animation
- script. It combines a file open dialog with a list box for dis-
- playing and editing the script itself. This dialog cannot appear
- in the limited version of the player, since animation scripts are
- not supported.
-
- The file open controls and list boxes are on the right side of
- the dialog. These are used to select animations or sounds to be
- entered in the script. To add an animation or sound to the
- script, the file is selected and then you can press the Insert
- button or double click on the file name in the file list box.
- This will insert the animation before the currently selected ani-
- mation in the script, or add the sound to the currently selected
- animation. You can also double click on an animation in the
- script list box which will insert the new animation before the
- selected animation.
-
- The list box on the left contains the lines of the script. Each
- line is identified by the name of the animation, followed by sev-
- eral characters indicating which animation parameters are changed
- from the default. These characters are:
-
- L - The number of loops is not 1.
- S - The speed is not the design speed.
- N - Sound has been added.
- R - The sound is to be repeated, if it finishes before the animation does.
- D - The sound does not start with the animation.
- C - Palette animation is inhibited.
- A - The entire palette is reserved for animation.
- M - The animation is loaded into memory before
- playing.
- F - The animation is to play in full screen mode.
- E - The last frame of the animation does not loop
- to the first frame.
- P - The animation is paused at its end.
- I - A transition has been added to the animation.
-
- Using the buttons at the bottom left you can Cut, Copy, and Paste
- lines in the script. Paste will paste text lines from other
- sources, if they are in the format of a script file. The Clear
- button deletes lines from the script without copying them to the
- Clipboard. The Undo button undoes the last change made to the
- script.
-
- The buttons at the lower right are used to exit the dialog, test
- the animation, save the script, change an animations parameters,
- and change the sound for an animation. Pressing the Done button
- will exit the dialog and leave the script as it was last changed.
- Pressing the Test button will test the animation script, begin-
- ning with the selected entry. If no entry is selected, the test
- will start at the beginning of the script. Pressing the Save but-
- ton will save the script as it is currently. When a single an-
- imation is selected in the script list box, the Parameters and
- Sound buttons are enabled. Pressing the parameters buttons will
- bring up the Animation Parameters Dialog, described below, and
- allow parameters for the animation to be changed in the script.
- Pressing the Sound button will change the mode of the dialog from
- adding animations to changing the sound for the selected anima-
- tion.
-
- When the sound button is pressed, the script list box is dis-
- abled, the edit buttons at the bottom left of the screen are dis-
- abled, and the parameters button is enabled. If the animation al-
- ready has a sound, the name of sound is displayed in the edit
- control, and the directory is displayed in the list boxes. At
- this point the user can either press the Flicks button which will
- return the dialog to the animation mode, or selects a sound and
- press the Insert button, which will add the sound to the anima-
- tion, or press the Off button at the bottom of the dialog, which
- will remove any sound from the animation, or press the Continue
- button at the dialog which will continue the sound from the pre-
- vious animation to this animation. When any of these actions take
- place, the dialog is returned to the animation mode.
-
- Animation Settings
-
- This dialog is produced when aaPrompt is called for a normal ani-
- mation, or the Parameters button is pressed for an animation in a
- script. It is used to adjust parameters of the animation such as
- speed and length of play.
-
- At the top right of the dialog, the speed, and length of one loop
- of the animation is displayed. Frames gives the length in frames
- of a single loop, Design Speed gives the speed of the animation
- as set in Animator, and Duration gives the duration of a single
- loop of the animation at the design speed in seconds.
-
- Also at the top of the dialog are five check boxes to control the
- mode of the animation:
-
- Load into Memory
- When set all of the animations frames are loaded
- from disk into memory when the animation is
- loaded. This can be used to improve playback
- speed of animation that have large average frame
- sizes.
-
- Full Screen
- This check box is only enabled if the FullScreen
- entry is present in the [AAPLAY Animation] sec-
- tion of win.ini. If it is checked, the animation
- will use the full screen to play, instead of
- playing in a window.
-
- Loop Frame
- This check box is only enabled for Windows Device
- Independent Bitmap Animations. It is used to in-
- dicate that the last frame of the animation is
- the deltas from the end of the animation to the
- beginning of the animation.
-
- Color Cycling OK
- This check box is used to inhibit palette anima-
- tions. It is usually checked which causes the
- player to reserve palette entries that change
- during an animation. If it is not checked, the
- player will not reserve any palette entries.
-
- Use All Colors
- This check box is only enabled if Animate Colors
- is checked. Checking this box will cause the
- player to reserve all palette entries for palette
- animation.
-
- The three edit controls and scroll bars in the middle of the dia-
- log labeled, Speed, Loops, and Duration are used to control the
- speed and length of an animation.
-
- Speed is given in frames per second, and defaults to the design
- speed. It can be changed using the scroll bar to its right, or
- by typing the desired speed in the field where the current value
- is displayed. It can range from 1.0 to 51.0 frames per second.
-
- Loops tells the player when to stop the animation. Its format is:
-
- loop:frame
-
- Loop gives the number of times to completely play the animation,
- and frame is the number of frames played after all of the loops
- are played. If frame is zero, it is not displayed and does not
- need to be entered. Loops can be changed using it's scroll bar,
- or by typing in the desired value. Loops can range from 1 frame
- to 999 Loops. It may also take on the value "Forever" which indi-
- cates that the animation can only by stopped by an external
- event. The number of whole loops can also be given the value
- "Sound" which indicates that the animation is to loop until the
- sound is finished playing. If no frame number is given, the ani-
- mation will end when the sound ends. If a frame number is given
- the animation will end immediately before the frame is played and
- after the sound has ended.
-
- Duration is the length of time the animation will play. It is
- calculated from the Speed and Loops values. Its format is:
-
- mm:ss.msec
-
- Mm is the number of minutes, ss the number of seconds and msec
- the number of milliseconds. It may range from the time of 1 frame
- to 49:59.999.
-
- It is when changing any of these three parameters, at least one
- of the other parameters must be changed to make the speed, length
- in loops and frame and duration in time consistent. The lock but-
- ton controls the parameter that is fixed in the calculation. The
- parameter that is not fixed is adjusted each time one of the
- other ones is changed.
-
- The Repeat Sound entry is used to change the number of times a
- sound is repeated. It can vary from 1 to 1000 times. It can also
- take on the value of "Forever" which indicates that the sound
- will repeat until the animation is stopped. This entry does not
- appear in the limited version of the player.
-
- The Delay Sound entry is used to delay sounds from the start of
- the animation. The number is given as a time in milliseconds and
- can range from -50:00.000 to 50:00.000. If the number is positive
- the sound start that length of time after the animation starts.
- If the number is negative the sound starts that length of time
- before the animation starts. The timing is directly tied to the
- speed of the animation, so the sound will be delayed longer than
- the time given if the animation cannot play at the requested
- speed. This entry does not appear in the limited version of the
- player.
-
- The Pause at End entry is used to length of time an animation is
- paused when it ends. It can vary from 0.000 to 50.000 seconds. If
- the animation loops is set to "Sound" with no frame given the an-
- imation is not paused if it is playing when the sound ends. If
- the animation has ended as is paused, in this case the ending of
- the sound will cause the animation end.
-
- The Test button will destroy the dialog, and run the animation
- with the currently selected values. Any key press, or mouse click
- in the animation window will stop the test and return to the dia-
- log.
- OK accepts the current values and CANCEL rejects the current val-
- ues.
-
- The Transitions button displays the Transition dialog described
- below.
-
- Transition Dialog
-
- The transition dialog is presented when the Transitions button is
- pressed in the Animation Settings dialog. This dialog is used to
- add fades to the beginning and end of animations. The duration of
- the fades can be set between .25 and 10.0 seconds.
-
- Function Summary
- The functions provided for frame animation are:
-
- aaOpen Opens the library.
-
- aaGetCaps Returns current capabilities of
- the animation player.
-
- aaClose Closes the library.
-
- aaLoad Loads a new animation.
-
- aaUnload Unloads a loaded animation.
-
- aaReLoad Loads an animation over a loaded
- animation.
-
- aaPlay Starts playing a loaded animation.
-
- aaPause Pauses a playing animation.
-
- aaStop Stops a playing animation.
-
- aaNotify Schedules frame synchronization
- messages.
-
- aaCancel Cancels frame synchronization mes-
- sages.
-
- aaPrompt Prompts for animation parameters
- using dialogs.
-
- aaGetParm Retrieves animation parameters.
-
- aaGetParmIndirect Retrieves animation parameters.
-
- aaSetParm Changes animation parameters.
-
- aaSetParmIndirect Changes animation parameters.
-
- aaShow Displays or hides the animation
- window.
-
- aaSound Places sound with an animation.
-
- aaGetFile Prompts for a file name using a
- dialog.
-
- aaSave Saves a loaded animation script.
- Using the Windows Animation Player
-
- There are three basic phases to using the player. During the
- first phase, an application must connect to the player. Once the
- connection is established, animations can be loaded and played.
- Finally the application must disconnect from the player before
- exiting.
-
- In order to connect to the player, the application must call the
- function aaOpen. This function has no arguments and returns a
- zero if the connection fails, or a non-zero value if the connec-
- tion succeeds. If the connection fails, no other call to the li-
- brary should be made. aaOpen should not be called again until af-
- ter a call to aaClose is made. The function aaGetCaps can be used
- to determine what player capabilities are available. Depending on
- the system and version, sound or scripting may not be available,
- and only reduced frame timing may be available.
-
- To disconnect from the player, the function aaClose is called.
- This function has no arguments or return value. The library
- should not be used after aaClose is called.
-
- In order to play animations they must first be loaded using
- aaLoad. aaLoad returns an unsigned integer which is used to ref-
- erence a loaded animation in other library functions. These func-
- tions can be used to begin play, stop or pause play, and reposi-
- tion the animation. When an application is finished with an ani-
- mation, it can be unloaded using aaUnload.
-
- After the library has been opened, an application can use aaGet-
- File to prompt for an animation or sound file name. Of course, an
- application can also use its own file name dialog, or some other
- mechanism to obtain the names of animations.
-
- Two primitives are supplied for frame synchronization. These
- primitives allow an application to request call backs from the
- animation player when certain frames are to be drawn. Using these
- call backs, the application can synchronize any other event with
- an animation frame. The primitives are aaNotify which schedules a
- call back, and aaCancel which cancels a call back. When a script
- is playing, call backs can only be scheduled for the currently
- playing animation. In order to facilitate synchronization in
- scripts, a call back is made at the start of each animation in
- the script.
-
- Call backs are provided for frame synchronization and state and
- error notification. The call back is made to the Window Procedure
- of the window set as the call back window. When an animation is
- loaded, the call back window is set to the hwnd parameter, but it
- may be changed by aaSetParm or aaSetParmIndirect. Two messages
- are used and the message number of these messages is determined
- using RegisterWindowMessage. The messages are identified by the
- following strings:
-
- "AAPLAY Notify" - Message string for frame syn-
- chronization messages.
- "AAPLAY Stop" - Message string for status and
- error messages.
- The call back function should be declared as follows:
-
- LONG FAR PASCAL CallBack(hwnd, msg, wparam, lparam);
- HWND hwnd;
- WORD msg;
- WORD wparam;
- DWORD lparam;
-
- The hwnd parameter always identifies the owner of the animation
- window. The msg parameter identifies the message, and is found by
- calling RegisterWindowMessage with the appropriate message
- string. The wparam parameter always identifies the animation that
- generated the message. It gives the value returned by aaLoad when
- the animation was loaded.
-
- For frame synchronization messages, lparam is the value requested
- by the application when the call back was requested, or zero for
- frame synchronization call backs generated at the beginning of an
- animation in a script.
-
- For status and error messages, lparam is an error code. If it is
- zero, the animation stopped at the end without an error. The fol-
- lowing error codes are defined:
-
- AA_BADPLAY - 1
- An error occurred reading the animation.
-
- AA_BADNOTIFY - 2
- A memory error occurred attempting a frame syn-
- chronization message.
-
- AA_BADSCRIPT - 3
- An error occurred loading an animation or sound
- for a script.
-
- When processing a callback message from the player, you should
- not use aaUnload to unload the animation, or aaClose to close the
- library. You may used aaReLoad to reload an animation when a stop
- callback is recieved, but not when a frame callback is recieved.
-
- Several function are provided for retrieving and changing parame-
- ters of an animation. The application can provide a user inter-
- face or use the one provided in aaPrompt. For normal animations,
- the application should retrieve the values of an animations pa-
- rameters and save them for later use. Scripted animations will
- save the animation parameters in the script.
- Animation Scripts
-
- Animation scripts are text files containing an order list of ani-
- mations. Animation scripts can not be played by the limited ver-
- sion of the player. An error is returned if the limited player
- attempts to open an animation script. The animations are played
- in the order given in the list. Each animation is listed on a
- separate line. Any line listing an animation to be played can be
- continued by putting a back slash "\" at the end of the line. The
- last continuation line must not have a "\" at its end. any number
- of spaces, tabs, or the end of continued lines are treated as
- though it was just one space.
-
- Each line in the script starts with the name of the animation to
- be played, followed by optional entries giving parameters used in
- playing the animation. Each option begins with a minus sign, "-".
- If an option uses a parameter, you may put a space between the
- option and the parameter, or not. However a space must precede
- the minus sign for each option.
-
- For more information on each option, see the information in
- aaLoad, aaGetParm, and aaSound. The following options are sup-
- ported:
-
- -L loops[:frame]
- Sets the length of the animation. If set to 0 or
- "Forever", the animation will loop forever. De-
- faults to 1:0. The loops may also be set to the
- value "Sound", which indicates that the animation
- is to loop until the sound is finished playing.
-
- -S speed
- Sets the speed of the animation in frames per
- second. This value can be specified to a tenth of
- a frame per second. Defaults to the design speed
- of the animation.
-
- -N [sound [device]]
- Puts a sound with the animation. If the sound is
- missing, the sound, if any, of the previous ani-
- mation is used with this animation. If the device
- is missing, the [MCI Extensions] section of sys-
- tem.ini is used to locate the device used by the
- sound. An animation that does not have this op-
- tion will turn any sound off before playing.
-
- -R sound-repeats
- Sets the number of times a sound is to repeat. If
- set to 0 or "Forever", the sound will continue to
- play until the animation is finished, or another
- sound is played. Defaults to 1. The value is only
- checked, when the sound reaches the end of play.
-
- -D sound-delay
- Sets a delay from the start of the animation to
- the start of the sound. The time is given in min-
- utes and seconds, and can be given to one thou-
- sandth of a second. The time can range from
- 50:00.000 to -50:00.000.
-
- -P pause-time
- Sets a time which the script will pause after
- this animation has finished before starting the
- next animation. The time is given in seconds, and
- can be given to one thousandth of a second.
-
- -I [transition [duration]]...
- Sets transitions for animations in scripts. The
- transition may be on of cutfrom, fromblack,
- fromwhite, cutto, toblack, or towhite.
- Transitions default to cutto or cutfrom. The
- duration of the transition can be given from
- between .250 seconds and 10.000 seconds. The
- default time is .500 seconds. More than one
- transition may follow the -I.
-
- -C
- Inhibits palette animation.
-
- -A
- Reserves all palette entries for palette anima-
- tion.
-
- -M
- Loads the animation into memory.
-
- -F
- Plays the animation in full screen mode.
-
- -E
- Indicates that the last frame of the animation is
- not the deltas between the end of the animation
- and the beginning. Only valid for Windows DIB an-
- imations.
- The Dynamic Link Library Entry Points
- _________________________________________________________________
-
- aaOpen
-
- Syntax BOOL aaOpen(void)
-
- aaOpen initializes the player for the application.
- TRUE is returned if the initialization succeeded.
- Otherwise FALSE is returned.
-
- An application must call aaOpen before making any
- other calls to the AA Play Library. aaOpen should
- not be called again before aaClose is called.
-
- Parameters None
-
- _________________________________________________________________
-
- aaClose
-
- Syntax void aaClose(void)
-
- aaClose releases the player from the application.
- Any loaded animations used by the application are
- unloaded.
-
- Other calls to the AA Play Library should not be
- performed after this call is made. aaOpen should be
- called again to reopen the library, if necessary.
-
- Parameters None
-
- _________________________________________________________________
-
- aaLoad
-
- Syntax HAA aaLoad(lpzFileName, hWnd, wMode, x, y, cx, cy,
- orgx, orgy)
-
- aaLoad loads an animation in preparation for play-
- ing. It returns a number between 1 and 65535, which
- is used to reference the loaded animation in other
- library calls. Once an animation is loaded, it can
- be played, and various parameters controlling its
- playing can be altered.
-
- If aaLoad is unable to load the animation, NULL
- (zero) is returned.
-
- Parameters LPSTR lpzFileName
-
- The name of the animation file to be opened or
- the contents of an animation script depending on
- the value of wMode. OpenFile is used to open ani-
- mation files and so the normal Windows file
- searching algorithm is used. This search algo-
- rithm will first search the current directory, then each directory in the PATH environment vari-
- able.
-
- If the wMode value indicates that lpzFileName is
- the contents of a script, the animation is opened
- as an untitled script.
-
- HWND hWnd
-
- The handle of a window that is to own this anima-
- tion. It must be supplied but may be null.
- Coordinates are given relative to this window and
- it is used to receive status and frame synchro-
- nization messages, when these are sent. The mes-
- sage numbers used for the status and notification
- messages are retrieved using RegisterWindowMes-
- sage. The following two messages are used by
- AAPLAY:
-
- AA_STOP - "AAPLAY Stop"
-
- The animation is being stopped. If lParam
- is non zero, the animation is being stopped
- because of an error. This message is not
- sent when the application stops the anima-
- tion using aaStop.
-
- AA_NOTIFY - "AAPLAY Notify"
-
- Sent because the user requested notifica-
- tion when a frame is drawn. See aaNotify
- and aaCancel.
-
- WORD wMode
-
- A word which indicates how the file is to be
- loaded. This value is found by adding the values
- desired below:
-
- AA_MEMORYLOAD - 1
-
- Loads the entire animation into memory.
- This requires more time, and may fail be-
- cause of insufficient memory.
-
- AA_HIDEWINDOW - 2
-
- Normally the frame at which the animation
- is stopped is displayed on the screen. If
- this value is added into the mode, the ani-
- mation is only displayed when it is play-
- ing.
-
- AA_NOPALETTE - 4
-
- Inhibits palette animation. When palette animation is enabled, some colors may be
- lost if more that 236 colors are used.
-
- AA_RESERVEPALETTE - 8
-
- If palette animation is not inhibited, this
- flag will reserve all of the palette en-
- tries for animation. Some colors may be
- lost if more that 236 colors are used. If
- the palette is changed without this flag
- being set, Windows will send a message to
- all windows on the screen informing them of
- the palette change. This can cause the ani-
- mation to stop momentarily.
-
- In order to prevent the palette change mes-
- sages when changing animations in scripts,
- or using aaReLoad, this flag must be set in
- the current animation and the following an-
- imation.
-
- AA_LOOPFRAME - 16
-
- Indicates that the last frame of a Windows
- device independent bitmap animation is ac-
- tually the deltas between the last frame of
- the animation and the first. This value is
- not used for Autodesk Animator Animations.
-
- AA_FULLSCREEN - 32
-
- Indicates that the animation is to be
- played on the full screen, not within the
- window hWnd.
-
- AA_STOPNOTIFY - 64
-
- Prevents notification messages from being
- sent to the window identified by hWnd.
-
- AA_STOPSTATUS - 128
-
- Prevents status messages from begin sent to
- the window identified by hWnd.
-
- AA_NOFAIL - 256
-
- If a memory load fails due to memory
- limitations, the animation is loaded to
- play from disk.
-
- AA_BUILDSCRIPT - 1024
- Indicates that an untitled script is to be
- built using the contents of the string ad-
- dressed by lpzFileName. If this mode is
- used for the limited version of the player,
- FALSE is returned.
-
- WORD x, y, cx, cy
-
- The coordinate of the upper left corner of
- the window used to display the animation,
- and the width (cx) and height (cy) of that
- window. X and y are relative to the upper
- left corner of the client are of the window
- hWnd. These values are modified to force
- the window to be contained in the window
- identified by hWnd.
-
- WORD orgx, orgy
-
- The coordinate of the animation displayed
- at the upper left corner of the window used
- to display the animation.
-
- _________________________________________________________________
-
- aaUnload
-
- Syntax BOOL aaUnload(hAa)
-
- Unloads an animation loaded by aaLoad. If the anima-
- tion is playing, it is stopped. aaUnload will ask
- the user to save a modified script. This can be in-
- hibited by clearing the modified flag using aaSet-
- Parm.
-
- Parameters HAA hAa
-
- A handle returned by aaLoad.
-
- _________________________________________________________________
-
- aaReLoad
-
- Syntax BOOL aaReLoad(hAa, lpzFileName, wMode, wMask)
-
- Loads another animation over an existing one. If the
- two animations use different colors, then setting
- AA_RESERVEPALETTE in both the existing animation and
- in wMode can improve the performance of this func-
- tion. The existing animation must be stopped,
- paused, or have finished playing in order to make
- this call.
-
- Parameters HAA hAa
-
- The handle of the animation returned by aaLoad.
- LPSTR lpzFileName
-
- The name of the animation file to be opened or
- the contents of an animation script depending on
- the value of wMode. OpenFile is used to open ani-
- mation files and so the normal Windows file
- searching algorithm is used. This search algo-
- rithm will first search the current directory,
- then each directory in the PATH environment vari-
- able.
-
- If the wMode value indicates that lpzFileName is
- the contents of a script, the animation is opened
- as an untitled script.
-
- WORD wMode
-
- This value is used exactly the same as in aaLoad.
- It uses the same value with the following addi-
- tional value:
-
- AA_DONTPAINT - 512
-
- Inhibits painting of the initial frame un-
- til the animation begins playing.
-
- WORD wMask
-
- A mask used for setting the mode. Setting of spe-
- cific mode values can be inhibited by adding the
- value not to be set into this argument.
-
- _________________________________________________________________
-
- aaPlay
-
- Syntax BOOL aaPlay(hAa)
-
- Plays the animation loaded by aaLoad. Play begins
- from the current position. aaPlay returns after the
- animation has begun playing. Returns TRUE if the an-
- imation is playing.
-
- Parameters HAA hAa
-
- A handle returned by aaLoad.
-
- _________________________________________________________________
-
- aaNotify
-
- Syntax BOOL aaNotify(hAa, lPosition, lParam)
- Requests a frame synchronization message for the ap-
- plication using aaPlay. The message is sent immedi-
- ately before the frame at position lPosition is
- drawn. lParam is a parameter set by the user which
- is passed to the message handler. The word parameter
- to the message routine is always the handle hAa. If
- the position at the time of the call is needed, it
- can be retrieved using aaGetParm. This call is used
- to synchronize other events to an animation frame.
-
- The player will automatically generate frame syn-
- chronization messages whose lParam is zero, when an
- animation begins playing. If the application re-
- quests frame synchronization with lParam zero, it is
- the responsibility of the application to determine
- which synchronization message is begin sent.
-
- Parameters HAA hAa
-
- A handle returned by aaLoad.
-
- DWORD lPosition
-
- The position at which the notification is to take
- place. The high order word is the loop and the
- low order word is the frame.
-
- DWORD lParam
-
- A double word passed to the notification func-
- tion.
-
- _________________________________________________________________
-
- aaCancel
-
- Syntax WORD aaCancel(hAa, lLowPos, lHighPos)
-
- Cancels frame synchronization messages. The number
- of messages canceled is returned.
-
- Parameters HAA hAa
-
- A handle returned by aaLoad
-
- DWORD lLowPos
-
- The lower loop and frame count where notification
- messages are canceled.
-
- DWORD lHighPos
-
- The upper loop and frame count where notification
- messages are canceled.
-
- _________________________________________________________________
- aaStop
-
- Syntax BOOL aaStop(hAa)
-
- Stops the playing animation. Returns TRUE if the an-
- imation is stopped. Stopped animations begin with
- the first frame of the animation, when they are re-
- played. You may also use aaSetParm to start a
- stopped animation at a frame other than the first
- frame.
-
- Parameters HAA hAa
-
- A handle returned by aaLoad
-
- _________________________________________________________________
-
- aaPause
-
- Syntax BOOL aaPause(hAa)
-
- Pauses a playing animation. Returns TRUE if the ani-
- mation is paused. A paused animation is still con-
- sidered playing, so no other full screen animations
- will play. Paused animations will continue playing
- from the current frame, when they are replayed by
- calling aaPlay.
-
- Parameters HAA hAa
-
- A handle returned by aaLoad.
-
- _________________________________________________________________
-
- aaPrompt
-
- Syntax BOOL aaPrompt(hAa, lpName)
-
- Produces a dialog box that prompts the user for pa-
- rameters for playing the animation whose handle is
- hAa.
-
- This call acts differently for scripts and normal
- animations. For normal animations, the values en-
- tered by the user can be retrieved using aaGetParm
- or aaGetParmIndirect. Scripts can be saved in a file
- using aaSave, or the contents of the script can be
- retrieved using aaGetParm. Scripts are not available
- in the limited version of the player.
-
- If a script is modified, aaUnload will ask the user
- to save the script when it is unloaded. This can be
- prevented by setting the modified flag to zero, us-
- ing aaSetParm.
-
- Parameters HAA hAa
- A handle returned by aaLoad.
-
- LPSTR lpName
-
- The name of the animation. This name is used only
- to provide a caption for the dialog for normal
- animations. If it is NULL, no name is provided in
- the dialog caption in this case.
-
- _________________________________________________________________
-
- aaGetParm
-
- Syntax LONG aaGetParm(hAa, wType)
-
- Gets current parameters for playing the animation.
- Parameters that are not valid are returned as zero.
- If the animation is a script, the parameters re-
- turned are for the currently visible animation.
-
- Parameters HAA hAa
-
- A handle returned by aaLoad.
-
- WORD wType
-
- The type of parameter to be retrieved:
-
- AA_STATUS - 1
-
- Returns a word containing current status of
- the animation. The status of an animation
- can be:
-
- AA_STOPPED - 1
-
- The animation is loaded and is not play-
- ing.
-
- AA_QUEUED - 2
-
- The animation is loaded and aaPlay has
- been used to start the animation, but
- the animation cannot be started because
- either it is a full screen animation, or
- a full screen animation is playing, or
- both. The animation will be begun as
- soon as possible.
-
- AA_PLAYING - 3
-
- The animation is playing.
-
- AA_PAUSED - 4
- The animation has been paused using aa-
- Pause.
-
- AA_DONE - 5
-
- A transitory state after an animation
- has finished playing, but before it has
- been stopped. The animation may be
- restarted from this state using aaPlay
- or reloaded using aaReLoad.
-
- AA_FILETYPE - 2
-
- Returns a word containing the format of the
- animation on disk. The values returned are:
-
- AA_FLI - 1
-
- Animator FLI format.
-
- AA_DIB - 2
-
- Windows DIB format.
-
- AA_SCRIPT - 3
-
- The animation is a script. This value
- will never be returned by the limited
- version of the player.
-
- AA_MODE - 3
-
- Returns a word containing the current mode
- of the animation. The values are the same
- as the mode described in aaLoad, except
- AA_NOFAIL and AA_BUILDSCRIPT are never set.
-
- AA_WINDOW - 4
-
- Returns a word containing the handle of the
- window that owns the animation.
-
- AA_SPEED - 5
-
- Returns a word containing the speed of the
- animation, given in milliseconds per frame.
- This is the current speed of the animation.
-
- AA_DESIGNSPEED - 6
-
- Returns a word containing the designed
- speed of the animation, given in millisec-
- onds per frame.
-
- AA_FRAMES - 7
- Returns a word containing the number of
- frames in the animation. If the animation
- type is a DIB file, this number will be un-
- known, until the animation has been com-
- pletely played. If the number of frames is
- unknown, 0 is returned.
-
- AA_POSITION - 8
-
- Returns a long containing the current posi-
- tion in the animation. The high order word
- is the current loop, the low order word is
- the current frame. The first loop is loop
- 0, and the first frame is frame 0.
-
- AA_LOOPS - 9
-
- Returns a long returning the position of
- the frame at which the animation ends. A 0
- indicates that the animation will not stop
- until an aaStop call is made. This number
- has the same format as AA_POSITION.
-
- If the value of the high order word of
- AA_LOOPS is AA_LOOPSOUND (which is 65535),
- then the animation loops until the sound
- finishes playing. If the low order word is
- also this value, the animation will end
- with the sound. Otherwise, the animation
- will stop on the frame number given by the
- low order word, after the sound has fin-
- ished.
-
- AA_X - 10
-
- Returns the x coordinate of the upper left
- corner of the animation window.
-
- AA_Y - 11
-
- Returns the y coordinate of the upper left
- corner of the animation window.
-
- AA_CX - 12
-
- Returns the width of the animation window.
-
- AA_CY - 13
-
- Returns the height of the animation window.
-
- AA_ORGX - 14
-
- Returns the x coordinate in the animation,
- displayed at the upper left corner of the
- animation window.
- AA_ORGY - 15
-
- Returns the y coordinate in the animation,
- display at the upper left corner of the an-
- imation window.
-
- AA_WIDTH - 16
-
- Returns the width of the animation.
-
- AA_HEIGHT - 17
-
- Returns the height of the animation.
-
- AA_RPTSOUND - 18
-
- Returns the number of times the sound will
- repeat before stopping. Zero indicates that
- the sound will repeat until the animation
- ends. Zero is always returned in the lim-
- ited version of the player.
-
- AA_PAUSE - 19
-
- Returns the length of time to pause this
- animation at the end in milliseconds.
-
- AA_DELAYSND - 20
-
- Returns length of time to delay the sound
- from the start of the animation in mil-
- liseconds. The delay is negative if the
- sound is to start before the animation.
- Zero is always returned in the limited ver-
- sion of the player.
-
- AA_TRANSIN - 21
-
- Returns the transition at the beginning of
- the animation. This transition may be:
-
- AA_CUT - 0
-
- No transition is performed.
-
- AA_FADEBLACK - 1
-
- Fade from black transition is performed.
-
- AA_FADEWHITE - 2
-
- Fade from white transition is performed.
-
- AA_TRANSOUT - 22
-
- Returns the transition at the end of the
- animation. The transition may be:
- AA_CUT - 0
-
- No transition is performed.
-
- AA_FADEBLACK - 1
-
- Fade to black transition is performed.
-
- AA_FADEWHITE - 2
-
- Fade to white transition is performed.
-
- AA_TIMEIN - 23
-
- Returns the duration of the transition at
- the beginning of the animation in
- milliseconds. This duration may be from
- .250 seconds to 10.000 seconds.
-
- AA_TIMEOUT -24
-
- Returns the duration of the transition at
- the end of the animation in milliseconds.
- This duration may be from .250 seconds to
- 10.00 seconds.
-
- AA_MODFLAG - 100
-
- Returns the modified flag for the script.
- Zero means the script is not modified and a
- non-zero value means the script is modi-
- fied.
-
- AA_CALLBACK - 25
-
- Returns the handle of the window used to
- receive the status and notification
- messages.
-
- AA_ANIMWND - 26
-
- Returns the handle of the window that
- actually contains the animation.
-
- AA_SCRIPTNAME - 101
-
- Returns a global memory handle containing
- the name of the script. If the script is
- untitled, or the animation is not a script,
- zero is returned.
-
- AA_ANIMATION - 102
-
- Returns the number of the currently visible
- animation in a script. Zero is the first
- animation of a script, or returned if the
- animation is not a script.
- AA_ANIMATIONCOUNT - 103
-
- Returns the number of animations in a
- script. Zero is returned if the animation
- is not a script.
-
- AA_SCRIPTCONTENTS - 104
-
- Returns a global memory handle containing
- the contents of the script. This handle
- contains the script as it would appear in a
- text file, and is terminated by a null
- character. If the script is empty, or the
- animation is not a script, zero is re-
- turned.
-
- AA_LASTERROR - 1001
-
- Return the code for the last error detected
- by the player. This type should be used
- immediately after detecting an error to
- determine the error. If the animation
- handle is zero, the player will search for
- the last error for the calling application.
- If the animation handle is a valid handle,
- the player searches for the last error for
- the application owning the animation. The
- error codes are:
-
- AA_ERR_NOERROR - 0
- No error was detected.
-
- AA_ERR_NOMEMORY - 256
- An out of memory condition was detected.
-
- AA_ERR_BADHANDLE - 257
- The handle used in the last call to the
- player was invalid.
-
- AA_ERR_NOTIMERS - 258
- A system timer could not be allocated
- for the animation.
-
- AA_ERR_BADSOUND - 259
- The sound could not be opened.
-
- AA_ERR_NOSCRIPT - 260
- The operation in error requires a
- script.
-
- AA_ERR_WRITEERR - 261
- An error occured while saving the
- script.
-
- AA_ERR_BADANIMATION - 262
- The animation could no be opened.
-
- AA_ERR_BADWINDOWHANDLE - 512
- An invalid window handle was given to
- the player.
-
- AA_ERR_WINDOWCREATE - 513
- An error occured when creating the
- animation window.
-
- AA_ERR_DLGERROR - 514
- An unexpected error occured while
- processing a dialog box.
-
- AA_ERR_INVALIDSTATUS 768
- The function failed because the state of
- the animation did not allow it.
-
- AA_ERR_BADDIBFORMAT - 769
- The Windows DIB file is corrupted.
-
- AA_ERR_BADFLIFORMAT - 770
- The Autodesk Animator or Animator Pro
- file is corrupted.
-
- AA_ERR_UNRECOGNIZEDFORMAT 771
- The file is in an unrecognized format.
-
- AA_ERR_NOSOUND - 772
- Sound is not supported by the player.
-
- AA_ERR_NOTVALIDFORSCRIPTS 773
- The request is not allowed for scripts,
- only for animations.
-
- AA_ERR_INVALIDFILE - 774
- The file handle for the animation is
- invalid.
-
- AA_ERR_NOSCRIPTS - 775
- Scripts are not supported by the player.
-
- AA_ERR_SPEED - 1024
- The speed is invalid. The speed must be
- from 19 to 1000 milliseconds.
-
- AA_ERR_LOOPS - 1025
- The loops are invalid. The number of
- loops may range from 0 to 999.
-
- AA_ERR_RPTSOUND - 1026
- The number of sound repetitions are
- invalid. This value may range from 0 to
- 1000.
-
- AA_ERR_PAUSE - 1027
- The time to pause at the end of the
- animation is invalid. This value may
- range from 0 to 50000 milliseconds.
-
- AA_ERR_TRANSIN - 1028
- The starting transition is invalid.
- Transitions must be one of the codes
- described above.
-
- AA_ERR_TIMEIN - 1029
- The duration of the starting transition
- is invalid. It ranges from 250 to 10000
- milliseconds.
-
- AA_ERR_TRANSOUT - 1030
- The ending transition is invalid. It
- must be one of the codes described
- above.
-
- AA_ERR_TIMEOUT - 1031
- The time of the ending transition is
- invalid. It may rang from 250 to 10000
- milliseconds.
-
- AA_ERR_DELAYSND - 1032
- The delay of the sound from the start of
- the animation is invalid. It may range
- from -3000000 to 3000000 milliseconds.
-
- AA_ERR_INVALIDTYPE - 1033
- The type parameter to aaGetParm
- aaSetParm or aaSetParmIndirect is
- invalid.
-
- AA_ERR_DUPLICATENOTIFY - 1280
- An attempt was made to add a duplicate
- notification.
-
- AA_ERR_NOSWITCH - 1536
- A script line is missing an option
- switch, or the switch is invalid.
-
- AA_ERR_PARSELOOPS - 1537
- The number of loops on a script line is
- invalid.
-
- AA_ERR_PARSESPEED - 1538
- The speed on a script line is invalid.
-
- AA_ERR_BADRPTSOUND - 1540
- The number of sound repetitions on a
- script line is invalid.
-
- AA_ERR_PARSEPAUSE - 1541
- The pause at the end of an animation on
- a script line is invalid.
-
- AA_ERR_PARSETRANS - 1542
- A transition value is invalid.
-
- AA_ERR_PARSEDELAYSND - 1543
- The delay of a sound from the beginning
- of the animation is invalid.
-
- AA_LASTERRORMESSAGE - 1002
-
- A handle to a string containing text for
- the error code retrieved by AA_LASTERROR is
- returned. This string may be displayed in a
- message box. If the error is in a script,
- and the animation name of the line which
- caused the error is known, the name of the
- animation will be in the message. The
- player will also copy the message into a
- buffer, if aaSetParm is used.
-
-
- _________________________________________________________________
-
- aaGetParmIndirect
-
- Syntax BOOL aaGetParmIndirect(hAa, lpAparm, wSize)
-
- Gets parameters for playing the animation into a
- structure. This allows an application to easily ob-
- tain all of an animations parameters.
-
- Parameters HAA hAa
-
- A handle returned by aaLoad.
-
- LPAAPARMS lpAparm
-
- A long pointer to the structure used to hold the
- parameters. The format of this structure is:
-
- struct {
- BYTE aa_status; /* offset 0 */
- BYTE aa_filetype; /* offset 1 */
- BYTE aa_mode; /* offset 2 */
- BYTE aa_bitpix; /* offset 3 */
-
- HWND aa_hwnd; /* offset 4 */
- int aa_x, /* offset 6 */
- aa_y, /* offset 8 */
- aa_cx, /* offset 10 */
- aa_cy; /* offset 12 */
- int aa_orgx, /* offset 14 */ aa_orgy; /* offset 16 */
-
- AASPEED aa_speed; /* offset 18 */
- AASPEED aa_designspeed; /* offset 20 */
-
- WORD aa_frames; /* offset 22 */
-
- DWORD aa_position; /* offset 24 */
- DWORD aa_loops; /* offset 28 */
- WORD aa_rptsound; /* offset 30 */
- WORD aa_pause; /* offset 32 */
- LONG aa_delaysnd; /* offset 34 */
- BYTE aa_transin; /* offset 36 */
- BYTE aa_transout; /* offset 37 */
- WORD aa_timein; /* offset 38 */
- WORD aa_timeout; /* offset 40 */
- HWND aa_callback; /* offset 42 */
- HWND aa_animwnd; /* offset 44 */
- };
-
- The contents of each field is described in aaGet-
- Parm.
-
- WORD wSize
-
- The size of the parameter structure.
-
- _________________________________________________________________
-
- aaSetParm
-
- Syntax HAA aaSetParm(hAa, wType, wValue1, lValue2)
-
- Sets parameters for playing the animation. The use
- of wValue1 and lValue2 depends on wType. The values
- of each field is described in aaGetParm. The handle
- of the animation with the new parameters is re-
- turned. If the value could not be set, NULL is re-
- turned. When NULL is returned, the original anima-
- tion handle is still valid.
-
- Parameters HAA hAa
-
- A handle returned by aaLoad.
-
- WORD wType
-
- The type of parameter to be set. The values of
- wValue1 and lValue2 vary depending on the parame-
- ter type.
-
- AA_MODE - 3
- wValue1 is the current mode of the anima-
- tion. The low order word of lValue2 is a
- mask for setting the mode. Mode values
- which are not to be set can inhibited by
- adding the value into the mask.
-
- AA_WINDOW - 4
-
- wValue1 is a the handle of a window in
- which the animation is to play. The call
- back window is changed if it has not been
- changed to another window handle.
-
- AA_SPEED - 5
-
- wValue1 is the speed, in milliseconds per
- frame.
-
- AA_POSITION - 8
-
- lValue2 is the number of frames and loops
- the frame position is to be moved. The high
- order word is the number of loops, the low
- order word is the number of frames. If the
- frames value wraps past the end of the ani-
- mation, it is carried into the loops value.
-
- wValue1 specifies the starting position. It
- is 0 if the starting position is the begin-
- ning of the animation, 1 if the starting
- position is the current frame, and 2 if the
- starting position is the end of the anima-
- tion.
-
- If the position is set while an animation
- is stopped, the animation will start from
- the given position, instead of from the be-
- ginning. In this case any sound associated
- with the animation is also started from its
- current position.
-
- AA_LOOPS - 9
-
- lValue2 is the position of the frame at
- which the animation ends.
-
- If the value of the high order word of AA_LOOPS is AA_LOOPSOUND (which is 65535),
- then the animation loops until the sound
- finishes playing. If the low order word is
- also this value, the animation will end
- with the sound. Otherwise, the animation
- will stop on the frame number given by the
- low order word, after the sound has fin-
- ished. In the limited version of the player
- the value AA_LOOPSOUND is accepted, but it
- is interpreted as though the animation
- plays forever.
-
- AA_X - 10
-
- wValue1 is the x coordinate of the upper
- left corner of the animation window.
-
- AA_Y - 11
-
- wValue1 is the y coordinate of the upper
- left corner of the animation window.
-
- AA_CX - 12
-
- wValue1 is the width of the animation win-
- dow.
-
- AA_CY - 13
-
- wValue1 is the height of the animation win-
- dow.
-
- AA_ORGX - 14
-
- wValue1 is the x coordinate in the anima-
- tion, displayed at the upper left corner of
- the animation window.
-
- AA_ORGY - 15
-
- wValue1 is the y coordinate in the anima-
- tion, display at the upper left corner of
- the animation window.
-
- AA_RPTSOUND - 18
-
- wValue1 is the number of times the sound is
- to repeat before stopping. The sound is al-
- ways stopped when the animation is stopped
- or paused. The limited version of the
- player ignore this parameter.
-
- AA_PAUSE - 19
-
- wValue1 is the length of time to pause the
- animation at its end, in milliseconds.
-
- AA_DELAYSND - 20
- lValue2 is the length of time to delay the
- sound from the start of the animation in
- milliseconds. The delay is negative if the
- sound is to start before the animation. The
- limited version of the player ignore this
- parameter.
-
- AA_TRANSIN - 21
-
- wValue1 is the transition at the beginning
- of the animation. This transition may be:
-
- AA_CUT - 0
-
- No transition is performed.
-
- AA_FADEBLACK - 1
-
- Fade from black transition is performed.
-
- AA_FADEWHITE - 2
-
- Fade from white transition is performed.
-
- AA_TRANSOUT - 22
-
- wValue1 is the transition at the end of the
- animation. The transition may be:
-
- AA_CUT - 0
-
- No transition is performed.
-
- AA_FADEBLACK - 1
-
- Fade to black transition is performed.
-
- AA_FADEWHITE - 2
-
- Fade to white transition is performed.
-
- AA_TIMEIN - 23
-
- wValue1 is the duration of the transition
- at the beginning of the animation in
- milliseconds. This duration may be from
- .250 seconds to 10.000 seconds.
-
- AA_TIMEOUT -24
-
- wValue1 is the duration of the transition
- at the end of the animation in
- milliseconds. This duration may be from
- .250 seconds to 10.00 seconds.
-
- AA_CALLBACK - 25
- wValue1 is the handle of the window used to
- receive the status and notification
- messages.
-
- AA_ANIMWND - 26
-
- wValue1 is the handle of the window that
- actually contains the animation.
-
- AA_MODFLAG - 100
-
- wValue1 contains the modified flag for the
- script. Zero means the script is not modi-
- fied and a non-zero value means the script
- is modified. The limited version of the
- player ignore this parameter.
-
- AA_SCRIPTNAME - 101
-
- lValue2 contains a pointer to the new name
- of the script. If lValue2 is zero, the
- script is untitled. The limited version of
- the player ignore this parameter.
-
- AA_ANIMATION - 102
-
- lValue2 contains the number of the anima-
- tion in the script which is to become visi-
- ble. The limited version of the player ig-
- nore this parameter.
-
- wValue1 specifies the starting position. It
- is 0 if the starting position is the begin-
- ning of the animation, 1 if the starting
- position is the current frame, and 2 if the
- starting position is the end of the anima-
- tion.
-
- AA_LASTERRORMESSAGE - 1002
-
- The string containing text for the error
- code retrieved by AA_LASTERROR is copied
- into a buffer. The buffer size is given in
- wValue1, and the address of the buffer is
- given in lValue2. This string may be
- displayed in a message box. If the error is
- in a script, and the animation name of the
- line which caused the error is known, the
- name of the animation will be in the
- message. The player will also return a
- handle to the message text, if aaGetParm is
- used.
-
- _________________________________________________________________
- aaSetParmIndirect
-
- Syntax HAA aaSetParmIndirect(hAa, dwType, lpAparm, wMask)
-
- Sets the animation parameters from a structure. The
- handle of the animation with the new parameters is
- returned. If the value could not be set, NULL is re-
- turned. When NULL is returned, the original anima-
- tion handle is still valid.
-
- Parameters HAA hAa
-
- A handle returned by aaLoad.
-
- DWORD dwType
-
- A mask containing a bit for each parameter. Any
- parameter is set only when the corresponding mask
- bit is on. The following values define the mask
- bits:
-
- AA_SETMODE - 1
- AA_SETWINDOW - 2
- AA_SETSPEED - 4
- AA_SETPOSITION - 8
- AA_SETLOOPS - 16
- AA_SETX - 32
- AA_SETY - 64
- AA_SETCX - 128
- AA_SETCY - 256
- AA_SETORGX - 512
- AA_SETORGY - 1024
- AA_SETRPTSOUND - 2048
- AA_SETPAUSE - 4096
- AA_SETDELAYSND - 8192
-
- LPAAPARMS lpAparm
-
- A long pointer to the structure containing the
- parameters being set. See aaGetParmIndirect for a
- description of this structure.
-
- WORD wMask
-
- A mask used for setting the mode if AA_SETMODE is
- set in wType. Setting of specific mode values can
- be inhibited by adding the value not to be set
- into this argument. This argument is used only
- when AA_SETMODE is set in wType.
-
- _________________________________________________________________
- aaShow
-
- Syntax BOOL aaShow(hAa, bShow)
-
- Shows or hides the animation window. This setting is
- independent of the mode value AA_HIDEWINDOW. This
- routine will hide playing animations and show hidden
- stopped animations.
-
- Parameters HAA hAa
-
- The handle of the animation returned by aaLoad.
-
- BOOL bShow
-
- The animation window is shown if bShow is TRUE,
- and hidden if bShow is FALSE.
-
- _________________________________________________________________
-
- aaSound
-
- Syntax BOOL aaSound(hAa, lpszDevice, lpszSound, wMode)
-
- Associates a sound with an animation. The sound is
- begun with the animation and will end when the ani-
- mation ends, unless it is shorter than the anima-
- tion. If it is shorter than the animation, it can be
- looped using aaSetParm with AA_RPTSOUND. FALSE is
- always returned by the limited version of the
- player.
-
- If the appropriate flag is set in wMode, when the
- sound is associated, an alias for the sound is cre-
- ated. This alias is formed by concatenating the word
- "AAPLAY" and the decimal value of the handle, hAa.
- This alias can be used to alter the playing of the
- sound.
-
- Parameters HAA hAa
-
- The handle of the animation returned by aaLoad.
-
- LPSTR lpszDevice
-
- If AA_SNDDEVICEID is not set in wMode, this argu-
- ment contains the name of the device used to play
- the sound. If you have setup MCI extensions, this
- argument can be NULL. If AA_SNDDEVICEID is set in
- wMode, this argument contains the MultiMedia Con-
- trol Interface Type ID.
-
- LPSTR lpszSound
-
- Either the name of the file containing the sound
- to be played, or a string used to play the sound.
- The format of the file must be supported by the device used to play it. If the device specified
- by lpszDevice is not given, or requires a file to
- be played, this argument is the name of the file
- to play. If the device does not use files for
- playing (cdaudio, videodisc, videotape, etc),
- this argument contains the play arguments for an
- MCI Command string to the device.
-
- WORD wMode
-
- This argument gives the mode of the sound The
- following modes are valid:
-
- AA_SNDFREEZE - 1
- Normally the animation continues to play when
- the sound is being prepared for playing.
- Setting this value prevents this from happen-
- ing.
-
- AA_SNDDEVICEID - 256
- Indicates that the device value is not the
- name of a sound device, but is the MultiMedia
- Control Interface Type ID.
-
- _________________________________________________________________
-
- aaGetCaps
- Syntax WORD aaGetCaps(type)
-
- Returns information on the current capabilities of
- the animation player.
-
- Parameters WORD type
-
- The type of information to be returned. This pa-
- rameter can take on the following values:
-
- AA_CAP_TIMER - 1
- Returns the accuracy of the timer in millisec-
- onds. The time between successive frames is
- always an integral multiple of the value re-
- turned. The value returned is 55 milliseconds
- if the Multimedia extensions are not in-
- stalled, or 1 millisecond if the extensions
- are installed.
-
- AA_CAP_SOUND - 2
- Returns zero if sound support is not available
- in the player. Otherwise a non-zero value is
- returned. Sound is not available in the lim-
- ited version of the player, when the Multi-
- media extensions are not installed, or when
- there are no drivers in the [MCI] section of
- system.ini. Some versions of the player may
- not support sound even when the Multimedia ex-
- tensions are installed and there are drivers
- in the [MCI] section of system.ini.
- AA_CAP_SCRIPT - 3
- Returns zero if script support is not avail-
- able in the player. Otherwise a non-zero value
- is returned. Scripts are not available in the
- limited version of the player.
-
- _________________________________________________________________
-
- aaGetFile
- Syntax int aaGetFile(wFlags, lpzFileName, wSizeFile, lpzDe-
- viceName, wSizeDevice)
-
- Prompts the user for the name of a file, and copies
- the name entered to the location addressed by lpz-
- FileName. If the file is the name of a sound file,
- the Sound device name is copied to the location ad-
- dressed by lpzDeviceName. The return value is 0, if
- the user presses the cancel button, -1 if the se-
- lected file does not exist, or a positive number if
- the selected file does exist.
-
- Parameters WORD wFlags
-
- Flags used to control the dialog box. It is
- formed by adding the following values:
-
- AA_GETFILE_MUSTEXIST - 1
- If set the file entered must exist before
- aaGetFile will return.
-
- AA_GETFILE_NOSHOWSPEC- 2
- If set the search specification is not dis-
- played in the file name edit control.
-
- AA_GETFILE_SAVE - 4
- If set the OK button is changed to read
- "Save", and the caption reads "Save". Setting
- this value automatically sets the
- AA_GETFILE_USEFILE flag. This flag is ignored
- in the limited version of the player.
-
- AA_GETFILE_OPEN - 8
- If set the OK button is changed to read
- "Open", and the caption reads "Open"
-
- AA_GETFILE_USEDIR - 16
- If set the directory of the current contents
- of the string addressed by lpzFileName is used
- as the initial directory in the dialog.
-
- AA_GETFILE_USEFILE - 32
- If set the file name of the current contents
- of the string addressed by lpzFileName is put
- in the file name edit control.
-
- AA_GETFILE_SOUND - 64
- If set the file specification for sound files
- is used in the dialog, and the caption reads
- "Sound". If neither AA_GETFILE_SOUND nor
- AA_GETFILE_SCRIPT is set in wFlags, the file
- specification for animation and script files
- is used in the dialog, and the caption reads
- "Animation". Setting this flag will cause the
- limited version of the player to return 0,
- indicating the cancel button was pressed.
-
- AA_GETFILE_SCRIPT - 128
- If set the file specification for script files
- is used in the dialog, and the caption reads
- "Script". If neither AA_GETFILE_SOUND nor
- AA_GETFILE_SCRIPT is set in wFlags, the file
- specification for animation and script files
- is used in the dialog, and the caption reads
- "Animation". Setting this flag will cause the
- limited version of the player to return 0,
- indicating the cancel button was pressed.
-
- LPSTR lpzFileName
-
- A pointer to a string used to hold the file name
- entered.
-
- WORD wSizeFile
-
- The maximum size of the file name which can be
- returned.
-
- LPSTR lpzDeviceName
-
- A pointer to a string used to hold the Sound De-
- vice name entered. This parameter is only used if
- AA_GETFILE_SOUND is set in wFlags.
-
- WORD wSizeDevice
-
- The maximum size of the Sound Device name which
- can be returned..
-
- _________________________________________________________________
-
- aaSave
- Syntax BOOL aaSave(hAa, wMode)
-
- Saves the script of the animation whose handle is
- hAa. Returns TRUE is the script is saved, otherwise
- FALSE is returned. False is always returned by the
- limited version of the player.
-
- Parameters HAA hAa
-
- The handle of the animation returned by aaLoad.
-
- WORD wMode
- The mode used to save the animation. It is formed
- by adding the following values:
-
- AA_SAVE_IFMODIFIED - 1
- The script is only saved if it has been modi-
- fied.
-
- AA_SAVE_AS - 2
- The user is prompted for a new file name to
- save the script. If the script is untitled,
- the used is always prompted for a file name,
- whether or not this flag is set.
-
- Error Dialogs
- The following error messages are presented in dialogs:
-
- The animation can The Test button was pressed in the Pa-
- not be tested with rameters dialog, but an error occurred
- the selected parame- when the animation was run.
- ters.
-
- The selected parame- The OK button was pressed in the Parame-
- ters can not be ters dialog, but an error prevented the
- changed in this ani- parameters from being changed.
- mation.
-
- The value for speed The speed entered was either not a num-
- is invalid. Please ber or was outside of the valid range.
- enter a value be- The valid range is displayed in the mes-
- tween nn.n and nn.n. sage.
-
- The value for loops The loops entered was either not in the
- is invalid. Please proper format or was outside of the
- enter a value be- valid range. The valid range is dis-
- tween nnnn:nnn and played in the message.
- nnnn:nnn.
-
- The value for dura- The duration entered was either not in
- tion is invalid. the proper format or was outside of the
- Please enter a value valid range. The valid range is dis-
- between mm:ss.sss played in the message.
- and mm:ss.sss.
-
- The number of times The repeat value for sound was either
- the sound is to be not a number or was outside of the valid
- repeated is invalid. range. The valid range is displayed in
- Please enter a value the message.
- between nnn and nnn.
-
- The value for paus- The pause at end value was either not a
- ing the animation is number or was outside of the valid
- invalid. Please en- range. The valid range is displayed in
- ter a value between the message.
- nn.nnn and nn.nnn.
-
- The value for delay The delay sound value was either not a
- sound is invalid. number or was outside of the valid
- Please enter a value range. The valid range is displayed in
- between mm:nn.nnn the message.
- and mm:nn.nnn.
-
- The number of frames The length of the animation changed af-
- found in the anima- ter the animation was loaded.
- tion was incorrect.
-
- Loops cannot be The value chosen for loops would require
- changed while Dura- that the duration be changed, but the
- tion is locked and duration is locked and can not be
- has the value changed.
- mm:ss.sss.
-
- Duration cannot be The value chosen for duration would re-
- changed while loops quire that the loops be changed, but the
- is locked and has loops are locked and can not be changed.
- the value nnnn:nnn.
-
- In the following messages the file name following Script: is the
- name of the script in which the error occurred. The file name
- following Line: is the name of the animation on which the error
- was found.
-
- Script: xxx\xxx\xxx A file error occurred while saving the
- An error occurred script. The disk is probably full, or
- while saving the the script may be read only.
- script.
-
- Script: xxx\xxx\xxx A memory allocation error occurred.
- Internal Error! In-
- sufficient memory
- for operation.
-
- Script: xxx\xxx\xxx While reading a script an option begin-
- Line: xxx\xxx\xxx ning with a '-' was expected. Instead
- Expected switch the characters displayed were found.
- found "xxxxx".
-
- Script: xxx\xxx\xxx The loop count entered on the script
- Line: xxx\xxx\xxx line was either not in the proper format
- Loop count, "xxxxx", or out of range.
- is invalid.
-
- Script: xxx\xxx\xxx The animation speed entered on the
- Line: xxx\xxx\xxx script line was either not a number or
- Animation speed, out of range.
- "xxxxx", is invalid.
-
- Script: xxx\xxx\xxx The number of sound repeats entered on
- Line: xxx\xxx\xxx the script line was either not a number
- Number of sound re- or out of range.
- peats, "xxxxx", is
- invalid.
-
- Script: xxx\xxx\xxx The length of pause at the animation end
- Line: xxx\xxx\xxx was either not a number or out of range.
- Animation pause
- time, "xxxxx", is
- invalid.
-
- Script: xxx\xxx\xxx The sound delay was either not a number
- Line: xxx\xxx\xxx or out of range.
- The sound delay,
- "xxxxx", is invalid.
-
- Script: xxx\xxx\xxx The options for the line are inconsis-
- Line: xxx\xxx\xxx tent and could not be set.
- An error occurred
- changing the parame-
- ters for this line.
-
- The following messages allow Yes or No responses from the user.
-
- Script: xxx\xxx\xxx Presented when a modified script is un-
- The animation script loaded using aaUnload. If the user
- has been modified. presses Yes, a file save dialog is pre-
- Do you want to save sented and the user can select a file to
- the script? save the script. If the user presses No,
- the modifications are lost.
-
- Script: xxx\xxx\xxx Presented when the user selects an ex-
- The script already isting file from the file save dialog.
- exists. Do you want This can happen when unloading a modi-
- to overwrite the fied script, or when using aaSave with
- current script? AA_SAVE_AS set. If Yes is pressed, the
- existing file is overwritten. If No is
- pressed, the user is prompted for an-
- other file name. If cancel is pressed,
- the save operation is canceled, which
- may cause modifications to be lost.
-
-