home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Enigma Amiga Life 109
/
EnigmaAmiga109CD.iso
/
software
/
testi
/
corsoasm
/
sorgenti9
/
lezione15f6.s
< prev
next >
Wrap
Text File
|
1995-04-28
|
12KB
|
372 lines
; Lezione15f6.s Premere il tasto destro per attivare BRDRSPRT, che
; permette la visualizzazione dello sprite fuori dalla
; finestra video, definita di proposito piu' stretta
; del normale.
SECTION AgaRulez,CODE
; Include "DaWorkBench.s" ; togliere il ; prima di salvare con "WO"
*****************************************************************************
include "startup2.s" ; Salva Copperlist Etc.
*****************************************************************************
;5432109876543210
DMASET EQU %1000001110100000 ; copper, bitplane, sprite DMA
WaitDisk EQU 30 ; 50-150 al salvataggio (secondo i casi)
START:
; Puntiamo la PIC "vuota"
MOVE.L #BITPLANE,d0 ; dove puntare
LEA BPLPOINTERS,A1 ; puntatori COP
move.w d0,6(a1)
swap d0
move.w d0,2(a1)
; Puntiamo tutti gli sprite allo sprite nullo
MOVE.L #SpriteNullo,d0 ; indirizzo dello sprite in d0
LEA SpritePointers,a1 ; Puntatori in copperlist
MOVEQ #8-1,d1 ; tutti gli 8 sprite
NulLoop:
move.w d0,6(a1)
swap d0
move.w d0,2(a1)
swap d0
addq.w #8,a1
dbra d1,NulLoop
; Puntiamo lo sprite
MOVE.L #MIOSPRITE64,d0 ; indirizzo dello sprite in d0
LEA SpritePointers,a1 ; Puntatori in copperlist
move.w d0,6(a1)
swap d0
move.w d0,2(a1)
MOVE.W #DMASET,$96(a5) ; DMACON - abilita bitplane, copper
move.l #CopList,$80(a5) ; Puntiamo la nostra COP
move.w d0,$88(a5) ; Facciamo partire la COP
move.w #0,$1fc(a5) ; Fmode azzerato, burst normale
move.w #$c00,$106(a5) ; BPLCON3 resettato
move.w #$11,$10c(a5) ; BPLCON4 resettato
move.b $dff00a,mouse_y
move.b $dff00b,mouse_x
mouse:
MOVE.L #$1ff00,d1 ; bit per la selezione tramite AND
MOVE.L #$12000,d2 ; linea da aspettare = $120
Waity1:
MOVE.L 4(A5),D0 ; VPOSR e VHPOSR - $dff004/$dff006
ANDI.L D1,D0 ; Seleziona solo i bit della pos. verticale
CMPI.L D2,D0 ; aspetta la linea $120
BNE.S Waity1
bsr.s LeggiMouse ; questa legge il mouse
move.w sprite_y(pc),d0 ; prepara i parametri per la routine
move.w sprite_x(pc),d1 ; universale
lea miosprite64,a1 ; indirizzo sprite
moveq #52,d2 ; altezza sprite
bsr.w UniMuoviSprite64F ; chiama la routine universale
MOVE.L #$1ff00,d1 ; bit per la selezione tramite AND
MOVE.L #$12000,d2 ; linea da aspettare = $120
Aspetta:
MOVE.L 4(A5),D0 ; VPOSR e VHPOSR - $dff004/$dff006
ANDI.L D1,D0 ; Seleziona solo i bit della pos. verticale
CMPI.L D2,D0 ; aspetta la linea $120
BEQ.S Aspetta
btst.b #2,$dff016 ; Tasto destro premuto?
bne.s NonScambiareRes ; Se no non cambiare
bchg.b #1,BplCon3 ; Se si, cambia il BRDRSPRT.
NonScambiareRes:
btst.b #6,$bfe001 ; mouse premuto?
bne.s mouse
rts
; Questa routine legge il mouse e aggiorna i valori contenuti nelle
; variabili sprite_x e sprite_y
LeggiMouse:
move.b $dff00a,d1 ; JOY0DAT posizione verticale mouse
move.b d1,d0 ; copia in d0
sub.b mouse_y(PC),d0 ; sottrai vecchia posizione mouse
beq.s no_vert ; se la differenza = 0, il mouse e` fermo
ext.w d0 ; trasforma il byte in word
; (vedi alla fine del listato)
add.w d0,sprite_y ; modifica posizione sprite
no_vert:
move.b d1,mouse_y ; salva posizione mouse per la prossima volta
move.b $dff00b,d1 ; posizione orizzontale mouse
move.b d1,d0 ; copia in d0
sub.b mouse_x(PC),d0 ; sottrai vecchia posizione
beq.s no_oriz ; se la differenza = 0, il mouse e` fermo
ext.w d0 ; trasforma il byte in word
; (vedi alla fine del listato)
add.w d0,sprite_x ; modifica pos. sprite
no_oriz
move.b d1,mouse_x ; salva posizione mouse per la prossima volta
RTS
SPRITE_Y: dc.w 0 ; qui viene memorizzata la Y dello sprite
SPRITE_X: dc.w 0 ; qui viene memorizzata la X dello sprite
MOUSE_Y: dc.b 0 ; qui viene memorizzata la Y del mouse
MOUSE_X: dc.b 0 ; qui viene memorizzata la X del mouse
; Routine universale di posizionamento degli sprite larghi 64 pixel, con
; posizione X da 0 a 1280, che usa il nuovo scroll AGA ad 1/4 di pixel
;
; Parametri in entrata di UniMuoviSprite64F:
;
; a1 = Indirizzo dello sprite
; d0 = posizione verticale Y dello sprite sullo schermo (0-1280)
; d1 = posizione orizzontale X dello sprite sullo schermo (0-320)
; d2 = altezza dello sprite
;
UniMuoviSprite64F:
; posizionamento verticale
ADD.W #$2c,d0 ; aggiungi l'offset dell'inizio dello schermo
; a1 contiene l'indirizzo dello sprite
MOVE.b d0,(a1) ; copia il byte in VSTART
btst.l #8,d0
beq.s NonVSTARTSET
bset.b #2,3+4+2(a1) ; Setta il bit 8 di VSTART (numero > $FF)
bra.s ToVSTOP
NonVSTARTSET:
bclr.b #2,3+4+2(a1) ; Azzera il bit 8 di VSTART (numero < $FF)
ToVSTOP:
ADD.w D2,D0 ; Aggiungi l'altezza dello sprite per
; determinare la posizione finale (VSTOP)
move.b d0,2+4+2(a1) ; Muovi il valore giusto in VSTOP
btst.l #8,d0
beq.s NonVSTOPSET
bset.b #1,3+4+2(a1) ; Setta il bit 8 di VSTOP (numero > $FF)
bra.w VstopFIN
NonVSTOPSET:
bclr.b #1,3+4+2(a1) ; Azzera il bit 8 di VSTOP (numero < $FF)
VstopFIN:
; posizionamento orizzontale - qua ci sono le modifiche!!!
add.w #128*4,D1 ; 128*4 - per centrare lo sprite.
btst.l #0,D1 ; bit basso 0 della coordinata X azzerato?
beq.s BitBassoZERO
bset.b #3,3+4+2(a1) ; SH0 - Settiamo il bit piu' basso di HSTART
bra.w PlaceCoords1
BitBassoZERO:
bclr.b #3,3+4+2(a1) ; Azzeriamo il bit basso di HSTART
PlaceCoords1:
btst.l #1,D1 ; bit basso 1 della coordinata X azzerato?
beq.s BitBassoZERO1
bset.b #4,3+4+2(a1) ; SH1 - Settiamo il bit basso di HSTART
bra.w PlaceCoords2
BitBassoZERO1:
bclr.b #4,3+4+2(a1) ; SH1 - Azzeriamo il bit basso di HSTART
PlaceCoords2:
btst.l #2,D1 ; bit basso 2 della coordinata X azzerato?
beq.s BitBassoZERO2
bset.b #0,3+4+2(a1) ; SH2 - Settiamo il bit basso di HSTART
bra.w PlaceCoords3
BitBassoZERO2:
bclr.b #0,3+4+2(a1) ; SH2 - Azzeriamo il bit basso di HSTART
PlaceCoords3:
lsr.w #3,D1 ; SHIFTIAMO, ossia spostiamo di 1 bit a destra
; il valore di HSTART, per "trasformarlo" nel
; valore fa porre nel byte HSTART, senza cioe'
; i 3 bit bassi.
move.b D1,1(a1) ; Poniamo il valore XX nel byte HSTART
rts
;*****************************************************************************
;* COPPERLIST *
;*****************************************************************************
CNOP 0,8 ; Allineo a 64 bit
section coppera,data_C
COPLIST:
SpritePointers:
dc.w $120,0,$122,0,$124,0,$126,0,$128,0 ; SPRITE
dc.w $12a,0,$12c,0,$12e,0,$130,0,$132,0
dc.w $134,0,$136,0,$138,0,$13a,0,$13c,0
dc.w $13e,0
dc.w $8E,$5c81 ; DiwStrt
dc.w $90,$fcc1 ; DiwStop
dc.w $92,$0038 ; DdfStart
dc.w $94,$00d0 ; DdfStop
dc.w $102,0 ; BplCon1
dc.w $104,0 ; BplCon2
dc.w $108,-8 ; Bpl1Mod (burst 64bit, modulo=modulo-8)
dc.w $10a,-8 ; Bpl2Mod (come sopra)
; 5432109876543210
dc.w $100,%0001001000000001 ; 1 bitplane LORES 320x256.
dc.w $1fc,%1111 ; Burst mode a 64 bit, sprite larghi 64 pixel
BPLPOINTERS:
dc.w $e0,0,$e2,0 ; primo bitplane
dc.w $e4,0,$e6,0 ; secondo "
dc.w $e8,0,$ea,0 ; terzo "
dc.w $ec,0,$ee,0 ; quarto "
dc.w $f0,0,$f2,0 ; quinto "
dc.w $f4,0,$f6,0 ; sesto "
dc.w $f8,0,$fA,0 ; settimo "
dc.w $fC,0,$fE,0 ; ottavo "
; Da notare che i colori dello sprite sono a 24 bit, anche se sono solo 3.
DC.W $106,$c00 ; SELEZIONA PALETTE 0 (0-31), NIBBLE ALTI
COLP0:
dc.w $180,$000 ; color0 ; sfondo nero
dc.w $182,$123 ; color1 ; colore 1 del bitplane, che
; in questo caso e' vuoto,
; per cui non compare.
dc.w $1A2,$F00 ; color17, ossia COLOR1 dello sprite0 - ROSSO
dc.w $1A4,$0F0 ; color18, ossia COLOR2 dello sprite0 - VERDE
dc.w $1A6,$FF0 ; color19, ossia COLOR3 dello sprite0 - GIALLO
DC.W $106,$e00 ; SELEZIONA PALETTE 0 (0-31), NIBBLE BASSI
COLP0B:
dc.w $180,$000 ; color0 ; sfondo nero
dc.w $182,$000 ; color1 ; colore 1 del bitplane, che
; in questo caso e' vuoto,
; per cui non compare.
dc.w $1A2,$462 ; color17, nibble bassi
dc.w $1A4,$2e4 ; color18, nibble bassi
dc.w $1A6,$672 ; color19, nibble bassi
dc.w $106 ; BPLCON3
dc.b 0
BplCon3:
; 76543210
dc.b %00000000 ; bit 7: sprites hires o lowres. Se si
; settano sia il bit 7 che il bit 6 lo sprite
; e' in superhires (1280x256), ma viene troppo
; "stretto", credo sia inutile, basta hires!
dc.w $FFFF,$FFFE ; Fine della copperlist
;*****************************************************************************
;************ Ecco gli sprite: OVVIAMENTE devono essere in CHIP RAM! *********
;*****************************************************************************
cnop 0,8
SpriteNullo: ; Sprite nullo da puntare in copperlist
dc.l 0,0,0,0 ; negli eventuali puntatori inutilizzati
cnop 0,8
MIOSPRITE64: ; lunghezza 13*4 linee
VSTART:
dc.b $50 ; Posizione verticale di inizio sprite (da $2c a $f2)
HSTART:
dc.b $90 ; Posizione orizzontale di inizio sprite (da $40 a $d8)
dc.w 0 ; Word + longword aggiunte per raggiungere la doppia
dc.l 0 ; longword nello sprite largo 64 pixel (2 long!)
VSTOP:
dc.b $5d ; $50+13=$5d ; posizione verticale di fine sprite
VHBITS:
dc.b $00 ; bit
dc.w 0 ; Word + longword aggiunte per raggiungere la doppia
dc.l 0 ; longword nello sprite largo 64 pixel (2 long!)
dc.l $00000000,$00000000,$00003000,$000c0000 ; Salvato con PicCon
dc.l $00000000,$00000000,$00003800,$001c0000
dc.l $00000000,$00000000,$00001c00,$00380000
dc.l $00000000,$00000000,$00000e00,$00700000
dc.l $00000000,$00000000,$00000700,$00e00000
dc.l $00000000,$00000000,$00000380,$01c00000
dc.l $00000000,$00000000,$000001c0,$03800000
dc.l $00000000,$00000000,$000000e0,$07000000
dc.l $00000000,$00000000,$00000070,$0e000000
dc.l $00000000,$00000000,$00000038,$1c000000
dc.l $00000000,$00000000,$00000038,$1c000000
dc.l $00000000,$00000000,$0000001c,$38000000
dc.l $0000000f,$f0000000,$000f001f,$f800f000
dc.l $0000003f,$fc000000,$003f003f,$fc00fc00
dc.l $0000007f,$fe000000,$007c007f,$fe003e00
dc.l $000000ff,$ff000000,$00f800ff,$ff001f00
dc.l $000001ff,$ff800000,$01f001ff,$ff800f80
dc.l $000003ff,$ffc00000,$03e003ff,$ffc007c0
dc.l $000007ff,$ffe00000,$07c007ff,$ffe003e0
dc.l $00000fff,$fff00000,$0f800fff,$fff001f0
dc.l $00001fff,$fff80000,$1f001c3f,$fc3800f8
dc.l $00003fff,$fffc0000,$3e00381f,$f81c007c
dc.l $00003fff,$fffc0000,$7c00300f,$f00c003e
dc.l $00007fff,$fffe0000,$fc00700f,$f00e003f
dc.l $00007f8f,$f1fe0000,$fffff00f,$f00fffff
dc.l $00007f0f,$f0fe0000,$fffff00f,$f00fffff
dc.l $00007f0f,$f0fe0000,$fffff80f,$f01fffff
dc.l $00007f1f,$f8fe0000,$7ffffc1f,$f83ffffe
dc.l $00003fff,$fffc0000,$00003fff,$fffc0000
dc.l $00003fff,$fffc0000,$00003fff,$fffc0000
dc.l $00001fff,$fff80000,$00007fff,$fffe0000
dc.l $00001fff,$fff80000,$0000ffff,$ffff0000
dc.l $00000fff,$fff00000,$0001ff80,$01ff8000
dc.l $00000fff,$fff00000,$0003ffc0,$03ffc000
dc.l $000007ff,$ffe00000,$0007ffe0,$07ffe000
dc.l $000003ff,$ffc00000,$0007fff0,$0fffe000
dc.l $000001ff,$ff800000,$000ff1ff,$ff8ff000
dc.l $000001ff,$ff800000,$001fe1ff,$ff87f800
dc.l $000000ff,$ff000000,$003fc0ff,$ff03fc00
dc.l $0000007f,$fe000000,$003fc07f,$fe03fc00
dc.l $0000003f,$fc000000,$007f803f,$fc01fe00
dc.l $0000001f,$f8000000,$007f801f,$f801fe00
dc.l $0000000f,$f0000000,$00ff000f,$f000ff00
dc.l $00000003,$c0000000,$00ff0003,$c000ff00
dc.l $00000000,$00000000,$03fe0000,$00007fc0
dc.l $00000000,$00000000,$0ffe0000,$00007ff0
dc.l $00000000,$00000000,$3ffe0000,$00007ffc
dc.l $00000000,$00000000,$7fff0000,$0000fffe
dc.l $00000000,$00000000,$ffff0000,$0000ffff
dc.l $00000000,$00000000,$ffff8000,$0001ffff
dc.l $00000000,$00000000,$ffff8000,$0001ffff
dc.l $00000000,$00000000,$ffff8000,$0001ffff
dc.l 0,0,0,0 ; Fine dello sprite (2 doppie longword).
cnop 0,8
SECTION PLANEVUOTO,BSS_C ; Il bitplane azzerato che usiamo,
; perche' per vedere gli sprite
; e' necessario che ci siano bitplanes
; abilitati
BITPLANE:
ds.b 40*256 ; bitplane azzerato lowres
end
Basta settare il bit magico, e gli sprite si possono muovere veramente in modo
indipendente dallo schermo, dato che non vengono "tagliati" dalla fine della
finestra video, e possono essere visualizzata anche se i bitplanes sono
disabilitati! Una liberazione degli sprites dalla schiavitu' del bplcon0 e dei
diwstart/diwstop!