mirror of
https://github.com/Relintai/pandemonium_engine.git
synced 2025-01-25 02:27:18 +01:00
Ported LineAction.
This commit is contained in:
parent
61a8942070
commit
bafde8e9db
@ -31,46 +31,61 @@ SOFTWARE.
|
|||||||
void LineAction::do_action(PaintCanvas *canvas, const Array &data) {
|
void LineAction::do_action(PaintCanvas *canvas, const Array &data) {
|
||||||
PaintAction::do_action(canvas, data);
|
PaintAction::do_action(canvas, data);
|
||||||
|
|
||||||
/*
|
if (!mouse_start_pos_set) {
|
||||||
.do_action(canvas, data)
|
mouse_start_pos = data[0];
|
||||||
|
mouse_start_pos_set = true;
|
||||||
if mouse_start_pos == null:
|
|
||||||
mouse_start_pos = data[0]
|
|
||||||
|
|
||||||
action_data.preview.cells.clear()
|
|
||||||
action_data.preview.colors.clear()
|
|
||||||
canvas.clear_preview_layer()
|
|
||||||
|
|
||||||
var pixels = GEUtils.get_pixels_in_line(data[0], mouse_start_pos)
|
|
||||||
for pixel in pixels:
|
|
||||||
if canvas.is_alpha_locked() and canvas.get_pixel_v(pixel) == Color.transparent:
|
|
||||||
continue
|
|
||||||
|
|
||||||
canvas.set_preview_pixel_v(pixel, data[2])
|
|
||||||
action_data.preview.cells.append(pixel)
|
|
||||||
action_data.preview.colors.append(data[2])
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
preview_cells.resize(0);
|
||||||
|
preview_colors.resize(0);
|
||||||
|
canvas->clear_preview_layer();
|
||||||
|
|
||||||
|
PoolVector2iArray pixels = PaintUtilities::get_pixels_in_line(data[0], mouse_start_pos);
|
||||||
|
|
||||||
|
for (int i = 0; i < pixels.size(); ++i) {
|
||||||
|
Vector2i pixel = pixels[i];
|
||||||
|
|
||||||
|
Color col = canvas->get_pixel_v(pixel);
|
||||||
|
|
||||||
|
if (canvas->is_alpha_locked() && col.a < 0.00001) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
Color nc = data[2];
|
||||||
|
|
||||||
|
canvas->set_preview_pixel_v(pixel, nc);
|
||||||
|
|
||||||
|
preview_cells.append(pixel);
|
||||||
|
preview_colors.append(nc);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void LineAction::commit_action(PaintCanvas *canvas) {
|
void LineAction::commit_action(PaintCanvas *canvas) {
|
||||||
/*
|
canvas->clear_preview_layer();
|
||||||
canvas.clear_preview_layer()
|
|
||||||
var cells = action_data.preview.cells
|
|
||||||
var colors = action_data.preview.colors
|
|
||||||
for idx in range(cells.size()):
|
|
||||||
if canvas.get_pixel_v(cells[idx]) == null:
|
|
||||||
continue
|
|
||||||
action_data.undo.cells.append(cells[idx])
|
|
||||||
action_data.undo.colors.append(canvas.get_pixel_v(cells[idx]))
|
|
||||||
|
|
||||||
canvas.set_pixel_v(cells[idx], colors[idx])
|
for (int i = 0; i < preview_cells.size(); ++i) {
|
||||||
|
Vector2i pc = preview_cells[i];
|
||||||
|
|
||||||
action_data.redo.cells.append(cells[idx])
|
if (!canvas->validate_pixel_v(pc)) {
|
||||||
action_data.redo.colors.append(colors[idx])
|
continue;
|
||||||
mouse_start_pos = null
|
}
|
||||||
*/
|
|
||||||
|
Color pcol = preview_colors[i];
|
||||||
|
|
||||||
|
undo_cells.append(pc);
|
||||||
|
undo_colors.append(canvas->get_pixel_v(pc));
|
||||||
|
|
||||||
|
canvas->set_pixel_v(pc, pcol);
|
||||||
|
|
||||||
|
redo_cells.append(pc);
|
||||||
|
redo_colors.append(pcol);
|
||||||
|
}
|
||||||
|
|
||||||
|
mouse_start_pos_set = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
LineAction::LineAction() {
|
LineAction::LineAction() {
|
||||||
|
mouse_start_pos_set = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
LineAction::~LineAction() {
|
LineAction::~LineAction() {
|
||||||
|
@ -39,6 +39,7 @@ public:
|
|||||||
LineAction();
|
LineAction();
|
||||||
~LineAction();
|
~LineAction();
|
||||||
|
|
||||||
|
bool mouse_start_pos_set;
|
||||||
Vector2 mouse_start_pos;
|
Vector2 mouse_start_pos;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
Loading…
Reference in New Issue
Block a user