Cleaned up my original prototype render_paint_node implementation. Now it's fast.

This commit is contained in:
Relintai 2022-11-20 02:44:27 +01:00
parent 240bfa8ed5
commit fcdce8336c

View File

@ -107,45 +107,25 @@ void PaintNode::render_paint_node(PaintNode *node, Transform2D transform, Ref<Im
Vector2i save_image_size = save_image->get_size(); Vector2i save_image_size = save_image->get_size();
Vector2i image_size = image->get_size(); Vector2i image_size = image->get_size();
// NOTE: this is EXTREMELY inefficient, and slow, however it does work for now.
// It will be rewritten soon.
Vector2 p0 = transform.xform(Vector2(0, 0)); Vector2 p0 = transform.xform(Vector2(0, 0));
Vector2 p1 = transform.xform(Vector2(0, save_image_size.y)); Vector2 p1 = transform.xform(Vector2(0, save_image_size.y));
Vector2 p2 = transform.xform(Vector2(save_image_size.x, 0)); Vector2 p2 = transform.xform(Vector2(save_image_size.x, 0));
Vector2 p3 = transform.xform(Vector2(save_image_size.x, save_image_size.y)); Vector2 p3 = transform.xform(Vector2(save_image_size.x, save_image_size.y));
Vector<Point2i> queued_points = Geometry::brenzenham_line(p0.x, p1.x, p0.y, p1.y); Rect2i bound(p0, Vector2());
queued_points.append_array(Geometry::brenzenham_line(p1.x, p3.x, p1.y, p3.y)); bound.expand_to(p1);
queued_points.append_array(Geometry::brenzenham_line(p2.x, p3.x, p2.y, p3.y)); bound.expand_to(p2);
queued_points.append_array(Geometry::brenzenham_line(p0.x, p2.x, p0.y, p2.y)); bound.expand_to(p3);
bound.grow(1);
Vector<Point2i> points_to_check;
for (int i = 0; i < queued_points.size(); ++i) {
Point2i p = queued_points[i];
Vector<Point2i> points = Geometry::brenzenham_line(p0.x, p.x, p0.y, p.y);
points.append_array(Geometry::brenzenham_line(p3.x, p.x, p3.y, p.y));
points.append_array(Geometry::brenzenham_line(p2.x, p.x, p2.y, p.y));
points.append_array(Geometry::brenzenham_line(p1.x, p.x, p1.y, p.y));
for (int j = 0; j < points.size(); ++j) {
Point2i pc = points[j];
if (points_to_check.find(pc) == -1) {
points_to_check.push_back(pc);
}
}
}
Transform2D inverse = transform.affine_inverse(); Transform2D inverse = transform.affine_inverse();
save_image->lock(); save_image->lock();
image->lock(); image->lock();
for (int i = 0; i < points_to_check.size(); ++i) { for (int x = bound.position.x; x < bound.position.x + bound.size.x; ++x) {
Point2i p = points_to_check[i]; for (int y = bound.position.y; y < bound.position.y + bound.size.y; ++y) {
Point2i p = Point2i(x, y);
if (p.x < 0 || p.y < 0 || p.x >= image_size.x || p.y >= image_size.y) { if (p.x < 0 || p.y < 0 || p.x >= image_size.x || p.y >= image_size.y) {
continue; continue;
@ -162,6 +142,7 @@ void PaintNode::render_paint_node(PaintNode *node, Transform2D transform, Ref<Im
image->set_pixel(p.x, p.y, oic.blend(sic)); image->set_pixel(p.x, p.y, oic.blend(sic));
} }
}
image->unlock(); image->unlock();
save_image->unlock(); save_image->unlock();