# Retro Sun (Processing)
# Part 1: Drawing the Sun
data:image/s3,"s3://crabby-images/6388d/6388d27a559d59c7c455da446c6bc9687162b4ae" alt=""
# Part 2: Drawing a color gradient on the sun
data:image/s3,"s3://crabby-images/aeaee/aeaee8195bb143c138483633c79e1c7e59e1343c" alt=""
Use the interpolateColor() method to find which color to change the pixel.
// Input variable 'step' is a value from 0.0 to 1.0, where
// 0.0 is the top of the sun and 1.0 is the bottom
interpolateColor(color[] arr, float step)
# Part 3: Drawing the missing sections at the bottom of the sun
data:image/s3,"s3://crabby-images/26e2f/26e2f40ff7c5c28449d5ffa08ccb6185c2064f21" alt=""
# Part 4: Moving the missing sun sections
data:image/s3,"s3://crabby-images/f67f7/f67f789edde6ad8e3b0dcf381cb87f65d11c82c6" alt=""
# Part 5: Managing the missing sun sections
data:image/s3,"s3://crabby-images/551b4/551b4248b508aec08cfccec06aa1a41cf3bd5798" alt=""
# Part 6: Adding reflections, stars, and other extras
data:image/s3,"s3://crabby-images/eba0b/eba0bfe251ccc55861d52a7dfaedcf8cdd526ca8" alt=""
class Star { int x; int y; color starColor; float startAlpha; float alpha; float diameter;
Star(int x, int y, color col) { this.x = x; this.y = y; starColor = col; this.diameter = random(0.1, 3); this.startAlpha = random(1, 200); this.alpha = startAlpha; }
void setAlpha(int alpha){ this.alpha = constrain(alpha, startAlpha, 255); }
void draw() { noStroke(); fill(starColor, alpha); float blink = random(0, 0.8); ellipse(x, y, diameter + blink, diameter + blink); }
class Reflection { /* // HSB colors color[] barColors = { color(285, 96.6, 23.1), color(312, 100, 42.7), color(340, 66.9, 60.4), color(11, 60.8, 62), color(340, 66.9, 60.4), color(312, 100, 42.7), color(285, 96.6, 23.1) }; */ // RGB colors color[] barColors = { color(45, 2, 59), color(109, 0, 88), color(154, 51, 86), color(158, 79, 62), color(154, 51, 86), color(109, 0, 88), color(45, 2, 59) };
int sunRadius; int numReflectionBars; int topX; int topY; int topWidth; int bottomY; int maxHeight; float speed; ArrayList lowerBars;
Reflection(int sunRadius, int numBars, int topX, int topY, float speed){ this.sunRadius = sunRadius; this.topX = topX; this.topY = topY; this.speed = speed;
initialize(numBars);
}
void initialize(int numBars){ this.numReflectionBars = numBars;
topWidth = 2 * (sunRadius + sunRadius/3);
maxHeight = 10;
bottomY = topY + (numBars * 2 * maxHeight);
lowerBars = new ArrayList();
// Setup bottom relection bars
int x = topX;
int y = topY;
int w = topWidth;
int h = maxHeight;
for ( int i = 0; i < numReflectionBars; i++ ) {
y += (bottomY - topY) / numBars;
x += sunRadius / 16;
w -= 2 * (sunRadius / 16);
Rectangle r = new Rectangle(x, y, w, h);
lowerBars.add(r);
}
}
void draw(){ strokeWeight(1);
for ( Rectangle bar : lowerBars ) {
for ( int i = (int)bar.x; i < bar.x + bar.w; i++ ) {
float alphaMax = -255 - (bar.y - topY);
float alphaMin = 255 + (bar.y - topY);
float alpha = map(i, bar.x, bar.x + bar.w, alphaMin, alphaMax);
float step = map(i, bar.x, bar.x + bar.w, 0, 1);
color lc = interpolateColor(barColors, step);
stroke(lc, 255 - abs(alpha));
line(i, bar.y, i, bar.y + bar.h);
}
bar.y += speed;
bar.x += speed;
bar.w -= 2 * speed;
if( bar.y > bottomY ) {
// Bar at bottom, reset to top
bar.x = topX;
bar.y = topY + maxHeight;
bar.w = topWidth;
bar.h = 1;
} else if( bar.y > bottomY - maxHeight ) {
// Bar near bottom
bar.h -= speed;
} else if( bar.h < maxHeight ) {
// Bar height just reset and at top
bar.y -= speed;
bar.h += speed;
}
}
} }