I still have an impression you haven't figured out howIs there a way to get the rect() to be rendered before the draw() is complete?
& especially when Processing renders a screen frame!
data:image/s3,"s3://crabby-images/729a9/729a99da85688eeea66d18eb182e6ff1a92e26e2" alt=""
Every drawing you do is actually stored inside a PGraphics instance kept by variable g.
This is called a screen or blit buffer.
Only when draw() is finished, Processing calls a hidden function called run(),
which is therefore tasked to render a screen frame based on that PGraphics most current state!
What it means is that if you draw something that gets in the way of another drawing,
no 1 will notice that happening, for the screen stays still until the end of draw()!
data:image/s3,"s3://crabby-images/41c59/41c59bdf0980f025a1d86047c29cf69550ed9777" alt=""
Here's a post which dealt w/ something similar to yours:
http://forum.processing.org/topic/saveframe-only-capturing-background-image