Carolina Bustos - Tarea 8

De Casiopea
Carolina Bustos - tarea 8


TítuloCarolina Bustos - tarea 8
Tipo de ProyectoProyecto de Curso
Palabras Clavetarea 8
AsignaturaImagen Escrita 2012
Del CursoImagen Escrita 2012
CarrerasArquitectura
Alumno(s)Carolina Bustos
ProfesorHerbert Spencer

/*

Imagen Escrita 2012: Construcción de un trazo
  • /

import processing.pdf.*;

PImage hola; // la foto: el encuadre, la escena, el paisaje PFont font; // la fuente tipográfica String[] code; // el texto del código

/* Al exportar un PDF, Processing translada

las unidades de pixeles a puntos tipográficos.

1 pt = 0.0352778 cm
1 cm = 28.346438837 pt
  • /

float margenIzquierda = 30; float margenArriba = 20; float margenDerecha = 20; float margenAbajo = 20; float escala;

void setup() {

 hola = loadImage("hola.jpg");   // se carga la imagen, se "construye" el objeto PImage hola
 size(609, 765, PDF, "hello.pdf");  // tamaño carta
 // cálculos para escalar desde la imagen hacia el pincel
 float ancho = width - (margenIzquierda + margenDerecha);
 escala = ancho/(float)hola.width;
 noStroke();
 noLoop(); 
 background(255);
 font = createFont("Courier", 8); // construyo la tipografía a partir de una fuente de sistema
 textFont(font, 8);
 code = loadStrings("trazo.pde"); // cargo el código "trazo" (el pincel)

}


void draw() {

 float spacer = 10;
 // muestreo regular desde la foto, esto se puede modificar....
 for (int y = 0; y < hola.height; y += spacer) {
   for (int x = 0; x < hola.width; x += spacer) {
     // obtengo el color
     float plotX = map(x, 0, hola.width, margenIzquierda, width-margenDerecha);
     float plotY = map(y, 0, hola.height, margenArriba, margenArriba + (hola.height * escala));
     color c = hola.get(x, y);


     trazo(plotX, plotY, c, spacer);
   }
 }
 printCode();
 println("----->PDF done!");
 exit();

}

void printCode() {

 float interlinea = 0;
 for (int i = 0; i < code.length; i++) {
   // escribo cada línea de código en la pantalla
   text(code[i], width/4, 2 * margenArriba + hola.height * escala + interlinea);
   interlinea += 15;
 }

}

                        • trazo ***************

void trazo(float x, float y, color c, float amp) {

 fill(c); 
 int puntos = round(random(35));
 for (int i = 0; i <= puntos; i++) {
 float ladoIzquierdo = hue(c) + random(30);
 float ladoDerecho = saturation(c) + random(20);
 float ladoInferior = brightness(c) + random(6);
 
   
   pushMatrix();
   line(x, y, x+random(20), y+random(22, -10)); 
   stroke(c);
   popMatrix();
 

}

}