Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Gráficos
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

 
 
Herramientas Buscar en Tema Desplegado
  #3  
Antiguo 11-01-2007
Avatar de Ñuño Martínez
Ñuño Martínez Ñuño Martínez is offline
Moderador
 
Registrado: jul 2006
Ubicación: Ciudad Catedral, Españistán
Posts: 6.025
Poder: 27
Ñuño Martínez Tiene un aura espectacularÑuño Martínez Tiene un aura espectacular
Una forma podría ser utilizar matrices. De hecho, es lo que usan los programas como potochop, The Gimp y similares. Intentaré explicarlo, a ver qué tal me sale.

Primero amplias la imagen por el método uno.
Cita:
Empezado por Delphius
1. Por repetitción: que consiste en repetir cada pixel K veces en k-1 columnas y filas siguientes. Es sencillo, pero para niveles de K grandes, se produce un efecto cuadriculado.
Después creas la matriz de pesos. Esta matriz tendrá un tamaño doble al índice de ampliación más uno ((k * 2) + 1) Por ejemplo, si amplías por 3 y quieres todos los puntos pesen igual, deberás crear una matriz de 7x7 con todos los elementos iguales a 1:

Código Delphi [-]
VAR
  MatrizPesos: ARRAY [1..(k*2)+1, 1..(k*2)+1] OF INTEGER;
  x, y: INTEGER;

...

  FOR y := 1 TO ImagenAmpliada.alto DO
    FOR x := 1 TO ImagenAmpliada.ancho DO
      MatrizPesos[mx, my] := 1;
Después recorres la imagen ampliada (cuyo tamaño es, por ejemplo <w, h>) y, sumas los pesos de los puntos que rodean el pixel según indica la matriz. El pixel resultante es dicha suma dividido por el total de los pesos:
Código Delphi [-]
VAR
  x, y: INTEGER;
  mx, my: INTEGER;
  PesoTotal: INTEGER;
  ValorPixel: INTEGER;

...

  FOR y := 1 TO ImagenAmpliada.alto DO
    FOR x := 1 TO ImagenAmpliada.ancho DO
    BEGIN
      PesoTotal := 0; { <-- Antes olvidé poner esto }
      ValorPixel := 0;
      FOR my := 1 TO (k*2)+1 DO 
        FOR mx := 1 TO (k*2)+1 DO
        BEGIN
        { Sólo procesar si el pixel está dentro de la imagen }
          IF (0 < x + (mx - k) AND (x + (mx - k) < ImagenAmpliada.ancho) AND
             (0 < x + (my - k)) AND (x + (my - k) < ImagenAmpliada.alto) THEN
          BEGIN
            PesoTotal := PesoTotal + MatrizPesos[mx, my]
            ValorPixel := ValorPixel + 
                          (ImagenAmpliada.GetPixel (x + (mx - k), y + (my - k)) *
                           MatrizPesos[mx, my]);
          END;
        END;
        ImagenFinal.PutPixel (x, y, ValorPixel DIV PesoTotal);
    END;

No he comprobado el código y lo he hecho de memoria, así que revísalo, en especial la parte de cálculo de coordenadas. De todas formas creo que se entiende lo que quiero hacer, ¿no? En resumidas cuentas se busca la media ponderada del color de los píxeles que rodean a uno dado.

En cuanto a la velocidad, eso se lo dejo a otro, que mi neurona no da ya para más.

Última edición por Ñuño Martínez fecha: 11-01-2007 a las 13:05:43. Razón: El editor me jugó una mala pasada.
Responder Con Cita
 


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
¿Crear email con imagen como parte del contenido del texto? burasu Varios 6 07-04-2006 19:11:30
Crear directorio con lista lineal davitcito Varios 4 07-05-2005 07:20:01
Programa que agrande una parte de la imagen maravert Gráficos 0 05-08-2004 01:12:50
Ampliar un campo en un dbgrid hogol Varios 1 21-11-2003 16:02:40


La franja horaria es GMT +2. Ahora son las 05:23:00.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi