home *** CD-ROM | disk | FTP | other *** search
-
- This is Esbeekay v1.2
- Bug-reports, questions and suggestions about changes to apl@vapl.demon.co.uk
-
- ========IMPORTANT=========
- You must have already installed win32s v1.2 in order to run Esbeekay.
- Win32s v1.1.5 may work but I haven't tried it.
- Alternatively run Esbeekay under Windows NT, it will work with the beta
- drivers.
- ==========================
-
- What is Esbeekay?
- -----------------
-
- Esbeekay is shareware, and it is used to edit soundfont banks, or SBKs.
- It can be used to create patches from waves, GUS patches, Kurzweil patches,
- MOD samples and also using the AWE ROM samples. It can edit any and all
- parameters in an SBK but not quite all parameters are known yet so some
- experimentation may be necessary. Samples can be multilayered, and each
- layer can have many samples for particular key ranges.
-
- Changes from 1.1
- ----------------
-
- Velocity split and other new parameters
- Macros can now be attached to windows and are generally expanded
- Now a 32-bit application, uses win32s v1.2 under Windows 3.x, native under NT.
- Improved documentation
- More sample macros
-
- The files included
- ------------------
-
- esbeekay.exe The Esbeekay program
- esbeekay.hlp Help file for Esbeekay
- esbk16.dll Additional .dll's for Esbeekay
- esbk32.dll
- versions List of changes and features on each version
- read.me This file
- dllcode/ Source code for reverse.dll, a macro dll
- macros/ Sample macros
- gus.mac Macro which imports GUS samples
- waves.mac Macro which imports wave samples and staggers them
- reverse.mac Macro which reverses samples
- reverse.dll DLL used by reverse.mac
- reverse2.mac Another macro to reverse a sample, attaches to sample dialog
- veltofc.mac A macro to make Fc depend on velocity by velocity splitting
-
-
- How to install
- --------------
-
- Make a subdirectory for all the files and copy them into that directory.
- It is a good idea to keep the same directory structure as outlined above
- but it's not compulsory. The files esbk16.dll, esbk32.dll and esbeekay.hlp
- have to be in the same directory as esbeekay.exe.
-
- Make sure you have win32s v1.2 installed if you're using Windows 3.x.
-
- To run, run esbeekay.exe under Windows 3.x or Windows NT.
- I don't know what happens if you run it under Windows 95, since I don't
- have that.
-
- Help
- ----
-
- The help file has been greatly expanded in the macro sections, thanks
- to Andy Robinson who has also helped with design ideas. For complete
- newcomers to the AWE it is recommended that you play around with
- Vienna first to get an idea of what's involved. Esbeekay lets you
- manipulate the complete SBK structure and consequently it may not suit
- everyone. On the other hand if you have to manipulate parameters such
- as velocity split, not found in Vienna, then Esbeekay is the program
- for you.
-
- Esbeekay is shareware
- ---------------------
-
- However it's not crippled. After a somewhat disappointing reception in
- terms of actual revenue the last time round (no-one sent anything), I've
- lowered the suggested donation to one GB pound. Alternatively if you're
- going to send something and can't get hold of pounds then send the
- equivalent in ecu's :-).
-
- What has happened with macros?
- ------------------------------
-
- In our efforts to both improve the macro language in Esbeekay, and make
- it more user friendly, new functions have been added and certain
- functions have been superceded.
-
- Where functions have been superceded, the original function is stil
- supported. We would urge you to use the new functions in future and to
- update your existing macro's at you earliest convenience.
- The new functions add so much more control to your macro's that you
- will probably want to do this anyway.
-
- Documentation for the pre-existing functions and the new functions can
- be found in the help file.
-
- valid()
- -------
- valid() is now replaced by objectIsValid() It's functionality remains
- identical. It's sole purpose is now to test the validity of objects as
- other functions have been introduced to test other conditions. We felt
- the new name was more appropriate.
-
- getObjectData()
- ---------------
- was used to retrieve the properties for patches, instruments and sample
- headers while setObjectData() was used to set properties for these
- objects.
- We felt in this case that the names ..
-
- getObjectProperties()
- setObjectProperties()
-
- are more suitable.
- In this version, we are trying to present the distinction between
- parameters and properties which was confusing for some users. We feel
- that these new names will assist in this regard. Their functionality is
- identical to that of the old functions .. getObjectData() and
- setObjectData()
-
- setObjectData() and getObjectData() wrt instruments takes and returns
- lists always.
-
- Field validation:
- ----------------
-
- In previous versions, attempting to use windowInput() on certain
- controls that had no contents, would genererate a run time error.
- This inconvenience no longer exists we are pleased to say.
-
- Some new functions were introduced specifically to address these
- issues. They are outlined briefly here. The help file contains more
- complete details.
-
- Any control that accepts user input may now be tested for valid
- contents. Depending on the control, valid contents means different
- things but conditions that are reported are ...
- No selection in listboxes and comboboxes
- SBKLink is empty
- Control is empty
- Value is below range
- Value is above range
- Value is OK.
-
- To report these conditions the new function getWindowInputError() has
- been introduced.
- By using this function on a control before windowInput(), the macro can
- ascertain the validity of control contents and can handle the situation
- to the benefit of the macro user.
-
- getWindowControlRange() has been introduced to retrieve the range for a
- valuein control. Used in combination with getWindowInputError(), a
- macro can inform a user of the acceptable ranges for the control.
-
- NoteIn and ValueIn controls no longer accept alphabetic input.
-
- Listboxes
- ---------
-
- Listboxes now support multiple selection in the expected fashion by
- supporting <SHIFT><CLICK> and <CTRL><CLICK>.
- <SHIFT><CLICK> to extend a selection
- <CTRL><CLICK> to individually toggle the selection status of an item.
-
- length()
- --------
- Supercedes listLength(). It reports the number of elements in a list or
- the number of characters in a string.
-
- subString()
- -----------
- Extracts asubstring from a string.
-
- displayHelp()
- -------------
- Calls a helpfile. Allows macro writers to document their macro's.
-
- itemsInWindowControl(controlId::string)
- ---------------------------------------
- Returns the number of lines or items in a listbox or combobox.
-
- filePrompt()
- ------------
- This function has been altered:
- Unfortunately, if you make use of this function in any of your macro's
- you will have to change it's parameters.
- It also returns an empty list where no selection has been made.
-
- importWave()
- ------------
- Now has import filters. You can specify left or right channels of
- stereo wave files and even disregard mono wave files.
-
- windowInput()
- -------------
- now returns a list for all list boxes and also comboboxes,
- which contains the index of the selected item(s) or an empty list if there
- is no selection.
-
- True & False
- ------------
- True and false have been introduced as langauge constants. Seeing as
- many functions in the macro langauge return a number for a tested
- condition, we felt that this would be helpfull.
- True evaluates to a 1 condition while
- False evaluates to a 0 condition.
-
- getObjectSBK()
- --------------
- This is a new function.
- It returns the SBK which contains a given object.
-
- setGroupCallback()
- ------------------
- Is a new function. Use it to specify which function a radio button
- should call when clicked. The button control id is passed as a
- parameter to the called function. You can use this function to 'group'
- radio buttons together.
-
- callMacro()
- -----------
- A new function allowing a macro to call a function in another macro.
- This means that macro libraries are now a possibility.
-
- openMacroWindow()
- -----------------
- New function:
- Opens the macro window for another macro. You can now run other macro's
- from one macro. By fixing a macro window to an sbk window, you can
- create a speedbar for your favourite macro's.
-
- closeMacroWindow()
- ------------------
- New function:
- Closes a macro window. You can now have exit buttons on your macro
- windows. (Least that's what I'm gonna use it for)
- I'm sure they'll be other applications for this function.
-
- New Parameters Supported
- ------------------------
-
- The macro language now supports these additional parameters. Will they
- never end? (No)
-
- "keyToHold"
- "keyToDecay"
- "sampleStartOffset"
- "sampleEndOffset"
- "forceKey"
- "forceVel"
-