Domanda

Quindi stavo cercando di applicare un filtro gaussiano a un'immagine che ho usando Java. Tuttavia, l'immagine non viene affatto effettuata dal filtro. Sto usando l'operatore di convoluzione integrato. Qualcuno potrebbe indicarmi cosa va storto?

public static void main(String[] args) {
  File img = new File( "C:\\Users\\Aditya\\Pictures\\20130729_140153.jpg" );
  BufferedImage a = null;
  try{ 
      a= ImageIO.read( img );
  }
  catch( Exception e ){
      System.out.print( e.toString() );
      return;
  }
  BufferedImage a9 = new BufferedImage( a.getWidth() , a.getHeight() , a.getType() ); 
  float[] matrix = {
    1f/273,4f/273,7f/273,4f/273,1f/273,
    4f/273,16f/273,26f/273,16f/273,4f/273,
    7f/273,26f/273,41f/273,26f/273,7f/273,
    4f/273,16f/273,26f/273,16f/273,4f/273,
    1f/273,4f/273,7f/273,4f/273,1f/273
    };
    BufferedImageOp op = new ConvolveOp( new Kernel( 5, 5, matrix ) );
    a9 = op.filter( a, a9 );
    try{
        ImageIO.write( a9 , "jpg" ,new File( "C:\\Users\\Aditya\\Pictures\\jim.jpg" ));
    }catch( Exception e ){
        System.out.println( e );
    }
    }
}

Non funzionando intendo che non c'è alcuna differenza nelle immagini di A e A9. È come se fossero stati copiati!

È stato utile?

Soluzione

Non c'è niente di sbagliato nel tuo codice, l'ho eseguito e vedo una leggera sfocatura nell'immagine di output. Se vuoi vedere un effetto più pronunciato, cambiarlo in un kernel di rilevamento dei bordi, ad esempio usando

    float[] matrix = {
             1,  0, -1,
             0,  0,  0,
            -1,  0,  1
    };
    BufferedImageOp op = new ConvolveOp(new Kernel(3, 3, matrix));
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top