commit 59cf8edecae3dab3493731d1a388a22f3bc7c146
parent c7644f90c195b984702973484b50faa42bf46e7a
Author: neauoire <aliceffekt@gmail.com>
Date: Sun, 28 Mar 2021 20:50:32 -0700
Various optimization to noodle
Diffstat:
1 file changed, 162 insertions(+), 197 deletions(-)
diff --git a/projects/software/noodle.usm b/projects/software/noodle.usm
@@ -22,20 +22,19 @@
%++ { #0001 ADD2 } %-- { #0001 SUB2 }
%2/ { #0001 SFT2 }
%8/ { #0003 SFT2 } %8* { #0030 SFT2 }
-%8+ { #0008 ADD2 } %8- { #0008 SUB2 }
+%8+ { #0008 ADD2 }
+%FILESIZE { ~canvas.w ~canvas.h MUL2 #0008 MUL2 }
( variables )
;cursor { x 2 y 2 x0 2 y0 2 dx 2 dy 2 }
;brush { tool 1 size 1 patt 1 drag 1 last 1 oper 2 }
;zoom { active 1 x 2 y 2 }
-( interface )
;toolpane { x1 2 y1 2 x2 2 y2 2 }
;pattpane { x1 2 y1 2 x2 2 y2 2 }
;sizepane { x1 2 y1 2 x2 2 y2 2 }
;viewpane { x1 2 y1 2 x2 2 y2 2 }
;canvas { x1 2 y1 2 x2 2 y2 2 w 2 h 2 }
-
;rect { x1 2 y1 2 x2 2 y2 2 }
;line { x1 2 y1 2 x2 2 y2 2 sx 2 sy 2 dx 2 dy 2 e1 2 e2 2 }
;origin { x1 2 y1 2 x2 2 y2 2 }
@@ -44,7 +43,8 @@
;pt1 { x 2 y 2 }
;pt2 { x 2 y 2 } ( paint-rect )
;px { x 1 y 1 }
-;document { state 1 edit 1 namelength 1 name 20 }
+;document { state 1 edit 1 }
+;path { length 1 name 20 }
;timer { byte 1 }
( devices )
@@ -52,53 +52,46 @@
|0100 ;Console { pad 8 char 1 byte 1 short 2 string 2 }
|0110 ;Screen { width 2 height 2 pad 4 x 2 y 2 color 1 }
|0120 ;Sprite { pad 8 x 2 y 2 addr 2 color 1 }
-|0130 ;Controller { buttons 1 }
+|0130 ;Controller { p1 1 }
|0140 ;Keys { key 1 }
|0150 ;Mouse { x 2 y 2 state 1 chord 1 }
|0160 ;File { pad 8 name 2 length 2 load 2 save 2 }
|01F0 ;System { pad 8 r 2 g 2 b 2 }
-
|0200 ,RESET JMP2
|0204 ,ERROR JMP2
|0208 ,FRAME JMP2
( program )
-@RESET
+@RESET ( -- )
- ( theme ) #e0fd =System.r #30fd =System.g #30fd =System.b
+ ( theme )
+ #e0fd =System.r #30fd =System.g #30fd =System.b
( default canvas )
#002a =canvas.w #001a =canvas.h
( default brush )
- #04 =brush.size
- #00 =brush.patt
- #00 =brush.tool
+ #04 =brush.size #00 =brush.patt #00 =brush.tool
( load file )
- ,document.name ,load-file JSR2
+ ,path.name ,load-file JSR2
( setup panes )
- #0010 =toolpane.x1 #0010 =toolpane.y1
- ~Screen.width #0050 SUB2 =pattpane.x1 #0010 =pattpane.y1
- #0040 =sizepane.x1 #0010 =sizepane.y1
- ~Screen.width #0078 SUB2 =viewpane.x1 #0010 =viewpane.y1
+ #0010 =toolpane.x1 #0010 =toolpane.y1 ~toolpane.x1 #0028 ADD2 =toolpane.x2 ~toolpane.y1 #0008 ADD2 =toolpane.y2
+ #0040 =sizepane.x1 #0010 =sizepane.y1 ~sizepane.x1 #0040 ADD2 =sizepane.x2 ~sizepane.y1 #0008 ADD2 =sizepane.y2
+ ~Screen.width #0078 SUB2 =viewpane.x1 #0010 =viewpane.y1 ~viewpane.x1 #0020 ADD2 =viewpane.x2 ~viewpane.y1 #0008 ADD2 =viewpane.y2
+ ~Screen.width #0050 SUB2 =pattpane.x1 #0010 =pattpane.y1 ~pattpane.x1 #0040 ADD2 =pattpane.x2 ~pattpane.y1 #0008 ADD2 =pattpane.y2
- ~toolpane.x1 #0028 ADD2 =toolpane.x2 ~toolpane.y1 #0008 ADD2 =toolpane.y2
- ~pattpane.x1 #0040 ADD2 =pattpane.x2 ~pattpane.y1 #0008 ADD2 =pattpane.y2
- ~sizepane.x1 #0040 ADD2 =sizepane.x2 ~sizepane.y1 #0008 ADD2 =sizepane.y2
- ~viewpane.x1 #0020 ADD2 =viewpane.x2 ~viewpane.y1 #0008 ADD2 =viewpane.y2
-
- ( center canvas )
+ ( ready. )
,center JSR2
,clear JSR2
BRK
-@FRAME
+@FRAME ( -- )
- ~document.edit #01 EQU ,on-document-edit JNZ2
+ ~document.edit #01 EQU ,on-rename JNZ2
,draw-cursor JSR2
@@ -108,10 +101,7 @@ BRK
~canvas.x1 -- ~canvas.y1 -- ~canvas.x2 ~canvas.y2 #10 ,line-rect JSR2
,draw-background JSR2
,fit-canvas JSR2
- ,draw-toolpane JSR2
- ,draw-pattpane JSR2
- ,draw-sizepane JSR2
- ,draw-viewpane JSR2
+ ,draw-foreground JSR2
#00 =brush.drag
$no-release
@@ -243,18 +233,17 @@ BRK
~Mouse.y STEP8 ~Screen.height #0010 SUB2 NEQ2 ^$no-touch-background JNZ
~Mouse.x ~Screen.width #0020 SUB2 SUB2 8/
DUP2 #0000 NEQ2 ^$no-clear-button JNZ
- ,center JSR2
,clear JSR2
#01 =document.edit
( release ) #00 =Mouse.state
$no-clear-button
DUP2 #0001 NEQ2 ^$no-load-button JNZ
- ,document.name ,load-file JSR2
+ ,path.name ,load-file JSR2
,draw-canvas JSR2
( release ) #00 =Mouse.state
$no-load-button
DUP2 #0002 NEQ2 ^$no-save-button JNZ
- ,document.name ,save-file JSR2
+ ,path.name ,save-file JSR2
( release ) #00 =Mouse.state
$no-save-button
POP2
@@ -265,16 +254,18 @@ BRK
$no-touch
- ~Controller.buttons #f0 AND
- DUP #04 SFT #01 AND #01 NEQ ^$no-up JNZ
- ( move ) ~zoom.y -- =zoom.y $no-up
- DUP #05 SFT #01 AND #01 NEQ ^$no-down JNZ
- ( move ) ~zoom.y ++ =zoom.y $no-down
- DUP #06 SFT #01 AND #01 NEQ ^$no-left JNZ
- ( move ) ~zoom.x -- =zoom.x $no-left
- DUP #07 SFT #01 AND #01 NEQ ^$no-right JNZ
- ( move ) ~zoom.x ++ =zoom.x $no-right
- #00 EQU #04 JNZ ,draw-canvas JSR2
+ ~Controller.p1 #00 EQU ,$no-ctrl JNZ2
+ ~Controller.p1 #f0 AND
+ DUP #04 SFT #01 AND #01 NEQ ^$no-up JNZ
+ ( move ) ~zoom.y -- =zoom.y $no-up
+ DUP #05 SFT #01 AND #01 NEQ ^$no-down JNZ
+ ( move ) ~zoom.y ++ =zoom.y $no-down
+ DUP #06 SFT #01 AND #01 NEQ ^$no-left JNZ
+ ( move ) ~zoom.x -- =zoom.x $no-left
+ DUP #07 SFT #01 AND #01 NEQ ^$no-right JNZ
+ ( move ) ~zoom.x ++ =zoom.x $no-right
+ #00 EQU #04 JNZ ,draw-canvas JSR2
+ $no-ctrl
~Keys #00 EQU ,$no-keys JNZ2
~Keys
@@ -305,44 +296,44 @@ BRK
BRK
-@on-document-edit
+@on-rename ( -- )
~Keys #00 EQU ,$no-keys JNZ2
- ~Keys #0d NEQ ,$no-enter JNZ2
+ ( enter )
+ ~Keys #0d NEQ ^$no-enter JNZ
#00 =document.edit
- ,redraw JSR2
- BRK
- $no-enter
- ~Keys #08 NEQ ,$no-backspace JNZ2
- ~document.namelength #00 EQU ,$end JNZ2
- ( incr ) ~document.namelength #01 SUB =document.namelength
- ,$end JSR2
- BRK
- $no-backspace
- ~document.namelength #1f EQU ,$end JNZ2
- ( store key ) ~Keys ,document.name #00 ~document.namelength ADD2 POK2
- ( incr ) ~document.namelength #01 ADD =document.namelength
- $end
- ( store end ) #00 ,document.name #00 ~document.namelength ADD2 POK2
- ( release ) #00 =Keys.key
+ ,redraw JSR2 BRK
+ $no-enter
+ ( backspace )
+ ~Keys #08 NEQ ^$no-backspace JNZ
+ ~path.length #00 EQU ^$end JNZ
+ ~path.length #01 SUB =path.length
+ ^$end JMP
+ $no-backspace
+ ( default )
+ ~path.length #1f EQU ^$end JNZ
+ ~Keys ,path.name #00 ~path.length ADD2 POK2
+ ~path.length #01 ADD =path.length
+ $end
+ #00 ,path.name #00 ~path.length ADD2 POK2
+ #00 =Keys.key
$no-keys
-
- ( move ) #0008 =Sprite.x ~Screen.height #0010 SUB2 =Sprite.y
- ( draw ) ,document.name #01 ~timer #04 DIV #03 AND #03 MUL ADD ,draw-label JSR2
-
- ~Sprite.x 8- =Sprite.x
+ ( draw )
+ #0008 =Sprite.x ~Screen.height #0010 SUB2 =Sprite.y
+ ,path.name #01 ~timer #04 DIV #03 AND #03 MUL ADD ,draw-label JSR2
$clear
- ~Sprite.x 8+ =Sprite.x
#00 =Sprite.color
- ~Sprite.x ~Screen.width LTH2 ^$clear JNZ
-
+ ~Sprite.x 8+ DUP2 =Sprite.x
+ ~Screen.width LTH2 ^$clear JNZ
+ ( blink timer )
~timer #01 ADD =timer
BRK
-@center
+@center ( -- )
- ( clear ) ~canvas.x1 #0002 SUB2 ~canvas.y1 #0002 SUB2 ~canvas.x2 #0002 ADD2 ~canvas.y2 #0002 ADD2 #00 ,fill-rect JSR2
+ ( clear old )
+ ~canvas.x1 #0002 SUB2 ~canvas.y1 #0002 SUB2 ~canvas.x2 #0002 ADD2 ~canvas.y2 #0002 ADD2 #00 ,fill-rect JSR2
,draw-background JSR2
@@ -351,40 +342,19 @@ BRK
,fit-canvas JSR2
- ,draw-toolpane JSR2
- ,draw-pattpane JSR2
- ,draw-sizepane JSR2
- ,draw-viewpane JSR2
+ ,draw-foreground JSR2
RTN
-@clear
+@clear ( -- )
- #00 =document.namelength
-
- ,untitled_txt ,document.name
- $rename
- ( copy src->dst ) OVR2 OVR2 SWP2 PEK2 ROT ROT POK2
- ( incr dst ) ++
- ( incr src ) SWP2 ++ SWP2
- ( incr len ) ~document.namelength #01 ADD =document.namelength
- OVR2 PEK2 #00 NEQ ^$rename JNZ
- #00 ROT ROT POK2 POP2
-
- ( erase old label )
- ~Screen.height #0010 SUB2 =Sprite.y
- #0000 =Sprite.x
- $erase
- ( draw ) #00 =Sprite.color
- ( incr ) ~Sprite.x ++ =Sprite.x
- ~Sprite.x ~Screen.width LTH2 ^$erase JNZ
-
- ,draw-background JSR2
-
- ( from ) ,data
- ( to ) ~canvas.w ~canvas.h MUL2 #0008 MUL2 ,data ADD2
+ ( new label )
+ ,untitled_txt ,path.name ,strcpy JSR2
+ #00 =path.length
+ ( erase data )
+ ,data FILESIZE ,data ADD2
$loop
- OVR2 #00 ROT ROT POK2
+ ( write ) OVR2 #00 ROT ROT POK2
( incr ) SWP2 #0001 ADD2 SWP2
OVR2 OVR2 LTH2 ^$loop JNZ
POP2 POP2
@@ -392,15 +362,15 @@ RTN
RTN
-@load-file ( path )
+@load-file ( path -- )
- =File.name ~canvas.w ~canvas.h MUL2 #0008 MUL2 =File.length ,data =File.load
+ =File.name FILESIZE =File.length ,data =File.load
RTN
-@save-file
+@save-file ( path -- )
- =File.name ~canvas.w ~canvas.h MUL2 #0008 MUL2 =File.length ,data =File.save
+ =File.name FILESIZE =File.length ,data =File.save
RTN
@@ -413,7 +383,7 @@ RTN
RTN
-@paint-line ( x1 y1 x2 y2 )
+@paint-line ( x1 y1 x2 y2 -- )
( load ) =line.y1 =line.x1 =line.y2 =line.x2
@@ -446,14 +416,11 @@ RTN
$end
,draw-canvas JSR2
- ,draw-toolpane JSR2
- ,draw-pattpane JSR2
- ,draw-sizepane JSR2
- ,draw-viewpane JSR2
+ ,draw-foreground JSR2
RTN
-@paint-rect ( x1 y1 x2 y2 )
+@paint-rect ( x1 y1 x2 y2 -- )
( load ) =rect.y2 =rect.x2 =rect.y1 =rect.x1
@@ -480,14 +447,11 @@ RTN
~pt2.y ~rect.y2 LTS2 ^$ver JNZ
,draw-canvas JSR2
- ,draw-toolpane JSR2
- ,draw-pattpane JSR2
- ,draw-sizepane JSR2
- ,draw-viewpane JSR2
+ ,draw-foreground JSR2
RTN
-@paint-brush ( x y )
+@paint-brush ( x y -- )
#0003 SUB2 =pt0.y #0003 SUB2 =pt0.x ( cursor offset )
@@ -512,14 +476,11 @@ RTN
~px.y #08 LTH ^$ver JNZ
,draw-canvas JSR2
- ,draw-toolpane JSR2
- ,draw-pattpane JSR2
- ,draw-sizepane JSR2
- ,draw-viewpane JSR2
+ ,draw-foreground JSR2
RTN
-@patternize
+@patternize ( -- )
~brush.patt #00 NEQ ^$noplain JNZ
#01 RTN
@@ -576,7 +537,7 @@ RTN
RTN
-@add-pixel ( x y )
+@add-pixel ( x y -- )
=pt1.y =pt1.x
( get tile addr ) ,data ~pt1.x 8/ ~pt1.y 8/ ~canvas.w MUL2 ADD2 8* ~pt1.y MOD8 ADD2 ADD2
@@ -586,7 +547,7 @@ RTN
RTN
-@remove-pixel ( x y )
+@remove-pixel ( x y -- )
=pt1.y =pt1.x
( get tile addr ) ,data ~pt1.x 8/ ~pt1.y 8/ ~canvas.w MUL2 ADD2 8* ~pt1.y MOD8 ADD2 ADD2
@@ -598,18 +559,15 @@ RTN
( Drawing )
-@redraw
+@redraw ( -- )
,draw-background JSR2
,draw-canvas JSR2
- ,draw-toolpane JSR2
- ,draw-pattpane JSR2
- ,draw-sizepane JSR2
- ,draw-viewpane JSR2
+ ,draw-foreground JSR2
RTN
-@draw-canvas
+@draw-canvas ( -- )
~zoom.active #01 EQU ,draw-canvas-zoom JNZ2
@@ -627,7 +585,7 @@ RTN
RTN
-@draw-canvas-zoom
+@draw-canvas-zoom ( -- )
~zoom.y =pt1.y
~canvas.y1 =Sprite.y
@@ -647,7 +605,7 @@ RTN
RTN
-@draw-cursor
+@draw-cursor ( -- )
~cursor.x ~Mouse.x NEQ2
~cursor.y ~Mouse.y NEQ2
@@ -657,54 +615,41 @@ RTN
#0101 EQU2 RTN? ( Return if unchanged )
,blank_icn =Sprite.addr
-
( clear brush size )
- ~cursor.x #0003 SUB2 =Sprite.x
- ~cursor.y #0003 SUB2 =Sprite.y
- #10 =Sprite.color
-
+ ~cursor.x #0003 SUB2 =Sprite.x ~cursor.y #0003 SUB2 =Sprite.y #10 =Sprite.color
( clear last cursor )
- ~cursor.x =Sprite.x
- ~cursor.y =Sprite.y
- #10 =Sprite.color
-
+ ~cursor.x =Sprite.x ~cursor.y =Sprite.y #10 =Sprite.color
( record cursor positions )
- ~Mouse.x =cursor.x
- ~Mouse.y =cursor.y
-
+ ~Mouse.x =cursor.x ~Mouse.y =cursor.y
( draw size cursor )
~brush.tool #01 NEQ ,$outside-canvas JNZ2
+ ( do not draw size when holding alt )
+ ~Controller #02 EQU ,$outside-canvas JNZ2
~Mouse.x CLN2r ~canvas.x1 GTH2 STH2r ~canvas.x2 LTH2 #0101 NEQ2 ,$outside-canvas JNZ2
~Mouse.y CLN2r ~canvas.y1 GTH2 STH2r ~canvas.y2 LTH2 #0101 NEQ2 ,$outside-canvas JNZ2
- ( do not draw size in toolpane )
- ~Mouse.x CLN2r ~toolpane.x1 GTH2 STH2r ~toolpane.x2 LTH2 #0101 EQU2 ~Mouse.y CLN2r ~toolpane.y1 GTH2 STH2r ~toolpane.y2 LTH2 #0101 EQU2 #0101 EQU2 ,$outside-canvas JNZ2
- ~Mouse.x CLN2r ~sizepane.x1 GTH2 STH2r ~sizepane.x2 LTH2 #0101 EQU2 ~Mouse.y CLN2r ~sizepane.y1 GTH2 STH2r ~sizepane.y2 LTH2 #0101 EQU2 #0101 EQU2 ,$outside-canvas JNZ2
- ~Mouse.x CLN2r ~pattpane.x1 GTH2 STH2r ~pattpane.x2 LTH2 #0101 EQU2 ~Mouse.y CLN2r ~pattpane.y1 GTH2 STH2r ~pattpane.y2 LTH2 #0101 EQU2 #0101 EQU2 ,$outside-canvas JNZ2
- ( do not draw size when holding alt )
- ~Controller #02 EQU ^$outside-canvas JNZ
- ~cursor.x #0003 SUB2 =Sprite.x
- ~cursor.y #0003 SUB2 =Sprite.y
+ ( do not draw size in toolpane )
+ ~Mouse.x CLN2r ~toolpane.x1 GTH2 STH2r ~toolpane.x2 LTH2 #0101 EQU2 ~Mouse.y CLN2r ~toolpane.y1 GTH2 STH2r ~toolpane.y2 LTH2 #0101 EQU2 #0101 EQU2 ,$outside-canvas JNZ2
+ ~Mouse.x CLN2r ~sizepane.x1 GTH2 STH2r ~sizepane.x2 LTH2 #0101 EQU2 ~Mouse.y CLN2r ~sizepane.y1 GTH2 STH2r ~sizepane.y2 LTH2 #0101 EQU2 #0101 EQU2 ,$outside-canvas JNZ2
+ ~Mouse.x CLN2r ~pattpane.x1 GTH2 STH2r ~pattpane.x2 LTH2 #0101 EQU2 ~Mouse.y CLN2r ~pattpane.y1 GTH2 STH2r ~pattpane.y2 LTH2 #0101 EQU2 #0101 EQU2 ,$outside-canvas JNZ2
+ ~cursor.x #0003 SUB2 =Sprite.x ~cursor.y #0003 SUB2 =Sprite.y
,brush_icns #00 ~brush.size 8* ADD2 =Sprite.addr
#11 ~Mouse.state #02 MUL ADD =Sprite.color
- ~Mouse.state #00 EQU ^$outside-canvas JNZ
- RTN
+ ~Mouse.state #00 EQU ^$outside-canvas JNZ RTN
$outside-canvas
-
- ~cursor.x =Sprite.x
- ~cursor.y =Sprite.y
+ ( draw new cursor )
+ ~cursor.x =Sprite.x ~cursor.y =Sprite.y
,pointers_icn #00 ~Controller #02 EQU 8* ADD2 =Sprite.addr
#1f =Sprite.color
RTN
-@draw-toolpane
+@draw-toolpane ( -- )
+ ( frame )
~toolpane.x1 -- ~toolpane.y1 -- ~toolpane.x2 ~toolpane.y2 #00 ,line-rect JSR2
~toolpane.x1 #0002 SUB2 ~toolpane.y1 #0002 SUB2 ~toolpane.x2 ~toolpane.y2 #01 ,line-rect JSR2
- ~toolpane.x1 =Sprite.x
- ~toolpane.y1 =Sprite.y
- ,tool_icns =Sprite.addr
+ ~toolpane.x1 =Sprite.x ~toolpane.y1 =Sprite.y ,tool_icns =Sprite.addr
$loop
( draw ) #01 ~Sprite.x ~toolpane.x1 SUB2 8/ SWP POP ~brush.tool EQU #02 MUL ADD =Sprite.color
@@ -716,18 +661,17 @@ RTN
~Sprite.x #0008 SUB2 =Sprite.x
,tool_icns #0028 ADD2 =Sprite.addr
#01 #04 ~brush.tool EQU #02 MUL ADD =Sprite.color
- $no-zoom
+ $no-zoom
RTN
-@draw-pattpane
+@draw-pattpane ( -- )
+ ( frame )
~pattpane.x1 -- ~pattpane.y1 -- ~pattpane.x2 ~pattpane.y2 #00 ,line-rect JSR2
~pattpane.x1 #0002 SUB2 ~pattpane.y1 #0002 SUB2 ~pattpane.x2 ~pattpane.y2 #01 ,line-rect JSR2
- ~pattpane.x1 =Sprite.x
- ~pattpane.y1 =Sprite.y
- ,patt_icns =Sprite.addr
+ ~pattpane.x1 =Sprite.x ~pattpane.y1 =Sprite.y ,patt_icns =Sprite.addr
$loop
( draw ) #01 ~Sprite.x ~pattpane.x1 SUB2 8/ SWP POP ~brush.patt EQU #02 MUL ADD =Sprite.color
@@ -737,14 +681,13 @@ RTN
RTN
-@draw-sizepane
-
+@draw-sizepane ( -- )
+
+ ( frame )
~sizepane.x1 -- ~sizepane.y1 -- ~sizepane.x2 ~sizepane.y2 #00 ,line-rect JSR2
~sizepane.x1 #0002 SUB2 ~sizepane.y1 #0002 SUB2 ~sizepane.x2 ~sizepane.y2 #01 ,line-rect JSR2
- ~sizepane.x1 =Sprite.x
- ~sizepane.y1 =Sprite.y
- ,size_icns =Sprite.addr
+ ~sizepane.x1 =Sprite.x ~sizepane.y1 =Sprite.y ,size_icns =Sprite.addr
$loop
( draw ) #01 ~Sprite.x ~sizepane.x1 SUB2 8/ SWP POP ~brush.size EQU #02 MUL ADD =Sprite.color
@@ -754,14 +697,13 @@ RTN
RTN
-@draw-viewpane
-
+@draw-viewpane ( -- )
+
+ ( frame )
~viewpane.x1 -- ~viewpane.y1 -- ~viewpane.x2 ~viewpane.y2 #00 ,line-rect JSR2
~viewpane.x1 #0002 SUB2 ~viewpane.y1 #0002 SUB2 ~viewpane.x2 ~viewpane.y2 #01 ,line-rect JSR2
- ~viewpane.x1 =Sprite.x
- ~viewpane.y1 =Sprite.y
- ,view_icns =Sprite.addr
+ ~viewpane.x1 =Sprite.x ~viewpane.y1 =Sprite.y ,view_icns =Sprite.addr
$loop
( draw ) #01 =Sprite.color
@@ -771,25 +713,21 @@ RTN
RTN
+@draw-foreground
+
+ ,draw-toolpane JSR2
+ ,draw-pattpane JSR2
+ ,draw-sizepane JSR2
+ ,draw-viewpane JSR2
+
+RTN
+
@draw-background
( draw hor line )
- #0000 =Screen.x ~Screen.height #0002 DIV2 =Screen.y
- #0000 ~Screen.width ( from/to )
- $draw-hor
- ( draw ) #01 =Screen.color
- ( incr ) SWP2 #0002 ADD2 DUP2 =Screen.x SWP2
- OVR2 OVR2 LTH2 ^$draw-hor JNZ
- POP2 POP2
-
+ #0000 ~Screen.width ~Screen.height #0002 DIV2 ,line-horizontal-dotted JSR2
( draw ver line )
- ~Screen.width #0002 DIV2 =Screen.x #0000 =Screen.y
- #0000 ~Screen.height ( from/to )
- $draw-ver
- ( draw ) #01 =Screen.color
- ( incr ) SWP2 #0002 ADD2 DUP2 =Screen.y SWP2
- OVR2 OVR2 LTH2 ^$draw-ver JNZ
- POP2 POP2
+ ~Screen.width #0002 DIV2 #0000 ~Screen.height ,line-vertical-dotted JSR2
( draw size )
#0010 =Sprite.y
@@ -803,32 +741,26 @@ RTN
( draw ) #01 =Sprite.color
~Sprite.x 8+ =Sprite.x ,font_hex ~canvas.h #0f AND #08 MUL ADD2 =Sprite.addr
( draw ) #01 =Sprite.color
-
( draw save/load/guides icons )
~Screen.height #0010 SUB2 =Sprite.y
-
~Screen.width #0020 SUB2 =Sprite.x
,filestate_icn =Sprite.addr
#01 =Sprite.color
-
~Sprite.x 8+ =Sprite.x
,load_icn =Sprite.addr
#01 =Sprite.color
-
~Sprite.x 8+ =Sprite.x
,save_icn =Sprite.addr
#01 =Sprite.color
-
- ( draw )
-
+ ( filename )
#0008 =Sprite.x
- ,document.name #01 ,draw-label JSR2
+ ,path.name #01 ,draw-label JSR2
RTN
( Generics )
-@line-rect ( x1 y1 x2 y2 color )
+@line-rect ( x1 y1 x2 y2 color -- )
( load ) =color =rect.y2 =rect.x2 DUP2 =Screen.y =rect.y1 DUP2 =Screen.x =rect.x1
$hor
@@ -845,7 +777,7 @@ RTN
RTN
-@fill-rect ( x1 y1 x2 y2 color )
+@fill-rect ( x1 y1 x2 y2 color -- )
( load ) =color =rect.y2 =rect.x2 DUP2 =Screen.y =rect.y1 DUP2 =Screen.x =rect.x1
$ver
@@ -859,7 +791,7 @@ RTN
RTN
-@draw-label ( addr )
+@draw-label ( addr -- )
=color
$loop
@@ -872,6 +804,39 @@ RTN
RTN
+@line-horizontal-dotted ( x0 x1 y -- )
+
+ =Screen.y OVR2 =Screen.x
+ $draw-hor
+ ( draw ) #01 =Screen.color
+ ( incr ) SWP2 #0002 ADD2 DUP2 =Screen.x SWP2
+ OVR2 OVR2 LTH2 ^$draw-hor JNZ
+ POP2 POP2
+
+RTN
+
+@line-vertical-dotted ( x y0 y1 -- )
+
+ STH2 SWP2 =Screen.x STH2r OVR2 =Screen.y
+ $draw-ver
+ ( draw ) #01 =Screen.color
+ ( incr ) SWP2 #0002 ADD2 DUP2 =Screen.y SWP2
+ OVR2 OVR2 LTH2 ^$draw-ver JNZ
+ POP2 POP2
+
+RTN
+
+@strcpy ( src* dst* -- )
+
+ $loop
+ ( copy src->dst ) OVR2 OVR2 SWP2 PEK2 ROT ROT POK2
+ ( incr dst ) ++
+ ( incr src ) SWP2 ++ SWP2
+ OVR2 PEK2 #00 NEQ ^$loop JNZ
+ #00 ROT ROT POK2 POP2
+
+RTN
+
@size_icns
[ 0000 0010 0000 0000 ]
[ 0000 1038 1000 0000 ]