Я рекомендую использовать mask вместо изменения пикселей изображения. Создайте пустое изображение и свяжите его как маску с изображением:
img = loadImage("back.jpg");
front = loadImage("front.jpg");
mask = createImage(img.width, img.height, RGB);
img.mask(mask);
Если вы теперь рисуете оба изображения, то вы можете «видеть» только изображение front
:
image(front, 0, 0);
image(img, 0, 0);
Установите цвет маски (255, 255, 255) вместо изменения пикселя front
:
mask.pixels[loc] = color(255, 255, 255);
и повторно примените маску к изображению
img.mask(mask);
Когда кнопка мыши отпущена, пиксели маски необходимо изменить обратно на (0, 0, 0) или просто создать новую и пустую маску:
mask = createImage(img.width, img.height, RGB);
См. Пример, где я применил предложения к вашему исходному коду:
PImage img, front, mask;
int xstart, ystart, xend, yend;
int ray;
void setup() {
size(961, 534);
img = loadImage("back.jpg");
front = loadImage("front.jpg");
mask = createImage(img.width, img.height, RGB);
img.mask(mask);
xstart = 0;
ystart = 0;
xend = img.width;
yend = img.height;
ray = 50;
}
void draw() {
img.loadPixels();
front.loadPixels();
// loop over image pixels
for (int x = xstart; x < xend; x++) {
for (int y = ystart; y < yend; y++ ) {
int loc = x + y*img.width;
float dd = dist(mouseX, mouseY, x, y);
if (mousePressed && dd < 50) {
mask.pixels[loc] = color(255, 255, 255);
}
else {
if (!mousePressed) {
//mask = createImage(img.width, img.height, RGB);
mask.pixels[loc] = color(0, 0, 0);
}
}
}
}
mask.updatePixels();
img.mask(mask);
// show front image
image(front, 0, 0);
image(img, 0, 0);
}