Carolina Bustos - Tarea 8
De Casiopea
Título | Carolina Bustos - tarea 8 |
---|---|
Tipo de Proyecto | Proyecto de Curso |
Palabras Clave | tarea 8 |
Asignatura | Imagen Escrita 2012 |
Del Curso | Imagen Escrita 2012 |
Carreras | Arquitectura |
Alumno(s) | Carolina Bustos |
Profesor | Herbert 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();
}
}