home *** CD-ROM | disk | FTP | other *** search
- -----------------------------------------------------------------------------
- *** MID-KIT ver 1.23 Documentation ***
- -----------------------------------------------------------------------------
-
- First of all, I'd like to thank Jean-Paul Mikkers, for letting me use some
- of his source code for the mixing routines. Without them, MID-KIT would not
- be what it is today. He has a great Mod player library, if any of you are
- interested. To contact him, write to:
- Jean-Paul Mikkers
- mikmak@stack.urc.tue.nl
-
- MID-KIT is shareware. If you would like to use MID-KIT in your own
- commercial software, please send in the registration form "REGISTER.FRM".
-
- Registering MID-KIT entitles you to free upgrades, up to ver 1.99.
- Once 2.0 comes out, you will need to only pay a $10 upgrade fee. MID-KIT is
- only $50! No royalties must be paid, even if your product goes to the shelf.
- It would be nice of you to include my name in the credits :-). So please
- register, it helps me improve the player engine, and it helps you get a
- better sound system. By any means, if you are not happy with MID-KIT, then
- tell me why! I need to know of any bugs, or such. Please rspond to:
-
- John Pollard
- Compuserve: 74723,1626
- Internet : 74723.1626@compuserve.com
-
- Address : John Pollard
- P.O. BOX 692044
- Tulsa, OK 74169-2044
-
- Phone : 1 (918) 234-1420
-
- If you are a member of compuserve, you can register right online! Just
- GO swreg. Registration ID: 7061.
- -----------------------------------------------------------------------------
- **INTRODUCTION**
- -----------------------------------------------------------------------------
-
- MID-KIT is a MIDI engine, for Sound Blasters & %100 compatibles. MID-KIT
- can also play 32 sound effects at the same time! That's right, you can have
- midi songs playing in the background, while 32 sound effects play. That does
- not mean you must use all 32 channels. About 8 channels, is good enough a
- normal game.
-
- FEATURES:
- Support for all SB & %100 compatibles up to SB16.
-
- MIDI Player:
- Drum support.
- Supports Pitch bends.
- After-Touch midi message support.
- Can use SB mixer if availible, else will mix in real-time.
- Can play multi-track midi files.
- DIGI Player:
- Plays any size .wav file!
- Supports looping sound effects.
- Support 16 - Bit .wav files.
- Stereo, and 16 bit support.
- Stereo panning effects.
- Up to 32 channels of sound!
-
-
- Will Feature in the future:
- MPU-401 support.
- More sound cards (GUS. Be sure and bug me about this, if you want it.)
- OPL3.
- Much MORE!!!
- This thing is new, give me some time!!!!!!!
- If you want Gravis Ultra-sound support, then give me a ring! I've
- got the code for a driver. Just need some motivation to add it in..
-
-
- You must convert the MIDI files into a format understood by MID-KIT. I've
- included a utility to do so. The utility is call "MID2MKS.EXE". Just type
- MID2MKS input.mid output.mks. That's it!. Then use the MKS loaders to load
- them up!
-
- MID-KIT uses a .MKI file (Mid Kit Instrument file) for playing the FM
- sounds for a .MKS (midi converted file, see above). Upon initiation, of the
- sound system, you must load in a .mki file. MKI files are stored in a
- structure called mki_file (see midkit.h for details). The routine
- MK_LoadMKI(mki_file *mki), loads in a file called "MID-KIT.MKI". You must
- load in this file, before using any MKS play routines, or MID-KIT won't be
- able to play any notes. You don't need to do this, if your not initiating the
- sound system for midi playing.
-
- A .MKI files consist of 1 general midi .ibk file, and 1 percussion .ibk
- file. I've included a utility to convert 2 .ibk's into an .MKI file. The
- utility is called "IBK2MKI.EXE". Just type IBK2MKI in1.ibk in2.ibk out.mki.
- The output file must be called MID-KIT.MKI for unregistered versions of
- MID-KIT. I've included 1 general midi .ibk (gm1.ibk), and a percussion .ibk
- (perc.ibk). It only uses the first 3 instruments of the percussion .ibk.
- These 3 instruments, define how it will play the drum sounds. I suggest just
- using the "perc.ibk" file I've included. You can use any general midi .ibk
- you want.
-
- You don't have to use both the MIDI player, and the DIGI player. You can
- use either one, or both. This means you can mix libraries if you want to.
-
- MID-KIT uses a timer interrupt, to call it's routines. You can install
- the sound system using this timer, or you may use your own. If you decide
- to use your own, you must call MK_Update(), 72.8 times/sec. If you want to
- use MID-KIT's timer, use MK_StartTimer() after initiating the sound system.
- NOTE - If MID-KIT return's 0 (no sound card) when you initiate MID-KIT,
- you can still install the timer. This is usefull, when someone does not have
- a sound card, but would still like to play. You can call all functions,
- as ussual. If you do install the timer, a variable "MK_Timer" will be
- incremented 72.8 times per second.
-
- NOTE - If MID-KIT detects digitized sound, but no FM chip, or vice versa.
- It will play anyone it detects. Also, if you do not want to use the midi
- player, and just digital sound. Install just for digital sound, or vice
- versa. You can call MK_Update() at any speed you like, if you're just using
- the DIGI routines. You'll have to adjust the playback frequency though.
-
- When you start up MK_StartTimer(), a variable MK_Timer, will be incremented
- every 72.8 times per second. You can allways check the value of this vari-
- able for game timing.
-
- Please see the file "MIDWAV.C" for a complete explanation of how to use the
- midi play routines, and the sound effects routines.
-
- MID-KIT uses a cool ERROR system. If a function was to return an error
- value, it would return 1 on succes, and 0 on failure. If it returned a 0,
- then it would have set the "mkerr" variable. Look at the midwav.c for an
- example on this error system....
-
-
- MID-KIT is very easy to use! Check out these MID-KIT commands below!
-
- - Page 1 -
- *****************************************************************************
- ***************** MID-KIT Initializing Routines *******************
- *****************************************************************************
- /////////////////////////////////////////////////////////////////////////////
- -MK_Init(UBYTE flag, int num_voices)
-
- You must call this routine before calling any other MID-KIT routine.
-
- flag = How MID-KIT will be initialized. Setting certain bits of
- this flag, will change the way MID-KIT installs itself.
- Just | (bit-wise or) the values you want together. The
- Avialible flags are:
- MK_MIDI - Selects MIDI play.
- MK_DIGI - Selects Digital sound effects playing.
- MK_AUTO - Auto detects the card.
-
- NOTE - See below about auto-detecting.
-
- num_voices = The number of voices MID-KIT should open for mixing (1-32);
-
- Eaxmple:
- MK_Init(MK_MIDI | MK_AUTO | MK_DIGI, 10);
-
- This will intialize MID-KIT using midi, digital sounds, with
- 10 channels of digital sound effects. It will auto-detect your
- soundcard... IF YOU DO NOT AUTO-DETECT, THEN YOU MUST SET
- THESE VARIABLES:
-
- sb_port =0x220;
- sb_irq =5;
- sb_lodma=1;
- sb_hidma=5; // this is for sb16's and up...
-
- Set them to whatever you save in your config files, etc...
-
- /////////////////////////////////////////////////////////////////////////////
- -MK_Exit(void)
-
- You must call this before exiting your program.
- /////////////////////////////////////////////////////////////////////////////
- -MK_StartTimer(void)
-
- Call this after initiating the sound system. Starting up the timer, will
- increment a variable MK_Timer, every 72.8 times per second.
- /////////////////////////////////////////////////////////////////////////////
- -MK_StopTimer(void)
-
- You MUST! call this routine, before you program exits, if you've installed
- MID-KIT's timer.
-
- /////////////////////////////////////////////////////////////////////////////
- -MK_Update(void)
-
- If the custom MID-KIT timer is not installed, this routine must be called
- 72.8 times/sec.
-
- *****************************************************************************
- ***************** Voice Routines and Wave play routines *******************
- *****************************************************************************
-
- /////////////////////////////////////////////////////////////////////////////
- -MK_VoiceSetVolume(UBYTE voice,
- UBYTE vol)
-
- Sets the volume of a voice.
-
- voice = The voice that you are going to set the volume of.
- This must be from 0 - the number of voices defined when you initiate
- the sound system
- vol = The actual volume of the voice (0-64)
-
- /////////////////////////////////////////////////////////////////////////////
- -MK_VoiceSetFrequency(UBYTE voice,
- ULONG frq)
-
- Sets the frequency of a voice.
-
- voice = The voice to change.
- frq = The actual frequency the voice will play sounds.
-
- ////////////////////////////////////////////////////////////////////////////
- -MK_VoiceSetPanning(UBYTE voice,
- ULONG pan)
-
- Sets the panning position of a voice.
-
- voice = The voice to change.
- pan = The new panning posistion for the voice.
- 1-255 - from left to right
- 1 = FULL Left
- 255 = FULL Right.
-
- ////////////////////////////////////////////////////////////////////////////
- -MK_VoiceStop(UBYTE voice)
-
- Stops a sound effect from playing on a certain voice.
-
- voice = The voice to stop playing.
- ////////////////////////////////////////////////////////////////////////////
- -MK_VoiceActive(UBYTE voice)
-
- This return a 1 if the voice is playing a sound effect, or 0 if it's not.
-
- voice = The voice to check.
- ////////////////////////////////////////////////////////////////////////////
- -MK_VoicePlay(UBYTE voice,
- WORD handle,
- ULONG start,
- ULONG size,
- ULONG reppos,
- ULONG repend,
- UWORD flags)
-
- Plays a sound effect (a previously loaded .wav file), on a certain voice.
-
- voice = The voice to play the sound effect on.
- handle = The handle defined in the SAMPLE structure.
- start = The start posistion defined in the SAMPLE structure.
- size = The size defined in the SAMPLE structure.
- reppos = If the repeat flag is set, then this is where it start repeating.
- repend = If the repeat flag is set, then this is where it stops repeating.
- flags = The flags defined in the SAMPLE structure.
- Please see midkit.h, for info on these flags.
- EXAMPLE:
- #include"midkit.h"
- #include"mtypes.h"
- #include"mwav.h"
- #include<stdio.h>
-
- SAMPLE *s; // define a sound effect.
-
- void main(void)
- { /*
- Initialize soundcard parameters.. you _have_ to do this
- before calling MD_Init(), and it's illegal to change them
- after you've called MD_Init()
-
- Initiate for digital routines, midi routines, 8 voices, and install
- MID-KITs custom timer (72.8 hz / interupt 8).
- */
- mk_mixfreq =44100; // standard mixing freq
- mk_dmabufsize =4000; // standard dma buf size
- mk_mode =BITS16|STEREO; // standard mixing mode
-
- // auto-detect all perameters.....
-
- if (!MK_Init(MK_DIGI | MK_MIDI | MK_AUTO, 8) )
- printf("Driver ERROR: %s",mkerr);
- else
- printf("Found Sound Blaster at port %0x, irq %i",sb_port,sb_irq);
-
- MK_StartTimer(); // install custom timer...
- // variable MK_Timer will be incremented
- // 72.8 times per second.
-
- if ((s=MK_LoadWave("sample.wav"))==NULL); // load the wave file
- { printf("Wave Loader ERROR: %s",mkerr);
- exit(-1);
- }
- MK_VoiceSetVolume(0,64); // set volumes and freqency's.
- MK_SetFrequency(0,12000);
- MK_SetPanning(0,100);
- MK_VoicePlay(0,s->handle,s->start,s->size,0,0,s->flags);
- while (!kbhit() );
- MK_FreeWave(s);
- MK_Exit();
- }
-
- - Page 2 -
-
- *****************************************************************************
- ***************** Wave Loading Routines *******************
- *****************************************************************************
- ////////////////////////////////////////////////////////////////////////////
- -MK_LoadWave(char *filename)
- Loads a wave file into a SAMPLE structure.
- EXAMPLE:
- SAMPLE *s;
- s=MK_LoadWave("sample.wav");
-
- ////////////////////////////////////////////////////////////////////////////
- -MK_FreeWave(SAMPLE *si)
- Frees a previously allocated SAMPLE structure.
- EXAMPLE:
- SAMPLE *s;
- s=MK_LoadWave("sample.wav");
- MK_FreeWave(s);
- ////////////////////////////////////////////////////////////////////////////
-
- *****************************************************************************
- ***************** MIDI Playing routines (.MKS files) *******************
- *****************************************************************************
-
- NOTE - You must convert midi files, to mid-kit's own format.
- Use MID2MKS.EXE to do this.....
-
- ////////////////////////////////////////////////////////////////////////////
- -MK_LoadMKI(mki_file *mki);
-
- Loads an .MKI bank file.
- You must do this before any MKS play routine, or it will play wrong.
-
- EXAMPLE:
- mki_file mki;
- MK_LoadMKI(&mki); // load in the MID-KIT.MKI data file
- ////////////////////////////////////////////////////////////////////////////
-
- -MK_LoadMKS(char *name, mdk_file *mdk);
-
- Loads a .mks file. For playing.
-
- EXAMPLE:
- mks_file mks;
- mki_file mki;
- MK_LoadMKI(&mki); // load in the MID-KIT.MKI data file
- MK_LoadMKS("hero.mks", &mks); // load in the song
-
- ////////////////////////////////////////////////////////////////////////////
- -MK_PlayMKS(mks_file *mks, mki_file *mki);
-
- Plays a mks file.
-
- EXAMPLE:
- mks_file mks;
- mki_file mki;
-
- MK_LoadMKI(&mki); // load in the MID-KIT.MKI data file
- MK_LoadMKS("hero.mks", &mks);
-
-
- MK_PlayMKS(&mks, &mki);
-
- MK_SetMusicVol(60); // volume can be from 1-130
-
- ( Of course, you must initialize the sound system. Look at the support
- file "MIDWAV.C" for further info.)
-
- ////////////////////////////////////////////////////////////////////////////
- -MK_SetMusicVol(int vol)
- You must set this after playing a .mks song.
- uses:
- vol = 1-130 (1=min, 130=max)
-
- returns - 1 on succes, 0 on out of range volume....
-
- ////////////////////////////////////////////////////////////////////////////
- -MK_FreeMKS(mdk_file *mks);
-
- Frees an allocated mks file.
-
- ////////////////////////////////////////////////////////////////////////////
- -MK_StopMKS(void);
-
- Stops the current playing song file from playing.
- Call this before playing other mks files.
- ////////////////////////////////////////////////////////////////////////////
-