commit 7e5779cfc3b4cdec683191fe8c26d1ca51bc6aaa
parent 11a299778a49e17a34740abe401117f783740447
Author: neauoire <aliceffekt@gmail.com>
Date: Thu, 25 Mar 2021 09:24:26 -0700
Fixed mouse pickin g for noodle
Diffstat:
2 files changed, 57 insertions(+), 39 deletions(-)
diff --git a/projects/pictures/macpaint4020.bit b/projects/pictures/macpaint4020.bit
Binary files differ.
diff --git a/projects/software/noodle.usm b/projects/software/noodle.usm
@@ -41,7 +41,7 @@
;canvas { x1 2 y1 2 x2 2 y2 2 w 2 h 2 }
;rect { x1 2 y1 2 x2 2 y2 2 }
-;line { x0 2 y0 2 x 2 y 2 sx 2 sy 2 dx 2 dy 2 e1 2 e2 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 }
;color { byte 1 }
;pt0 { x 2 y 2 }
@@ -66,7 +66,7 @@
|0200 @RESET
( default canvas )
- #002a =canvas.w #001a =canvas.h
+ #0020 =canvas.w #0010 =canvas.h
( default brush )
#04 =brush.size
@@ -92,7 +92,7 @@
#0010 =pattpane.x1 ~Screen.height #0018 SUB2 =pattpane.y1
~Screen.width #0050 SUB2 =sizepane.x1 #0010 =sizepane.y1
- ~toolpane.x1 #0020 ADD2 =toolpane.x2
+ ~toolpane.x1 #0028 ADD2 =toolpane.x2
~toolpane.y1 #0008 ADD2 =toolpane.y2
,draw-toolpane JSR2
@@ -210,16 +210,20 @@ BRK
,$touch-end JMP2
$no-touch-brush
+ ,$no-touch-zoom ~brush.tool #04 NEQ JMP2?
+ ~zoom.active #00 EQU =zoom.active
+ ( release ) #00 =Mouse.state
+ ~Mouse.x ~canvas.x1 SUB2 ~canvas.w 2/ SUB2 =zoom.x
+ ~Mouse.y ~canvas.y1 SUB2 ~canvas.h 2/ SUB2 =zoom.y
+ ,redraw JSR2
+ ,$touch-end JMP2
+ $no-touch-zoom
+
$no-touch-canvas
( background interface )
,$no-touch-background ~Mouse.y STEP8 ~Screen.height #0010 SUB2 NEQ2 JMP2?
~Mouse.x ~Screen.width #0020 SUB2 SUB2 8/
- DUP2 #0000 NEQ2 ,$no-toggle-zoom ROT JMP2?
- ~zoom.active #00 EQU =zoom.active
- ( release ) #00 =Mouse.state
- ,redraw JSR2
- $no-toggle-zoom
DUP2 #0001 NEQ2 ,$no-load-button ROT JMP2?
,filepath ,load-file JSR2
,draw-canvas JSR2
@@ -262,6 +266,8 @@ BRK
( tool0 ) #02 =brush.tool ,draw-toolpane JSR2 $no-ekey
DUP #72 NEQ ,$no-rkey ROT JMP2?
( tool0 ) #03 =brush.tool ,draw-toolpane JSR2 $no-rkey
+ DUP #74 NEQ ,$no-tkey ROT JMP2?
+ ( tool0 ) #04 =brush.tool ,draw-toolpane JSR2 $no-tkey
DUP
DUP #30 GTH SWP #39 LTH #0101 NEQ2 ,$no-numkey ROT JMP2?
( size ) ~Keys #31 SUB =brush.size ,draw-sizepane JSR2 $no-numkey
@@ -311,23 +317,32 @@ RTN
@paint-line ( x1 y1 x2 y2 )
- ( load ) =line.y0 =line.x0 =line.y =line.x
- ~line.x0 ~line.x SUB2 ABS2 =line.dx
- ~line.y0 ~line.y SUB2 ABS2 #0000 SWP2 SUB2 =line.dy
- #ffff #00 ~line.x ~line.x0 LTS2 #0002 MUL2 ADD2 =line.sx
- #ffff #00 ~line.y ~line.y0 LTS2 #0002 MUL2 ADD2 =line.sy
+ ( load ) =line.y1 =line.x1 =line.y2 =line.x2
+
+ ( trim if zoomed )
+ ,$no-zoom ~zoom.active #01 NEQ JMP2?
+ ~line.x1 8/ ~zoom.x ADD2 =line.x1
+ ~line.y1 8/ ~zoom.y ADD2 =line.y1
+ ~line.x2 8/ ~zoom.x ADD2 =line.x2
+ ~line.y2 8/ ~zoom.y ADD2 =line.y2
+ $no-zoom
+
+ ~line.x1 ~line.x2 SUB2 ABS2 =line.dx
+ ~line.y1 ~line.y2 SUB2 ABS2 #0000 SWP2 SUB2 =line.dy
+ #ffff #00 ~line.x2 ~line.x1 LTS2 #0002 MUL2 ADD2 =line.sx
+ #ffff #00 ~line.y2 ~line.y1 LTS2 #0002 MUL2 ADD2 =line.sy
~line.dx ~line.dy ADD2 =line.e1
$loop
- ( paint ) ~line.x ~line.y ~brush.oper JSR2
- ,$end ~line.x ~line.x0 EQU2 ~line.y ~line.y0 EQU2 #0101 EQU2 JMP2?
+ ( paint ) ~line.x2 ~line.y2 ~brush.oper JSR2
+ ,$end ~line.x2 ~line.x1 EQU2 ~line.y2 ~line.y1 EQU2 #0101 EQU2 JMP2?
~line.e1 #0002 MUL2 =line.e2
,$skipy ~line.e2 ~line.dy LTS2 JMP2?
~line.e1 ~line.dy ADD2 =line.e1
- ~line.x ~line.sx ADD2 =line.x
+ ~line.x2 ~line.sx ADD2 =line.x2
$skipy
,$skipx ~line.e2 ~line.dx GTS2 JMP2?
~line.e1 ~line.dx ADD2 =line.e1
- ~line.y ~line.sy ADD2 =line.y
+ ~line.y2 ~line.sy ADD2 =line.y2
$skipx
,$loop JMP2
@@ -342,7 +357,19 @@ RTN
@paint-rect ( x1 y1 x2 y2 )
- ( load ) =rect.y2 =rect.x2 DUP2 =pt2.y =rect.y1 DUP2 =pt2.x =rect.x1
+ ( load ) =rect.y2 =rect.x2 =rect.y1 =rect.x1
+
+ ( trim if zoomed )
+ ,$no-zoom ~zoom.active #01 NEQ JMP2?
+ ~rect.x1 8/ ~zoom.x ADD2 =rect.x1
+ ~rect.y1 8/ ~zoom.y ADD2 =rect.y1
+ ~rect.x2 8/ ~zoom.x ADD2 #0001 ADD2 =rect.x2
+ ~rect.y2 8/ ~zoom.y ADD2 #0001 ADD2 =rect.y2
+ $no-zoom
+
+ ~rect.x1 =pt2.x
+ ~rect.y1 =pt2.y
+
$ver
~rect.x1 =pt2.x
$hor
@@ -351,9 +378,9 @@ RTN
( draw ) ~pt2.x ~pt2.y ~brush.oper JSR2
$no-pixel
( incr ) ~pt2.x ++ =pt2.x
- ,$hor ~pt2.x ~rect.x2 LTH2 JMP2?
+ ,$hor ~pt2.x ~rect.x2 LTS2 JMP2?
~pt2.y ++ =pt2.y
- ,$ver ~pt2.y ~rect.y2 LTH2 JMP2?
+ ,$ver ~pt2.y ~rect.y2 LTS2 JMP2?
,draw-canvas JSR2
,draw-toolpane JSR2
@@ -372,12 +399,6 @@ RTN
~pt0.y 8/ ~zoom.y ADD2 #0003 SUB2 =pt0.y
$no-zoom
- ( center zoom on paint )
- ,$no-follow ~zoom.active JMP2?
- ~pt0.x ~canvas.w 2/ SUB2 #0003 ADD2 =zoom.x
- ~pt0.y ~canvas.h 2/ SUB2 #0003 ADD2 =zoom.y
- $no-follow
-
#00 =px.x #00 =px.y
$ver
#00 =px.x
@@ -592,6 +613,12 @@ RTN
( incr ) ~Sprite.addr 8+ =Sprite.addr
,$tools ~Sprite.x ~toolpane.x2 LTH2 JMP2?
+ ,$no-zoom ~zoom.active #01 NEQ JMP2?
+ ~Sprite.x #0008 SUB2 =Sprite.x
+ ,tool_icn #0028 ADD2 =Sprite.addr
+ #01 #04 ~brush.tool EQU #02 MUL ADD =Sprite.color
+ $no-zoom
+
RTN
@draw-pattpane
@@ -657,11 +684,9 @@ RTN
,save_icn =Sprite.addr
#01 =Sprite.color
~Screen.width #0020 SUB2 =Sprite.x
- ,zoom_icn #00 ~zoom.active 8* ADD2 =Sprite.addr
- #01 =Sprite.color
( draw width )
- ~Screen.width #0048 SUB2 =Sprite.x
+ ~Screen.width #0040 SUB2 =Sprite.x
,font_hex ~canvas.w #f0 AND #04 SFT #08 MUL ADD2 =Sprite.addr
( draw ) #02 =Sprite.color
~Sprite.x 8+ =Sprite.x
@@ -735,11 +760,8 @@ RTN
[ e0d0 a844 2212 0c00 ]
[ c0b8 4848 7804 0200 ]
[ 44ba 4444 44ba 4400 ]
- [ 3844 8282 8244 3800 ]
- [ fe82 8282 8282 fe00 ]
- [ 80c0 e0f0 f8e0 1000 ]
- [ 0202 0438 4080 8000 ]
- [ 0204 0810 2040 8000 ]
+ [ 3048 8484 4834 0200 ] ( zoom )
+ [ 3245 8284 4834 0200 ] ( zoom out )
@brush_view
[ 0000 0010 0000 0000 ]
@@ -752,10 +774,6 @@ RTN
[ 7c82 8282 8282 7c00 ]
[ 7cfe fefe fefe 7c00 ]
-@zoom_icn
- [ 3048 8484 4834 0200 ]
- [ 3245 8284 4834 0200 ]
-
@bigpixel_icn
[ 5580 0080 0080 0080 ]
[ 55ff 7fff 7fff 7fff ]
@@ -768,7 +786,7 @@ RTN
@save_icn [ fe82 8282 848a f400 ]
@blank_icn [ 0000 0000 0000 0000 ]
-@filepath [ projects/pictures/tima2a1a.bit 00 ]
+@filepath [ projects/pictures/akane2010.bit 00 ]
@font_hex ( 0-F )
[