home *** CD-ROM | disk | FTP | other *** search
/ Sound, Music & MIDI Collection 2 / SMMVOL2.bin / MIDI_PAT / MEGAM111.ZIP / MEGAMID.DOC < prev    next >
Encoding:
Text File  |  1995-07-05  |  18.7 KB  |  436 lines

  1. **********************************************************************
  2.  
  3.                               MegaMID v1.11
  4.                        -+ The DOS MIDI player +-
  5.  
  6. **********************************************************************
  7.  
  8.  
  9. *** IMPORTANT : Setup information - read this first ***
  10.  
  11. To get MegaMID working, you need to:
  12. - Place all the following files in a directory:
  13.         
  14.         MEGAMID.EXE
  15.         NORMAL.F6T
  16.         NORMAL.F4T
  17.         G_MIDI.PAT
  18.         MT32.PAT
  19.  
  20. - Add that directory to your PATH statement. Otherwise, MegaMID
  21.   will not be able to locate the files it needs.
  22.  
  23. **********************************************************************
  24.  
  25. ### USAGE ###
  26.  
  27.  
  28. Format :
  29.  
  30.                 MEGAMID <MIDI file> [options]
  31.  
  32.                             or
  33.                 MEGAMID @<script file> [options]
  34.  
  35. Where :
  36.  
  37. <MIDI file>
  38.         Name of the MIDI file you wish to play. If no extension is
  39.         given, the extension .MID is assumed. Any valid DOS path
  40.         can also be specified as part of the filename. Wildcards like
  41.         * and ? can also be specified. If wildcards are used, MegaMID
  42.         will play all the songs that match the wildcard specifications.
  43.         
  44.         EXAMPLES :
  45.             MEGAMID demo0011
  46.             MEGAMID \MID\POP\*  /MPU              
  47.             MEGAMID D:\MID\SAMPLES\DEMO0001.MID  /K0 /SBMIDI
  48.  
  49. <script file>
  50.         This is a text file containing a list of MIDI files to play
  51.         in sequential order - sort of a album file if you like. Options
  52.         (given below) specific to each MIDI file can also be specified.
  53.         Any valid DOS path can also be specified along with the filename. 
  54.         The wildcards * and ? can also be used.
  55.  
  56.         EXAMPLE :
  57.             MEGAMID @SONGS.ALB
  58.  
  59.         where the text file SONGS.ALB could contain:
  60.             
  61.             ALMONDS /E
  62.             POP\STRIVING
  63.             JAZZ\NEW_YORK 
  64.             D:\MID\CLASSIC\*
  65.             C:\WINDOWS\CANYON /E /K2
  66.  
  67. [options]
  68.         The optional options :)  They are -
  69.         /MPU
  70.                 Use the Roland MPU-401 interface (default). Automatically
  71.                 detects whether the port address is 300h or 330h. Other
  72.                 port addresses not checked. 
  73.         /SBMIDI
  74.                 Use the Sound Blaster's MIDI OUT interface. Only port
  75.                 220h is currently supported.
  76.         /QUIET
  77.                 Quiet mode. Plays the songs while not playing the song...
  78.                 No sound devices required!
  79.         /GMIDI  
  80.                 Use the General MIDI patches (default).
  81.         /MT32
  82.                 Use the MT-32 patches. Good for playing MIDI files
  83.                 written for the Roland MT-32, LAPC-1, CM-64, CM-32L
  84.                 or other devices using similar patch maps.
  85.         /D10
  86.                 Use channel 10 as the drum channel(default). 
  87.         /D16    
  88.                 Use channel 16 as the drum channel. What MegaMID does
  89.                 is that it reroutes all events designated for channel
  90.                 16 to channel 10, and everything meant for channel 10
  91.                 to 16. This option is good for playing those MIDI files
  92.                 that use channel 16 for drums (like those meant for the
  93.                 SB FM synthesizer chip) on your General MIDI device.
  94.         /G
  95.                 Use the General MIDI specs(default). This means that
  96.                 all 16 channels are active, and channel 10 is set
  97.                 as the drum channel. 
  98.         /E      
  99.                 Uses the Extended MIDI specs. Sets channels 1 to 10
  100.                 ON, and channels 11-16 OFF. Picks channel 10 as the
  101.                 drum channel.
  102.         /B      
  103.                 Uses the Base MIDI specs. Sets channels 1 to 10 OFF,
  104.                 and channels 11 to 16 ON. Picks channel 16 as the
  105.                 drum channel, and reroutes it to channel 10.
  106.         /FAST
  107.                 Plays the MIDI file as fast as your computer can go.
  108.                 During that time, you cannot exit MegaMID until playback
  109.                 stops (which shouldn't take too long). This option is
  110.                 good for finding out the total playback time of the file,
  111.                 or for some really weird music.
  112.         /K0 
  113.                 Select bar display mode. All notes played appear on the
  114.                 screen as colour bars (vertical lines). This is the
  115.                 default mode.
  116.         /K1     
  117.                 Select keyboard display mode 1. All notes played appear as
  118.                 highlighted keys on keyboards.
  119.         /K2
  120.                 Select keyboard display mode 2. Similar to keyboard mode 1 
  121.                 except that only "keyboards" of active channels will be 
  122.                 shown.
  123.         /WC<BMP file>
  124.                 Use the specified BMP file as background, centred. BMP file
  125.                 may also be placed anywhere in search path.
  126.         /WT<BMP file>
  127.                 Use the specified BMP file as background, tiled. BMP file
  128.                 may also be placed anywhere in search path.
  129.         /PL<color>
  130.                 Specify set of colors used for background bitmap. 
  131.                 The range of <color> is from 0 to 8. If not specified, a
  132.                 set of colors is chosen randomly.
  133.         /MV<volume level>
  134.                 Sets the initial Master Volume level. Valid values are
  135.                 0 to 127.
  136.  
  137. Regularly used parameters can also now be placed in the file - MEGAMID.CFG !
  138. Command-line parameters will have precedence over parameters specified
  139. in the configuration file. If a script file is specified, any parameters
  140. found in the script file will have precedence over all other parameters.
  141. For example, if you have /G and /K1 in MEGAMID.CFG, and specify /E in your
  142. command line, /E will have precedence over /G (since they are of the same 
  143. class of parameters), but it will not affect the /K1 parameter.
  144.  
  145. **********************************************************************
  146.  
  147. ### CONTROL KEYS ###
  148.  
  149. While a song is playing, the following keys below can be used to
  150. perform specific functions :
  151.  
  152.   Up/Dn Arrow       Select Channel
  153.   +/-               Change patch
  154.   ,/.               Change drum kit
  155.   [/]               Change tempo
  156.   Bkspace           Restore original patch settings and tempo
  157.   M                 Mute/Unmute current channel
  158.   S                 Solo - turn current channel on and mute all other channels
  159.   A                 All channels on
  160.   v/b               Increase/Decrease master volume
  161.   V/B               Increase/Decrease master volume in fine steps
  162.   P                 Pause/Unpause
  163.   C                 Change background colors
  164.   K                 Toggle bar mode/keyboard mode 1/keyboard mode 2
  165.   ENTER             End current song and play next song if available
  166.   ESC               Quit MegaMID completely
  167.  
  168. **********************************************************************
  169.  
  170. ### YOUR QUESTIONS ANSWERED ###
  171. (Well, some of them anyway!) 
  172.  
  173.  
  174. *** What does MegaMID do ? ***
  175.  
  176.         MegaMID plays MIDI files (those with extension .MID) through
  177. whatever MIDI device you have connected to the Roland MPU-401 interface 
  178. or SB MIDI port - with a lot of style!
  179.         MegaMID will also work if you have a daugtherboard installed - like 
  180. Wave Blaster, Roland SCD, etc.
  181.         MegaMID also works with the Gravis Ultrasound under Roland 
  182. emulation mode (by running MEGAEM + EMUSET). It does not sound as good as the 
  183. GUS native mode, of course.
  184.         MegaMID will probably also work with the SB AWE32 if the AWEUTIL
  185. TSR is used. This has not been tested though...
  186.  
  187. *** Why was MegaMID written ? ***
  188.  
  189.         I saw the GUS's DOS-base MID file player (PLAYMIDI.EXE) and fell 
  190. in love with it. As far as I know, there is nothing else like it for other 
  191. sound cards - I was really disappointed. I own a Sound Blaster 16 as
  192. well as a Sound Blaster Pro, and managed to get the Yamaha TG100 Tone
  193. Generator - a General MIDI device, and I wanted something just as cool
  194. (as PLAYMIDI) to play my 1000+ MIDI files. Therefore, I set out to 
  195. write one...
  196.         MegaMID is something like PLAYMIDI was, and more. I crammed it
  197. with just about every feature I wished PLAYMIDI had! 
  198.  
  199. *** What hardware do I need ? ***
  200.  
  201.         MegaMID should run even on a 16 Mhz 286 with 640K RAM and a 
  202. VGA display. It's interrupt driven, so it will run just fine if you 
  203. have 100Mhz Pentium though (and not at some breakneck speed).
  204.         At this moment, MegaMID supports playback via the Sound Blaster 
  205. family MIDI port. That means you must have a SB, SB Pro or SB 16 for it 
  206. to work. Now, to hear something, you will need some sort of MIDI device 
  207. connected to the SB MIDI port - like a tone module (eg. Roland MT-32, 
  208. LAPC-1, Sound Canvas) or a MIDI keyboard.
  209.         Roland MPU-401 support has now been added to MegaMID! This also
  210. means that all other devices and sound cards that emulates the Roland
  211. are also supported by MegaMID. This includes the Gravis Ultrasound 
  212. under MEGAEM + EMUSET(Roland emulation) and possibly the SB AWE32 (with 
  213. the AWEUTIL TSR).
  214.         There is no support yet for the FM chip, but hopefully this and
  215. other devices will be supported in future releases of MegaMID.
  216.         This version of MegaMID only supports the SB port address 
  217. of 220H (default). If you are using another port address, please change
  218. it back to 220H or be patient and wait for the next release of MegaMID.
  219.  
  220. *** Why can't I hear anything when MegaMID is playing ? ***
  221.  
  222.     Probably because you have a Sound Blaster and nothing else. With
  223. a Sound Blaster card, you need an external MIDI device in order to hear
  224. what MegaMID is playing.
  225.  
  226. *** Why doesn't any text appear when I use MegaMID ? ***
  227.  
  228.     MegaMID can't find the font files (.F?T) and patch files (.PAT).
  229. The most common reason is that MegaMID was run from outside its own 
  230. directory, and MegaMID can't find those files. To fix this, just add 
  231. the MegaMID directory to your DOS path.
  232.  
  233. ************************************************************************
  234.  
  235. ## REVISION HISTORY ##
  236.  
  237. Version 1.11        29th April 1995.
  238.  
  239. - Added in the ability for MegaMID to read in script or album files,
  240.   along with command-line parameters specific to each file!
  241.   When a script file is used, the ESC key can be used to exit MegaMID
  242.   (ie. stop all songs), and the ENTER key for terminating current song
  243.   (and to play the next song if it exists).
  244. - MegaMID now accepts wilcards in the MIDI filename. If wildcards are
  245.   specified, MegaMID will play all the songs that match the wildcard
  246.   specifications.
  247. - Added in the /QUIET mode! You can now show MegaMID off to friends 
  248.   without soundcards and make them wish they had one!
  249. - Also added wildcard handling for album files.
  250. - Added in ability to read in BMP files, and to tile or center them.
  251.   MegaMID can currently read 4, 8 and 24-bit color formats, as well
  252.   as OS/2 and Windows RGB-encoded formats. It cannot yet handle Windows
  253.   RLE-encoded formats. Loaded all BMPs are converted to 64-color greyscale
  254.   before they are displayed.
  255. - Added in the C key to change background colors.
  256. - Modified (OK, fixed) the way SysEx messages are handled. Think it works
  257.   better now. MegaMID now also handles F7h type SysEx messages.
  258. - Added in Master Volume control - achieved using the SysEx sequence:
  259.     F0 7F 7F 04 01 11 xx F7
  260.   The range of volume control is from 0 to 127, and can be achieved using
  261.   keyboard with the keys v/b, or V/B for finer steps. An vertical bar on
  262.   the bottom-left of the screen shows the current volume level.
  263. - Can also set initial master volume from command line using the /MV 
  264.   parameter.
  265.  
  266. Version 1.10        17th April 1995.
  267.  
  268. - Fixed a bug which causes some command line parameters to be skipped.
  269. - Added in user interaction! Users can now use the Up/Down arrow keys
  270.   to select a channel (An arrow points to the channel you have selected).
  271.   Then, use the following keys to :        
  272.   +/-       Change patch
  273.   ,/.       Change drum kit
  274.   [/]       Change tempo
  275.   Bkspace   Restore original patch settings
  276.   M         Mute/Unmute current channel
  277.   S         Solo - turn current channel on and mute all other channels
  278.   A         All channels on
  279.   P         Pause/Unpause
  280.   K         Toggle bar mode/keyboard mode 1/keyboard mode 2 (see below)
  281. - Added in keyboard mode, where played notes appear as hightlighted
  282.   keys on keyboards! Looks really cool, and good for picking off notes
  283.   and chords, and generally seeing what the piece would look like when 
  284.   played on a keyboard (with 10 octaves!). This mode can be selected using 
  285.   command-line parameters, or toggled using the "K" key. Keyboard mode 1 
  286.   shows keyboards of all 16 channels, whereas keyboard mode 2 shows keyboards
  287.   of channels that are actually used (ie. notes are/have been played
  288.   on that particular channel. This mode is good for making the screen
  289.   less cluttered (ie. when there's just a solo piano track playing).
  290.   The pitch bend indicator- marked "P", is placed on the right of the
  291.   keyboard display in the keyboard modes. I wasn't going to make those
  292.   keyboards `bend' !
  293. - Fixed a problem that causes certain MID files to crash the computer
  294.   and/or shift the polyphony display around! It is caused by the MIDI
  295.   stream having a velocity v=0 note-on (equivalent to note-off) without
  296.   having played that note earlier. At this stage, me thinks all fatal
  297.   bugs have been squashed!
  298. - Added in configuration file option ! MegaMID will read in parameters
  299.   from the file MEGAMID.CFG, if it exists. Saves you from typing those
  300.   regularly used parameters!
  301. - Keyboard is active when song is paused! This means that song tempo,
  302.   patch assignments, channel muting etc. can be performed while song
  303.   is stopped. Just press P again to unpause.
  304.  
  305.  
  306. Version 1.02        6th April 1995.
  307.  
  308. - Finally fixed this problem that causes some songs to hang. It's not the 
  309.   fault of my player, really, but the quirkiness of the songs - a NOTE OFF 
  310.   (0x80) is sometimes received before a NOTE ON (0x90) for a note with
  311.   duration of zero !
  312. - Fixed a bug which causes MegaMID to report 'Unknown Type : ...'. This is
  313.   caused by my mistake in assuming that (0xFF) event message size formats
  314.   is ONE BYTE wheras it is actually in the format identical to the one
  315.   used for time-stamping the events...
  316. - The text window now actually scrolls the old text up to accommodate new
  317.   ones when they are received.
  318.  
  319.  
  320. Version 1.01        29th March 1995.
  321.  
  322. - Added support for the MPU-401, thanks to programming info from Martin 
  323.   Biribauer and Bernie Maier. Tested MPU-401 support on the GUS, courtesy 
  324.   of Wong Sui Jye.
  325. - Minor display changes.
  326. - Added the key display. Not many MIDI files seem to specify the key
  327.   of the song, so it's not being used much. I might take it out in
  328.   later versions...
  329.  
  330.  
  331. Version 1.00        12th March 1995.
  332.  
  333. First release?
  334.  
  335. Features :
  336.  
  337. - Handles Type 0 (single track) and Type 1 (multi-track) MIDI formats.
  338. - Handles files with up to 256 tracks.
  339. - Maximum MIDI file size that can be loaded is limited only by amount
  340.   of free conventional memory (I've loaded a 300K+ file before!).
  341. - Uses the VGA 320x200 256-color mode.
  342. - Displays the name of the instrument selected for each channel!
  343. - Has General MIDI as well as MT-32 instrument patch names.
  344. - Displays Roland GS drum kits selected for the drum channel.
  345. - Able to remap channel 16 to channel 10 as the active drum channel!
  346. - Supports mapping of Base or Extended MIDI to General MIDI.
  347. - Transmits all Program Change, Channel Aftertouch, Controllers,
  348.   Pitch Bend, Note On, Note Off, Key Aftertouch and SysEx messages.
  349. - All notes currently played on each 16 channels appear as vertical
  350.   bars on the screen on a 9-octave range (any note above that range 
  351.   ie. >112  mucks up the screen but does no damage).
  352. - The brightness of each individual note displayed corresponds to the
  353.   velocity of the note; the darker or brighter the note is, the softer
  354.   or harder it was hit.
  355. - Notes actually "bend" when the pitch-bender is used - looks really
  356.   cool! (people who have seen the GUS PLAYMIDI program will know what I
  357.   mean)
  358. - Displays the TEMPO; good for tracking tempo changes.
  359. - Able to handle up to 150 notes polyphony without crashing. Why so many,
  360.   you ask? STRIVING.MID tried to play 109 notes simultaneously (it's right
  361.   at the end...) and fried MegaMID. Anyway, it'll start mucking up the  
  362.   screen if it's more than about 40 notes. No damage though...
  363. - Displays current polyphony as a dynamic bar, with peak polyphony hold.
  364. - Gives the numerical value of the maximum polyphony as well. Pretty good
  365.   to know if the MIDI file is actually pushing your MIDI hardware to the
  366.   limit.
  367. - Displays text from the MIDI file (4 lines max.) - stuff like song title,
  368.   copyright messages, markers etc.
  369. - Displays time elapsed in HH:MM:SS format.
  370. - Displays a multi-segment LED type beat indicator; tracks beats per
  371.   measure as well as the tempo.
  372. - Displays as vertical bars the status of the following controllers :
  373.   Reverb (R)
  374.   Modulation (M)
  375.   Sustain (S)
  376.   Volume/Expression (V)
  377. - Displays Pan Position status, as centered vertical bars (as they should
  378.   be).
  379. - /FAST option; good for finding out the playing time of the MIDI file.
  380.  
  381.  
  382. ************************************************************************
  383.  
  384. ### DISCLAIMERS AND OTHER LEGAL MUMBO-JUMBO ###
  385.  
  386.      For non-commercial use, this version is cardware. If you like this 
  387. program and continue to use it, please send the Author a postcard. This     
  388. helps motivate him to keep improving this program.
  389.      This program may be freely distributed on the conditions that it is
  390. distributed as all whole with all accompanying files (including this one),
  391. and that it is not sold for profit.   
  392.     Please contact the Author if this program is to be used for commercial
  393. purposes.
  394.      This program is supplied as it is. Use it at your own risk.
  395. I will not be responsible for any injuries or death, computer or hard disk
  396. crashes, loss of data, or any other disaster as a consequence, directly
  397. or otherwise, of the usage of this program.
  398.      This program is copyrighted material. You may use it on the
  399. condition that it is not to be altered, hacked or reverse-engineered in
  400. any way.
  401.  
  402. ************************************************************************
  403.  
  404. ### CONTACTING THE AUTHOR ###
  405.  
  406. MegaMID was created by FONG Chee Keat, in the year 1995.
  407.  
  408. Please send all comments, complaints, suggestions and bug-reports
  409. (or anything else you want) to:
  410.  
  411. INTERNET
  412.  
  413. rocfong@halls1.cc.monash.edu.au
  414.  
  415. CURRENT ADDRESS
  416.  
  417. Roberts Hall
  418. Monash Uni
  419. Wellington Rd.
  420. Clayton
  421. VIC 3168
  422. AUSTRALIA.
  423.  
  424. HOME ADDRESS
  425.  
  426. 254 Jln. Sultan Azlan Shah Selatan
  427. Taman Beauty
  428. 30250 Ipoh
  429. Perak
  430. MALAYSIA
  431.  
  432. ************************************************************************
  433.  
  434.  
  435.  
  436.