Alvaro Aedo tarea 8: Rain

De Casiopea

Archivo:Alvaro Aedo Tarea 8.rar


TítuloAlvaro Aedo tarea 8: Rain
Tipo de ProyectoProyecto de Curso
Palabras Clavetarea 8
Período2012-2012
AsignaturaImagen Escrita 2012,
Del CursoImagen Escrita 2012,
CarrerasArquitectura
Alumno(s)Alvaro Aedo
ProfesorHerbert Spencer
/*
Se toma como base el codigo proporcionado por el profesor Herbert y se modifica principalmente el trazo
 Imagen Escrita 2012: Construcción de un trazo (algoritmo pictórico de la luz y el color) 
 
 */

import processing.pdf.*;

PImage rain;  // 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() {

  rain = loadImage("rain.jpg");   // se carga la imagen, se "construye" el objeto PImage rain
  size(609, 765, PDF, "Rain_AlvaroAedo.pdf");  // tamaño carta

  // cálculos para escalar desde la imagen hacia el pincel

  float ancho = width - (margenIzquierda + margenDerecha);
  escala = ancho/(float)rain.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 = 40;

  // muestreo regular desde la foto, esto se puede modificar....
  for (int y = 0; y < rain.height; y += spacer) {
    for (int x = 0; x < rain.width; x += spacer) {

      // obtengo el color
      float plotX = map(x, 0, rain.width, margenIzquierda, width-margenDerecha);
      float plotY = map(y, 0, rain.height, margenArriba, margenArriba + (rain.height * escala));
      color c = rain.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 + rain.height * escala + interlinea);
    interlinea += 15;
  }
}
/*_______________________________trazo____________+/
 
/* Trazo Pictórico , Alvaro Aedo 1ºAño Arquitectura */

void trazo(float x, float y, color c, float amp) {
  fill(c);
  // trazo elemental, pincel

  triangle(x, y, x+20, y+14, x-20, y+14);
  pushMatrix();
  translate(-1, -1);
  triangle(x, y, x+6, y+4, x-6, y+4);
  translate(1, 1);
  triangle(x, y, x+6, y+4, x-6, y+4);
  popMatrix();
}