Skip to content

Commit 19e5eca

Browse files
committed
Merge pull request #39 from STRd6/bitblat
bitblat
2 parents fed64f3 + c17e0b2 commit 19e5eca

14 files changed

+534
-668
lines changed

TODO.md

Lines changed: 102 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,90 @@
11
TODO
22
====
33

4-
Transparancy Mode (index 0 or none)
4+
Opacity/Alpha
5+
6+
Polishing
7+
---------
8+
9+
Icons, Icon offsets for tools
10+
11+
Palette styling, editing palette colors
12+
13+
Preview window on large images
14+
15+
Thumbnail viewing mini-map rectangle
16+
17+
Responsive Design
18+
-----------------
19+
20+
Styling for mobile viewports.
21+
22+
Better Symmetry/Multi Modes
23+
---------------------------
24+
25+
Multiply events through symmetry so that flood fill and others
26+
can work better with symmetry modes.
27+
28+
Radial symmetry
29+
30+
Simple Replays
31+
--------------
32+
33+
Make sure replays can be saved and loaded
34+
35+
Vintage Replays
36+
---------------
37+
38+
Be able to display PixieEngine replays
39+
40+
Brush Options
41+
-------------
42+
43+
Should symmetry be a per-brush option, along with brush sizes, etc?
44+
45+
Memory Usage
46+
------------
47+
48+
Reduce memory usage in undo using dirty regions.
49+
50+
Platforms
51+
---------
52+
53+
Chrome Web Store
54+
Downloadable
55+
Others?
56+
57+
Promotional Media
58+
-----------------
59+
60+
Screenshots
61+
Promo images
62+
63+
Documentation
64+
-------------
65+
66+
Manual
67+
Tutorials
68+
Plugins
569

670
Bugs
771
----
872

73+
Eraser
74+
975
V2
10-
----
76+
====
77+
78+
True replays
79+
------------
80+
81+
Capture all user input as events, replay entire event stream.
82+
83+
Minimize Memory Footprint
84+
-------------------------
85+
86+
Use quadtrees for diffing regions in undo stack.
1187

12-
Selection Tool
1388

1489
Hot reload editor state / initial editor state
1590

@@ -19,8 +94,6 @@ Autosave
1994

2095
Analytics
2196

22-
Better Circle/Ellipse Tool
23-
2497
Layers
2598
Reorder Layers
2699
Delete Layers
@@ -50,6 +123,30 @@ Display transparent preview as transparent instead of white
50123

51124
Done
52125
====
126+
127+
Color Picker
128+
129+
Better performance
130+
------------------
131+
132+
Use true size canvas, not enlarged canvas. Avoid lots of pixel manipulation and
133+
let the canvas drawing functions do the work for us. Blit the 'work' canvas onto
134+
the active layer when the command completes.
135+
136+
Never call `repaint` on the whole editor, all the layers should always paint
137+
themselves, and only the regions necessary should be repainted.
138+
139+
Operate directly on imageData arrays where possible.
140+
141+
Better Circle Tool
142+
------------------
143+
144+
Calculate midpoint of [start, end], use that as center and radius as length/2
145+
146+
Selection Tool
147+
148+
Transparancy Mode (index 0 or none)
149+
53150
Prompt unsaved on exit
54151

55152
Palette

actions.coffee.md

Lines changed: 15 additions & 65 deletions
Original file line numberDiff line numberDiff line change
@@ -79,30 +79,23 @@ Actions
7979
8080
icon: ""
8181

82-
"ctrl+e":
83-
name: "Export"
84-
description: """
85-
Export image in a chunky size
86-
"""
87-
method: ({editor}) ->
88-
if name = prompt("File name", "image")
89-
if size = prompt("Pixel Size", 4)
90-
editor.outputCanvas(parseInt(size, 10)).toBlob (blob) ->
91-
saveAs blob, "#{name}.png"
92-
icon: ""
93-
9482
"ctrl+r":
9583
name: "Resize"
9684
description: """
9785
Resize
9886
"""
9987
method: ({editor}) ->
100-
{width, height} = editor.pixelExtent()
88+
{width, height} = size = editor.pixelExtent()
10189
10290
if newSize = prompt("New Size (WxH)", "#{width}x#{height}")
10391
[width, height] = newSize.split("x").map (v) -> parseInt v, 10
10492
105-
editor.execute editor.Command.Resize({width, height})
93+
command = editor.Command.Resize
94+
size: {width, height}
95+
sizePrevious: size
96+
imageDataPrevious: editor.getSnapshot()
97+
98+
editor.execute command
10699
107100
icon: ""
108101
@@ -112,12 +105,15 @@ Actions
112105
Clear image
113106
"""
114107
method: ({editor}) ->
115-
command = editor.Command.Composite()
116-
editor.execute command
108+
previous = editor.getSnapshot()
109+
editor.canvas.clear()
110+
111+
editor.execute editor.Command.PutImageData
112+
imageData: editor.getSnapshot()
113+
imageDataPrevious: previous
114+
x: 0
115+
y: 0
117116
118-
# Kind of a hack, just removing the top layer and adding a new one
119-
command.push editor.Command.RemoveLayer()
120-
command.push editor.Command.NewLayer()
121117
icon: ""
122118
123119
"+":
@@ -151,52 +147,6 @@ Actions
151147
editor.grid.toggle()
152148
icon: ""
153149
154-
"t":
155-
name: "Transparency Mode"
156-
description: """
157-
Toggle palette 0 transparent
158-
"""
159-
method: ({editor}) ->
160-
editor.execute editor.Command.ChangeTransparencyMode()
161-
icon: ""
162-
163-
"ctrl+shift+p":
164-
name: "Load Palette"
165-
description: """
166-
Load a JASC-PAL palette file (max 32 colors)
167-
"""
168-
method: ({editor}) ->
169-
Modal.show FileReading.readerInput
170-
accept: "*/*"
171-
image: (dataURL) ->
172-
# TODO: Load palette from image
173-
json: (data) ->
174-
# TODO: Load json palette
175-
alert "Unknown palette type"
176-
text: (text) ->
177-
if palette = Palette.load(text)
178-
# TODO: Check if palette is different from current palette
179-
editor.execute editor.Command.ChangePalette
180-
palette: palette
181-
else
182-
# TODO: Unknown palette type
183-
184-
chose: ->
185-
Modal.hide()
186-
icon: ""
187-
188-
"ctrl+shift+e":
189-
name: "Edit Palette"
190-
description: """
191-
Edit the color palette
192-
"""
193-
method: ({editor}) ->
194-
# Show palette editor text
195-
# Live update palette in image
196-
197-
$(".palette-editor").removeClass("hide").find("textarea").val editor.palette().join("\n")
198-
icon: ""
199-
200150
"f5":
201151
name: "Replay"
202152
description: """

command.coffee.md

Lines changed: 6 additions & 50 deletions
Original file line numberDiff line numberDiff line change
@@ -27,63 +27,19 @@ versions.
2727
2828
return command
2929
30-
C "ChangePalette", (data) ->
31-
data.previous ?= self.palette()
32-
33-
execute: ->
34-
self.palette data.palette
35-
36-
undo: ->
37-
self.palette data.previous
38-
39-
C "ChangePixel", (data) ->
40-
data.previous ?= self.getPixel(data).index
41-
42-
execute: ->
43-
self.changePixel(data)
44-
45-
undo: ->
46-
self.changePixel extend {}, data, index: data.previous
47-
48-
C "ChangeTransparencyMode", (data) ->
49-
data.previous ?= self.paletteZeroTransparent()
50-
51-
execute: ->
52-
self.paletteZeroTransparent !data.previous
53-
54-
undo: ->
55-
self.paletteZeroTransparent data.previous
56-
5730
C "Resize", (data) ->
58-
{width, height, state} = data
59-
60-
data.previous ?= self.pixelExtent()
61-
62-
state ?= self.layerState()
63-
6431
execute: ->
65-
self.resize(data)
32+
self.resize(data.size, data.imageData)
6633
6734
undo: ->
68-
self.restoreLayerState state
35+
self.resize(data.sizePrevious, data.imageDataPrevious)
6936
70-
C "NewLayer", (data) ->
37+
C "PutImageData", (data) ->
38+
# TODO: Layers?
7139
execute: ->
72-
self.newLayer(data)
73-
74-
undo: ->
75-
# TODO: May need to know layer index and previously active layer
76-
# index
77-
self.removeLayer(data)
78-
79-
C "RemoveLayer", (data) ->
80-
data.previous ?= self.layer().toJSON()
81-
82-
execute: ->
83-
self.removeLayer()
84-
40+
self.putImageData(data.imageData, data.x, data.y)
8541
undo: ->
86-
self.newLayer(data.previous)
42+
self.putImageData(data.imageDataPrevious, data.x, data.y)
8743
8844
C "Composite", (data) ->
8945
if data.commands

0 commit comments

Comments
 (0)