Skip to content

Commit

Permalink
chore(*): add sound and music initial page
Browse files Browse the repository at this point in the history
  • Loading branch information
alekmaul committed Mar 23, 2024
1 parent 91bc91e commit a6c9e8d
Show file tree
Hide file tree
Showing 2 changed files with 64 additions and 1 deletion.
64 changes: 63 additions & 1 deletion wiki/Sounds.md
Original file line number Diff line number Diff line change
@@ -1 +1,63 @@
**to do **
PVSneslib uses IT files to play musics

## Tools to create IT files

You can use a tool like [openMPT](https://openmpt.org/) to create your song.

## Composition rules for your IT files

Impulse tracker format must be used. 8 Channels MAX!
Notes can not exceed 128Khz playback rate!
The module must be in instrument mode. It must have instruments!

DO NOT USE UNDEFINED INSTRUMENTS, they will not silence the channel, THEY WILL CAUSE MALFUNCTION!

The 64 or less samples must fit within 58K of memory. This is AFTER "BRR" compression. 8-bit samples will be reduced to 9/16 size. 16-bit samples will be reduced to 9/32 size.

## Tips from KungFuFurby about samples in IT files

When something going wrong for the songs you attempted to convert:

- Sample loop points must be divisible by 16. Loop points not divisible by 16 may not convert correctly.
If you don't use loop points divisible by 16, at least make sure the loop length is divisible by 16.

I use Schism Tracker to perform the job of loop point analysis and loop point adjustments since I can just simply type in the numbers.

I use a calculator to take care of loop point problems simply related to the sample being at the wrong sample rate to have loop point lengths divisible by 16 (the length of the looping portion of the sample should at the very least be divisible by 16).
You usually perform this on samples with shorter loop point lengths.

I don't think it works so well on ones with longer loop point lengths, mainly because by then you're probably not dealing with simple waveforms as loops.

Using the Bass & Lead sample as an example...

Loop point is currently defined as...
Start: 3213
End: 3382

That's a loop length of 169.

I like using powers of 2 for my loop points so that if I have to decrease the quality of the sample, then I can do so as painlessly as possible to the sample (unless I find the degraded quality to be a bad idea), so that means 128 is the value I use here.

Divide 169 by 128 gets you an unusual decimal number... copy that number.

Now get the full length of the sample (that's 3383 for this sample) and divide by that decimal number you acquired earlier (169/128).
You'll most likely get another unusual decimal number. Round that off and there's your new length that you will resize the sample to.

I use Alt-E in Schism Tracker to perform the resize sample command.
The program will ask for the new size of the sample.

Now you should have a loop length that is divisible by 16. You can perfect the loop point by adjusting them so that the loop point themselves are divisible by 16.

- Only one sample can be defined per instrument...

You'd have to duplicate the instruments and then enter the sample ID for all of those notes... and then you have to redefine the instrument IDs depending on the pitch from the old note table. Yeah...

- I thought in one case, I saw the pitch go too high (it went over 128khz). That's because I noticed a hiccup in the notation.

For the one song that has this problem, I usually resize the sample and make it half of its length...
however, I may have to make additional adjustments depending on how the loop points are holding up (length may or may not be involved, although usually I'm checking the loop points themselves to make sure that they are divisible by 32 or some higher power of 16... this indicates how many times you can cut the sample in half).

- Note Cut is the only New Note Action supported for SNESMod.

One of these songs is the most visibly affected by this problem, and that's because SNESMod doesn't virtually allocate channels.
You have to modify the patterns so that the note off commands go where the note would originally play, and the new note is put on another channel.
1 change: 1 addition & 0 deletions wiki/_Sidebar.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@
1. **[Sprites](https://github.com/alekmaul/pvsneslib/wiki/Sprites)**
1. **[Dynamic Sprites](https://github.com/alekmaul/pvsneslib/wiki/Dynamic-Sprites)**
1. **[Backgrounds](https://github.com/alekmaul/pvsneslib/wiki/Backgrounds)**
1. **[Sounds and Musics](https://github.com/alekmaul/pvsneslib/wiki/Sounds)**
1. **[Map Engine 1: Import maps for Tiled](https://github.com/alekmaul/pvsneslib/wiki/Import-maps-for-Tiled)**
1. **[Map Engine 2: Update maps in Tiled](https://github.com/alekmaul/pvsneslib/wiki/Update-Maps-in-Tiled)**
1. **[Map Engine 3: Display map on SNES (I)]( https://github.com/alekmaul/pvsneslib/wiki/Display-map-on-SNES-(1))**
Expand Down

0 comments on commit a6c9e8d

Please sign in to comment.