add another part of the circle. now 1/4 circle done
This commit is contained in:
parent
c2a5af481f
commit
380728a80a
3 changed files with 60 additions and 1 deletions
|
@ -7,3 +7,7 @@
|
||||||
t2 = $E1
|
t2 = $E1
|
||||||
X_rel = radius
|
X_rel = radius
|
||||||
Y_rel = $E3
|
Y_rel = $E3
|
||||||
|
temp = $E4
|
||||||
|
temp_ = $E7
|
||||||
|
btp_mem_pos_center = $E5 ;; 16bit <fix>
|
||||||
|
btp_mem_pos_inv = $EE ;; 16bit <fix>
|
||||||
|
|
|
@ -19,16 +19,71 @@
|
||||||
LSR
|
LSR
|
||||||
STA t1
|
STA t1
|
||||||
|
|
||||||
|
|
||||||
|
draw_center_px_in_circle:
|
||||||
|
JSR pixel_draw
|
||||||
|
LDA btp_mem_pos
|
||||||
|
STA btp_mem_pos_center
|
||||||
|
LDA btp_mem_pos + 1
|
||||||
|
STA btp_mem_pos_center + 1
|
||||||
|
;; btp_mem_pos_center_two = 2*btp_mem_pos_center | used later for calculating btp_mem_pos_inv
|
||||||
|
btp_mem_pos_center_two = btp_mem_pos_center
|
||||||
|
Mult_16 btp_mem_pos_center, btp_mem_pos_center + 1
|
||||||
|
|
||||||
|
|
||||||
|
draw_right_px_in_circle:
|
||||||
|
CLC
|
||||||
|
LDA X_pos
|
||||||
|
ADC radius
|
||||||
|
STA X_pos
|
||||||
;; We only draw the first pixel using absolute position.
|
;; We only draw the first pixel using absolute position.
|
||||||
;; After that we use relative position.
|
;; After that we use relative position.
|
||||||
JSR pixel_draw
|
JSR pixel_draw
|
||||||
;; This sets byte_to_paint, btp_mem_pos and Y
|
;; This sets byte_to_paint, btp_mem_pos and Y
|
||||||
|
|
||||||
while_x_bigger_then_y:
|
while_x_bigger_then_y:
|
||||||
|
|
||||||
|
;STY temp
|
||||||
|
;LDY #$00
|
||||||
|
draw_pixel:
|
||||||
LDA byte_to_paint ;A byte containing a single 1. Coresponds to X position in the chunk.
|
LDA byte_to_paint ;A byte containing a single 1. Coresponds to X position in the chunk.
|
||||||
ORA (btp_mem_pos), Y
|
ORA (btp_mem_pos), Y
|
||||||
STA (btp_mem_pos), Y
|
STA (btp_mem_pos), Y
|
||||||
|
|
||||||
|
draw_pixel_inv:
|
||||||
|
SEC
|
||||||
|
LDA btp_mem_pos_center_two
|
||||||
|
SBC btp_mem_pos
|
||||||
|
STA btp_mem_pos_inv
|
||||||
|
LDA btp_mem_pos_center_two + 1
|
||||||
|
SBC btp_mem_pos + 1
|
||||||
|
STA btp_mem_pos_inv + 1
|
||||||
|
|
||||||
|
;; calculate the inverted y value Y = 7-Y
|
||||||
|
STY temp
|
||||||
|
LDA #$07
|
||||||
|
SEC
|
||||||
|
SBC temp
|
||||||
|
TAY
|
||||||
|
|
||||||
|
;; calculate byte_to_paint_inv (could be faster with lookup table)
|
||||||
|
LDA byte_to_paint
|
||||||
|
STA temp_
|
||||||
|
LDA #%10000000
|
||||||
|
jmp start_calc
|
||||||
|
calc:
|
||||||
|
LSR A
|
||||||
|
start_calc:
|
||||||
|
LSR temp_
|
||||||
|
BCC calc
|
||||||
|
|
||||||
|
; A = byte_to_paint_inv
|
||||||
|
ORA (btp_mem_pos_inv), Y
|
||||||
|
STA (btp_mem_pos_inv), Y
|
||||||
|
|
||||||
|
;;Recover the Y value (we changed it because evrything is inverted)
|
||||||
|
ldy temp
|
||||||
|
|
||||||
increment_y_pos:
|
increment_y_pos:
|
||||||
INC Y_rel ; y++
|
INC Y_rel ; y++
|
||||||
INY
|
INY
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
LDA #$50
|
LDA #$50
|
||||||
STA X_pos
|
STA X_pos
|
||||||
STA Y_pos
|
STA Y_pos
|
||||||
LDA #$55
|
LDA #$35
|
||||||
STA radius
|
STA radius
|
||||||
JSR circle
|
JSR circle
|
||||||
.endscope
|
.endscope
|
||||||
|
|
Loading…
Add table
Reference in a new issue