AutoHotkey | Android | Arduino | COMM140 | Fractals | Grammar Checkers | Knots | A Million Dots Activity | Processing | Processing for Scratch Users | Redbubble | Tutorials | Weather | World Time Meeting Planner | Favicon Generator.
Home > Tutorials > Processing > Processing Examples > Evolution of Xanthoria 001 > Evolution of Xanthorrhoea 001_4
Comments:
Added a fower stem and head as well as the ability to change colour of tree
Note the stem should be drawn from the center of the top of the trunk this is still not quite right.
// Author: Rupert Russell // Title: xanthorrhoea 001.4 // Date: October 21, 2010 // global vairables float min_x1 = 0; float max_x2 = 0; float center_of_trunk; void setup() { size(300, 300); smooth(); noLoop(); } // end of viod setup void draw() { int trunk_width; int trunk_height; float lean; int start_x; int start_y; int colour; // draw first trunk trunk_width = 25; trunk_height = 150; lean = 0; start_x = width /4; start_y = height - 20; colour = 60; xanthorrhoea(trunk_width, trunk_height, lean, start_x, start_y, colour); // draw second trunk trunk_width = 24; trunk_height = 170; lean = -0.1; start_x = width /2; start_y = height; colour = 110; xanthorrhoea(trunk_width, trunk_height, lean, start_x, start_y, colour); } // end void draw() void xanthorrhoea(int trunk_width, int trunk_height, float lean, int start_x, int start_y, int colour){ // draw trunk float step = 0.5; float x1; float y1; float x2; float y2; float y_stem; float x_stem; for (int counter = 0; counter < trunk_height; counter ++){ // generate random values for trunk stroke(colour); strokeWeight(random(0.2, 2)); float rand_y = random(0.2, 5); float rand_x = random(10); x1 = start_x + rand_x + (lean * counter); // apply a lean to the trunk y1 = start_y - (step * counter) - rand_y; x2 = start_x + trunk_width + rand_x + (lean * counter); // slightly random trunk width y2 = start_y - (step * counter) - rand_y * 2; line(x1, y1, x2, y2); center_of_trunk = (x2 - x1) / 2 + x1; // center_of_trunk is a global variable used to position the flower stem } // end of for loop // draw flower stem y_stem = start_y - (step * trunk_height); // flower stem x_stem = center_of_trunk; for (int count = 0; count < 90; count ++) { x_stem = x_stem + random(-1, 1); if(count < 50 ){ //draw stem strokeWeight(2); } else{ //draw flower head strokeWeight(4); } point(x_stem, y_stem - count); } } // end of viod xanthorrhoea
APA citation:
Russell, R. (2016, July 05, 07:26 am). Evolution of Xanthorrhoea 001_4.
Retrieved January 22, 2025, from http://www.rupert.id.au/tutorials/processing/examples/xanthorrea001/001_4.php
Last refreshed: January 22 2025. 03:32.03 pm
This work is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 2.5 License.