Overview
Improved version
Interface
Hotkeys
Import effects
Export effects
File formats
ZX Spectrum player
Demo video
Version history
Thanks
Contacts
AY Sound FX Editor is a complete solution to create sound effects for the AY-3-8910 sound chip. The effects can be used in games or other software for ZX Spectrum. It is also possible to use them with other micro computers that use the AY-3-8910. The package includes a Windows cross editor, an example sound effects player with Z80 assembly source code, a compiled example, and a sound effects library.
The editor allows to create single channel sound effects with duration up to 4096 TV frames. Frame duration is 1/50s, so maximum effect duration is about 80 seconds. Volume, noise and mixer settings can be changed every frame. Data is stored in a compact format that omits repeating values. Effects are combined into banks, up to 256 effects. The effects player works with a bank, and an effect is played using its order number in the bank.
It should be noted that the editor can't create effects on its own, it only allows to edit AY registers data in easy way. It is quite similar to the sample editors in AY music trackers. You have to know how the AY sound chip works in order to get your desired results. However, the editor allows you to import data from various formats, which can make things easier.
This "improved" version is a fork of Shiru's superb ayfxedit tool and player, available here. It's not really improved in any meaningful way; the name was a good-natured nod to the Vortex II AY tracker mod made by siril/4d, called Vortex Tracker II Improved :)
I got frustrated trying to build Shiru's C++ Builder source in any of the publicly available C++ Builder versions, so I converted the project to unicode and built this fork in the free C++ Builder 10.2 Tokyo Starter Edition.
The main reason I forked ayfxedit was because I wanted to add looped sustain effects to the editor and player - my use case was a thrust sound for Jet Power Jack that ramps up when you thrust, sustains as long as you hold '''SPACE''' down, then fades away when you release SPACE
. I eventually realised I could do this in the player without needing to modifiy the editor, but by then I had made some other small UI enhancements like aligning the column headers, and being able to double-click on .afx and .afb files if the file extensions are registed.
I would also like to make an enhanced player that locks certain sounds to certain channels, so thrust is panned center, and other sounds like pick up and die are panned left/right. ANn maybe even a pseudo-surround-sound mode that bounces a monophonic fx around all three channels...
I added an alternate set of z80 player and test files optimised for the Zeus Windows cross-assembler, and translated Shiru's Russian comments into English.
Basically, treat anything in this fork as experimental and possibly buggy, and go to the original source for the definitive version of ayfxedit.
Program interface is all-english. There is main menu at the top of the window. The items:
New bank - Clear effects bank, create one empty effect;
Load bank - Load effects bank from file;
Save bank - Save effects bank into file;
Save bank w/o names - Save effects bank into file without effect names;
Clear current effect - Clear current effect;
Load current effect - Load single effect file as current effect;
Save current effect - Save current effect into single effect file;
Multi-load to bank - Append a number of single effect files to end of the bank, starting from last empty effect;
Multi-save from bank - Save all effects from bank into separate single effect files. Names will be taken from effect names, all effects will be stored in the selected folder;
Exit - Exit from the editor.
Cut - Cut selected frames from effect and put them into the clipboard. For this and the next action, when there is no selection, current frame will be used (the one under the cursor);
Copy - Copy selected frames into the clipboard, they will get deselected after this action;
Paste - Paste the clipboard contents into the cursor position, current and subsequent frames will be shifted down;
Delete - Delete selected frames;
Select all - Select all frames that contain actual data;
Unselect all - Remove selection;
Inverse selection - Invert selection.
Piano input - Show/hide virtual piano window (see below);
Linear period - Display tone values in linear scale (irregular spread of actual frequences);
Logarithmic period - Display tone values in logarithmic scale.
Add new effect - Append a new effect to the end of the bank and make it current;
Delete effect - Delete current effect from the bank;
Insert new effect - Insert a new effect in place of current, the current and all subsequent will be shifted.
Import (see Import effects)
PSG for AY - Import from PSG;
VTX file - Import from VTX;
VGM file - Import from VGM;
Wave file - Import from WAV.
Export (see Export effects)
VTII Sample - Export as Vortex Tracker II instrument;
Wave file- Export as WAV file;
CSV - Export as text-based CSV file.
Below the main menu there is a bar with a number of controls. When you hover the mouse above them, a hint is displayed.
At the left of the bar there are three buttons. Play and Stop perform corresponding actions with the current effect. The button with the piano keys shows or hides the virtual piano window (see below).
At the right of the bar there are bank controls. [Add] appends an effect to the end of the bank. [Del] deletes current effect. Next four buttons with two numbers (current effect and total number of effects in bank) in between are to navigate between effects. Double arrows are to go to the first and the last effect in the bank. Last in the bar there is effect name. You can edit it by clicking it with left mouse button, entering a new name, and pressing Enter to confirm changes. Some hotkeys won't work while the name editor is active.
All remaining space of the program window is the effect editor. You can use either mouse or keyboard to edit values. There are few columns. Pos is frame number. You can select frames with LMB on the frame number or deselect them with RMB. T, N are the AY mixer bits, edited similar to the selection. Per is the tone period. Ns is the noise period. V is the volume. When you click on any of Per, NS or V value, cursor moves to the frame. In the right part of the window the same values are represented in graphic form, they can also be edited using mouse buttons. When the Ctrl button is held down, mouse won't move horizontally, allowing easier drawing a sequence of the same values.
The editor window can be resized vertically with one frame step, but can not be resized horizontally.
There is a special window to simplify creation of sound effects based on musical notes. It can be brought with the button with piano keys or through View->Piano Input item of the main menu. At the left part of the window there is a hint which keyboard buttons correspond to notes. At the right there are controls that affect to the input. The Octave field sets up the current octave (1...8). The Step field sets up the number of frames that the cursor will advance after entering a note. The Fill field sets up how many subsequent frames will be set to the same value with a single note input. The Link button links Step and Fill fields, matching up the fill value to the step. When the Set T button is down, T flag is set for frame at note input, when it is up, existing T value of a frame won't be changed. Set Volume does the same for volume column, entering value that can be changed at the right of the button.
Key | Action |
---|---|
Cursor Up/Down | Go to the previous/next frame. |
Cursor Left/Right | Switch between tone/noise/volume columns. |
0-9, A-F | Enter tone/noise/volume value. |
Page Up/Down | Go a page up/down. |
Mouse wheel | Go five frames up/down. |
Home | Go to the begin of current effect (frame 0). |
End | Go to the end of current effect (last frame with non-zero volume). |
Mouse buttons | On the tone/noise/volume bars - change a value, on the effect name - edit name mode. |
Left Mouse Button | On the T/N flags - set them; on a frame number - select frame. |
Right Mouse Button | On the T/N flags - reset them; on a frame number - deselect frame. |
Ctrl | Disable horizontal mouse movements inside the effect value bars. |
~ | Show/hide the piano input window. |
Enter | In the effect edit mode - play current effect; in the name edit mode - go to the effect edit mode. |
Ctrl+Enter | Play effect starting from current frame. |
Space | Stop playing. |
Delete | Delete selection, selected frames will be removed, remaining will be shifted. When there is no selection, current frame will be deleted. |
Insert | Insert an empty frame, current and subsequent frames will be shifted down. |
Ctrl+Insert | Clone current frame, subsequent frames will be shifted down. |
T | Toggle T flag for the current frame. |
N | Toggle N flag for the current frame. |
Ctrl+A | Select the whole actual effect, from start to last frame with non-zero volume. |
Ctrl+I | Invert selection in the actual effect frames. |
Ctrl+X | Cut frames into the clipboard. |
Ctrl+C | Copy frames into the clipboard, selection will be reset. |
Ctrl+V | Paste the clipboard content into the cursor position, current and subsequent frames will be shifted down. |
[+] or Numpad [+] | Go to the next effect. |
[-] or Numpad [-] | Go to the previous effect. |
Shift+[+] or Shift+Numpad [+] | Increase tone, noise, or volume value by 1. |
Shift+[-] or Shift+Numpad [-] | Decrease tone, noise, or volume value by 1. |
Key | Action |
---|---|
Z,S,X,D,C,V,G,B,H,N,J,M | Note keys, input notes in range of current octave. |
Shift+Note key | Input note one octave higher. |
Ctrl+Note key | Input note one octave below. |
Numpad 1...8 | Change current octave. |
Following file formats are supported.
AY registers dump. Files with complete 16-byte header are supported. These files could be created with AY Emulator or Z80Stealth. You can select channel that will be source of data before import. Auto option will select the channel where the volume changes first, with automatic skip of the pause before. Tone, noise, volume, and mixer settings of selected channel will be imported. To simplify things, it is better to use source files with single channel effects.
AY registers dump. These files could be created with AY Emulator and UnrealSpeccy. Import options are the same as for PSG.
Registers dump for SN76489 or compatibles, the sound chip that has been used in Master System, Game Gear, Sega Genesis, ColecoVision, and some other computers or game consoles. The imported data is adapted to get similar sound, but as the chip capabilities are quite different, there will be difference.
Only standard, unpacked PCM files supported, of any sample rate, bits depth, mono or stereo. Volume envelope gets imported, tone pitch gets analyzed. If it is possible to detect pitch for a frame, T flag sets along with the pitch value, otherwise N flag sets.
Following file formats are supported.
Vortex Tracker II instrument, which is a plain text file. Export dialogs allows to set a base note that should be used to get original pitch in the tracker.
Standard uncompressed PCM file, 44100 Hz, 16 bit, mono.
Comma separated values in a text file. Can be handy for further parsing and processing with external tools.
When this item is checked, export functions will export current effect only, under specified filename.
When this item is checked, export functions will export all effects from the bank. The filename can have an optional prefix with effect number and name, this can be selected as the file type in the export dialog.
16-bit numbers stored in the LSB,MSB format.
Every frame encoded with a flag byte and a number of bytes, which is vary depending from value change flags.
Bit(s) | Purpose |
---|---|
bit0..3 | Volume |
bit4 | Disable T |
bit5 | Change Tone |
bit6 | Change Noise |
bit7 | Disable N |
When the bit5 set, two bytes with tone period will follow; when the bit6 set, a single byte with noise period will follow; when both bits are set, first two bytes of tone period, then single byte with noise period will follow. When none of the bits are set, next flags byte will follow.
End of the effect is marked with byte sequence #D0, #20
. Player should detect it before outputting it to the AY registers, by checking noise period value to be equal #20
. The editor considers last non-zero volume value as the last frame of an effect, other parameters aren't matter.
Offset | Contents |
---|---|
+0 (1 byte) | Total number of effects in the bank, up to 256 (0 means 256); |
+1 (2 bytes per effect) | Table of offsets to data of every effect. Offset value is given relative to the second byte of the offset itself, this allows to calculate absolute address very fast: |
hl=offset in the effects table
ld c,(hl)
inc hl
ld b,(hl)
add hl,bc
hl=absolute address of effect data
Offset | Contents |
---|---|
+n (m bytes) | The effects data, format is the same as in the single effect file. After every effect there could be a null terminated text string with name of the effect. It may absent, if the bank was saved into a file using corresponding item of the File menu, in this case null terminator bytes are absent as well. |
The package includes a simple sound effects player. It is located at /z80player/ayfxplay.a80. This file is a text file with Z80 source code for asm80 cross assembler. There are comments on use and internals as well.
The player can play effects using all three AY channels. When there is an empty (not playing) channel, it will be used, otherwise the one that was active for longest time will be used. AY music can't play while this version of the player is active.
Besides the player, there is an example program, available as compiled SCL disk image and source code. All keys has sound effects assigned to them. Space key turns on/off music that is played on the second sound chip of TurboSound device (NedoPC version), if it is available. If the TurboSound is absent, music will play on the same chip, producing various sound artefacts.
v0.6 01.02.17
v0.5, v0.51, v0.52 unreleased during 2006-2017
v0.4 09.05.06
v0.3 28.02.06
v0.2 12.02.06
v0.1 02.02.06
Thanks goes to:
- Shiru, for the definitive original version of the project;
- Alone Coder, for help with the project;
- Sergey Bulba, for AY Emulator, Vortex Tracker, and various docs at his webpage;
- SMT, for UnrealSpeccy and open source VTX format player;
- Copper Feet/Bytex, for asm80 cross assembler;
- Also thanks to authors of the sound effects that are included into the library.
You can send bug reports, suggestions, or sound effects to include into the bundled library, at shiru@mail.ru.