Lydia Huerta tarea 8
De Casiopea
Título | Lydia Huerta tarea 8 |
---|---|
Palabras Clave | tarea 8 |
Período | 2012- |
Del Curso | Imagen Escrita 2012, |
Carreras | Arquitectura |
Alumno(s) | Lydia Huerta Madariaga |
Profesor | Herbert Spencer |
Imagen Escrita 2012: Construcción de un trazo (algoritmo pictórico de la luz y el color)
- /
import processing.pdf.*;
PImage valparaiso; // 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() {
valparaiso = loadImage("valparaiso.jpg"); // se carga la imagen, se "construye" el objeto PImage ritoque size(609, 765, PDF, "vanessa.pdf"); // tamaño carta
// cálculos para escalar desde la imagen hacia el pincel
float ancho = width - (margenIzquierda + margenDerecha); escala = ancho/(float)valparaiso.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 < valparaiso.height; y += spacer) { for (int x = 0; x < valparaiso.width; x += spacer) {
// obtengo el color float plotX = map(x, 0, valparaiso.width, margenIzquierda, width-margenDerecha); float plotY = map(y, 0, valparaiso.height, margenArriba, margenArriba + (valparaiso.height * escala)); color c = valparaiso.get(x, y);
trazo(plotX, plotY, c, spacer); } } printCode(); println("listo"); 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 + valparaiso.height * escala + interlinea); interlinea += 15; }
}
/* Trazo Pictórico*/
void trazo(float x, float y, color c, float amp) {
float r=red(c); // obtengo valores en los 3 colores rgb float v=green(c); float a=blue(c); fill(c); // trazo elemental, deben cambiar todo este código ellipse(x, y, map(brightness(c), 0, 300, 5, amp), map(brightness(c), 0, 255, amp,5));
}