171
edits
| Diannamertz (talk | contribs)  | |||
| (44 intermediate revisions by 11 users not shown) | |||
| Line 46: | Line 46: | ||
| Soak is an empty canvas made of an elastic material. The moment you touch it the canvas gets virtually soaked with color.<br/> | Soak is an empty canvas made of an elastic material. The moment you touch it the canvas gets virtually soaked with color.<br/> | ||
| A Kinect detects any deformation of the elastic surface and passes this data to Processing, which then simulates virtual drops of dye.<br/> | A [[Kinect]] detects any deformation of the elastic surface and passes this data to Processing, which then simulates virtual drops of dye.<br/> | ||
| What I like about this project is the combination of digital tools with analog materials and the beauty of being so simple. The simulation of watercolor on the other hand is very interesting as well. (*cellular automata) | What I like about this project is the combination of digital tools with analog materials and the beauty of being so simple. The simulation of watercolor on the other hand is very interesting as well. (*cellular automata) | ||
| Line 215: | Line 215: | ||
| == Homework == | == Homework == | ||
| Look for a visual pattern on your way home, at your house, somewhere around you. that can be: a textile, the pattern on the sidepath, a pattern in the sky, a pattern on your wallpaper. Make a photo or a sketch. | Look for a visual pattern on your way home, at your house, somewhere around you. that can be: a textile, the pattern on the sidepath, a pattern in the sky, a pattern on your wallpaper. Make a photo or a sketch. | ||
| Patterns are always repetitions of elements. The elements are sorted in a certain way. That’s the rhythm. try to describe the rhythm. cut your pattern in its smallest elements. How many elements do you have. in which way are they composed? write a short text about the composition. | Patterns are always repetitions of elements. The elements are sorted in a certain way. That’s the rhythm. try to describe the rhythm. cut your pattern in its smallest elements. How many elements do you have. in which way are they composed? write a short text about the composition. | ||
| === cobblestone === | === cobblestone === | ||
| Line 226: | Line 223: | ||
| http://farm6.static.flickr.com/5280/5895055290_ebde12b4b0_m.jpg<br/> | http://farm6.static.flickr.com/5280/5895055290_ebde12b4b0_m.jpg<br/> | ||
| ''cobblestone'' (photo cc-by-sa by a2t [http://www.flickr.com/photos/a2t/]) | ''cobblestone'' (photo cc-by-sa by a2t [http://www.flickr.com/photos/a2t/]) | ||
| Cobblestone pavements are often laid in interesting patterns like the one shown above. | Cobblestone pavements are often laid in interesting patterns like the one shown above. | ||
| Line 233: | Line 229: | ||
| Due to the irregularities in the stone's sizes a random component is added to the pattern, making it harder to decode while still keeping it repetitive. | Due to the irregularities in the stone's sizes a random component is added to the pattern, making it harder to decode while still keeping it repetitive. | ||
| '''Pattern definition''': | '''Pattern definition''': | ||
| Line 254: | Line 249: | ||
| === Growing Ivy === | === Growing Ivy === | ||
| [[File:tree all elements.jpg|thumb]] | |||
| [[File: | The pattern of growing ivy is a pretty dense one. The leaves are the smallest elements within that pattern. Looking at the boundaries of it you can observe that ivy grows up in lines, each covered with leaves to the left and right side by turn. Through this the pattern has an appearance like an organic, random grid which is extendable in all directions. | ||
| The pattern of growing ivy is a pretty dense one. The  | |||
| --Julia Putscher | --Julia Putscher | ||
| <br clear="all" /> | |||
| === Textile on a Chair === | === Textile on a Chair === | ||
| [[File:Chair4.jpg|thumb]] | |||
| The textile pattern on this chair has alternating vertical stripes. Some of these stripes are solid colors; others have patterns within them. Within the patterned stripes, a few have vertically stacked repeating elements. One set has a floral pattern sitting alone a line that resembles a sine wave. The floral pattern mirrors itself along the vertical axis. <br /> | |||
| Color plays an important role in this textile pattern, as the plain black stripe is consistently placed between the two main alternating floral stripes. The black stripe contrasts sharply with the flowery pastels. | |||
| --Dianna M. | |||
| <br clear="all" /> | |||
| === Spider === | === Spider === | ||
| [[File:Spider0.jpg|thumb]] | |||
| [[File:Spider0.jpg]] | |||
| This is the spider on the white wall. It has two antennas and 8 feet, 3 long and 5 short feet. The most part of it is symmetrical. I think it can be realized through rotation and mirror effects. | This is the spider on the white wall. It has two antennas and 8 feet, 3 long and 5 short feet. The most part of it is symmetrical. I think it can be realized through rotation and mirror effects. | ||
| --Lu Jin | --Lu Jin | ||
| <br clear="all" /> | |||
| === Case=== | === Case=== | ||
| [[File:Upperpartofaharddrive.jpg|thumb]] | |||
| [[File:Upperpartofaharddrive.jpg| | |||
| A sketch of a part from a hard drive case. It consists of two lines of a different length and a point. Put this in a line, one line, one point, one line, three points, and in the next line just mirror it. | A sketch of a part from a hard drive case. It consists of two lines of a different length and a point. Put this in a line, one line, one point, one line, three points, and in the next line just mirror it. | ||
| Raphael K. | Raphael K. | ||
| <br clear="all" /> | |||
| === My midnight pizza=== | === My midnight pizza=== | ||
| [[File:pizza surface2.gif|thumb]] | |||
| [[File: | |||
| Do you like pizza? yes I like it. Pizza is always founded as circle big shape background then come after with a lot of edible stuffs on second layer or surface. Your favorite pizza always decorates with tomatoes, concentrated-tomatoes sauce, cheese, pepperoni, paprika, salami,  and so on. | Do you like pizza? yes I like it. Pizza is always founded as circle big shape background then come after with a lot of edible stuffs on second layer or surface. Your favorite pizza always decorates with tomatoes, concentrated-tomatoes sauce, cheese, pepperoni, paprika, salami,  and so on. | ||
| They are laid on the surface with random position but with sense of human that drop anythings on surface with an appropriate position:- not too far, no too close to each other. More,each will be laid on each other layer by layer. | They are laid on the surface with random position but with sense of human that drop anythings on surface with an appropriate position:- not too far, no too close to each other. More,each will be laid on each other layer by layer. | ||
| -PATawat. P- | -PATawat. P- | ||
| <br clear="all" /> | |||
| === Plattenbau === | === Plattenbau === | ||
| http://farm6.static.flickr.com/5305/5597569756_aff9d2942c_m.jpg<br/> | http://farm6.static.flickr.com/5305/5597569756_aff9d2942c_m.jpg<br/> | ||
| Line 303: | Line 289: | ||
| // [[Sebastian Wolf|Sebastian]] | // [[Sebastian Wolf|Sebastian]] | ||
| <br clear="all" /> | |||
| === Sofakissen === | === Sofakissen === | ||
| [[File:Sofakissen.jpg|thumb]] | |||
| [[File:Sofakissen.jpg]] | |||
| (Farben auf dem Bild nicht originalgetreu...) | (Farben auf dem Bild nicht originalgetreu...) | ||
| Line 320: | Line 304: | ||
| |Alexander Gustke| | |Alexander Gustke| | ||
| <br clear="all" /> | |||
| ===Jelena Djokic=== | ===Jelena Djokic=== | ||
| [[File:Pattv.jpg|thumb]] | |||
| A tent pattern | A tent pattern | ||
| Though is the composition of the pattern simple central structure, the complexity comes from the structure and the way, the patterns with each other connected are. This provokes 3dimensionality, on the way, that putting facets together by different angles provokes the look of broken lines and broken shapes. | Though is the composition of the pattern simple central structure, the complexity comes from the structure and the way, the patterns with each other connected are. This provokes 3dimensionality, on the way, that putting facets together by different angles provokes the look of broken lines and broken shapes. | ||
| <clear="all" /> | |||
| ===Andreas Dietrich: Pavement=== | ===Andreas Dietrich: Pavement=== | ||
| [[File:ProcessingStone.JPG|thumb]] | |||
| Pavements have often paving stones. The are many patterns available. In this example the pavement consists of two rectangle. Both have the same heights. The bigger one has a width of the height times two. The width and the height of the smaller one is equal. | Pavements have often paving stones. The are many patterns available. In this example the pavement consists of two rectangle. Both have the same heights. The bigger one has a width of the height times two. The width and the height of the smaller one is equal. | ||
| Line 337: | Line 320: | ||
| Repeat this steps, if you want. | Repeat this steps, if you want. | ||
| <br clear="all" /> | |||
| <br /> | |||
| ===Tristan Weis: Couch cloth pattern=== | ===Tristan Weis: Couch cloth pattern=== | ||
| [[File:Couchclothpattern.jpg| | [[File:Couchclothpattern.jpg|thumb]] | ||
| [[File:Couchclothpatternsketch.jpg|thumb]] | |||
| The pattern consists of very small strings. There are strings from the bottom to the top, and from left to right. Running from one side to another, every few millimeters a batch of strings runs over the crossing batch; after that it runs under the next one; over the one after - and so on. The batches running from left to right seem slightly thicker, forming a diversified web with the thinner ones from top to bottom. | The pattern consists of very small strings. There are strings from the bottom to the top, and from left to right. Running from one side to another, every few millimeters a batch of strings runs over the crossing batch; after that it runs under the next one; over the one after - and so on. The batches running from left to right seem slightly thicker, forming a diversified web with the thinner ones from top to bottom. | ||
| <br clear="all" /> | |||
| ===Florian Meyer: Fake 3D=== | ===Florian Meyer: Fake 3D=== | ||
| [[File: | [[File:pattern rhombus.jpg|thumb|Click me!]] | ||
| This pattern provides an illusion of depth due to use of simple 2D geometry (rhombus) with different shades that matches with our conception of how three-dimensional shapes must look like as soon as light is getting reflected off their surfaces  from a specific angle. | |||
| This pattern provides an illusion of depth due to use of simple 2D geometry (rhombus)  | |||
| with different shades that matches with our conception of how three-dimensional  | |||
| shapes must look like as soon as light is getting reflected off their surfaces  | |||
| from a specific angle. | |||
| <br clear="all" /> | |||
| ===Jan Schepanski: Schneefall=== | ===Jan Schepanski: Schneefall=== | ||
| http://www.buecherundbilder.de/images/schneefall.jpg | http://www.buecherundbilder.de/images/schneefall.jpg | ||
| Line 368: | Line 339: | ||
| So wie jede Schneeflocke nach dem Regelwerk der Natur gebildet wird, so segeln sie dahin, getrieben von Wind, Schwerkraft und der Lust des Tanzes. | So wie jede Schneeflocke nach dem Regelwerk der Natur gebildet wird, so segeln sie dahin, getrieben von Wind, Schwerkraft und der Lust des Tanzes. | ||
| <br clear="all" /> | |||
| ===Johannes Konrad Altmann=== | ===Johannes Konrad Altmann=== | ||
| [[File: | [[File:Asymmetrie 1.jpg|thumb]] | ||
| [[File: | [[File:Asymmetrie 2.jpg|thumb]] | ||
| '''Asymmetric Balance!''' | '''Asymmetric Balance!''' | ||
| Line 382: | Line 352: | ||
| <br><br> | <br><br> | ||
| One way to achieve balance that is almost a formula is to have more or less equally interesting things randomly distributed throughout the format. The effect is like confetti dropped on the area. There is balance because interest is evenly distributed, and there is unity. The problem is that everything is likely to seem too equal and hence too uniform. There is not enough variety and the design soon becomes boring. | One way to achieve balance that is almost a formula is to have more or less equally interesting things randomly distributed throughout the format. The effect is like confetti dropped on the area. There is balance because interest is evenly distributed, and there is unity. The problem is that everything is likely to seem too equal and hence too uniform. There is not enough variety and the design soon becomes boring. | ||
| <br clear="all" /> | |||
| = 11/11 = | = 11/11 = | ||
| Line 405: | Line 377: | ||
| For B), we create yet another "for" structure, this time repeating an image along a vertical line.   | For B), we create yet another "for" structure, this time repeating an image along a vertical line.   | ||
| --Dianna  | --Dianna M. | ||
| === Textile on Pizza Chilino  === | === Textile on Pizza Chilino  === | ||
| Line 417: | Line 389: | ||
| 1) Make a pizza flour base layer by drawing an ellipse and fill with cream or yellow color. <br/>'''Function''': ''ellipse()'',''fill()'' <br/><br/> | 1) Make a pizza flour base layer by drawing an ellipse and fill with cream or yellow color. <br/>'''Function''': ''ellipse()'',''fill()'' <br/><br/> | ||
| 2) Put a concentrate tomato sauce by drawing another layer on top of pizza flour, after that, fill red color. <br/>'''Function''': ''ellipse()'',''fill()'',  ''pushMatrix()'', ''popMatrix()''<br/><br/> | 2) Put a concentrate tomato sauce by drawing another layer on top of pizza flour, after that, fill red color. <br/>'''Function''': ''ellipse()'',''fill()'',  ''pushMatrix()'', ''popMatrix()''<br/><br/> | ||
| 3) Create salamis() function by drawing ellipses and put little white spots on around salamis' surface. <br/>'''Function''': ''ellipse()'',''fill()'', ''point()'', random() <br/><br/> | 3) Create salamis() function by drawing ellipses and put little white spots on around salamis' surface. <br/>'''Function''': ''ellipse()'',''fill()'', ''point()'', ''random()'' <br/><br/> | ||
| 4) Spread salamis around the pizza with random() function BUT not further than pizza flour edge(2*PI*radian). Furthermore, we could use ''For loop'' or ''While loop'' iteration to  | 4) Spread salamis around the pizza with random() function BUT not further than pizza flour edge(2*PI*radian). Furthermore, we could use ''For loop'' or ''While loop'' iteration to identify a number of salamis we need. <br/>'''Function''': ''salamis()'', ''random()'',''constrain()'' <br/><br/> | ||
| 5) Repeat 3) and 4) to drop more tomatoes, chilis, basils and mozarella cheese layer by layer. Moreover, we could rotate assets to make it more real pizza by rotating function.<br/>'''Function''': ''tomatoes()'', ''chilis()'', ''basils()'', ''mozarella()'', ''random()'', ''rotate()''<br/><br/> | 5) Repeat 3) and 4) to drop more tomatoes, chilis, basils and mozarella cheese layer by layer. Moreover, we could rotate assets to make it more real pizza by rotating function.<br/>'''Function''': ''tomatoes()'', ''chilis()'', ''basils()'', ''mozarella()'', ''random()'', ''rotate()''<br/><br/> | ||
| 6) Enjoy your Pizza Chilino :) | 6) Enjoy your Pizza Chilino :) | ||
| --Patawat P. | --Patawat P. | ||
| ===Florian Meyer: Fake 3D=== | ===Florian Meyer: Fake 3D=== | ||
| Line 459: | Line 430: | ||
| In einem Pseudocode könnte dies so aussehen: | In einem Pseudocode könnte dies so aussehen: | ||
| <syntaxhighlight lang="cpp"> | |||
| for: i=0; i<8; ++i | |||
|     if: i mod 4 = 0 | |||
|        draw yellow-orange rectangle | |||
|     if: i mod 4 = 1 or 3 | |||
|        draw little squares and a red rectangle between two of them // from the top to the bottom | |||
|     if: i = 2 | |||
|        draw orange rectangle | |||
|     if: i = 6 | |||
|        draw big red rectangle | |||
| </syntaxhighlight> | |||
| ===Sofastoff=== | ===Sofastoff=== | ||
| Line 476: | Line 447: | ||
| Das Muster wird mit zwei ineinander greifenden for-Schleifen eingeleitet; eine für die horizontale und eine für die vertikale Wiederholung. Eine Variable wird bei jeder Ausführung der Schleife erhöht. Ist dieser Counter gerade, so werden vier parallele Linien von rechts nach links gezeichnet, deren Anfangs- und Endpunkte jeweils in Abhängigkeit zu den Schleifenvariablen stehen. Wenn der Counter ungerade ist, so werden in gleicher Weise fünf parallele Linien von oben nach unten gezeichnet. | Das Muster wird mit zwei ineinander greifenden for-Schleifen eingeleitet; eine für die horizontale und eine für die vertikale Wiederholung. Eine Variable wird bei jeder Ausführung der Schleife erhöht. Ist dieser Counter gerade, so werden vier parallele Linien von rechts nach links gezeichnet, deren Anfangs- und Endpunkte jeweils in Abhängigkeit zu den Schleifenvariablen stehen. Wenn der Counter ungerade ist, so werden in gleicher Weise fünf parallele Linien von oben nach unten gezeichnet. | ||
| Die parallelen Linien können auch in (zwei unterschiedliche) for-Schleifen gepackt werden, womit das Muster in insgesamt vier for-Schleifen aufgelöst wird. | |||
| <syntaxhighlight lang="cpp"> | |||
| int patternsize = 50; | |||
| int count = 0; | |||
|   for (int ex = 0; ex <= width; ex = ex+patternsize) | |||
|   { | |||
|     count++; | |||
|     for (int yp = 0; yp <= height; yp = yp+patternsize) | |||
|     { | |||
|       count++; | |||
|       float test = pow(-1, count); | |||
|       float linespacing = patternsize; | |||
|       if (test==1) | |||
|       { | |||
|         for (int verti = 1; verti <= 4; verti++) | |||
|         { | |||
|           line(ex-(linespacing/20), (verti*linespacing/5)+yp, (linespacing+(linespacing/20))+ex, (verti*linespacing/5)+yp); | |||
|         } | |||
|       } | |||
|       else | |||
|       { | |||
|         for (int hori = 1; hori <= 5; hori++) | |||
|         { | |||
|           line((hori*linespacing/6)+ex, yp-(linespacing/20), (hori*linespacing/6)+ex, (linespacing+(linespacing/20))+yp); | |||
|         } | |||
|       } | |||
|     } | |||
|   } | |||
| </syntaxhighlight> | |||
| - Tristan Weis | |||
| === Spider === | |||
| [[File:Spider0.jpg]] | |||
| Most part of spider consists of symmetrical patterns. The definition of size (width, height, P3D) can let the patterns move around the y-axis and present as the mirror effects. Looking closely to the spider, it can be divided into 4 parts, antenna, head, body, and leg, which are mostly made up by circles and lines.  | |||
| # The antenna is not a regular pattern,use the shape() to draw on of this and then move it around the Y-axis for (PI). <br/>'''Function''': ''beginShape();endShape();rotateY ();'' | |||
| # The head of spider is very simple, only a ellipse. <br/>'''Function''': ''ellipse(), fill()'' | |||
| # body can also be seen as collection of ellipse. Two big ellipse are surrounded by 6 small ellipses. <br/>'''Function''': ''ellipse ();fill();for(){};rotate();'' | |||
| # The spider has 8 legs, 3 long and 5 short feet. Use for(){} to copy the lines and make it turns in the certain angle. | |||
| #'''Function''': '' for(){};line();strokeWeight();rotate();pushMatrix();popMateix();'' | |||
| ——Lu | |||
| === Julia Putscher === | |||
| ==== Growing Ivy ==== | |||
| [[File:tree all elements changed.jpg|800px]] | |||
| The pattern consists of one basic shape – the shape of the leaves. One leave has an organic figure which could be transformed into a geometric form. This geometric shape exists of three equilateral triangles: the first one is the biggest with the hypotenuse at the bottom. The other two triangles are smaller than the first one. They are half sized and arranged in a diagonal way. Two-thirds of those triangles are inside the bigger triangle. Their top shows one to the left and one to the right side.  | |||
| The leaves have different sizes which are organized randomly. They are arranged along a line, one to the left and one to the right side by turn. Those lines grow in parallel and even sometimes overlapping. Through this the pattern has an appearance like an organic, random grid which is extendable in all directions.  | |||
| ==== Processing Codes For Similar Patterns ==== | |||
| ===== First Sketch ===== | |||
| [[File:green pattern.jpg]] | |||
| <syntaxhighlight lang="cpp"> | |||
| int x = 0; | |||
| int y = 0; | |||
| int t = 0; //color transparency | |||
| void setup() | |||
| { | |||
|   size(600,300); | |||
|   background(255); | |||
|   smooth(); | |||
| } | |||
| void draw() | |||
| { | |||
|   strokeWeight(0.25); | |||
|   stroke(0,255,0); | |||
|   for(int i=0; i<10; i++) | |||
|   { | |||
|     fill(0,255,0,t); | |||
|     t = t+10; | |||
|     for(int j=0; j<10; j++) | |||
|     { | |||
|       beginShape(QUAD_STRIP);  | |||
|       vertex(x, y);  | |||
|       vertex(x, y+40); | |||
|       vertex(x+30, y+40); | |||
|       vertex(x+30, y); | |||
|       endShape(); | |||
|       y += 40; | |||
|     } | |||
|     y = 0; | |||
|     x += 30; | |||
|   } | |||
| } | |||
| </syntaxhighlight> | |||
| ===== Second Sketch ===== | |||
| [[File:black pattern.jpg]] | |||
| <syntaxhighlight lang="cpp"> | |||
| int x = 0; | |||
| int y = 0; | |||
| int t = 0; | |||
| void setup() | |||
| { | |||
|   size(600,300); | |||
|   background(0); | |||
|   smooth(); | |||
| } | |||
| void draw() | |||
| { | |||
|   strokeWeight(2); | |||
|   stroke(255); | |||
|   for(int i=0; i<10; i++) | |||
|   { | |||
|     fill(255,255,255,t); | |||
|     t = t+20; | |||
|     for(int j=0; j<10; j++) | |||
|     { | |||
|       beginShape(QUAD_STRIP);  | |||
|       vertex(x, y);  | |||
|       vertex(x+40, y); | |||
|       vertex(x+40, y+30); | |||
|       vertex(x, y+30); | |||
|       endShape(); | |||
|       y += 40; | |||
|     } | |||
|     y = 0; | |||
|     x += 30; | |||
|   } | |||
| } | |||
| </syntaxhighlight> | |||
| ===== Third Sketch ===== | |||
| [[File:layered pattern.jpg]] | |||
| <syntaxhighlight lang="cpp"> | |||
| int x = 0; | |||
| int y = 0; | |||
| int t = 0; //color transparency | |||
| void setup() | |||
| { | |||
|   size(400,300); | |||
|   background(100); | |||
|   smooth(); | |||
| } | |||
| void draw() | |||
| { | |||
|   strokeWeight(0.25); | |||
|   stroke(0,255,0); | |||
|   pushMatrix(); | |||
|   scale(0.5); | |||
|   translate(10,300); | |||
|   rotate(150); | |||
|   for(int i=0; i<10; i++) | |||
|   { | |||
|     fill(0,255,0,50); | |||
|     for(int j=0; j<10; j++) | |||
|     { | |||
|       beginShape(QUAD_STRIP);  | |||
|       vertex(x, y);  | |||
|       vertex(x, y+40); | |||
|       vertex(x+30, y+40); | |||
|       vertex(x+30, y); | |||
|       endShape(); | |||
|       y += 40; | |||
|     } | |||
|     y = 0; | |||
|     x += 30; | |||
|   } | |||
|   popMatrix(); | |||
|   pushMatrix(); | |||
|   translate(-77,249); | |||
|   scale(0.5); | |||
|   rotate(150); | |||
|   for(int k=0; k<10; k++) | |||
|   { | |||
|     fill(0,255,255,50); | |||
|     for(int l=0; l<10; l++) | |||
|     { | |||
|       beginShape(QUAD_STRIP);  | |||
|       vertex(x, y);  | |||
|       vertex(x, y+40); | |||
|       vertex(x+30, y+40); | |||
|       vertex(x+30, y); | |||
|       endShape(); | |||
|       y += 40; | |||
|     } | |||
|     y = 0; | |||
|     x += 30; | |||
|   } | |||
|   popMatrix(); | |||
|   pushMatrix(); | |||
|   translate(-137,327); | |||
|   scale(0.5); | |||
|   rotate(150); | |||
|   for(int h=0; h<10; h++) | |||
|   { | |||
|     fill(255,255,0,50); | |||
|     for(int g=0; g<10; g++) | |||
|     { | |||
|       beginShape(QUAD_STRIP);  | |||
|       vertex(x, y);  | |||
|       vertex(x, y+40); | |||
|       vertex(x+30, y+40); | |||
|       vertex(x+30, y); | |||
|       endShape(); | |||
|       y += 40; | |||
|     } | |||
|     y = 0; | |||
|     x += 30; | |||
|   } | |||
|   popMatrix(); | |||
| } | |||
| </syntaxhighlight> | |||
| === Andreas Dietrich === | |||
| Sketches for the practice homework: | |||
| ===== First Sketch ===== | |||
| [[File:Homework AD 1.png]] | |||
| <syntaxhighlight lang="cpp"> | |||
| int dia=50; | |||
| int innerDia=150; | |||
| int steps=30; | |||
| int steps2=30; | |||
| int steps3=30; | |||
| int offset1=0; | |||
| int offset2=10; | |||
| int offset3=20; | |||
| size(900, 600); | |||
| for (int k=0;k<3; k++) { | |||
|   for (int l=0;l<2; l++) { | |||
|     pushMatrix(); | |||
|     translate(k*innerDia*2+innerDia, 2*innerDia*l+innerDia); | |||
|     smooth(); | |||
|     noStroke(); | |||
|     fill(255); | |||
|     beginShape(); | |||
|     for (int i=0; i<360/steps;i++) { | |||
|       vertex(sin(radians(i*steps+offset1))*dia, cos(radians(i*steps+offset1))*dia); | |||
|       vertex(sin(radians(i*steps+steps/2.0+offset1))*innerDia, cos(radians(i*steps+steps/2.0+offset1))*innerDia); | |||
|     } | |||
|     endShape(CLOSE); | |||
|     fill(150); | |||
|     beginShape(); | |||
|     for (int i=0; i<360/steps2;i++) { | |||
|       vertex(sin(radians(i*steps2+offset2))*dia, cos(radians(i*steps2+offset2))*dia); | |||
|       vertex(sin(radians(i*steps2+steps2/2.0+offset2))*innerDia, cos(radians(i*steps2+steps2/2.0+offset2))*innerDia); | |||
|     } | |||
|     endShape(CLOSE); | |||
|     fill(0); | |||
|     beginShape(); | |||
|     for (int i=0; i<360/steps3;i++) { | |||
|       vertex(sin(radians(i*steps3+offset3))*dia, cos(radians(i*steps3+offset3))*dia); | |||
|       vertex(sin(radians(i*steps3+steps3/2.0+offset3))*innerDia, cos(radians(i*steps3+steps3/2.0+offset3))*innerDia); | |||
|     } | |||
|     endShape(CLOSE); | |||
|     popMatrix(); | |||
|   } | |||
| } | |||
| </syntaxhighlight> | |||
| ===== Second Sketch ===== | |||
| [[File:Homework AD 2.png]] | |||
| <syntaxhighlight lang="cpp"> | |||
| int dia=50; | |||
| int innerDia=150; | |||
| int steps=60; | |||
| float offset1=0; | |||
| float offset2=10; | |||
| float offset3=20; | |||
| float CONST_OFFSET1=0; | |||
| float CONST_OFFSET2=10; | |||
| float CONST_OFFSET3=20; | |||
| float speed1=1; | |||
| float speed2=0.5; | |||
| float speed3=0.7; | |||
| void setup() { | |||
|   size(900, 600); | |||
|   smooth(); | |||
|   noStroke(); | |||
| } | |||
| void draw() { | |||
|   background(255); | |||
|   for (int k=0;k<3; k++) { | |||
|     for (int l=0;l<2; l++) { | |||
|       pushMatrix(); | |||
|       translate(k*innerDia*2+innerDia, 2*innerDia*l+innerDia); | |||
|       fill(255, 0, 0); | |||
|       beginShape(); | |||
|       for (int i=0; i<360/steps;i++) { | |||
|         vertex(sin(radians(i*steps+offset1))*dia, cos(radians(i*steps+offset1))*dia); | |||
|         vertex(sin(radians(i*steps+steps/2.0+offset1))*innerDia, cos(radians(i*steps+steps/2.0+offset1))*innerDia); | |||
|       } | |||
|       endShape(CLOSE); | |||
|       fill(0, 255, 0); | |||
|       beginShape(); | |||
|       for (int i=0; i<360/steps;i++) { | |||
|         vertex(sin(radians(i*steps+offset2))*dia, cos(radians(i*steps+offset2))*dia); | |||
|         vertex(sin(radians(i*steps+steps/2.0+offset2))*innerDia, cos(radians(i*steps+steps/2.0+offset2))*innerDia); | |||
|       } | |||
|       endShape(CLOSE); | |||
|       fill(0, 0, 255); | |||
|       beginShape(); | |||
|       for (int i=0; i<360/steps;i++) { | |||
|         vertex(sin(radians(i*steps+offset3))*dia, cos(radians(i*steps+offset3))*dia); | |||
|         vertex(sin(radians(i*steps+steps/2.0+offset3))*innerDia, cos(radians(i*steps+steps/2.0+offset3))*innerDia); | |||
|       } | |||
|       endShape(CLOSE); | |||
|       offset1+=speed1; | |||
|       offset2+=speed2; | |||
|       offset3+=speed3; | |||
|       if (offset1> steps+CONST_OFFSET1) { | |||
|         offset1=CONST_OFFSET1; | |||
|       } | |||
|       if (offset2> steps+CONST_OFFSET2) { | |||
|         offset2=CONST_OFFSET2; | |||
|       } | |||
|       if (offset3> steps+CONST_OFFSET3) { | |||
|         offset3=CONST_OFFSET3; | |||
|       } | |||
|       popMatrix(); | |||
|     } | |||
|   } | |||
| } | |||
| </syntaxhighlight> | |||
| ===== Third Sketch ===== | |||
| [[File:Homework AD 3.png]] | |||
| <syntaxhighlight lang="cpp"> | |||
| int dia=50; | |||
| int innerDia=150; | |||
| int steps=30; | |||
| float offset1=0; | |||
| float offset2=10; | |||
| float offset3=20; | |||
| float CONST_OFFSET1=0; | |||
| float CONST_OFFSET2=10; | |||
| float CONST_OFFSET3=20; | |||
| float speed1=1; | |||
| float speed2=0.5; | |||
| float speed3=0.7; | |||
| float scaleVal=0.1; | |||
| float currentScale=1; | |||
| float toScaleVal=1; | |||
| void setup() { | |||
|   size(900, 600); | |||
|   smooth(); | |||
|   frameRate(12); | |||
|   noStroke(); | |||
| } | |||
| void draw() { | |||
|   background(255); | |||
|   for (int k=0;k<3; k++) { | |||
|     for (int l=0;l<2; l++) { | |||
|       pushMatrix(); | |||
|       translate(k*innerDia*2+innerDia, 2*innerDia*l+innerDia); | |||
|       if (scaleVal>0) { | |||
|         if (currentScale>=toScaleVal) { | |||
|           toScaleVal=random(2.0)-1.0; | |||
|           if (toScaleVal>currentScale) { | |||
|             scaleVal=+0.1; | |||
|           } | |||
|           else { | |||
|             scaleVal=-0.1; | |||
|           } | |||
|         } | |||
|       } | |||
|       if (scaleVal<0) { | |||
|         if (currentScale<=toScaleVal) { | |||
|           toScaleVal=random(2.0)-1.0; | |||
|           if (toScaleVal>currentScale) { | |||
|             scaleVal=+0.01; | |||
|           } | |||
|           else { | |||
|             scaleVal=-0.01; | |||
|           } | |||
|         } | |||
|       } | |||
|       currentScale+=scaleVal; | |||
|       scale(currentScale); | |||
|       fill(255, 0, 0); | |||
|       beginShape(); | |||
|       for (int i=0; i<360/steps;i++) { | |||
|         vertex(sin(radians(i*steps+offset1))*dia, cos(radians(i*steps+offset1))*dia); | |||
|         vertex(sin(radians(i*steps+steps/2.0+offset1))*innerDia, cos(radians(i*steps+steps/2.0+offset1))*innerDia); | |||
|       } | |||
|       endShape(CLOSE); | |||
|       fill(0, 255, 0); | |||
|       beginShape(); | |||
|       for (int i=0; i<360/steps;i++) { | |||
|         vertex(sin(radians(i*steps+offset2))*dia, cos(radians(i*steps+offset2))*dia); | |||
|         vertex(sin(radians(i*steps+steps/2.0+offset2))*innerDia, cos(radians(i*steps+steps/2.0+offset2))*innerDia); | |||
|       } | |||
|       endShape(CLOSE); | |||
|       fill(0, 0, 255); | |||
|       beginShape(); | |||
|       for (int i=0; i<360/steps;i++) { | |||
|         vertex(sin(radians(i*steps+offset3))*dia, cos(radians(i*steps+offset3))*dia); | |||
|         vertex(sin(radians(i*steps+steps/2.0+offset3))*innerDia, cos(radians(i*steps+steps/2.0+offset3))*innerDia); | |||
|       } | |||
|       endShape(CLOSE); | |||
|       offset1+=speed1; | |||
|       offset2+=speed2; | |||
|       offset3+=speed3; | |||
|       if (offset1> steps+CONST_OFFSET1) { | |||
|         offset1=CONST_OFFSET1; | |||
|       } | |||
|       if (offset2> steps+CONST_OFFSET2) { | |||
|         offset2=CONST_OFFSET2; | |||
|       } | |||
|       if (offset3> steps+CONST_OFFSET3) { | |||
|         offset3=CONST_OFFSET3; | |||
|       } | |||
|       popMatrix(); | |||
|     } | |||
|   } | |||
| } | |||
| </syntaxhighlight> | |||
edits