Added libraries/ufmod source code.
git-svn-id: svn://kolibrios.org@1845 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
32e469b81f
commit
d21a6e85e7
142
programs/develop/libraries/ufmod/Fasm/frmwrk.asm
Normal file
142
programs/develop/libraries/ufmod/Fasm/frmwrk.asm
Normal file
@ -0,0 +1,142 @@
|
||||
; FRMWRK.ASM
|
||||
; ----------
|
||||
; A set of common GUI code used in uFMOD examples for KolibriOS.
|
||||
; Feel free to reuse it in your own projects if you like it ;)
|
||||
|
||||
; ---------------------------------------------------------------
|
||||
; void _cdecl _MessageBox (szCap, lpString, cbString);
|
||||
; void _cdecl _MessageBoxCB(szCap, lpString, cbString, cbProc);
|
||||
; ---------------------------------------------------------------
|
||||
|
||||
; This is similar to a Win32 MessageBox. The box is centered
|
||||
; on screen. It contains a single-line text message and an
|
||||
; "OK" button. This function returns when user closes the
|
||||
; box (via the X button or via the OK button). An optional
|
||||
; callback subroutine may be specified to be called when no
|
||||
; events are pending in the event queue.
|
||||
|
||||
; NOTE: Doesn't work if you already have defined a window
|
||||
; in the current process! Doesn't modify the event mask. So,
|
||||
; make sure keyboard events are enabled before calling this
|
||||
; function. This function doesn't check the validity of the
|
||||
; supplied parameters!
|
||||
|
||||
; Parameters:
|
||||
; szCap - A pointer to the ASCIIz string containing the
|
||||
; caption. A trailing zero char IS required.
|
||||
; lpString - A pointer to an ASCII string containing a single
|
||||
; line message to pop up in the box. No trailing
|
||||
; zero char is required.
|
||||
; cbString - number of characters in string.
|
||||
; cbProc - Address of the callback subroutine. Can be NULL.
|
||||
|
||||
sOK db "OK"
|
||||
if FRMWRK_CALLBACK_ON
|
||||
_MessageBoxCB:
|
||||
else
|
||||
_MessageBox:
|
||||
end if
|
||||
push ebp
|
||||
push esi
|
||||
push edi
|
||||
push ebx
|
||||
xor ebp,ebp ; global 0
|
||||
mov esi,[esp+28] ; cbString
|
||||
mov edi,[esp+20] ; szCap
|
||||
|
||||
; Get screen metrics.
|
||||
lea eax,[ebp+14]
|
||||
int 40h
|
||||
mov ecx,eax
|
||||
movzx eax,ax
|
||||
shr ecx,16 ; screen w
|
||||
xchg eax,edx ; screen h
|
||||
lea ebx,[esi*2+esi]
|
||||
lea ebx,[ebx*2+28] ; w = string len * 6 + 28
|
||||
sub ecx,ebx
|
||||
shr ecx,1
|
||||
shl ecx,16
|
||||
or ebx,ecx
|
||||
lea ecx,[ebp+52h] ; h = 52h
|
||||
sub edx,ecx
|
||||
shr edx,1
|
||||
shl edx,16
|
||||
or ecx,edx ; y = (screen h - window h) / 2
|
||||
mov edx,ebx ; x = (screen w - window w) / 2
|
||||
|
||||
_MessageBoxCB_redraw:
|
||||
; Start redraw.
|
||||
push edx
|
||||
lea eax,[ebp+12]
|
||||
lea ebx,[ebp+1]
|
||||
int 40h
|
||||
|
||||
; Define and draw window.
|
||||
xor eax,eax
|
||||
mov ebx,edx ; x, w (ECX: y, h)
|
||||
mov edx,34C0C0C0h ; style and BG color
|
||||
int 40h
|
||||
|
||||
; Define the OK button.
|
||||
push esi
|
||||
lea eax,[ebp+8]
|
||||
sub ebx,28+0Ah
|
||||
shr bx,1
|
||||
shl ebx,16 ; x = (window w - button w) / 2
|
||||
mov bx,18+0Ah ; w = 18 + 0Ah
|
||||
mov ecx,001C0012h ; y = 1Ch, h = 12h
|
||||
lea edx,[ebp+1] ; ID = close
|
||||
mov esi,0C0C0C0h ; color
|
||||
int 40h
|
||||
|
||||
; Draw the OK label.
|
||||
lea eax,[ebp+4]
|
||||
add ebx,90000h ; x = button x + 9
|
||||
mov bx,22h ; y = 22h
|
||||
xor ecx,ecx ; style, font and color
|
||||
mov edx,sOK ; string
|
||||
lea esi,[ebp+2] ; length
|
||||
int 40h
|
||||
pop esi
|
||||
|
||||
; Draw text string.
|
||||
lea eax,[ebp+4]
|
||||
mov ebx,000A000Ah ; x = 0Ah, y = 0Ah
|
||||
xor ecx,ecx ; style, font and color
|
||||
mov edx,[esp+28] ; lpString
|
||||
int 40h
|
||||
|
||||
; End redraw.
|
||||
lea eax,[ebp+12]
|
||||
lea ebx,[ebp+2]
|
||||
int 40h
|
||||
|
||||
if FRMWRK_CALLBACK_ON
|
||||
_MessageBoxCB_eventloop:
|
||||
mov edx,[esp+36] ; cbProc
|
||||
test edx,edx
|
||||
lea eax,[ebp+10]
|
||||
jz _MessageBoxCB_peekevent
|
||||
|
||||
; Invoke the callback.
|
||||
call edx
|
||||
|
||||
lea eax,[ebp+23]
|
||||
lea ebx,[ebp+10] ; wait for at most 0.1 sec
|
||||
_MessageBoxCB_peekevent:
|
||||
int 40h
|
||||
dec eax
|
||||
js _MessageBoxCB_eventloop
|
||||
else
|
||||
lea eax,[ebp+10]
|
||||
int 40h
|
||||
dec eax
|
||||
end if
|
||||
pop edx
|
||||
jz _MessageBoxCB_redraw
|
||||
|
||||
pop ebx
|
||||
pop edi
|
||||
pop esi
|
||||
pop ebp
|
||||
ret
|
239
programs/develop/libraries/ufmod/Fasm/jmp2pat.asm
Normal file
239
programs/develop/libraries/ufmod/Fasm/jmp2pat.asm
Normal file
@ -0,0 +1,239 @@
|
||||
; JMP2PAT.ASM
|
||||
; -----------
|
||||
; Sometimes it makes sense merging various XM tracks
|
||||
; sharing the same instruments in a single XM file.
|
||||
; This example program uses such an XM file actually
|
||||
; containing 3 tracks and the _uFMOD_Jump2Pattern
|
||||
; function to play all 3 tracks in the same file.
|
||||
|
||||
; A precompiled version (not packed or whatever) is
|
||||
; available in bin\
|
||||
|
||||
use32
|
||||
org 0
|
||||
db 'MENUET01'
|
||||
dd 1
|
||||
dd START ; Entry point
|
||||
dd uFMOD_IMG_END ; End of code and initialized data
|
||||
dd MEMORY_END ; End of uninitialized (BSS) data
|
||||
dd STACK_B ; Bottom of the stack
|
||||
dd 0 ; Args
|
||||
dd 0 ; Reserved
|
||||
|
||||
; uFMOD setup:
|
||||
UF_FREQ equ 48000 ; Set sampling rate to 48KHz (22050, 44100, 48000)
|
||||
UF_RAMP equ STRONG ; Select STRONG interpolation (NONE, WEAK, STRONG)
|
||||
UD_MODE equ UNSAFE ; Select UNSAFE mode (NORMAL, UNSAFE)
|
||||
DEBUG equ 0 ; Skip debug-board messages
|
||||
NOLINKER equ 1 ; Select "no linker" mode
|
||||
|
||||
; uFMOD constants:
|
||||
XM_MEMORY = 1
|
||||
XM_FILE = 2
|
||||
XM_NOLOOP = 8
|
||||
XM_SUSPENDED = 16
|
||||
uFMOD_MIN_VOL = 0
|
||||
uFMOD_MAX_VOL = 25
|
||||
uFMOD_DEFAULT_VOL = 25
|
||||
|
||||
; BLITZXMK.XM tracked by Kim (aka norki):
|
||||
; [00:07] - track #1
|
||||
; [08:10] - track #2
|
||||
; [11:13] - track #3
|
||||
xm file '..\ufmodlib\media\BLITZXMK.XM'
|
||||
xm_length = $ - xm
|
||||
|
||||
; Optimization:
|
||||
; This header file is suitable for blitzxmk.xm track only!
|
||||
; If you change the track, update the optimization header.
|
||||
; (Use the standart eff.inc file for a general purpose player app.)
|
||||
include '..\ufmodlib\media\blitz.eff.inc'
|
||||
|
||||
; Include the GUI framework.
|
||||
FRMWRK_CALLBACK_ON equ 0 ; Disable callback
|
||||
include 'frmwrk.asm'
|
||||
|
||||
; UI text messages.
|
||||
vals dd 0,8,11 ; Preset pattern indexes
|
||||
wnd_btns1 db "1 2 3 Pause "
|
||||
wnd_btns2 db "1 2 3 Resume"
|
||||
wnd_btns_l = $ - wnd_btns2
|
||||
wnd_cap db "Jump2Pattern",0
|
||||
err_txt db "Error"
|
||||
err_txt_l = $ - err_txt
|
||||
err_cap db ":-(",0
|
||||
|
||||
START:
|
||||
; Start playback.
|
||||
push XM_MEMORY
|
||||
push xm_length
|
||||
push xm
|
||||
call _uFMOD_LoadSong
|
||||
|
||||
; Stack fixing is required here, but in this simple
|
||||
; example leaving ESP as it is won't harm. In a real
|
||||
; application you should uncomment the following line:
|
||||
; add esp,12
|
||||
|
||||
test eax,eax
|
||||
jz error
|
||||
xor ebp,ebp ; global 0
|
||||
mov [wnd_btns],wnd_btns1
|
||||
|
||||
; Switch keyboard mode to SCANCODE.
|
||||
lea ebx,[ebp+1]
|
||||
lea eax,[ebp+66]
|
||||
mov ecx,ebx
|
||||
int 40h
|
||||
|
||||
; Get screen metrics.
|
||||
lea eax,[ebp+14]
|
||||
int 40h
|
||||
mov ecx,eax
|
||||
movzx eax,ax
|
||||
shr ecx,16 ; screen w
|
||||
xchg eax,edx ; screen h
|
||||
mov ebx,wnd_btns_l*6+42
|
||||
sub ecx,ebx
|
||||
shr ecx,1
|
||||
shl ecx,16
|
||||
or ebx,ecx
|
||||
lea ecx,[ebp+40h] ; h = 40h
|
||||
sub edx,ecx
|
||||
shr edx,1
|
||||
shl edx,16
|
||||
or ecx,edx ; y = (screen h - window h) / 2
|
||||
mov edx,ebx ; x = (screen w - window w) / 2
|
||||
|
||||
redraw:
|
||||
; Start redraw.
|
||||
push edx
|
||||
lea eax,[ebp+12]
|
||||
lea ebx,[ebp+1]
|
||||
int 40h
|
||||
|
||||
; Define and draw window.
|
||||
xor eax,eax
|
||||
mov ebx,edx ; x, w (ECX: y, h)
|
||||
mov edx,34C0C0C0h ; style and BG color
|
||||
mov edi,wnd_cap
|
||||
int 40h
|
||||
|
||||
; Define the 1 2 3 Pause/Resume buttons.
|
||||
lea eax,[ebp+8]
|
||||
mov ebx,0A0012h ; x = 0Ah, w = 12h
|
||||
mov ecx,0A0012h ; y = 0Ah, h = 10h
|
||||
lea edx,[ebp+10] ; ID = #10
|
||||
mov esi,0C0C0C0h ; color
|
||||
int 40h
|
||||
mov ebx,280012h ; x = 28h, w = 12h
|
||||
inc edx ; ID = #11
|
||||
int 40h
|
||||
mov ebx,460012h ; x = 46h, w = 12h
|
||||
inc edx ; ID = #12
|
||||
int 40h
|
||||
mov ebx,640030h ; x = 64h, w = 30h
|
||||
inc edx ; ID = #13
|
||||
int 40h
|
||||
|
||||
; Draw the labels.
|
||||
lea eax,[ebp+4]
|
||||
mov ebx,120011h ; x = 12h, y = 11h
|
||||
xor ecx,ecx ; style, font and color
|
||||
mov edx,[wnd_btns] ; string
|
||||
lea esi,[ebp+wnd_btns_l] ; length
|
||||
int 40h
|
||||
|
||||
; End redraw.
|
||||
lea eax,[ebp+12]
|
||||
lea ebx,[ebp+2]
|
||||
int 40h
|
||||
|
||||
eventloop:
|
||||
; Update the PCM buffer.
|
||||
call _uFMOD_WaveOut
|
||||
|
||||
lea eax,[ebp+23]
|
||||
lea ebx,[ebp+10] ; wait for at most 0.1 sec
|
||||
int 40h
|
||||
dec eax
|
||||
js eventloop ; 0 = idle
|
||||
jz redraw ; 1 = redraw
|
||||
|
||||
dec eax ; 2 = keyboard event
|
||||
jnz chk_eventbutton
|
||||
|
||||
; Get key scancode.
|
||||
lea eax,[ebp+2]
|
||||
int 40h
|
||||
cmp ah,19h ; P
|
||||
je do_PauseResume
|
||||
cmp ah,13h ; R
|
||||
je do_PauseResume
|
||||
chk_kb123:
|
||||
movzx eax,ah
|
||||
sub eax,2
|
||||
jmp do_Jump2Pat123
|
||||
|
||||
chk_eventbutton: ; 3 = button event
|
||||
lea eax,[ebp+17]
|
||||
int 40h
|
||||
cmp ah,1 ; Close
|
||||
je break_loop
|
||||
cmp ah,13 ; Pause/Resume
|
||||
jne chk_btn123
|
||||
|
||||
do_PauseResume:
|
||||
cmp BYTE [paused],1
|
||||
mov edx,_uFMOD_Resume
|
||||
mov ebx,wnd_btns1
|
||||
je do_Resume
|
||||
mov edx,_uFMOD_Pause
|
||||
mov ebx,wnd_btns2
|
||||
do_Resume:
|
||||
call edx
|
||||
xor BYTE [paused],1
|
||||
mov [wnd_btns],ebx
|
||||
jmp redraw
|
||||
|
||||
chk_btn123: ; 1 2 3
|
||||
movzx eax,ah
|
||||
sub eax,10
|
||||
|
||||
do_Jump2Pat123:
|
||||
cmp eax,3
|
||||
jae eventloop
|
||||
push DWORD [vals+eax*4]
|
||||
call _uFMOD_Jump2Pattern
|
||||
pop eax ; fix stack
|
||||
jmp eventloop
|
||||
break_loop:
|
||||
|
||||
; Stop playback.
|
||||
call _uFMOD_StopSong
|
||||
|
||||
r: ; Exit.
|
||||
xor eax,eax
|
||||
dec eax
|
||||
int 40h
|
||||
|
||||
error:
|
||||
push err_txt_l ; cbString
|
||||
push err_txt ; lpString
|
||||
push err_cap ; szCap
|
||||
call _MessageBox
|
||||
; add esp,16
|
||||
jmp r
|
||||
|
||||
; Include the whole uFMOD sources here. (Right after
|
||||
; your main code to avoid naming conflicts, but still
|
||||
; inside your code section.)
|
||||
macro PUBLIC symbol {} ; hide all publics
|
||||
include '..\ufmodlib\src\fasm.asm'
|
||||
|
||||
wnd_btns dd ?
|
||||
paused db ?
|
||||
align 4
|
||||
rb 1020
|
||||
STACK_B dd ? ; Stack bottom
|
||||
MEMORY_END: ; End of uninitialized (BSS) data
|
20
programs/develop/libraries/ufmod/Fasm/make.bat
Normal file
20
programs/develop/libraries/ufmod/Fasm/make.bat
Normal file
@ -0,0 +1,20 @@
|
||||
@echo off
|
||||
rem Make the uFMOD examples.
|
||||
rem Compiler: FASM
|
||||
rem Target OS: KolibriOS
|
||||
|
||||
rem FASM Path:
|
||||
SET UF_FASM=\fasm
|
||||
|
||||
if not exist "%UF_FASM%\fasm.exe" goto Err1
|
||||
"%UF_FASM%\fasm" mini.asm mini
|
||||
"%UF_FASM%\fasm" jmp2pat.asm jmp2pat
|
||||
goto TheEnd
|
||||
|
||||
:Err1
|
||||
echo Couldn't find fasm.exe in %UF_FASM%\
|
||||
|
||||
:TheEnd
|
||||
pause
|
||||
@echo on
|
||||
cls
|
109
programs/develop/libraries/ufmod/Fasm/mini.asm
Normal file
109
programs/develop/libraries/ufmod/Fasm/mini.asm
Normal file
@ -0,0 +1,109 @@
|
||||
; MINI.ASM
|
||||
; --------
|
||||
; Minimalistic uFMOD usage example.
|
||||
|
||||
; Shows how to play an XM track in memory,
|
||||
; including proper error handling.
|
||||
|
||||
; A precompiled version (not packed or whatever) is
|
||||
; available in bin\
|
||||
|
||||
use32
|
||||
org 0
|
||||
db 'MENUET01'
|
||||
dd 1
|
||||
dd START ; Entry point
|
||||
dd uFMOD_IMG_END ; End of code and initialized data
|
||||
dd MEMORY_END ; End of uninitialized (BSS) data
|
||||
dd STACK_B ; Bottom of the stack
|
||||
dd 0 ; Args
|
||||
dd 0 ; Reserved
|
||||
|
||||
; uFMOD setup:
|
||||
UF_FREQ equ 48000 ; Set sampling rate to 48KHz (22050, 44100, 48000)
|
||||
UF_RAMP equ STRONG ; Select STRONG interpolation (NONE, WEAK, STRONG)
|
||||
UD_MODE equ UNSAFE ; Select UNSAFE mode (NORMAL, UNSAFE)
|
||||
DEBUG equ 0 ; Skip debug-board messages
|
||||
NOLINKER equ 1 ; Select "no linker" mode
|
||||
|
||||
; uFMOD constants:
|
||||
XM_MEMORY = 1
|
||||
XM_FILE = 2
|
||||
XM_NOLOOP = 8
|
||||
XM_SUSPENDED = 16
|
||||
uFMOD_MIN_VOL = 0
|
||||
uFMOD_MAX_VOL = 25
|
||||
uFMOD_DEFAULT_VOL = 25
|
||||
|
||||
; The XM track.
|
||||
xm file '..\ufmodlib\media\mini.xm'
|
||||
xm_length = $ - xm
|
||||
|
||||
; Optimization:
|
||||
; This header file is suitable for mini.xm track only!
|
||||
; If you change the track, update the optimization header.
|
||||
; (Use the standart eff.inc file for a general purpose player app.)
|
||||
include '..\ufmodlib\media\mini.eff.inc'
|
||||
|
||||
; Include the GUI framework.
|
||||
FRMWRK_CALLBACK_ON equ 1 ; Enable callback
|
||||
include 'frmwrk.asm'
|
||||
|
||||
; UI text messages.
|
||||
msg_txt db "uFMOD ruleZ!"
|
||||
msg_txt_l = $ - msg_txt
|
||||
msg_cap db "FASM",0
|
||||
err_txt db "Error"
|
||||
err_txt_l = $ - err_txt
|
||||
err_cap db ":-(",0
|
||||
|
||||
START:
|
||||
; Start playback.
|
||||
push XM_MEMORY
|
||||
push xm_length
|
||||
push xm
|
||||
call _uFMOD_LoadSong
|
||||
|
||||
; Stack fixing is required here, but in this simple
|
||||
; example leaving ESP as it is won't harm. In a real
|
||||
; application you should uncomment the following line:
|
||||
; add esp,12
|
||||
|
||||
test eax,eax
|
||||
jz error
|
||||
|
||||
; Wait for user input.
|
||||
push _uFMOD_WaveOut ; cbProc <- continue fetching data!
|
||||
push msg_txt_l ; cbString
|
||||
push msg_txt ; lpString
|
||||
push msg_cap ; szCap
|
||||
call _MessageBoxCB
|
||||
; add esp,16
|
||||
|
||||
; Stop playback.
|
||||
call _uFMOD_StopSong
|
||||
|
||||
r: ; Exit.
|
||||
xor eax,eax
|
||||
dec eax
|
||||
int 40h
|
||||
|
||||
error:
|
||||
push 0 ; cbProc <- no callback
|
||||
push err_txt_l ; cbString
|
||||
push err_txt ; lpString
|
||||
push err_cap ; szCap
|
||||
call _MessageBoxCB
|
||||
; add esp,16
|
||||
jmp r
|
||||
|
||||
; Include the whole uFMOD sources here. (Right after
|
||||
; your main code to avoid naming conflicts, but still
|
||||
; inside your code section.)
|
||||
macro PUBLIC symbol {} ; hide all publics
|
||||
include '..\ufmodlib\src\fasm.asm'
|
||||
|
||||
align 4
|
||||
rb 1020
|
||||
STACK_B dd ? ; Stack bottom
|
||||
MEMORY_END: ; End of uninitialized (BSS) data
|
35
programs/develop/libraries/ufmod/Masm32/make.bat
Normal file
35
programs/develop/libraries/ufmod/Masm32/make.bat
Normal file
@ -0,0 +1,35 @@
|
||||
@echo off
|
||||
rem Set compiler location:
|
||||
SET MASM32=\masm32
|
||||
SET UF_FASM=\fasm
|
||||
|
||||
if not exist "%MASM32%\bin\ml.exe" goto Err1
|
||||
if not exist "%UF_FASM%\fasm.exe" goto Err2
|
||||
"%MASM32%\bin\ml" /c /coff mini.asm
|
||||
"%MASM32%\bin\link" /DRIVER /SUBSYSTEM:NATIVE /BASE:-0x10000 /ALIGN:0x10000 /MERGE:.data=.text -ignore:4078 mini.obj ufmod.obj
|
||||
del mini.obj
|
||||
echo virtual at 0 >tmp.asm
|
||||
echo file 'mini.exe':3Ch,4 >>tmp.asm
|
||||
echo load pehea dword from 0 >>tmp.asm
|
||||
echo file 'mini.exe':pehea+0F8h,28h >>tmp.asm
|
||||
echo load physofs dword from 4+14h >>tmp.asm
|
||||
echo load mem dword from 4+8 >>tmp.asm
|
||||
echo file 'mini.exe':physofs+16,4 >>tmp.asm
|
||||
echo load sz dword from $-4 >>tmp.asm
|
||||
echo end virtual >>tmp.asm
|
||||
echo file 'mini.exe':physofs,sz >>tmp.asm
|
||||
echo store dword mem at 14h >>tmp.asm
|
||||
"%UF_FASM%\fasm" tmp.asm mini
|
||||
del mini.exe
|
||||
del tmp.asm
|
||||
|
||||
goto TheEnd
|
||||
:Err1
|
||||
echo Couldn't find ml.exe in %MASM32%\bin
|
||||
goto TheEnd
|
||||
:Err2
|
||||
echo Couldn't find fasm.exe in %UF_FASM%\
|
||||
|
||||
:TheEnd
|
||||
pause
|
||||
cls
|
266
programs/develop/libraries/ufmod/Masm32/mini.asm
Normal file
266
programs/develop/libraries/ufmod/Masm32/mini.asm
Normal file
@ -0,0 +1,266 @@
|
||||
; MINI.ASM
|
||||
; --------
|
||||
; Shows how to place data and code inside (!!!) the XM track.
|
||||
|
||||
.386
|
||||
.model flat
|
||||
|
||||
include ufmod.inc ; uFMOD API
|
||||
|
||||
.CODE
|
||||
|
||||
PE_BASE db "MENUET01"
|
||||
dd 1
|
||||
dd OFFSET _START ; Entry point
|
||||
dd OFFSET BSS_START ; End of code and initialized data
|
||||
dd OFFSET BSS_END ; End of uninitialized (BSS) data
|
||||
dd OFFSET STACK_B ; Bottom of the stack
|
||||
dd 0 ; Args
|
||||
dd 0 ; Reserved
|
||||
|
||||
err_txt db "Error"
|
||||
err_txt_l EQU $ - err_txt
|
||||
|
||||
_START:
|
||||
; Start playback.
|
||||
push XM_MEMORY
|
||||
push xm_length
|
||||
push BYTE PTR xm
|
||||
|
||||
; Let's place the stream right inside the code section.
|
||||
xm_length EQU 905
|
||||
xm EQU $ - PE_BASE
|
||||
xm_unused_000 LABEL BYTE
|
||||
|
||||
; *** The following 60 bytes are not used. So, we'll place
|
||||
; *** some code here.
|
||||
; (the actual size and location of such gaps may be
|
||||
; found out using the Eff utility)
|
||||
|
||||
call uFMOD_LoadSong
|
||||
xor ebp,ebp ; global 0
|
||||
|
||||
; Stack fixing is required here, but in this simple
|
||||
; example leaving ESP as it is won't harm. In a real
|
||||
; application you should uncomment the following line:
|
||||
; add esp,12
|
||||
|
||||
test eax,eax
|
||||
jz error
|
||||
|
||||
; Wait for user input.
|
||||
push uFMOD_WaveOut ; cbProc <- continue fetching data!
|
||||
push BYTE PTR msg_txt_l ; cbString
|
||||
push OFFSET msg_txt ; lpString
|
||||
push OFFSET msg_cap ; szCap
|
||||
call MessageBoxCB
|
||||
; add esp,16
|
||||
|
||||
; Stop playback.
|
||||
call uFMOD_StopSong
|
||||
|
||||
r: ; Exit.
|
||||
lea eax,[ebp-1]
|
||||
int 40h
|
||||
|
||||
error:
|
||||
push ebp ; cbProc <- no callback
|
||||
push BYTE PTR err_txt_l ; cbString
|
||||
push BYTE PTR (err_txt - PE_BASE) ; lpString
|
||||
push OFFSET err_cap ; szCap
|
||||
call MessageBoxCB
|
||||
; add esp,16
|
||||
jmp r
|
||||
|
||||
org xm_unused_000 + 60
|
||||
db 034h,000h,000h,000h,020h,000h,000h,000h,002h,000h,00Dh,000h,001h,000h,001h,000h
|
||||
db 00Ah,000h,091h,000h,000h,001h,002h,003h,004h,005h,006h,007h,000h,001h,002h,003h
|
||||
db 004h,005h,006h,007h,008h,009h,00Ah,00Bh,008h,009h,00Ch,00Bh,008h,009h,00Ah,00Bh
|
||||
db 008h,009h,00Ch,00Bh,009h,000h,000h,000h,000h,004h,000h,001h,000h,083h,016h,001h
|
||||
db 080h,080h,02Eh,001h,000h,00Eh,060h,080h,03Ah,001h,000h,00Eh,062h,081h,061h,083h
|
||||
db 035h,001h,009h,000h,000h,000h,000h,004h,000h,001h,000h,083h,016h,001h,080h,080h
|
||||
db 02Eh,001h,000h,00Eh,060h,080h,035h,001h,000h,00Eh,062h,081h,061h,083h,038h,001h
|
||||
db 009h,000h,000h,000h,000h,004h,000h,001h,000h,083h,016h,001h,080h,080h,02Eh,001h
|
||||
db 000h,00Eh,060h,080h,038h,001h,000h,00Eh,062h,080h,083h,033h,001h,009h,000h,000h
|
||||
db 000h,000h,006h,000h,001h,000h,083h,016h,001h,080h,080h,02Eh,001h,000h,00Eh,060h
|
||||
db 080h,033h,001h,000h,00Eh,061h,081h,061h,083h,035h,001h,083h,00Dh,001h,083h,036h
|
||||
db 001h,080h,083h,036h,001h,009h,000h,000h,000h,000h,004h,000h,001h,000h,083h,00Fh
|
||||
db 001h,080h,080h,02Eh,001h,000h,00Eh,060h,080h,036h,001h,000h,00Eh,062h,081h,061h
|
||||
db 083h,033h,001h,009h,000h,000h,000h,000h,006h,000h,001h,000h,083h,00Fh,001h,080h
|
||||
db 080h,02Eh,001h,000h,00Eh,060h,080h,033h,001h,000h,00Eh,061h,081h,061h,083h,02Eh
|
||||
db 001h,083h,012h,001h,083h,033h,001h,080h,083h,035h,001h,009h,000h,000h,000h,000h
|
||||
db 006h,000h,001h,000h,083h,016h,001h,080h,080h,02Eh,001h,000h,00Eh,060h,080h,035h
|
||||
db 001h,000h,00Eh,061h,081h,061h,083h,02Eh,001h,083h,00Dh,001h,083h,031h,001h,080h
|
||||
db 083h,02Eh,001h,009h,000h,000h,000h,000h,008h,000h,001h,000h,083h,012h,001h,098h
|
||||
db 00Ah,001h,083h,019h,001h,088h,00Ah,083h,01Eh,001h,081h,061h,083h,012h,001h,080h
|
||||
db 083h,014h,001h,080h,083h,01Bh,001h,080h,083h,020h,001h,080h,083h,014h,001h,080h
|
||||
db 009h,000h,000h,000h,000h,008h,000h,001h,000h,083h,012h,001h,081h,061h,083h,019h
|
||||
db 001h,080h,083h,01Eh,001h,080h,083h,012h,001h,080h,083h,019h,001h,083h,031h,001h
|
||||
db 083h,01Eh,001h,080h,083h,012h,001h,083h,031h,001h,083h,019h,001h,080h,009h,000h
|
||||
db 000h,000h,000h,008h,000h,001h,000h,083h,014h,001h,083h,033h,001h,083h,01Bh,001h
|
||||
db 080h,083h,020h,001h,083h,031h,001h,083h,014h,001h,080h,083h,01Bh,001h,083h,030h
|
||||
db 001h,083h,020h,001h,080h,083h,014h,001h,083h,031h,001h,083h,01Bh,001h,080h,009h
|
||||
db 000h,000h,000h,000h,008h,000h,001h,000h,083h,016h,001h,083h,030h,001h,083h,01Dh
|
||||
db 001h,083h,031h,001h,083h,022h,001h,083h,035h,001h,083h,016h,001h,098h,00Ah,001h
|
||||
db 083h,01Dh,001h,088h,00Ah,083h,022h,001h,081h,061h,083h,016h,001h,080h,083h,01Dh
|
||||
db 001h,080h,009h,000h,000h,000h,000h,008h,000h,001h,000h,083h,016h,001h,080h,083h
|
||||
db 01Dh,001h,080h,083h,022h,001h,080h,083h,016h,001h,080h,083h,018h,001h,080h,083h
|
||||
db 01Dh,001h,080h,083h,011h,001h,080h,083h,018h,001h,080h,009h,000h,000h,000h,000h
|
||||
db 008h,000h,001h,000h,083h,016h,001h,083h,030h,001h,083h,01Dh,001h,083h,031h,001h
|
||||
db 083h,019h,001h,083h,02Eh,001h,083h,016h,001h,098h,00Ah,001h,083h,01Dh,001h,088h
|
||||
db 00Ah,083h,019h,001h,081h,061h,083h,016h,001h,080h,083h,01Dh,001h,080h,0F1h,000h
|
||||
db 000h,000h
|
||||
xm_unused_001 LABEL BYTE
|
||||
|
||||
; The following 23 bytes are not used.
|
||||
; So, let's place the MessageBox text and caption instead.
|
||||
; UI text messages.
|
||||
msg_txt db "uFMOD ruleZ!"
|
||||
msg_txt_l equ $ - msg_txt
|
||||
msg_cap db "MASM32",0
|
||||
err_cap db ":-(",0
|
||||
|
||||
org xm_unused_001 + 23
|
||||
db 001h,000h,012h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h
|
||||
db 000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h
|
||||
db 000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h
|
||||
db 000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h
|
||||
db 000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h
|
||||
db 000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h,000h
|
||||
db 000h,000h,000h,000h,000h,000h,000h,000h,040h,000h,008h,000h,02Ch,000h,00Eh,000h
|
||||
db 008h,000h,018h,000h,016h,000h,020h,000h,008h,000h,02Dh,000h,00Dh,000h,032h,000h
|
||||
db 004h,000h,03Ch,000h,007h,000h,044h,000h,004h,000h,05Ah,000h,000h,000h,064h,000h
|
||||
db 000h,000h,06Eh,000h,000h,000h,000h,000h,020h,000h,00Ah,000h,028h,000h,01Eh,000h
|
||||
db 018h,000h,032h,000h,020h,000h,03Ch,000h,020h,000h,046h,000h,020h,000h,050h,000h
|
||||
db 020h,000h,05Ah,000h,020h,000h,064h,000h,020h,000h,06Eh,000h,020h,000h,078h,000h
|
||||
db 020h,000h,082h,000h,020h,000h,009h,006h,001h,002h,004h,002h,003h,005h,001h,000h
|
||||
db 000h,000h,000h,000h,080h,000h,00Ch,000h,000h,000h,000h,000h,000h,000h,00Ch,000h
|
||||
db 000h,000h,040h,000h,001h,080h,0F9h,000h,0BFh,000h,0C3h,000h,00Ah,000h,057h,000h
|
||||
db 06Eh,000h,023h,000h
|
||||
|
||||
; ----------------------------------------------------------
|
||||
; void MessageBoxCB(szCap, lpString, cbString, cbProc);
|
||||
; ----------------------------------------------------------
|
||||
|
||||
; This is similar to a Win32 MessageBox. The box is centered
|
||||
; on screen. It contains a single-line text message and an
|
||||
; "OK" button. This function returns when user closes the
|
||||
; box (via the X button or via the OK button). An optional
|
||||
; callback subroutine may be specified to be called when no
|
||||
; events are pending in the event queue.
|
||||
|
||||
; NOTE: Doesn't work if you already have defined a window
|
||||
; in the current process! Doesn't modify the event mask. So,
|
||||
; make sure keyboard events are enabled before calling this
|
||||
; function. This function doesn't check the validity of the
|
||||
; supplied parameters!
|
||||
|
||||
; Parameters:
|
||||
; szCap - A pointer to the ASCIIz string containing the
|
||||
; caption. A trailing zero char IS required.
|
||||
; lpString - A pointer to an ASCII string containing a single
|
||||
; line message to pop up in the box. No trailing
|
||||
; zero char is required.
|
||||
; cbString - number of characters in string.
|
||||
; cbProc - Address of the callback subroutine. Can be NULL.
|
||||
|
||||
sOK db "OK"
|
||||
MessageBoxCB:
|
||||
; EBP = 0
|
||||
mov esi,[esp+12] ; cbString
|
||||
mov edi,[esp+4] ; szCap
|
||||
|
||||
; Get screen metrics.
|
||||
lea eax,[ebp+14]
|
||||
int 40h
|
||||
mov ecx,eax
|
||||
movzx eax,ax
|
||||
shr ecx,16 ; screen w
|
||||
xchg eax,edx ; screen h
|
||||
lea ebx,[esi*2+esi]
|
||||
lea ebx,[ebx*2+28] ; w = string len * 6 + 28
|
||||
sub ecx,ebx
|
||||
shr ecx,1
|
||||
shl ecx,16
|
||||
or ebx,ecx
|
||||
lea ecx,[ebp+52h] ; h = 52h
|
||||
sub edx,ecx
|
||||
shr edx,1
|
||||
shl edx,16
|
||||
or ecx,edx ; y = (screen h - window h) / 2
|
||||
mov edx,ebx ; x = (screen w - window w) / 2
|
||||
|
||||
_MessageBoxCB_redraw:
|
||||
; Start redraw.
|
||||
push edx
|
||||
lea eax,[ebp+12]
|
||||
lea ebx,[ebp+1]
|
||||
int 40h
|
||||
|
||||
; Define and draw window.
|
||||
xor eax,eax
|
||||
mov ebx,edx ; x, w (ECX: y, h)
|
||||
mov edx,34C0C0C0h ; style and BG color
|
||||
int 40h
|
||||
|
||||
; Define the OK button.
|
||||
push esi
|
||||
lea eax,[ebp+8]
|
||||
sub ebx,28+0Ah
|
||||
shr bx,1
|
||||
shl ebx,16 ; x = (window w - button w) / 2
|
||||
mov bx,18+0Ah ; w = 18 + 0Ah
|
||||
mov ecx,001C0012h ; y = 1Ch, h = 12h
|
||||
lea edx,[ebp+1] ; ID = close
|
||||
mov esi,0C0C0C0h ; color
|
||||
int 40h
|
||||
|
||||
; Draw the OK label.
|
||||
lea eax,[ebp+4]
|
||||
add ebx,90000h ; x = button x + 9
|
||||
mov bx,22h ; y = 22h
|
||||
xor ecx,ecx ; style, font and color
|
||||
mov edx,OFFSET sOK ; string
|
||||
lea esi,[ebp+2] ; length
|
||||
int 40h
|
||||
pop esi
|
||||
|
||||
; Draw text string.
|
||||
lea eax,[ebp+4]
|
||||
mov ebx,000A000Ah ; x = 0Ah, y = 0Ah
|
||||
xor ecx,ecx ; style, font and color
|
||||
mov edx,[esp+12] ; lpString
|
||||
int 40h
|
||||
|
||||
; End redraw.
|
||||
lea eax,[ebp+12]
|
||||
lea ebx,[ebp+2]
|
||||
int 40h
|
||||
|
||||
_MessageBoxCB_eventloop:
|
||||
mov edx,[esp+20] ; cbProc
|
||||
test edx,edx
|
||||
lea eax,[ebp+10]
|
||||
jz _MessageBoxCB_peekevent
|
||||
|
||||
; Invoke the callback.
|
||||
call edx
|
||||
|
||||
lea eax,[ebp+23]
|
||||
lea ebx,[ebp+10] ; wait for at most 0.1 sec
|
||||
_MessageBoxCB_peekevent:
|
||||
int 40h
|
||||
dec eax
|
||||
js _MessageBoxCB_eventloop
|
||||
|
||||
pop edx
|
||||
jz _MessageBoxCB_redraw
|
||||
ret
|
||||
|
||||
.DATA?
|
||||
BSS_START LABEL BYTE
|
||||
db 1020 dup (?)
|
||||
STACK_B dd ? ; Stack bottom
|
||||
BSS_END LABEL BYTE
|
||||
|
||||
END _START
|
241
programs/develop/libraries/ufmod/Masm32/ufmod.inc
Normal file
241
programs/develop/libraries/ufmod/Masm32/ufmod.inc
Normal file
@ -0,0 +1,241 @@
|
||||
; uFMOD header file
|
||||
; Target OS: KolibriOS
|
||||
; Compiler: MASM32
|
||||
|
||||
; HANDLE uFMOD_LoadSong(
|
||||
; void *lpXM,
|
||||
; void *param,
|
||||
; int fdwSong
|
||||
; )
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Loads the given XM song and starts playing it as soon as you
|
||||
; call uFMOD_WaveOut for the first time. Playback won't begin
|
||||
; if XM_SUSPENDED flag is specified. It will stop any currently
|
||||
; playing song before loading the new one.
|
||||
; ---
|
||||
; Parameters:
|
||||
; ---
|
||||
; lpXM
|
||||
; Specifies the song to load. If this parameter is 0, any
|
||||
; currently playing song is stopped. In such a case, function
|
||||
; does not return a meaningful value. fdwSong parameter
|
||||
; determines whether this value is interpreted as a filename
|
||||
; or as a pointer to an image of the song in memory.
|
||||
; param
|
||||
; If XM_MEMORY is specified, this parameter should be the size
|
||||
; of the image of the song in memory.
|
||||
; If XM_FILE is specified, this parameter is ignored.
|
||||
; fdwSong
|
||||
; Flags for playing the song. The following values are defined:
|
||||
; XM_FILE lpXM points to filename. param is ignored.
|
||||
; XM_MEMORY lpXM points to an image of a song in memory.
|
||||
; param is the image size. Once, uFMOD_LoadSong
|
||||
; returns, it's safe to free/discard the memory
|
||||
; buffer.
|
||||
; XM_NOLOOP An XM track plays repeatedly by default. Specify
|
||||
; this flag to play it only once.
|
||||
; XM_SUSPENDED The XM track is loaded in a suspended state,
|
||||
; and will not play until the uFMOD_Resume function
|
||||
; is called. This is useful for preloading a song
|
||||
; or testing an XM track for validity.
|
||||
; ---
|
||||
; Return Values:
|
||||
; ---
|
||||
; On success, returns the handle of the Infinity Sound driver.
|
||||
; Returns 0 on failure.
|
||||
uFMOD_LoadSong PROTO C :DWORD,:DWORD,:DWORD
|
||||
|
||||
; int uFMOD_WaveOut(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Updates the internal playback buffer.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; This function should be called from the same thread
|
||||
; uFMOD_LoadSong was previously called. Playback doesn't actually
|
||||
; begin when calling uFMOD_LoadSong, but when calling uFMOD_WaveOut
|
||||
; after a successful uFMOD_LoadSong call. Afterwards, you should
|
||||
; call uFMOD_WaveOut repeatedly at least once every 250 ms to
|
||||
; prevent "buffer underruns".
|
||||
; uFMOD_WaveOut is a non-blocking function. The accuracy of the
|
||||
; InfoAPI functions (uFMOD_GetStats, uFMOD_GetRowOrder and
|
||||
; uFMOD_GetTime) depends on the periodicity of this function being
|
||||
; invoked.
|
||||
; ---
|
||||
; Return Values:
|
||||
; ---
|
||||
; Returns non zero on error.
|
||||
uFMOD_WaveOut PROTO C
|
||||
|
||||
; void uFMOD_StopSong(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Stops the currently playing song, freeing the associated
|
||||
; resources.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; Does nothing if no song is playing at the time the call is made.
|
||||
uFMOD_StopSong PROTO C
|
||||
|
||||
; void uFMOD_Jump2Pattern(
|
||||
; unsigned int pat
|
||||
; )
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Jumps to the specified pattern index.
|
||||
; ---
|
||||
; Parameters:
|
||||
; ---
|
||||
; pat
|
||||
; Next zero based pattern index.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; uFMOD doesn't automatically perform Note Off effects before jumping
|
||||
; to the target pattern. In other words, the original pattern will
|
||||
; remain in the mixer until it fades out. You can use this feature to
|
||||
; your advantage. If you don't like it, just insert leading Note Off
|
||||
; commands in all patterns intended to be used as uFMOD_Jump2Pattern
|
||||
; targets.
|
||||
; if the pattern index lays outside of the bounds of the pattern order
|
||||
; table, calling this function jumps to pattern 0, effectively
|
||||
; rewinding playback.
|
||||
uFMOD_Jump2Pattern PROTO C :DWORD
|
||||
|
||||
; void uFMOD_Pause(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Pauses the currently playing song, if any.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; While paused you can still control the volume (uFMOD_SetVolume) and
|
||||
; the pattern order (uFMOD_Jump2Pattern). The RMS volume coefficients
|
||||
; (uFMOD_GetStats) will go down to 0 and the progress tracker
|
||||
; (uFMOD_GetTime) will "freeze" while the song is paused.
|
||||
; uFMOD_Pause doesn't perform the request immediately. Instead, it
|
||||
; signals to pause when playback reaches next chunk of data.
|
||||
; This way, uFMOD_Pause performs asynchronously and returns very fast.
|
||||
; It is not cumulative. So, calling uFMOD_Pause many times in a row
|
||||
; has the same effect as calling it once.
|
||||
; You shouldn't stop calling uFMOD_WaveOut while the song is paused!
|
||||
uFMOD_Pause PROTO C
|
||||
|
||||
; void uFMOD_Resume(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Resumes the currently paused song, if any.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; uFMOD_Resume doesn't perform the request immediately. Instead, it
|
||||
; signals to resume when uFMOD_WaveOut is called again. uFMOD_Resume
|
||||
; is not cumulative. So, calling it many times in a row has the same
|
||||
; effect as calling it once.
|
||||
uFMOD_Resume PROTO C
|
||||
|
||||
; unsigned int uFMOD_GetStats(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Returns the current RMS volume coefficients in (L)eft and (R)ight
|
||||
; channels.
|
||||
; low-order word: RMS volume in R channel
|
||||
; hi-order word: RMS volume in L channel
|
||||
; Range from 0 (silence) to $7FFF (maximum) on each channel.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; This function is useful for updating a VU meter. It's recommended
|
||||
; to rescale the output to log10 (decibels or dB for short), because
|
||||
; human ears track volume changes in a dB scale. You may call
|
||||
; uFMOD_GetStats() as often as you like, but take in mind that uFMOD
|
||||
; updates both channel RMS volumes at the same rate uFMOD_WaveOut
|
||||
; function is called. In other words, you should call uFMOD_WaveOut
|
||||
; more often to increase the accuracy of uFMOD_GetStats.
|
||||
uFMOD_GetStats PROTO C
|
||||
|
||||
; unsigned int uFMOD_GetRowOrder(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Returns the currently playing row and order.
|
||||
; low-order word: row
|
||||
; hi-order word: order
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; This function is useful for synchronization. uFMOD updates both
|
||||
; row and order values at the same rate uFMOD_WaveOut function is
|
||||
; called. In other words, you should call uFMOD_WaveOut more often
|
||||
; to increase the accuracy of uFMOD_GetRowOrder.
|
||||
uFMOD_GetRowOrder PROTO C
|
||||
|
||||
; unsigned int uFMOD_GetTime(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Returns the time in milliseconds since the song was started.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; This function is useful for synchronizing purposes. Multimedia
|
||||
; applications can use uFMOD_GetTime to synchronize GFX to sound,
|
||||
; for example. An XM player can use this function to update a progress
|
||||
; meter.
|
||||
uFMOD_GetTime PROTO C
|
||||
|
||||
; unsigned char* uFMOD_GetTitle(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Returns the current song's title.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; Not every song has a title, so be prepared to get an empty string.
|
||||
uFMOD_GetTitle PROTO C
|
||||
|
||||
; void uFMOD_SetVolume(
|
||||
; unsigned int vol
|
||||
; )
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Sets the global volume. The volume scale is linear.
|
||||
; ---
|
||||
; Parameters:
|
||||
; ---
|
||||
; vol
|
||||
; New volume. Range: from uFMOD_MIN_VOL (muting) to uFMOD_MAX_VOL
|
||||
; (maximum volume). Any value above uFMOD_MAX_VOL maps to maximum
|
||||
; volume.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; uFMOD internally converts the given values to a logarithmic scale (dB).
|
||||
; Maximum volume is set by default. The volume value is preserved across
|
||||
; uFMOD_LoadSong calls. You can set the desired volume level before
|
||||
; actually starting to play a song.
|
||||
; You can use Infinity Sound API to control the L and R channels volumes
|
||||
; separately. It also has a wider range than uFMOD_SetVolume, sometimes
|
||||
; allowing to amplify the sound volume as well, as opposed to
|
||||
; uFMOD_SetVolume only being able to attenuate it.
|
||||
uFMOD_SetVolume PROTO C :DWORD
|
||||
|
||||
XM_MEMORY EQU 1
|
||||
XM_FILE EQU 2
|
||||
XM_NOLOOP EQU 8
|
||||
XM_SUSPENDED EQU 16
|
||||
uFMOD_MIN_VOL EQU 0
|
||||
uFMOD_MAX_VOL EQU 25
|
||||
uFMOD_DEFAULT_VOL EQU 25
|
BIN
programs/develop/libraries/ufmod/Masm32/ufmod.obj
Normal file
BIN
programs/develop/libraries/ufmod/Masm32/ufmod.obj
Normal file
Binary file not shown.
18
programs/develop/libraries/ufmod/Nasm/make.bat
Normal file
18
programs/develop/libraries/ufmod/Nasm/make.bat
Normal file
@ -0,0 +1,18 @@
|
||||
@echo off
|
||||
rem Compiler: NASM
|
||||
rem Target OS: KolibriOS
|
||||
|
||||
rem NASM Path:
|
||||
SET UF_NASM=\nasm
|
||||
|
||||
if not exist "%UF_NASM%\nasmw.exe" goto Err1
|
||||
"%UF_NASM%\nasmw" -fbin -t -O5 -i..\ufmodlib\src\ mini.asm
|
||||
goto TheEnd
|
||||
|
||||
:Err1
|
||||
echo Couldn't find nasmw.exe in %UF_NASM%\
|
||||
|
||||
:TheEnd
|
||||
pause
|
||||
@echo on
|
||||
cls
|
225
programs/develop/libraries/ufmod/Nasm/mini.asm
Normal file
225
programs/develop/libraries/ufmod/Nasm/mini.asm
Normal file
@ -0,0 +1,225 @@
|
||||
; MINI.ASM
|
||||
; --------
|
||||
; Minimalistic uFMOD usage example.
|
||||
|
||||
; Shows how to play an XM track in memory,
|
||||
; including proper error handling.
|
||||
|
||||
BITS 32
|
||||
org 0
|
||||
db "MENUET01"
|
||||
dd 1
|
||||
dd START ; Entry point
|
||||
dd uFMOD_IMG_END ; End of code and initialized data
|
||||
dd MEMORY_END ; End of uninitialized (BSS) data
|
||||
dd STACK_B ; Bottom of the stack
|
||||
dd 0 ; Args
|
||||
dd 0 ; Reserved
|
||||
|
||||
; uFMOD setup:
|
||||
%define f48000 ; Set sampling rate to 48KHz (22050, 44100, 48000)
|
||||
%define STRONG ; Select STRONG interpolation (NONE, WEAK, STRONG)
|
||||
%define UNSAFE ; Select UNSAFE mode (NORMAL, UNSAFE)
|
||||
%define NODEBUG ; Skip debug-board messages
|
||||
%define NOLINKER ; Select "no linker" mode
|
||||
|
||||
; uFMOD constants:
|
||||
%define uFMOD_MIN_VOL 0
|
||||
%define uFMOD_MAX_VOL 25
|
||||
%define uFMOD_DEFAULT_VOL 25
|
||||
|
||||
; The XM track.
|
||||
xm incbin "..\ufmodlib\media\mini.xm"
|
||||
xm_length equ $ - xm
|
||||
|
||||
; Optimization:
|
||||
; This header file is suitable for mini.xm track only!
|
||||
; If you change the track, update the optimization header.
|
||||
; (Use the standart eff.inc file for a general purpose player app.)
|
||||
%include "..\ufmodlib\media\mini.eff.inc"
|
||||
|
||||
; UI text messages.
|
||||
msg_txt db "uFMOD ruleZ!"
|
||||
msg_txt_l equ $ - msg_txt
|
||||
msg_cap db "NASM",0
|
||||
err_txt db "Error"
|
||||
err_txt_l equ $ - err_txt
|
||||
err_cap db ":-(",0
|
||||
|
||||
START:
|
||||
; Start playback.
|
||||
push XM_MEMORY
|
||||
push xm_length
|
||||
push xm
|
||||
call _uFMOD_LoadSong
|
||||
|
||||
; Stack fixing is required here, but in this simple
|
||||
; example leaving ESP as it is won't harm. In a real
|
||||
; application you should uncomment the following line:
|
||||
; add esp,12
|
||||
|
||||
test eax,eax
|
||||
jz error
|
||||
|
||||
; Wait for user input.
|
||||
push _uFMOD_WaveOut ; cbProc <- continue fetching data!
|
||||
push msg_txt_l ; cbString
|
||||
push msg_txt ; lpString
|
||||
push msg_cap ; szCap
|
||||
call _MessageBoxCB
|
||||
; add esp,16
|
||||
|
||||
; Stop playback.
|
||||
call _uFMOD_StopSong
|
||||
|
||||
r: ; Exit.
|
||||
xor eax,eax
|
||||
dec eax
|
||||
int 40h
|
||||
|
||||
error:
|
||||
push 0 ; cbProc <- no callback
|
||||
push err_txt_l ; cbString
|
||||
push err_txt ; lpString
|
||||
push err_cap ; szCap
|
||||
call _MessageBoxCB
|
||||
; add esp,16
|
||||
jmp r
|
||||
|
||||
; ---------------------------------------------------------------
|
||||
; void _cdecl _MessageBoxCB(szCap, lpString, cbString, cbProc);
|
||||
; ---------------------------------------------------------------
|
||||
|
||||
; This is similar to a Win32 MessageBox. The box is centered
|
||||
; on screen. It contains a single-line text message and an
|
||||
; "OK" button. This function returns when user closes the
|
||||
; box (via the X button or via the OK button). An optional
|
||||
; callback subroutine may be specified to be called when no
|
||||
; events are pending in the event queue.
|
||||
|
||||
; NOTE: Doesn't work if you already have defined a window
|
||||
; in the current process! Doesn't modify the event mask. So,
|
||||
; make sure keyboard events are enabled before calling this
|
||||
; function. This function doesn't check the validity of the
|
||||
; supplied parameters!
|
||||
|
||||
; Parameters:
|
||||
; szCap - A pointer to the ASCIIz string containing the
|
||||
; caption. A trailing zero char IS required.
|
||||
; lpString - A pointer to an ASCII string containing a single
|
||||
; line message to pop up in the box. No trailing
|
||||
; zero char is required.
|
||||
; cbString - number of characters in string.
|
||||
; cbProc - Address of the callback subroutine. Can be NULL.
|
||||
|
||||
sOK db "OK"
|
||||
_MessageBoxCB:
|
||||
push ebp
|
||||
push esi
|
||||
push edi
|
||||
push ebx
|
||||
xor ebp,ebp ; global 0
|
||||
mov esi,[esp+28] ; cbString
|
||||
mov edi,[esp+20] ; szCap
|
||||
|
||||
; Get screen metrics.
|
||||
lea eax,[ebp+14]
|
||||
int 40h
|
||||
mov ecx,eax
|
||||
movzx eax,ax
|
||||
shr ecx,16 ; screen w
|
||||
xchg eax,edx ; screen h
|
||||
lea ebx,[esi*2+esi]
|
||||
lea ebx,[ebx*2+28] ; w = string len * 6 + 28
|
||||
sub ecx,ebx
|
||||
shr ecx,1
|
||||
shl ecx,16
|
||||
or ebx,ecx
|
||||
lea ecx,[ebp+52h] ; h = 52h
|
||||
sub edx,ecx
|
||||
shr edx,1
|
||||
shl edx,16
|
||||
or ecx,edx ; y = (screen h - window h) / 2
|
||||
mov edx,ebx ; x = (screen w - window w) / 2
|
||||
|
||||
_MessageBoxCB_redraw:
|
||||
; Start redraw.
|
||||
push edx
|
||||
lea eax,[ebp+12]
|
||||
lea ebx,[ebp+1]
|
||||
int 40h
|
||||
|
||||
; Define and draw window.
|
||||
xor eax,eax
|
||||
mov ebx,edx ; x, w (ECX: y, h)
|
||||
mov edx,34C0C0C0h ; style and BG color
|
||||
int 40h
|
||||
|
||||
; Define the OK button.
|
||||
push esi
|
||||
lea eax,[ebp+8]
|
||||
sub ebx,28+0Ah
|
||||
shr bx,1
|
||||
shl ebx,16 ; x = (window w - button w) / 2
|
||||
mov bx,18+0Ah ; w = 18 + 0Ah
|
||||
mov ecx,001C0012h ; y = 1Ch, h = 12h
|
||||
lea edx,[ebp+1] ; ID = close
|
||||
mov esi,0C0C0C0h ; color
|
||||
int 40h
|
||||
|
||||
; Draw the OK label.
|
||||
lea eax,[ebp+4]
|
||||
add ebx,90000h ; x = button x + 9
|
||||
mov bx,22h ; y = 22h
|
||||
xor ecx,ecx ; style, font and color
|
||||
mov edx,sOK ; string
|
||||
lea esi,[ebp+2] ; length
|
||||
int 40h
|
||||
pop esi
|
||||
|
||||
; Draw text string.
|
||||
lea eax,[ebp+4]
|
||||
mov ebx,000A000Ah ; x = 0Ah, y = 0Ah
|
||||
xor ecx,ecx ; style, font and color
|
||||
mov edx,[esp+28] ; lpString
|
||||
int 40h
|
||||
|
||||
; End redraw.
|
||||
lea eax,[ebp+12]
|
||||
lea ebx,[ebp+2]
|
||||
int 40h
|
||||
|
||||
_MessageBoxCB_eventloop:
|
||||
mov edx,[esp+36] ; cbProc
|
||||
test edx,edx
|
||||
lea eax,[ebp+10]
|
||||
jz _MessageBoxCB_peekevent
|
||||
|
||||
; Invoke the callback.
|
||||
call edx
|
||||
|
||||
lea eax,[ebp+23]
|
||||
lea ebx,[ebp+10] ; wait for at most 0.1 sec
|
||||
_MessageBoxCB_peekevent:
|
||||
int 40h
|
||||
dec eax
|
||||
js _MessageBoxCB_eventloop
|
||||
|
||||
pop edx
|
||||
jz _MessageBoxCB_redraw
|
||||
|
||||
pop ebx
|
||||
pop edi
|
||||
pop esi
|
||||
pop ebp
|
||||
ret
|
||||
|
||||
; Include the whole uFMOD sources here. (Right after
|
||||
; your main code to avoid naming conflicts, but still
|
||||
; inside your code section.)
|
||||
%include "nasm.asm"
|
||||
|
||||
alignb 4
|
||||
resb 1020
|
||||
STACK_B resd 1 ; Stack bottom
|
||||
MEMORY_END: ; End of uninitialized (BSS) data
|
3374
programs/develop/libraries/ufmod/core.asm
Normal file
3374
programs/develop/libraries/ufmod/core.asm
Normal file
File diff suppressed because it is too large
Load Diff
60
programs/develop/libraries/ufmod/eff.inc
Normal file
60
programs/develop/libraries/ufmod/eff.inc
Normal file
@ -0,0 +1,60 @@
|
||||
; XM-file: full.xm
|
||||
|
||||
; uFMOD optional features:
|
||||
INFO_API_ON equ 1 ; enable InfoAPI
|
||||
NOLOOP_ON equ 1 ; enable XM_NOLOOP
|
||||
PAUSE_RESUME_ON equ 1 ; enable pause/resume and XM_SUSPENDED
|
||||
VOL_CONTROL_ON equ 1 ; enable volume control
|
||||
JUMP_TO_PAT_ON equ 1 ; enable Jump2Pattern
|
||||
XM_FILE_ON equ 1 ; enable file loading
|
||||
|
||||
; Special flags:
|
||||
INSTRUMENTVIBRATO_ON equ 1
|
||||
VOLUMEENVELOPE_ON equ 1
|
||||
PANENVELOPE_ON equ 1
|
||||
VOLUMEBYTE_ON equ 1
|
||||
ADPCM_ON equ 1
|
||||
AMIGAPERIODS_ON equ 1
|
||||
|
||||
; XM effects:
|
||||
ARPEGGIO_ON equ 1
|
||||
PORTAUP_ON equ 1
|
||||
PORTADOWN_ON equ 1
|
||||
PORTATO_ON equ 1
|
||||
VIBRATO_ON equ 1
|
||||
PORTATOVOLSLIDE_ON equ 1
|
||||
VIBRATOVOLSLIDE_ON equ 1
|
||||
TREMOLO_ON equ 1
|
||||
SETPANPOSITION_ON equ 1
|
||||
SETSAMPLEOFFSET_ON equ 1
|
||||
VOLUMESLIDE_ON equ 1
|
||||
PATTERNJUMP_ON equ 1
|
||||
SETVOLUME_ON equ 1
|
||||
PATTERNBREAK_ON equ 1
|
||||
SETSPEED_ON equ 1
|
||||
SETGLOBALVOLUME_ON equ 1
|
||||
GLOBALVOLSLIDE_ON equ 1
|
||||
KEYOFF_ON equ 1
|
||||
SETENVELOPEPOS_ON equ 1
|
||||
PANSLIDE_ON equ 1
|
||||
MULTIRETRIG_ON equ 1
|
||||
TREMOR_ON equ 1
|
||||
EXTRAFINEPORTA_ON equ 1
|
||||
FINEPORTAUP_ON equ 1
|
||||
FINEPORTADOWN_ON equ 1
|
||||
SETVIBRATOWAVE_ON equ 1
|
||||
SETFINETUNE_ON equ 1
|
||||
PATTERNLOOP_ON equ 1
|
||||
SETTREMOLOWAVE_ON equ 1
|
||||
SETPANPOSITION16_ON equ 1
|
||||
RETRIG_ON equ 1
|
||||
NOTECUT_ON equ 1
|
||||
NOTEDELAY_ON equ 1
|
||||
PATTERNDELAY_ON equ 1
|
||||
PORTAUP_OR_DOWN_ON equ 1
|
||||
VIBRATO_OR_VOLSLIDE equ 1
|
||||
VIBRATO_OR_TREMOLO equ 1
|
||||
PORTATO_OR_VOLSLIDE equ 1
|
||||
VOLUME_OR_PANENVELOPE equ 1
|
||||
ROWCOMMANDS_ON equ 1
|
||||
FINEVOLUMESLIDE_ON equ 1
|
342
programs/develop/libraries/ufmod/fasm.asm
Normal file
342
programs/develop/libraries/ufmod/fasm.asm
Normal file
@ -0,0 +1,342 @@
|
||||
; FASM.ASM
|
||||
; --------
|
||||
; uFMOD public source code release. Provided as-is.
|
||||
|
||||
; *** This stub allows compiling uFMOD sources using FASM.
|
||||
|
||||
; *** CONSTANTS ***
|
||||
|
||||
if UF_FREQ eq 44100
|
||||
FSOUND_MixRate = 44100
|
||||
FREQ_40HZ_p = 1DB8Bh
|
||||
FREQ_40HZ_f = 3B7160h
|
||||
PCM_format = 3 ; PCM_2_16_44
|
||||
else
|
||||
if UF_FREQ eq 22050
|
||||
FSOUND_MixRate = 22050
|
||||
FREQ_40HZ_p = 3B716h
|
||||
FREQ_40HZ_f = 76E2C0h
|
||||
PCM_format = 9 ; PCM_2_16_22
|
||||
else
|
||||
if UF_FREQ eq 48000
|
||||
else
|
||||
display 'UF_FREQ not specified (defaulting to 48KHz)',13,10
|
||||
end if
|
||||
FSOUND_MixRate = 48000
|
||||
FREQ_40HZ_p = 1B4E8h
|
||||
FREQ_40HZ_f = 369D00h
|
||||
PCM_format = 1 ; PCM_2_16_48
|
||||
end if
|
||||
end if
|
||||
|
||||
if UF_RAMP eq NONE
|
||||
RAMP_NONE = 1
|
||||
RAMP_WEAK = 0
|
||||
RAMP_STRONG = 0
|
||||
else
|
||||
if UF_RAMP eq WEAK
|
||||
RAMP_NONE = 0
|
||||
RAMP_WEAK = 1
|
||||
RAMP_STRONG = 0
|
||||
else
|
||||
if UF_RAMP eq STRONG
|
||||
else
|
||||
display 'UF_RAMP not specified (defaulting to STRONG)',13,10
|
||||
end if
|
||||
RAMP_NONE = 0
|
||||
RAMP_WEAK = 0
|
||||
RAMP_STRONG = 1
|
||||
end if
|
||||
end if
|
||||
|
||||
UCODE equ 0
|
||||
|
||||
if UF_MODE eq UNSAFE
|
||||
display 'WARNING! Unsafe mod is ON. Library may crash while loading damaged XM tracks!',13,10
|
||||
CHK4VALIDITY = 0
|
||||
AC97SND_ON = 0
|
||||
else
|
||||
CHK4VALIDITY = 1
|
||||
if UF_MODE eq AC97SND
|
||||
AC97SND_ON = 1
|
||||
else
|
||||
AC97SND_ON = 0
|
||||
end if
|
||||
end if
|
||||
|
||||
if NOLINKER
|
||||
else
|
||||
format MS COFF
|
||||
section '.text' code readable executable
|
||||
end if
|
||||
|
||||
; *** STRUCTS ***
|
||||
|
||||
; Sample type - contains info on sample
|
||||
struc FSOUND_SAMPLE{
|
||||
|
||||
; Don't change order .:.
|
||||
._length dd ? ; sample length
|
||||
.loopstart dd ? ; loop start
|
||||
.looplen dd ? ; loop length
|
||||
.defvol db ? ; default volume
|
||||
.finetune db ? ; finetune value from -128 to 127
|
||||
.bytes db ? ; type [b 0-1] : 0 - no loop
|
||||
; 1 - forward loop
|
||||
; 2 - bidirectional loop (aka ping-pong)
|
||||
; [b 4] : 0 - 8-bit sample data
|
||||
; 1 - 16-bit sample data
|
||||
.defpan db ? ; default pan value from 0 to 255
|
||||
.relative db ? ; relative note (signed value)
|
||||
.Resved db ? ; reserved, known values: 00h - regular delta packed sample data
|
||||
; ADh - ModPlug 4-bit ADPCM packed sample data
|
||||
; .:.
|
||||
|
||||
.loopmode db ?
|
||||
._align db ?
|
||||
.buff db ?,? ; sound data
|
||||
}
|
||||
virtual at 0
|
||||
FSOUND_SAMPLE FSOUND_SAMPLE
|
||||
FSOUND_SAMPLE_size = $-FSOUND_SAMPLE
|
||||
end virtual
|
||||
|
||||
|
||||
; Channel type - contains information on a mixing channel
|
||||
struc FSOUND_CHANNEL{
|
||||
.actualvolume dd ? ; driver level current volume
|
||||
.actualpan dd ? ; driver level panning value
|
||||
.fsampleoffset dd ? ; sample offset (sample starts playing from here)
|
||||
.leftvolume dd ? ; mixing information. adjusted volume for left channel (panning involved)
|
||||
.rightvolume dd ? ; mixing information. adjusted volume for right channel (panning involved)
|
||||
.mixpos dd ? ; mixing information. high part of 32:32 fractional position in sample
|
||||
.speedlo dd ? ; mixing information. playback rate - low part fractional
|
||||
.speedhi dd ? ; mixing information. playback rate - high part fractional
|
||||
.ramp_lefttarget dw ?
|
||||
.ramp_righttarget dw ?
|
||||
.ramp_leftspeed dd ?
|
||||
.ramp_rightspeed dd ?
|
||||
|
||||
; Don't change order .:.
|
||||
.fsptr dd ? ; pointer to FSOUND_SAMPLE currently playing sample
|
||||
.mixposlo dd ? ; mixing information. low part of 32:32 fractional position in sample
|
||||
.ramp_leftvolume dd ?
|
||||
.ramp_rightvolume dd ?
|
||||
.ramp_count dw ?
|
||||
.speeddir db ?,? ; mixing information. playback direction - forwards or backwards
|
||||
; .:.
|
||||
|
||||
}
|
||||
virtual at 0
|
||||
FSOUND_CHANNEL FSOUND_CHANNEL
|
||||
FSOUND_CHANNEL_size = $-FSOUND_CHANNEL
|
||||
end virtual
|
||||
|
||||
; Single note type - contains info on 1 note in a pattern
|
||||
struc FMUSIC_NOTE{
|
||||
.unote db ? ; note to play at (0-97) 97=keyoff
|
||||
.number db ? ; sample being played (0-128)
|
||||
.uvolume db ? ; volume column value (0-64) 255=no volume
|
||||
.effect db ? ; effect number (0-1Ah)
|
||||
.eparam db ? ; effect parameter (0-255)
|
||||
}
|
||||
virtual at 0
|
||||
FMUSIC_NOTE FMUSIC_NOTE
|
||||
FMUSIC_NOTE_size = $-FMUSIC_NOTE
|
||||
end virtual
|
||||
|
||||
; Pattern data type
|
||||
struc FMUSIC_PATTERN{
|
||||
.rows dw ?
|
||||
.patternsize dw ?
|
||||
.data dd ? ; pointer to FMUSIC_NOTE
|
||||
}
|
||||
virtual at 0
|
||||
FMUSIC_PATTERN FMUSIC_PATTERN
|
||||
FMUSIC_PATTERN_size = $-FMUSIC_PATTERN
|
||||
end virtual
|
||||
|
||||
; Multi sample extended instrument
|
||||
struc FMUSIC_INSTRUMENT{
|
||||
.sample rd 16 ; 16 pointers to FSOUND_SAMPLE per instrument
|
||||
|
||||
; Don't change order .:.
|
||||
.keymap rb 96 ; sample keymap assignments
|
||||
.VOLPoints rw 24 ; volume envelope points
|
||||
.PANPoints rw 24 ; panning envelope points
|
||||
.VOLnumpoints db ? ; number of volume envelope points
|
||||
.PANnumpoints db ? ; number of panning envelope points
|
||||
.VOLsustain db ? ; volume sustain point
|
||||
.VOLLoopStart db ? ; volume envelope loop start
|
||||
.VOLLoopEnd db ? ; volume envelope loop end
|
||||
.PANsustain db ? ; panning sustain point
|
||||
.PANLoopStart db ? ; panning envelope loop start
|
||||
.PANLoopEnd db ? ; panning envelope loop end
|
||||
.VOLtype db ? ; type of envelope,bit 0:On 1:Sustain 2:Loop
|
||||
.PANtype db ? ; type of envelope,bit 0:On 1:Sustain 2:Loop
|
||||
.VIBtype db ? ; instrument vibrato type
|
||||
.VIBsweep db ? ; time it takes for vibrato to fully kick in
|
||||
.iVIBdepth db ? ; depth of vibrato
|
||||
.VIBrate db ? ; rate of vibrato
|
||||
.VOLfade dw ? ; fade out value
|
||||
; .:.
|
||||
|
||||
}
|
||||
virtual at 0
|
||||
FMUSIC_INSTRUMENT FMUSIC_INSTRUMENT
|
||||
FMUSIC_INSTRUMENT_size = $-FMUSIC_INSTRUMENT
|
||||
end virtual
|
||||
|
||||
; Channel type - contains information on a mod channel
|
||||
struc FMUSIC_CHANNEL{
|
||||
.note db ? ; last note set in channel
|
||||
.samp db ? ; last sample set in channel
|
||||
.notectrl db ? ; flags for DoFlags proc
|
||||
.inst db ? ; last instrument set in channel
|
||||
.cptr dd ? ; pointer to FSOUND_CHANNEL system mixing channel
|
||||
.freq dd ? ; current mod frequency period for this channel
|
||||
.volume dd ? ; current mod volume for this channel
|
||||
.voldelta dd ? ; delta for volume commands... tremolo/tremor, etc
|
||||
.freqdelta dd ? ; delta for frequency commands... vibrato/arpeggio, etc
|
||||
.pan dd ? ; current mod pan for this channel
|
||||
|
||||
; Don't change order .:.
|
||||
.envvoltick dd ? ; tick counter for envelope position
|
||||
.envvolpos dd ? ; envelope position
|
||||
.envvoldelta dd ? ; delta step between points
|
||||
.envpantick dd ? ; tick counter for envelope position
|
||||
.envpanpos dd ? ; envelope position
|
||||
.envpandelta dd ? ; delta step between points
|
||||
.ivibsweeppos dd ? ; instrument vibrato sweep position
|
||||
.ivibpos dd ? ; instrument vibrato position
|
||||
.keyoff db ?,? ; flag whether keyoff has been hit or not
|
||||
.envvolstopped db ? ; flag to say whether envelope has finished or not
|
||||
.envpanstopped db ? ; flag to say whether envelope has finished or not
|
||||
; .:.
|
||||
|
||||
.envvolfrac dd ? ; fractional interpolated envelope volume
|
||||
.envvol dd ? ; final interpolated envelope volume
|
||||
.fadeoutvol dd ? ; volume fade out
|
||||
.envpanfrac dd ? ; fractional interpolated envelope pan
|
||||
.envpan dd ? ; final interpolated envelope pan
|
||||
.period dd ? ; last period set in channel
|
||||
.sampleoffset dd ? ; sample offset for this channel in SAMPLES
|
||||
.portatarget dd ? ; note to porta to
|
||||
.patloopno db ?,?,?,? ; pattern loop variables for effect E6x
|
||||
.patlooprow dd ?
|
||||
.realnote db ? ; last realnote set in channel
|
||||
.recenteffect db ? ; previous row's effect... used to correct tremolo volume
|
||||
.portaupdown db ? ; last porta up/down value
|
||||
db ? ; unused
|
||||
.xtraportadown db ? ; last porta down value
|
||||
.xtraportaup db ? ; last porta up value
|
||||
.volslide db ? ; last volume slide value
|
||||
.panslide db ? ; pan slide parameter
|
||||
.retrigx db ? ; last retrig volume slide used
|
||||
.retrigy db ? ; last retrig tick count used
|
||||
.portaspeed db ? ; porta speed
|
||||
.vibpos db ? ; vibrato position
|
||||
.vibspeed db ? ; vibrato speed
|
||||
.vibdepth db ? ; vibrato depth
|
||||
.tremolopos db ? ; tremolo position
|
||||
.tremolospeed db ? ; tremolo speed
|
||||
.tremolodepth db ? ; tremolo depth
|
||||
.tremorpos db ? ; tremor position
|
||||
.tremoron db ? ; remembered parameters for tremor
|
||||
.tremoroff db ? ; remembered parameters for tremor
|
||||
.wavecontrol db ? ; waveform type for vibrato and tremolo (4bits each)
|
||||
.finevslup db ? ; parameter for fine volume slide down
|
||||
.fineportaup db ? ; parameter for fine porta slide up
|
||||
.fineportadown db ? ; parameter for fine porta slide down
|
||||
}
|
||||
virtual at 0
|
||||
FMUSIC_CHANNEL FMUSIC_CHANNEL
|
||||
FMUSIC_CHANNEL_size = $-FMUSIC_CHANNEL
|
||||
end virtual
|
||||
|
||||
; Song type - contains info on song
|
||||
struc FMUSIC_MODULE{
|
||||
|
||||
; Don't change order .:.
|
||||
.pattern dd ? ; pointer to FMUSIC_PATTERN array for this song
|
||||
.instrument dd ? ; pointer to FMUSIC_INSTRUMENT array for this song
|
||||
.mixer_samplesleft dd ?
|
||||
.globalvolume dd ? ; global mod volume
|
||||
.tick dd ? ; current mod tick
|
||||
.speed dd ? ; speed of song in ticks per row
|
||||
.order dd ? ; current song order position
|
||||
.row dd ? ; current row in pattern
|
||||
.patterndelay dd ? ; pattern delay counter
|
||||
.nextorder dd ? ; current song order position
|
||||
.nextrow dd ? ; current row in pattern
|
||||
.unused1 dd ?
|
||||
.numchannels dd ? ; number of channels
|
||||
.Channels dd ? ; channel pool
|
||||
.uFMOD_Ch dd ? ; channel array for this song
|
||||
.mixer_samplespertick dd ?
|
||||
.numorders dw ? ; number of orders (song length)
|
||||
.restart dw ? ; restart position
|
||||
.numchannels_xm db ?
|
||||
.globalvsl db ? ; global mod volume
|
||||
.numpatternsmem dw ? ; number of allocated patterns
|
||||
.numinsts dw ? ; number of instruments
|
||||
.flags dw ? ; flags such as linear frequency, format specific quirks, etc
|
||||
.defaultspeed dw ?
|
||||
.defaultbpm dw ?
|
||||
.orderlist rb 256 ; pattern playing order list
|
||||
; .:.
|
||||
|
||||
}
|
||||
virtual at 0
|
||||
FMUSIC_MODULE FMUSIC_MODULE
|
||||
FMUSIC_MODULE_size = $-FMUSIC_MODULE
|
||||
end virtual
|
||||
|
||||
OFFSET equ
|
||||
PTR equ
|
||||
endif equ end if
|
||||
|
||||
include 'ufmod.asm'
|
||||
include 'core.asm'
|
||||
|
||||
if NOLINKER
|
||||
uFMOD_IMG_END: ; End of uFMOD's code. BSS follows.
|
||||
align 16
|
||||
else
|
||||
section '.bss' readable writeable align 16
|
||||
end if
|
||||
|
||||
; Don't change order!
|
||||
_mod rb FMUSIC_MODULE_size ; currently playing track
|
||||
mmt rd 3
|
||||
ufmod_heap dd ?
|
||||
dd ? ; unused
|
||||
if AC97SND_ON
|
||||
extrn hSound
|
||||
dd ?
|
||||
else
|
||||
hSound dd ?
|
||||
endif
|
||||
hBuff dd ?
|
||||
SW_Exit dd ?
|
||||
; mix buffer memory block (align 16!)
|
||||
MixBuf rb FSOUND_BlockSize*8
|
||||
ufmod_noloop db ?
|
||||
ufmod_pause_ db ?
|
||||
mix_endflag rb 2
|
||||
mmf rd 4
|
||||
ufmod_vol dd ? ; global volume scale
|
||||
; * LPCALLBACKS *
|
||||
uFMOD_fopen dd ?
|
||||
uFMOD_fread dd ?
|
||||
file_struct rd 7
|
||||
cache_offset dd ?
|
||||
if INFO_API_ON
|
||||
time_ms dd ?
|
||||
L_vol dw ? ; L channel RMS volume
|
||||
R_vol dw ? ; R channel RMS volume
|
||||
s_row dw ?
|
||||
s_order dw ?
|
||||
szTtl rb 24
|
||||
end if
|
||||
DummySamp rb FSOUND_SAMPLE_size
|
68
programs/develop/libraries/ufmod/makeobj.bat
Normal file
68
programs/develop/libraries/ufmod/makeobj.bat
Normal file
@ -0,0 +1,68 @@
|
||||
@echo off
|
||||
rem Make the uFMOD libraries in COFF object format
|
||||
rem Target OS: KolibriOS
|
||||
|
||||
rem *** CONFIG START
|
||||
rem *** Check the Readme docs for a complete reference
|
||||
rem *** on configuring the following options
|
||||
|
||||
rem Pathes:
|
||||
SET UF_MASM=\masm32\bin
|
||||
SET UF_NASM=\nasm
|
||||
SET UF_FASM=\fasm
|
||||
|
||||
rem Select compiler: MASM, NASM or FASM
|
||||
SET UF_ASM=FASM
|
||||
|
||||
rem Select mixing rate: 22050, 44100 or 48000 (22.05 KHz, 44.1 KHz or 48 KHz)
|
||||
SET UF_FREQ=48000
|
||||
|
||||
rem Set volume ramping mode (interpolation): NONE, WEAK or STRONG
|
||||
SET UF_RAMP=STRONG
|
||||
|
||||
rem Set build mode: NORMAL, UNSAFE or AC97SND
|
||||
SET UF_MODE=NORMAL
|
||||
rem *** CONFIG END
|
||||
|
||||
if %UF_ASM%==MASM goto MASM
|
||||
if %UF_ASM%==NASM goto NASM
|
||||
if %UF_ASM%==FASM goto FASM
|
||||
echo %UF_ASM% not supported
|
||||
goto TheEnd
|
||||
|
||||
:MASM
|
||||
if not exist "%UF_MASM%\ml.exe" goto Err1
|
||||
"%UF_MASM%\ml" /c /coff /nologo /Df%UF_FREQ% /D%UF_RAMP% /D%UF_MODE% /Fo ufmod.obj src\masm.asm
|
||||
goto TheEnd
|
||||
|
||||
:NASM
|
||||
if not exist "%UF_NASM%\nasmw.exe" goto Err2
|
||||
"%UF_NASM%\nasmw" -O4 -t -fwin32 -dNODEBUG -df%UF_FREQ% -d%UF_RAMP% -d%UF_MODE% -isrc\ -oufmod.obj src\nasm.asm
|
||||
goto TheEnd
|
||||
|
||||
:FASM
|
||||
if not exist "%UF_FASM%\fasm.exe" goto Err3
|
||||
echo UF_FREQ equ %UF_FREQ% >tmp.asm
|
||||
echo UF_RAMP equ %UF_RAMP% >>tmp.asm
|
||||
echo UF_MODE equ %UF_MODE% >>tmp.asm
|
||||
echo DEBUG equ 0 >>tmp.asm
|
||||
echo NOLINKER equ 0 >>tmp.asm
|
||||
echo include 'src\eff.inc' >>tmp.asm
|
||||
echo include 'src\fasm.asm' >>tmp.asm
|
||||
"%UF_FASM%\fasm" tmp.asm ufmod.obj
|
||||
del tmp.asm
|
||||
goto TheEnd
|
||||
|
||||
:Err1
|
||||
echo Couldn't find ml.exe in %UF_MASM%\
|
||||
goto TheEnd
|
||||
:Err2
|
||||
echo Couldn't find nasmw.exe in %UF_NASM%\
|
||||
goto TheEnd
|
||||
:Err3
|
||||
echo Couldn't find fasm.exe in %UF_FASM%\
|
||||
|
||||
:TheEnd
|
||||
pause
|
||||
@echo on
|
||||
cls
|
270
programs/develop/libraries/ufmod/masm.asm
Normal file
270
programs/develop/libraries/ufmod/masm.asm
Normal file
@ -0,0 +1,270 @@
|
||||
; MASM.ASM
|
||||
; --------
|
||||
; uFMOD public source code release. Provided as-is.
|
||||
|
||||
; *** This stub allows compiling uFMOD sources using MASM32.
|
||||
|
||||
.386
|
||||
.model flat
|
||||
|
||||
ifdef f44100
|
||||
FSOUND_MixRate = 44100
|
||||
FREQ_40HZ_p = 1DB8Bh
|
||||
FREQ_40HZ_f = 3B7160h
|
||||
PCM_format = 3
|
||||
else
|
||||
ifdef f22050
|
||||
FSOUND_MixRate = 22050
|
||||
FREQ_40HZ_p = 3B716h
|
||||
FREQ_40HZ_f = 76E2C0h
|
||||
PCM_format = 9
|
||||
else
|
||||
ifndef f48000
|
||||
echo UF_FREQ not specified (defaulting to 48KHz)
|
||||
endif
|
||||
FSOUND_MixRate = 48000
|
||||
FREQ_40HZ_p = 1B4E8h
|
||||
FREQ_40HZ_f = 369D00h
|
||||
PCM_format = 1
|
||||
endif
|
||||
endif
|
||||
|
||||
RAMP_NONE = 0
|
||||
RAMP_WEAK = 0
|
||||
RAMP_STRONG = 0
|
||||
ifdef NONE
|
||||
RAMP_NONE = 1
|
||||
else
|
||||
ifdef WEAK
|
||||
RAMP_WEAK = 1
|
||||
else
|
||||
ifndef STRONG
|
||||
echo UF_RAMP not specified (defaulting to STRONG)
|
||||
endif
|
||||
RAMP_STRONG = 1
|
||||
endif
|
||||
endif
|
||||
|
||||
UCODE = 0
|
||||
DEBUG = 0
|
||||
|
||||
CHK4VALIDITY = 1
|
||||
ifdef UNSAFE
|
||||
echo WARNING! Unsafe mod is ON. Library may crash while loading damaged XM tracks!
|
||||
CHK4VALIDITY = 0
|
||||
endif
|
||||
|
||||
AC97SND_ON = 0
|
||||
ifdef AC97SND
|
||||
AC97SND_ON = 1
|
||||
endif
|
||||
|
||||
include eff.inc
|
||||
|
||||
FSOUND_SAMPLE STRUC
|
||||
_length dd ?
|
||||
loopstart dd ?
|
||||
looplen dd ?
|
||||
defvol db ?
|
||||
finetune db ?
|
||||
bytes db ?
|
||||
defpan db ?
|
||||
relative db ?
|
||||
Resved db ?
|
||||
loopmode db ?
|
||||
_align db ?
|
||||
buff db ?,?
|
||||
FSOUND_SAMPLE ENDS
|
||||
|
||||
FSOUND_CHANNEL STRUC
|
||||
actualvolume dd ?
|
||||
actualpan dd ?
|
||||
fsampleoffset dd ?
|
||||
leftvolume dd ?
|
||||
rightvolume dd ?
|
||||
mixpos dd ?
|
||||
speedlo dd ?
|
||||
speedhi dd ?
|
||||
ramp_lefttarget dw ?
|
||||
ramp_righttarget dw ?
|
||||
ramp_leftspeed dd ?
|
||||
ramp_rightspeed dd ?
|
||||
fsptr dd ?
|
||||
mixposlo dd ?
|
||||
ramp_leftvolume dd ?
|
||||
ramp_rightvolume dd ?
|
||||
ramp_count dw ?
|
||||
speeddir db ?,?
|
||||
FSOUND_CHANNEL ENDS
|
||||
|
||||
FMUSIC_NOTE STRUC
|
||||
unote db ?
|
||||
number db ?
|
||||
uvolume db ?
|
||||
effect db ?
|
||||
eparam db ?
|
||||
FMUSIC_NOTE ENDS
|
||||
|
||||
FMUSIC_PATTERN STRUC
|
||||
rows dw ?
|
||||
patternsize dw ?
|
||||
data dd ?
|
||||
FMUSIC_PATTERN ENDS
|
||||
|
||||
FMUSIC_INSTRUMENT STRUC
|
||||
sample dd 16 dup (?)
|
||||
keymap db 96 dup (?)
|
||||
VOLPoints dw 24 dup (?)
|
||||
PANPoints dw 24 dup (?)
|
||||
VOLnumpoints db ?
|
||||
PANnumpoints db ?
|
||||
VOLsustain db ?
|
||||
VOLLoopStart db ?
|
||||
VOLLoopEnd db ?
|
||||
PANsustain db ?
|
||||
PANLoopStart db ?
|
||||
PANLoopEnd db ?
|
||||
VOLtype db ?
|
||||
PANtype db ?
|
||||
VIBtype db ?
|
||||
VIBsweep db ?
|
||||
iVIBdepth db ?
|
||||
VIBrate db ?
|
||||
VOLfade dw ?
|
||||
FMUSIC_INSTRUMENT ENDS
|
||||
|
||||
FMUSIC_CHANNEL STRUC
|
||||
note db ?
|
||||
samp db ?
|
||||
notectrl db ?
|
||||
inst db ?
|
||||
cptr dd ?
|
||||
freq dd ?
|
||||
volume dd ?
|
||||
voldelta dd ?
|
||||
freqdelta dd ?
|
||||
pan dd ?
|
||||
envvoltick dd ?
|
||||
envvolpos dd ?
|
||||
envvoldelta dd ?
|
||||
envpantick dd ?
|
||||
envpanpos dd ?
|
||||
envpandelta dd ?
|
||||
ivibsweeppos dd ?
|
||||
ivibpos dd ?
|
||||
keyoff db ?,?
|
||||
envvolstopped db ?
|
||||
envpanstopped db ?
|
||||
envvolfrac dd ?
|
||||
envvol dd ?
|
||||
fadeoutvol dd ?
|
||||
envpanfrac dd ?
|
||||
envpan dd ?
|
||||
period dd ?
|
||||
sampleoffset dd ?
|
||||
portatarget dd ?
|
||||
patloopno db ?,?,?,?
|
||||
patlooprow dd ?
|
||||
realnote db ?
|
||||
recenteffect db ?
|
||||
portaupdown db ?
|
||||
db ?
|
||||
xtraportadown db ?
|
||||
xtraportaup db ?
|
||||
volslide db ?
|
||||
panslide db ?
|
||||
retrigx db ?
|
||||
retrigy db ?
|
||||
portaspeed db ?
|
||||
vibpos db ?
|
||||
vibspeed db ?
|
||||
vibdepth db ?
|
||||
tremolopos db ?
|
||||
tremolospeed db ?
|
||||
tremolodepth db ?
|
||||
tremorpos db ?
|
||||
tremoron db ?
|
||||
tremoroff db ?
|
||||
wavecontrol db ?
|
||||
finevslup db ?
|
||||
fineportaup db ?
|
||||
fineportadown db ?
|
||||
FMUSIC_CHANNEL ENDS
|
||||
|
||||
FMUSIC_MODULE STRUC
|
||||
pattern dd ?
|
||||
instrument dd ?
|
||||
mixer_samplesleft dd ?
|
||||
globalvolume dd ?
|
||||
tick dd ?
|
||||
speed dd ?
|
||||
order dd ?
|
||||
row dd ?
|
||||
patterndelay dd ?
|
||||
nextorder dd ?
|
||||
nextrow dd ?
|
||||
unused1 dd ?
|
||||
numchannels dd ?
|
||||
Channels dd ?
|
||||
uFMOD_Ch dd ?
|
||||
mixer_samplespertick dd ?
|
||||
numorders dw ?
|
||||
restart dw ?
|
||||
numchannels_xm db ?
|
||||
globalvsl db ?
|
||||
numpatternsmem dw ?
|
||||
numinsts dw ?
|
||||
flags dw ?
|
||||
defaultspeed dw ?
|
||||
defaultbpm dw ?
|
||||
orderlist db 256 dup (?)
|
||||
FMUSIC_MODULE ENDS
|
||||
|
||||
FMUSIC_MODULE_size = SIZE FMUSIC_MODULE
|
||||
FSOUND_CHANNEL_size = SIZE FSOUND_CHANNEL
|
||||
FMUSIC_CHANNEL_size = SIZE FMUSIC_CHANNEL
|
||||
FMUSIC_INSTRUMENT_size = SIZE FMUSIC_INSTRUMENT
|
||||
FMUSIC_PATTERN_size = SIZE FMUSIC_PATTERN
|
||||
FMUSIC_NOTE_size = SIZE FMUSIC_NOTE
|
||||
|
||||
; FPU register stack
|
||||
st0 TEXTEQU <st(0)>
|
||||
st1 TEXTEQU <st(1)>
|
||||
|
||||
.CODE
|
||||
include ufmod.asm
|
||||
include core.asm
|
||||
|
||||
.DATA?
|
||||
_mod = $
|
||||
FMUSIC_MODULE<>
|
||||
mmt dd ?,?,?
|
||||
ufmod_heap dd ?,?
|
||||
if AC97SND_ON
|
||||
EXTERN hSound:DWORD
|
||||
dd ?
|
||||
else
|
||||
hSound dd ?
|
||||
endif
|
||||
hBuff dd ?
|
||||
SW_Exit dd ?
|
||||
MixBuf db FSOUND_BlockSize*8 dup (?)
|
||||
ufmod_noloop db ?
|
||||
ufmod_pause_ db ?
|
||||
mix_endflag db ?,?
|
||||
mmf dd ?,?,?,?
|
||||
ufmod_vol dd ?
|
||||
uFMOD_fopen dd ?
|
||||
uFMOD_fread dd ?
|
||||
file_struct dd 7 dup (?)
|
||||
cache_offset dd ?
|
||||
if INFO_API_ON
|
||||
time_ms dd ?
|
||||
L_vol dw ?
|
||||
R_vol dw ?
|
||||
s_row dw ?
|
||||
s_order dw ?
|
||||
szTtl db 24 dup (?)
|
||||
endif
|
||||
DummySamp FSOUND_SAMPLE<>
|
||||
end
|
BIN
programs/develop/libraries/ufmod/media/BLITZXMK.XM
Normal file
BIN
programs/develop/libraries/ufmod/media/BLITZXMK.XM
Normal file
Binary file not shown.
60
programs/develop/libraries/ufmod/media/blitz.eff.inc
Normal file
60
programs/develop/libraries/ufmod/media/blitz.eff.inc
Normal file
@ -0,0 +1,60 @@
|
||||
; XM-file: BLITZXMK.XM
|
||||
|
||||
; uFMOD optional features:
|
||||
INFO_API_ON equ 0 ; disable InfoAPI
|
||||
NOLOOP_ON equ 0 ; disable XM_NOLOOP
|
||||
PAUSE_RESUME_ON equ 1 ; enable pause/resume and XM_SUSPENDED
|
||||
VOL_CONTROL_ON equ 0 ; disable volume control
|
||||
JUMP_TO_PAT_ON equ 1 ; enable Jump2Pattern
|
||||
XM_FILE_ON equ 0 ; disable file loading
|
||||
|
||||
; Special flags:
|
||||
INSTRUMENTVIBRATO_ON equ 1
|
||||
VOLUMEENVELOPE_ON equ 1
|
||||
PANENVELOPE_ON equ 0
|
||||
VOLUMEBYTE_ON equ 1
|
||||
ADPCM_ON equ 0
|
||||
AMIGAPERIODS_ON equ 0
|
||||
|
||||
; XM effects:
|
||||
ARPEGGIO_ON equ 0
|
||||
PORTAUP_ON equ 0
|
||||
PORTADOWN_ON equ 0
|
||||
PORTATO_ON equ 1
|
||||
VIBRATO_ON equ 1
|
||||
PORTATOVOLSLIDE_ON equ 0
|
||||
VIBRATOVOLSLIDE_ON equ 0
|
||||
TREMOLO_ON equ 0
|
||||
SETPANPOSITION_ON equ 0
|
||||
SETSAMPLEOFFSET_ON equ 0
|
||||
VOLUMESLIDE_ON equ 0
|
||||
PATTERNJUMP_ON equ 1
|
||||
SETVOLUME_ON equ 0
|
||||
PATTERNBREAK_ON equ 0
|
||||
SETSPEED_ON equ 1
|
||||
SETGLOBALVOLUME_ON equ 0
|
||||
GLOBALVOLSLIDE_ON equ 0
|
||||
KEYOFF_ON equ 0
|
||||
SETENVELOPEPOS_ON equ 0
|
||||
PANSLIDE_ON equ 0
|
||||
MULTIRETRIG_ON equ 0
|
||||
TREMOR_ON equ 0
|
||||
EXTRAFINEPORTA_ON equ 0
|
||||
FINEPORTAUP_ON equ 0
|
||||
FINEPORTADOWN_ON equ 0
|
||||
SETVIBRATOWAVE_ON equ 0
|
||||
SETFINETUNE_ON equ 0
|
||||
PATTERNLOOP_ON equ 0
|
||||
SETTREMOLOWAVE_ON equ 0
|
||||
SETPANPOSITION16_ON equ 0
|
||||
RETRIG_ON equ 0
|
||||
NOTECUT_ON equ 1
|
||||
NOTEDELAY_ON equ 1
|
||||
PATTERNDELAY_ON equ 0
|
||||
PORTAUP_OR_DOWN_ON equ 0
|
||||
VIBRATO_OR_VOLSLIDE equ 1
|
||||
VIBRATO_OR_TREMOLO equ 1
|
||||
PORTATO_OR_VOLSLIDE equ 1
|
||||
VOLUME_OR_PANENVELOPE equ 1
|
||||
ROWCOMMANDS_ON equ 1
|
||||
FINEVOLUMESLIDE_ON equ 0
|
60
programs/develop/libraries/ufmod/media/mini.eff.inc
Normal file
60
programs/develop/libraries/ufmod/media/mini.eff.inc
Normal file
@ -0,0 +1,60 @@
|
||||
; XM-file: mini.xm
|
||||
|
||||
; uFMOD optional features:
|
||||
INFO_API_ON equ 0 ; disable InfoAPI
|
||||
NOLOOP_ON equ 0 ; disable XM_NOLOOP
|
||||
PAUSE_RESUME_ON equ 0 ; disable pause/resume and XM_SUSPENDED
|
||||
VOL_CONTROL_ON equ 0 ; disable volume control
|
||||
JUMP_TO_PAT_ON equ 0 ; disable Jump2Pattern
|
||||
XM_FILE_ON equ 0 ; disable file loading
|
||||
|
||||
; Special flags:
|
||||
INSTRUMENTVIBRATO_ON equ 0
|
||||
VOLUMEENVELOPE_ON equ 1
|
||||
PANENVELOPE_ON equ 0
|
||||
VOLUMEBYTE_ON equ 0
|
||||
ADPCM_ON equ 0
|
||||
AMIGAPERIODS_ON equ 0
|
||||
|
||||
; XM effects:
|
||||
ARPEGGIO_ON equ 0
|
||||
PORTAUP_ON equ 0
|
||||
PORTADOWN_ON equ 0
|
||||
PORTATO_ON equ 0
|
||||
VIBRATO_ON equ 0
|
||||
PORTATOVOLSLIDE_ON equ 0
|
||||
VIBRATOVOLSLIDE_ON equ 0
|
||||
TREMOLO_ON equ 0
|
||||
SETPANPOSITION_ON equ 0
|
||||
SETSAMPLEOFFSET_ON equ 0
|
||||
VOLUMESLIDE_ON equ 1
|
||||
PATTERNJUMP_ON equ 0
|
||||
SETVOLUME_ON equ 0
|
||||
PATTERNBREAK_ON equ 0
|
||||
SETSPEED_ON equ 0
|
||||
SETGLOBALVOLUME_ON equ 0
|
||||
GLOBALVOLSLIDE_ON equ 0
|
||||
KEYOFF_ON equ 0
|
||||
SETENVELOPEPOS_ON equ 0
|
||||
PANSLIDE_ON equ 0
|
||||
MULTIRETRIG_ON equ 0
|
||||
TREMOR_ON equ 0
|
||||
EXTRAFINEPORTA_ON equ 0
|
||||
FINEPORTAUP_ON equ 0
|
||||
FINEPORTADOWN_ON equ 0
|
||||
SETVIBRATOWAVE_ON equ 0
|
||||
SETFINETUNE_ON equ 0
|
||||
PATTERNLOOP_ON equ 1
|
||||
SETTREMOLOWAVE_ON equ 0
|
||||
SETPANPOSITION16_ON equ 0
|
||||
RETRIG_ON equ 0
|
||||
NOTECUT_ON equ 0
|
||||
NOTEDELAY_ON equ 0
|
||||
PATTERNDELAY_ON equ 0
|
||||
PORTAUP_OR_DOWN_ON equ 0
|
||||
VIBRATO_OR_VOLSLIDE equ 0
|
||||
VIBRATO_OR_TREMOLO equ 0
|
||||
PORTATO_OR_VOLSLIDE equ 0
|
||||
VOLUME_OR_PANENVELOPE equ 1
|
||||
ROWCOMMANDS_ON equ 1
|
||||
FINEVOLUMESLIDE_ON equ 0
|
BIN
programs/develop/libraries/ufmod/media/mini.xm
Normal file
BIN
programs/develop/libraries/ufmod/media/mini.xm
Normal file
Binary file not shown.
278
programs/develop/libraries/ufmod/nasm.asm
Normal file
278
programs/develop/libraries/ufmod/nasm.asm
Normal file
@ -0,0 +1,278 @@
|
||||
; NASM.ASM
|
||||
; --------
|
||||
; uFMOD public source code release. Provided as-is.
|
||||
|
||||
; *** This stub allows compiling uFMOD sources using NASM.
|
||||
; Everything documented in fasm stub!
|
||||
|
||||
; %error directive in NASM causes multiple prompts to appear due to
|
||||
; multiple passes :( So, we'd better avoid using %error.
|
||||
|
||||
ifdef f44100
|
||||
FSOUND_MixRate equ 44100
|
||||
FREQ_40HZ_p equ 1DB8Bh
|
||||
FREQ_40HZ_f equ 3B7160h
|
||||
PCM_format equ 3
|
||||
else
|
||||
ifdef f22050
|
||||
FSOUND_MixRate equ 22050
|
||||
FREQ_40HZ_p equ 3B716h
|
||||
FREQ_40HZ_f equ 76E2C0h
|
||||
PCM_format equ 9
|
||||
else
|
||||
FSOUND_MixRate equ 48000
|
||||
FREQ_40HZ_p equ 1B4E8h
|
||||
FREQ_40HZ_f equ 369D00h
|
||||
PCM_format equ 1
|
||||
endif
|
||||
endif
|
||||
|
||||
ifdef NONE
|
||||
RAMP_NONE equ 1
|
||||
RAMP_WEAK equ 0
|
||||
RAMP_STRONG equ 0
|
||||
else
|
||||
ifdef WEAK
|
||||
RAMP_NONE equ 0
|
||||
RAMP_WEAK equ 1
|
||||
RAMP_STRONG equ 0
|
||||
else
|
||||
RAMP_NONE equ 0
|
||||
RAMP_WEAK equ 0
|
||||
RAMP_STRONG equ 1
|
||||
endif
|
||||
endif
|
||||
|
||||
UCODE equ 0
|
||||
|
||||
ifdef NODEBUG
|
||||
DEBUG equ 0
|
||||
else
|
||||
DEBUG equ 1
|
||||
endif
|
||||
|
||||
ifdef UNSAFE
|
||||
CHK4VALIDITY equ 0
|
||||
AC97SND_ON equ 0
|
||||
else
|
||||
CHK4VALIDITY equ 1
|
||||
ifdef AC97SND
|
||||
AC97SND_ON equ 1
|
||||
else
|
||||
AC97SND_ON equ 0
|
||||
endif
|
||||
endif
|
||||
|
||||
ifndef NOLINKER
|
||||
%include "eff.inc"
|
||||
|
||||
[segment .text align=4]
|
||||
endif
|
||||
|
||||
STRUC FSOUND_SAMPLE
|
||||
FSOUND_SAMPLE._length resd 1
|
||||
FSOUND_SAMPLE.loopstart resd 1
|
||||
FSOUND_SAMPLE.looplen resd 1
|
||||
FSOUND_SAMPLE.defvol resb 1
|
||||
FSOUND_SAMPLE.finetune resb 1
|
||||
FSOUND_SAMPLE.bytes resb 1
|
||||
FSOUND_SAMPLE.defpan resb 1
|
||||
FSOUND_SAMPLE.relative resb 1
|
||||
FSOUND_SAMPLE.Resved resb 1
|
||||
FSOUND_SAMPLE.loopmode resb 1
|
||||
FSOUND_SAMPLE._align resb 1
|
||||
FSOUND_SAMPLE.buff resb 2
|
||||
ENDSTRUC
|
||||
|
||||
STRUC FSOUND_CHANNEL
|
||||
FSOUND_CHANNEL.actualvolume resd 1
|
||||
FSOUND_CHANNEL.actualpan resd 1
|
||||
FSOUND_CHANNEL.fsampleoffset resd 1
|
||||
FSOUND_CHANNEL.leftvolume resd 1
|
||||
FSOUND_CHANNEL.rightvolume resd 1
|
||||
FSOUND_CHANNEL.mixpos resd 1
|
||||
FSOUND_CHANNEL.speedlo resd 1
|
||||
FSOUND_CHANNEL.speedhi resd 1
|
||||
FSOUND_CHANNEL.ramp_lefttarget resw 1
|
||||
FSOUND_CHANNEL.ramp_righttarget resw 1
|
||||
FSOUND_CHANNEL.ramp_leftspeed resd 1
|
||||
FSOUND_CHANNEL.ramp_rightspeed resd 1
|
||||
FSOUND_CHANNEL.fsptr resd 1
|
||||
FSOUND_CHANNEL.mixposlo resd 1
|
||||
FSOUND_CHANNEL.ramp_leftvolume resd 1
|
||||
FSOUND_CHANNEL.ramp_rightvolume resd 1
|
||||
FSOUND_CHANNEL.ramp_count resw 1
|
||||
FSOUND_CHANNEL.speeddir resb 2
|
||||
ENDSTRUC
|
||||
|
||||
STRUC FMUSIC_NOTE
|
||||
FMUSIC_NOTE.unote resb 1
|
||||
FMUSIC_NOTE.number resb 1
|
||||
FMUSIC_NOTE.uvolume resb 1
|
||||
FMUSIC_NOTE.effect resb 1
|
||||
FMUSIC_NOTE.eparam resb 1
|
||||
ENDSTRUC
|
||||
|
||||
STRUC FMUSIC_PATTERN
|
||||
FMUSIC_PATTERN.rows resw 1
|
||||
FMUSIC_PATTERN.patternsize resw 1
|
||||
FMUSIC_PATTERN.data resd 1
|
||||
ENDSTRUC
|
||||
|
||||
STRUC FMUSIC_INSTRUMENT
|
||||
FMUSIC_INSTRUMENT.sample resd 16
|
||||
FMUSIC_INSTRUMENT.keymap resb 96
|
||||
FMUSIC_INSTRUMENT.VOLPoints resw 24
|
||||
FMUSIC_INSTRUMENT.PANPoints resw 24
|
||||
FMUSIC_INSTRUMENT.VOLnumpoints resb 1
|
||||
FMUSIC_INSTRUMENT.PANnumpoints resb 1
|
||||
FMUSIC_INSTRUMENT.VOLsustain resb 1
|
||||
FMUSIC_INSTRUMENT.VOLLoopStart resb 1
|
||||
FMUSIC_INSTRUMENT.VOLLoopEnd resb 1
|
||||
FMUSIC_INSTRUMENT.PANsustain resb 1
|
||||
FMUSIC_INSTRUMENT.PANLoopStart resb 1
|
||||
FMUSIC_INSTRUMENT.PANLoopEnd resb 1
|
||||
FMUSIC_INSTRUMENT.VOLtype resb 1
|
||||
FMUSIC_INSTRUMENT.PANtype resb 1
|
||||
FMUSIC_INSTRUMENT.VIBtype resb 1
|
||||
FMUSIC_INSTRUMENT.VIBsweep resb 1
|
||||
FMUSIC_INSTRUMENT.iVIBdepth resb 1
|
||||
FMUSIC_INSTRUMENT.VIBrate resb 1
|
||||
FMUSIC_INSTRUMENT.VOLfade resw 1
|
||||
ENDSTRUC
|
||||
|
||||
STRUC FMUSIC_CHANNEL
|
||||
FMUSIC_CHANNEL.note resb 1
|
||||
FMUSIC_CHANNEL.samp resb 1
|
||||
FMUSIC_CHANNEL.notectrl resb 1
|
||||
FMUSIC_CHANNEL.inst resb 1
|
||||
FMUSIC_CHANNEL.cptr resd 1
|
||||
FMUSIC_CHANNEL.freq resd 1
|
||||
FMUSIC_CHANNEL.volume resd 1
|
||||
FMUSIC_CHANNEL.voldelta resd 1
|
||||
FMUSIC_CHANNEL.freqdelta resd 1
|
||||
FMUSIC_CHANNEL.pan resd 1
|
||||
FMUSIC_CHANNEL.envvoltick resd 1
|
||||
FMUSIC_CHANNEL.envvolpos resd 1
|
||||
FMUSIC_CHANNEL.envvoldelta resd 1
|
||||
FMUSIC_CHANNEL.envpantick resd 1
|
||||
FMUSIC_CHANNEL.envpanpos resd 1
|
||||
FMUSIC_CHANNEL.envpandelta resd 1
|
||||
FMUSIC_CHANNEL.ivibsweeppos resd 1
|
||||
FMUSIC_CHANNEL.ivibpos resd 1
|
||||
FMUSIC_CHANNEL.keyoff resb 2
|
||||
FMUSIC_CHANNEL.envvolstopped resb 1
|
||||
FMUSIC_CHANNEL.envpanstopped resb 1
|
||||
FMUSIC_CHANNEL.envvolfrac resd 1
|
||||
FMUSIC_CHANNEL.envvol resd 1
|
||||
FMUSIC_CHANNEL.fadeoutvol resd 1
|
||||
FMUSIC_CHANNEL.envpanfrac resd 1
|
||||
FMUSIC_CHANNEL.envpan resd 1
|
||||
FMUSIC_CHANNEL.period resd 1
|
||||
FMUSIC_CHANNEL.sampleoffset resd 1
|
||||
FMUSIC_CHANNEL.portatarget resd 1
|
||||
FMUSIC_CHANNEL.patloopno resb 4
|
||||
FMUSIC_CHANNEL.patlooprow resd 1
|
||||
FMUSIC_CHANNEL.realnote resb 1
|
||||
FMUSIC_CHANNEL.recenteffect resb 1
|
||||
FMUSIC_CHANNEL.portaupdown resb 2
|
||||
FMUSIC_CHANNEL.xtraportadown resb 1
|
||||
FMUSIC_CHANNEL.xtraportaup resb 1
|
||||
FMUSIC_CHANNEL.volslide resb 1
|
||||
FMUSIC_CHANNEL.panslide resb 1
|
||||
FMUSIC_CHANNEL.retrigx resb 1
|
||||
FMUSIC_CHANNEL.retrigy resb 1
|
||||
FMUSIC_CHANNEL.portaspeed resb 1
|
||||
FMUSIC_CHANNEL.vibpos resb 1
|
||||
FMUSIC_CHANNEL.vibspeed resb 1
|
||||
FMUSIC_CHANNEL.vibdepth resb 1
|
||||
FMUSIC_CHANNEL.tremolopos resb 1
|
||||
FMUSIC_CHANNEL.tremolospeed resb 1
|
||||
FMUSIC_CHANNEL.tremolodepth resb 1
|
||||
FMUSIC_CHANNEL.tremorpos resb 1
|
||||
FMUSIC_CHANNEL.tremoron resb 1
|
||||
FMUSIC_CHANNEL.tremoroff resb 1
|
||||
FMUSIC_CHANNEL.wavecontrol resb 1
|
||||
FMUSIC_CHANNEL.finevslup resb 1
|
||||
FMUSIC_CHANNEL.fineportaup resb 1
|
||||
FMUSIC_CHANNEL.fineportadown resb 1
|
||||
ENDSTRUC
|
||||
|
||||
STRUC FMUSIC_MODULE
|
||||
FMUSIC_MODULE.pattern resd 1
|
||||
FMUSIC_MODULE.instrument resd 1
|
||||
FMUSIC_MODULE.mixer_samplesleft resd 1
|
||||
FMUSIC_MODULE.globalvolume resd 1
|
||||
FMUSIC_MODULE.tick resd 1
|
||||
FMUSIC_MODULE.speed resd 1
|
||||
FMUSIC_MODULE.order resd 1
|
||||
FMUSIC_MODULE.row resd 1
|
||||
FMUSIC_MODULE.patterndelay resd 1
|
||||
FMUSIC_MODULE.nextorder resd 1
|
||||
FMUSIC_MODULE.nextrow resd 1
|
||||
FMUSIC_MODULE.unused1 resd 1
|
||||
FMUSIC_MODULE.numchannels resd 1
|
||||
FMUSIC_MODULE.Channels resd 1
|
||||
FMUSIC_MODULE.uFMOD_Ch resd 1
|
||||
FMUSIC_MODULE.mixer_samplespertick resd 1
|
||||
FMUSIC_MODULE.numorders resw 1
|
||||
FMUSIC_MODULE.restart resw 1
|
||||
FMUSIC_MODULE.numchannels_xm resb 1
|
||||
FMUSIC_MODULE.globalvsl resb 1
|
||||
FMUSIC_MODULE.numpatternsmem resw 1
|
||||
FMUSIC_MODULE.numinsts resw 1
|
||||
FMUSIC_MODULE.flags resw 1
|
||||
FMUSIC_MODULE.defaultspeed resw 1
|
||||
FMUSIC_MODULE.defaultbpm resw 1
|
||||
FMUSIC_MODULE.orderlist resb 256
|
||||
ENDSTRUC
|
||||
|
||||
%macro PUBLIC 1
|
||||
ifndef NOLINKER
|
||||
GLOBAL %1
|
||||
endif
|
||||
%endmacro
|
||||
%define OFFSET
|
||||
%define PTR
|
||||
|
||||
include "ufmod.asm"
|
||||
include "core.asm"
|
||||
|
||||
ifdef NOLINKER
|
||||
uFMOD_IMG_END: ; End of uFMOD's code. BSS follows.
|
||||
align 16
|
||||
[segment .bss]
|
||||
else
|
||||
[segment .bss align=16]
|
||||
endif
|
||||
|
||||
_mod resb FMUSIC_MODULE_size
|
||||
mmt resd 3
|
||||
ufmod_heap resd 2
|
||||
if AC97SND_ON
|
||||
extern hSound
|
||||
resd 1
|
||||
else
|
||||
hSound resd 1
|
||||
endif
|
||||
hBuff resd 1
|
||||
SW_Exit resd 1
|
||||
MixBuf resb FSOUND_BlockSize*8
|
||||
ufmod_noloop resb 1
|
||||
ufmod_pause_ resb 1
|
||||
mix_endflag resb 2
|
||||
mmf resd 4
|
||||
ufmod_vol resd 1
|
||||
uFMOD_fopen resd 1
|
||||
uFMOD_fread resd 1
|
||||
file_struct resd 7
|
||||
cache_offset resd 1
|
||||
if INFO_API_ON
|
||||
time_ms resd 1
|
||||
L_vol resw 1
|
||||
R_vol resw 1
|
||||
s_row resw 1
|
||||
s_order resw 1
|
||||
szTtl resb 24
|
||||
endif
|
||||
DummySamp resb FSOUND_SAMPLE_size
|
33
programs/develop/libraries/ufmod/readme_en.htm
Normal file
33
programs/develop/libraries/ufmod/readme_en.htm
Normal file
File diff suppressed because one or more lines are too long
34
programs/develop/libraries/ufmod/readme_es.htm
Normal file
34
programs/develop/libraries/ufmod/readme_es.htm
Normal file
File diff suppressed because one or more lines are too long
33
programs/develop/libraries/ufmod/readme_ru.htm
Normal file
33
programs/develop/libraries/ufmod/readme_ru.htm
Normal file
File diff suppressed because one or more lines are too long
89
programs/develop/libraries/ufmod/ufmod-codec.h
Normal file
89
programs/develop/libraries/ufmod/ufmod-codec.h
Normal file
@ -0,0 +1,89 @@
|
||||
/*
|
||||
uFMOD API reference (AC97SND mode)
|
||||
=========================================================
|
||||
|
||||
NOTE: ufmod.obj should be rebuilt setting UF_MODE=AC97SND
|
||||
in order to make it usable in AC97SND player.
|
||||
|
||||
The Infinity Sound driver handle should be available as
|
||||
a public symbol named hSound. It is so when using Serge's
|
||||
sound.lib.
|
||||
*/
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/* HANDLE uFMOD_LoadSong(char *lpXM);
|
||||
---
|
||||
Description:
|
||||
---
|
||||
Loads the given XM song and starts playing it as soon as you
|
||||
call uFMOD_WaveOut for the first time. It will stop any
|
||||
currently playing song before loading the new one. Heap should
|
||||
be initialized before calling this function!
|
||||
---
|
||||
Parameters:
|
||||
---
|
||||
lpXM
|
||||
Specifies the filename of the song to load.
|
||||
---
|
||||
Return Values:
|
||||
---
|
||||
On success, returns a non zero value. Returns 0 on failure.
|
||||
*/
|
||||
int __cdecl uFMOD_LoadSong(char*);
|
||||
|
||||
/* int uFMOD_WaveOut(SNDBUF hBuff)
|
||||
---
|
||||
Description:
|
||||
---
|
||||
Updates the internal playback buffer.
|
||||
---
|
||||
Parameters:
|
||||
---
|
||||
hBuff
|
||||
The Infinity Sound buffer to update.
|
||||
---
|
||||
Remarks:
|
||||
---
|
||||
Playback doesn't actually begin when calling uFMOD_LoadSong,
|
||||
but when calling uFMOD_WaveOut after a successful uFMOD_LoadSong
|
||||
call. Afterwards, you should call uFMOD_WaveOut repeatedly at
|
||||
least once every 250 ms to prevent "buffer underruns".
|
||||
uFMOD_WaveOut is a non-blocking function.
|
||||
---
|
||||
Return Values:
|
||||
---
|
||||
Returns non zero on error.
|
||||
*/
|
||||
int __cdecl uFMOD_WaveOut(unsigned int);
|
||||
|
||||
/* void uFMOD_StopSong(void)
|
||||
---
|
||||
Description:
|
||||
---
|
||||
Stops the currently playing song, freeing the associated
|
||||
resources.
|
||||
---
|
||||
Remarks:
|
||||
---
|
||||
Does nothing if no song is playing at the time the call is made.
|
||||
*/
|
||||
void __cdecl uFMOD_StopSong();
|
||||
|
||||
/* unsigned char* _uFMOD_GetTitle(void)
|
||||
---
|
||||
Description:
|
||||
---
|
||||
Returns the current song's title.
|
||||
---
|
||||
Remarks:
|
||||
---
|
||||
Not every song has a title, so be prepared to get an empty string.
|
||||
*/
|
||||
unsigned char* __cdecl uFMOD_GetTitle();
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
1104
programs/develop/libraries/ufmod/ufmod.asm
Normal file
1104
programs/develop/libraries/ufmod/ufmod.asm
Normal file
File diff suppressed because it is too large
Load Diff
253
programs/develop/libraries/ufmod/ufmod.inc
Normal file
253
programs/develop/libraries/ufmod/ufmod.inc
Normal file
@ -0,0 +1,253 @@
|
||||
; uFMOD API reference (NORMAL/UNSAFE mode)
|
||||
; ====================================================================
|
||||
|
||||
; NOTE: All functions follow the cdecl calling convention!
|
||||
; _uFMOD_LoadSong
|
||||
; _uFMOD_WaveOut
|
||||
; _uFMOD_StopSong
|
||||
; _uFMOD_Jump2Pattern
|
||||
; _uFMOD_Pause
|
||||
; _uFMOD_Resume
|
||||
; _uFMOD_GetStats
|
||||
; _uFMOD_GetRowOrder
|
||||
; _uFMOD_GetTime
|
||||
; _uFMOD_GetTitle
|
||||
; _uFMOD_SetVolume
|
||||
|
||||
; ====================================================================
|
||||
; HANDLE _uFMOD_LoadSong(
|
||||
; void *lpXM,
|
||||
; void *param,
|
||||
; int fdwSong
|
||||
; )
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Loads the given XM song and starts playing it as soon as you
|
||||
; call _uFMOD_WaveOut for the first time. Playback won't begin
|
||||
; if XM_SUSPENDED flag is specified. It will stop any currently
|
||||
; playing song before loading the new one.
|
||||
; ---
|
||||
; Parameters:
|
||||
; ---
|
||||
; lpXM
|
||||
; Specifies the song to load. If this parameter is 0, any
|
||||
; currently playing song is stopped. In such a case, function
|
||||
; does not return a meaningful value. fdwSong parameter
|
||||
; determines whether this value is interpreted as a filename
|
||||
; or as a pointer to an image of the song in memory.
|
||||
; param
|
||||
; If XM_MEMORY is specified, this parameter should be the size
|
||||
; of the image of the song in memory.
|
||||
; If XM_FILE is specified, this parameter is ignored.
|
||||
; fdwSong
|
||||
; Flags for playing the song. The following values are defined:
|
||||
; XM_FILE lpXM points to filename. param is ignored.
|
||||
; XM_MEMORY lpXM points to an image of a song in memory.
|
||||
; param is the image size. Once, _uFMOD_LoadSong
|
||||
; returns, it's safe to free/discard the memory
|
||||
; buffer.
|
||||
; XM_NOLOOP An XM track plays repeatedly by default. Specify
|
||||
; this flag to play it only once.
|
||||
; XM_SUSPENDED The XM track is loaded in a suspended state,
|
||||
; and will not play until the _uFMOD_Resume function
|
||||
; is called. This is useful for preloading a song
|
||||
; or testing an XM track for validity.
|
||||
; ---
|
||||
; Return Values:
|
||||
; ---
|
||||
; On success, returns the handle of the Infinity Sound driver.
|
||||
; Returns 0 on failure.
|
||||
|
||||
; ====================================================================
|
||||
; int _uFMOD_WaveOut(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Updates the internal playback buffer.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; This function should be called from the same thread
|
||||
; _uFMOD_LoadSong was previously called. Playback doesn't actually
|
||||
; begin when calling _uFMOD_LoadSong, but when calling _uFMOD_WaveOut
|
||||
; after a successful _uFMOD_LoadSong call. Afterwards, you should
|
||||
; call _uFMOD_WaveOut repeatedly at least once every 250 ms to
|
||||
; prevent "buffer underruns".
|
||||
; _uFMOD_WaveOut is a non-blocking function. The accuracy of the
|
||||
; InfoAPI functions (_uFMOD_GetStats, _uFMOD_GetRowOrder and
|
||||
; _uFMOD_GetTime) depends on the periodicity of this function being
|
||||
; invoked.
|
||||
; ---
|
||||
; Return Values:
|
||||
; ---
|
||||
; Returns non zero on error.
|
||||
|
||||
; ====================================================================
|
||||
; void _uFMOD_StopSong(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Stops the currently playing song, freeing the associated
|
||||
; resources.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; Does nothing if no song is playing at the time the call is made.
|
||||
|
||||
; ====================================================================
|
||||
; void _uFMOD_Jump2Pattern(
|
||||
; unsigned int pat
|
||||
; )
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Jumps to the specified pattern index.
|
||||
; ---
|
||||
; Parameters:
|
||||
; ---
|
||||
; pat
|
||||
; Next zero based pattern index.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; uFMOD doesn't automatically perform Note Off effects before jumping
|
||||
; to the target pattern. In other words, the original pattern will
|
||||
; remain in the mixer until it fades out. You can use this feature to
|
||||
; your advantage. If you don't like it, just insert leading Note Off
|
||||
; commands in all patterns intended to be used as _uFMOD_Jump2Pattern
|
||||
; targets.
|
||||
; if the pattern index lays outside of the bounds of the pattern order
|
||||
; table, calling this function jumps to pattern 0, effectively
|
||||
; rewinding playback.
|
||||
|
||||
; ====================================================================
|
||||
; void _uFMOD_Pause(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Pauses the currently playing song, if any.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; While paused you can still control the volume (_uFMOD_SetVolume) and
|
||||
; the pattern order (_uFMOD_Jump2Pattern). The RMS volume coefficients
|
||||
; (_uFMOD_GetStats) will go down to 0 and the progress tracker
|
||||
; (_uFMOD_GetTime) will "freeze" while the song is paused.
|
||||
; _uFMOD_Pause doesn't perform the request immediately. Instead, it
|
||||
; signals to pause when playback reaches next chunk of data.
|
||||
; This way, _uFMOD_Pause performs asynchronously and returns very fast.
|
||||
; It is not cumulative. So, calling _uFMOD_Pause many times in a row
|
||||
; has the same effect as calling it once.
|
||||
; You shouldn't stop calling _uFMOD_WaveOut while the song is paused!
|
||||
|
||||
; ====================================================================
|
||||
; void _uFMOD_Resume(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Resumes the currently paused song, if any.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; _uFMOD_Resume doesn't perform the request immediately. Instead, it
|
||||
; signals to resume when _uFMOD_WaveOut is called again. _uFMOD_Resume
|
||||
; is not cumulative. So, calling it many times in a row has the same
|
||||
; effect as calling it once.
|
||||
|
||||
; ====================================================================
|
||||
; unsigned int _uFMOD_GetStats(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Returns the current RMS volume coefficients in (L)eft and (R)ight
|
||||
; channels.
|
||||
; low-order word: RMS volume in R channel
|
||||
; hi-order word: RMS volume in L channel
|
||||
; Range from 0 (silence) to $7FFF (maximum) on each channel.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; This function is useful for updating a VU meter. It's recommended
|
||||
; to rescale the output to log10 (decibels or dB for short), because
|
||||
; human ears track volume changes in a dB scale. You may call
|
||||
; _uFMOD_GetStats() as often as you like, but take in mind that uFMOD
|
||||
; updates both channel RMS volumes at the same rate _uFMOD_WaveOut
|
||||
; function is called. In other words, you should call _uFMOD_WaveOut
|
||||
; more often to increase the accuracy of _uFMOD_GetStats.
|
||||
|
||||
; ====================================================================
|
||||
; unsigned int _uFMOD_GetRowOrder(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Returns the currently playing row and order.
|
||||
; low-order word: row
|
||||
; hi-order word: order
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; This function is useful for synchronization. uFMOD updates both
|
||||
; row and order values at the same rate _uFMOD_WaveOut function is
|
||||
; called. In other words, you should call _uFMOD_WaveOut more often
|
||||
; to increase the accuracy of _uFMOD_GetRowOrder.
|
||||
|
||||
; ====================================================================
|
||||
; unsigned int _uFMOD_GetTime(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Returns the time in milliseconds since the song was started.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; This function is useful for synchronizing purposes. Multimedia
|
||||
; applications can use _uFMOD_GetTime to synchronize GFX to sound,
|
||||
; for example. An XM player can use this function to update a progress
|
||||
; meter.
|
||||
|
||||
; ====================================================================
|
||||
; unsigned char* _uFMOD_GetTitle(void)
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Returns the current song's title.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; Not every song has a title, so be prepared to get an empty string.
|
||||
|
||||
; ====================================================================
|
||||
; void _uFMOD_SetVolume(
|
||||
; unsigned int vol
|
||||
; )
|
||||
; ---
|
||||
; Description:
|
||||
; ---
|
||||
; Sets the global volume. The volume scale is linear.
|
||||
; ---
|
||||
; Parameters:
|
||||
; ---
|
||||
; vol
|
||||
; New volume. Range: from uFMOD_MIN_VOL (muting) to uFMOD_MAX_VOL
|
||||
; (maximum volume). Any value above uFMOD_MAX_VOL maps to maximum
|
||||
; volume.
|
||||
; ---
|
||||
; Remarks:
|
||||
; ---
|
||||
; uFMOD internally converts the given values to a logarithmic scale (dB).
|
||||
; Maximum volume is set by default. The volume value is preserved across
|
||||
; _uFMOD_LoadSong calls. You can set the desired volume level before
|
||||
; actually starting to play a song.
|
||||
; You can use Infinity Sound API to control the L and R channels volumes
|
||||
; separately. It also has a wider range than _uFMOD_SetVolume, sometimes
|
||||
; allowing to amplify the sound volume as well, as opposed to
|
||||
; _uFMOD_SetVolume only being able to attenuate it.
|
||||
|
||||
XM_MEMORY equ 1
|
||||
XM_FILE equ 2
|
||||
XM_NOLOOP equ 8
|
||||
XM_SUSPENDED equ 16
|
||||
uFMOD_MIN_VOL equ 0
|
||||
uFMOD_MAX_VOL equ 25
|
||||
uFMOD_DEFAULT_VOL equ 25
|
Loading…
Reference in New Issue
Block a user