Java DIP - Guide rapide

Digital Image Processing (DIP) traite de la manipulation d'images numériques à l'aide d'un ordinateur numérique. C'est un sous-domaine des signaux et des systèmes mais se concentre particulièrement sur les images. DIP se concentre sur le développement d'un système informatique capable de traiter une image. L'entrée d'un tel système est une image numérique. Le système traite l'image à l'aide d'algorithmes efficaces et donne une image en sortie.

Java est un langage de programmation de haut niveau largement utilisé dans le monde moderne. Il peut prendre en charge et gérer efficacement le traitement d'image numérique à l'aide de diverses fonctions.

La BufferedImageclasse Java est une sous-classe de la classe Image. Il est utilisé pour gérer et manipuler les données d'image. A BufferedImageest constitué de ColorModel de données d'image. Tous les BufferedImageobjets ont une coordonnée dans le coin supérieur gauche de (0, 0).

Constructeurs

Cette classe prend en charge trois types de constructeurs.

Le premier constructeur construit un nouveau BufferedImageavec un ColorModel et un Raster spécifiés.

BufferedImage(ColorModel cm, WritableRaster raster, 
boolean isRasterPremultiplied, Hashtable<?,?> properties)

Le deuxième constructeur construit un BufferedImagede l'un des types d'image prédéfinis.

BufferedImage(int width, int height, int imageType)

Le troisième constructeur construit l'un BufferedImagedes types d'image prédéfinis: TYPE_BYTE_BINARY ou TYPE_BYTE_INDEXED.

BufferedImage(int width, int height, int imageType, IndexColorModel cm)

Sr.Non Méthode et description
1

copyData(WritableRaster outRaster)

Il calcule une région rectangulaire arbitraire du BufferedImageet la copie dans un WritableRaster spécifié.

2

getColorModel()

Il renvoie l'objet de la classe ColorModel d'une image.

3

getData()

Il renvoie l'image comme une grande tuile.

4

getData(Rectangle rect)

Il calcule et renvoie une région arbitraire du BufferedImage.

5

getGraphics()

Cette méthode renvoie un Graphics2D, conserve la compatibilité descendante.

6

getHeight()

Il renvoie la hauteur du BufferedImage.

sept

getMinX()

Il renvoie la coordonnée x minimale de ceci BufferedImage.

8

getMinY()

Il renvoie la coordonnée y minimale de ceci BufferedImage.

9

getRGB(int x, int y)

Il renvoie un pixel entier dans le modèle de couleur RVB par défaut (TYPE_INT_ARGB) et dans l'espace de couleurs sRGB par défaut.

dix

getType()

Il renvoie le type d'image.

Exemple

L'exemple suivant illustre l'utilisation de la BufferedImageclasse java qui dessine du texte à l'écran à l'aide de Graphics Object -

import java.awt.Graphics;
import java.awt.Image;
import java.awt.image.BufferedImage;

import javax.swing.JFrame;
import javax.swing.JPanel;

public class Test extends JPanel {

   public void paint(Graphics g) {
      Image img = createImageWithText();
      g.drawImage(img, 20,20,this);
   }

   private Image createImageWithText() {
      BufferedImage bufferedImage = new BufferedImage(200,200,BufferedImage.TYPE_INT_RGB);
      Graphics g = bufferedImage.getGraphics();

      g.drawString("www.tutorialspoint.com", 20,20);
      g.drawString("www.tutorialspoint.com", 20,40);
      g.drawString("www.tutorialspoint.com", 20,60);
      g.drawString("www.tutorialspoint.com", 20,80);
      g.drawString("www.tutorialspoint.com", 20,100);
      
      return bufferedImage;
   }
   
   public static void main(String[] args) {
      JFrame frame = new JFrame();
      frame.getContentPane().add(new Test());

      frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
      frame.setSize(200, 200);
      frame.setVisible(true);
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Dans ce chapitre, nous allons voir comment vous pouvez télécharger une image sur Internet, appliquer certaines techniques de traitement d'image sur l'image, puis télécharger à nouveau l'image traitée sur un serveur.

Téléchargement d'une image

Pour télécharger une image depuis un site Web, nous utilisons la classe java nommée URL, qui se trouve sous java.netpaquet. Sa syntaxe est donnée ci-dessous -

String website = "http://tutorialspoint.com";
URL url = new URL(website);

En dehors de la méthode ci-dessus, il existe d'autres méthodes disponibles dans l'URL de classe comme décrit brièvement -

Sr.No. Méthode et description
1

public String getPath()

Il renvoie le chemin de l'URL.

2

public String getQuery()

Il renvoie la partie requête de l'URL.

3

public String getAuthority()

Il renvoie l'autorité de l'URL.

4

public int getPort()

Il renvoie le port de l'URL.

5

public int getDefaultPort()

Il renvoie le port par défaut pour le protocole de l'URL.

6

public String getProtocol()

Il renvoie le protocole de l'URL.

sept

public String getHost()

Il renvoie l'hôte de l'URL.

Exemple

L'exemple suivant illustre l'utilisation de la classe URL java pour télécharger une image à partir d'Internet -

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;

import java.net.URL;

public class Download {

   public static void main(String[] args) throws Exception {
   
      try{
         String fileName = "digital_image_processing.jpg";
         String website = "http://tutorialspoint.com/java_dip/images/"+fileName;
         
         System.out.println("Downloading File From: " + website);
         
         URL url = new URL(website);
         InputStream inputStream = url.openStream();
         OutputStream outputStream = new FileOutputStream(fileName);
         byte[] buffer = new byte[2048];
         
         int length = 0;
         
         while ((length = inputStream.read(buffer)) != -1) {
            System.out.println("Buffer Read of length: " + length);
            outputStream.write(buffer, 0, length);
         }
         
         inputStream.close();
         outputStream.close();
         
      } catch(Exception e) {
         System.out.println("Exception: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez ce qui précède, la sortie suivante s'affiche.

Il téléchargerait l'image suivante à partir du serveur.

Télécharger une image

Voyons comment télécharger une image sur un serveur Web. Nous convertissons une BufferedImage en tableau d'octets afin de l'envoyer au serveur.

Nous utilisons la classe Java ByteArrayOutputStream, qui se trouve sous java.iopaquet. Sa syntaxe est donnée ci-dessous -

ByteArrayOutputStream baos = new ByteArrayOutputStream();
ImageIO.write(image, "jpg", baos);

Afin de convertir l'image en tableau d'octets, nous utilisons toByteArray() méthode de ByteArrayOutputStreamclasse. Sa syntaxe est donnée ci-dessous -

byte[] bytes = baos.toByteArray();

Outre la méthode ci-dessus, il existe d'autres méthodes disponibles dans la classe ByteArrayOutputStream comme décrit brièvement -

Sr.No. Méthode et description
1

public void reset()

Cette méthode réinitialise le nombre d'octets valides du flux de sortie du tableau d'octets à zéro, de sorte que toute la sortie accumulée dans le flux est supprimée.

2

public byte[] toByteArray()

Cette méthode crée un tableau d'octets nouvellement alloué. Sa taille serait la taille actuelle du flux de sortie et le contenu du tampon y sera copié. Il renvoie le contenu actuel du flux de sortie sous forme de tableau d'octets.

3

public String toString()

Convertit le contenu du tampon en une chaîne. La traduction sera effectuée selon le codage de caractères par défaut. Il renvoie la chaîne traduite à partir du contenu du tampon.

4

public void write(int w)

Il écrit le tableau spécifié dans le flux de sortie.

5

public void write(byte []b, int of, int len)

Il écrit un nombre d'octets à partir du décalage vers le flux.

6

public void writeTo(OutputStream outSt)

Il écrit tout le contenu de ce Stream dans l'argument de flux spécifié.

Exemple

L'exemple suivant montre ByteArrayOutputStream pour télécharger une image sur le serveur -

Code client

import javax.swing.*;  
import java.net.*; 
import java.awt.image.*;
import javax.imageio.*;
import java.io.*;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.IOException;
import javax.imageio.ImageIO;

public class Client{
   public static void main(String args[]) throws Exception{
   
      Socket soc;
      BufferedImage img = null;
      soc=new Socket("localhost",4000);
      System.out.println("Client is running. ");
      
      try {
         System.out.println("Reading image from disk. ");
         img = ImageIO.read(new File("digital_image_processing.jpg"));
         ByteArrayOutputStream baos = new ByteArrayOutputStream();
         
         ImageIO.write(img, "jpg", baos);
         baos.flush();
         
         byte[] bytes = baos.toByteArray();
         baos.close();
         
         System.out.println("Sending image to server. ");
         
         OutputStream out = soc.getOutputStream(); 
         DataOutputStream dos = new DataOutputStream(out);
         
         dos.writeInt(bytes.length);
         dos.write(bytes, 0, bytes.length);
         
         System.out.println("Image sent to server. ");

         dos.close();
         out.close();
         
      } catch (Exception e) {
         System.out.println("Exception: " + e.getMessage());
         soc.close();
      }
      soc.close();
   }
}

Code serveur

import java.net.*;
import java.io.*;
import java.awt.image.*;

import javax.imageio.*; 
import javax.swing.*; 

class Server {
   public static void main(String  args[]) throws Exception{
      ServerSocket server=null;
      Socket socket;
      server = new ServerSocket(4000);
      System.out.println("Server Waiting for image");

      socket = server.accept();
      System.out.println("Client connected.");
      
      InputStream in = socket.getInputStream();
      DataInputStream dis = new DataInputStream(in);

      int len = dis.readInt();
      System.out.println("Image Size: " + len/1024 + "KB");
      
      byte[] data = new byte[len];
      dis.readFully(data);
      dis.close();
      in.close();

      InputStream ian = new ByteArrayInputStream(data);
      BufferedImage bImage = ImageIO.read(ian);
 
      JFrame f = new JFrame("Server");
      ImageIcon icon = new ImageIcon(bImage);
      JLabel l = new JLabel();
      
      l.setIcon(icon);
      f.add(l);
      f.pack();
      f.setVisible(true);
   }
}

Production

Sortie côté client

Lorsque vous exécutez le code client, la sortie suivante apparaît côté client -

Sortie côté serveur

Lorsque vous exécutez le code serveur, la sortie suivante apparaît côté serveur -

Après avoir reçu l'image, le serveur affiche l'image comme indiqué ci-dessous -

Une image contient un tableau bidimensionnel de pixels. C'est en fait la valeur de ces pixels qui composent une image. Une image peut généralement être en couleur ou en niveaux de gris.

En Java, la classe BufferedImage est utilisée pour gérer les images. Vous devez appelergetRGB() méthode de la BufferedImage class pour obtenir la valeur du pixel.

Obtenir la valeur en pixels

La valeur du pixel peut être reçue en utilisant la syntaxe suivante:

Color c = new Color(image.getRGB(j, i));

Obtention des valeurs RVB

La méthode getRGB()prend l'index de ligne et de colonne comme paramètre et renvoie le pixel approprié. Dans le cas d'une image couleur, il renvoie trois valeurs qui sont (Rouge, Vert, Bleu). Ils peuvent être obtenus comme suit -

c.getRed();
c.getGreen();
c.getBlue();

Obtenir la largeur et la hauteur de l'image

La hauteur et la largeur de l'image peuvent être obtenues en appelant le getWidth() et getHeight()méthodes de la classe BufferedImage. Sa syntaxe est donnée ci-dessous -

int width = image.getWidth();
int height = image.getHeight();

En dehors de ces méthodes, il existe d'autres méthodes prises en charge dans la classe BufferedImage. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

copyData(WritableRaster outRaster)

Il calcule une région rectangulaire arbitraire de BufferedImage et la copie dans un WritableRaster spécifié.

2

getColorModel()

Il renvoie le ColorModel d'une image.

3

getData()

Il renvoie l'image comme une grande tuile.

4

getData(Rectangle rect)

Il calcule et renvoie une région arbitraire de BufferedImage.

5

getGraphics()

Cette méthode renvoie un Graphics2D, mais est là pour la compatibilité descendante.

6

getHeight()

Il renvoie la hauteur de BufferedImage.

sept

getMinX()

Il renvoie la coordonnée x minimale de cette BufferedImage.

8

getMinY()

Il renvoie la coordonnée y minimale de cette BufferedImage.

9

getRGB(int x, int y)

Il renvoie un pixel entier dans le modèle de couleur RVB par défaut (TYPE_INT_ARGB) et dans l'espace de couleurs sRGB par défaut.

dix

getType()

Il renvoie le type d'image.

Exemple

L'exemple suivant montre l'utilisation de la classe java BufferedImage qui affiche les pixels d'une image de taille (100 x 100) -

import java.awt.*;
import java.awt.image.BufferedImage;

import java.io.*;

import javax.imageio.ImageIO;
import javax.swing.JFrame;

class Pixel {
   BufferedImage image;
   int width;
   int height;
   
   public Pixel() {
      try {
         File input = new File("blackandwhite.jpg");
         image = ImageIO.read(input);
         width = image.getWidth();
         height = image.getHeight();
         
         int count = 0;
         
         for(int i=0; i<height; i++) {
         
            for(int j=0; j<width; j++) {
            
               count++;
               Color c = new Color(image.getRGB(j, i));
               System.out.println("S.No: " + count + " Red: " + c.getRed() +"  Green: " + c.getGreen() + " Blue: " + c.getBlue());
            }
         }

      } catch (Exception e) {}
   }
   
   static public void main(String args[]) throws Exception {
      Pixel obj = new Pixel();
   }
}

Production

Lorsque vous exécutez l'exemple ci-dessus, il imprimera les pixels de l'image suivante -

Original Image

Pixels Output

Si vous faites défiler la sortie vers le bas, le modèle suivant apparaît:

Pour convertir une image couleur en image en niveaux de gris, vous devez lire les pixels ou les données de l'image en utilisant File et ImageIO objets et stockez l'image dans BufferedImageobjet. Sa syntaxe est donnée ci-dessous -

File input = new File("digital_image_processing.jpg");
BufferedImage image = ImageIO.read(input);

De plus, obtenez la valeur du pixel en utilisant la méthode getRGB()et exécutez la méthode GrayScale () dessus. La méthode getRGB () prend l'index de ligne et de colonne comme paramètre.

Color c = new Color(image.getRGB(j, i));
int red = (c.getRed() * 0.299);
int green =(c.getGreen() * 0.587);
int blue = (c.getBlue() *0.114);

En dehors de ces trois méthodes, il existe d'autres méthodes disponibles dans la classe Color comme décrit brièvement -

Sr.No. Méthode et description
1

brighter()

Cela crée une nouvelle couleur qui est une version plus lumineuse de cette couleur.

2

darker()

Cela crée une nouvelle couleur qui est une version plus sombre de cette couleur.

3

getAlpha()

Il renvoie la composante alpha comprise entre 0 et 255.

4

getHSBColor(float h, float s, float b)

Il crée un objet Color basé sur les valeurs spécifiées pour le modèle de couleur TSL.

5

HSBtoRGB(float hue, float saturation, float brightness)

Il convertit les composants d'une couleur, comme spécifié par le modèle TSL, en un ensemble équivalent de valeurs pour le modèle RVB par défaut.

6

toString()

Il renvoie une représentation sous forme de chaîne de cette couleur.

La dernière étape consiste à ajouter ces trois valeurs et à la redéfinir sur la valeur de pixel correspondante. Sa syntaxe est donnée ci-dessous -

int sum = red+green+blue;
Color newColor = new Color(sum,sum,sum);
image.setRGB(j,i,newColor.getRGB());

Exemple

L'exemple suivant illustre l'utilisation de la classe Java BufferedImage qui convertit une image en niveaux de gris -

import java.awt.*;
import java.awt.image.BufferedImage;

import java.io.*;

import javax.imageio.ImageIO;
import javax.swing.JFrame;

public class GrayScale {

   BufferedImage  image;
   int width;
   int height;
   
   public GrayScale() {
   
      try {
         File input = new File("digital_image_processing.jpg");
         image = ImageIO.read(input);
         width = image.getWidth();
         height = image.getHeight();
         
         for(int i=0; i<height; i++) {
         
            for(int j=0; j<width; j++) {
            
               Color c = new Color(image.getRGB(j, i));
               int red = (int)(c.getRed() * 0.299);
               int green = (int)(c.getGreen() * 0.587);
               int blue = (int)(c.getBlue() *0.114);
               Color newColor = new Color(red+green+blue,
               
               red+green+blue,red+green+blue);
               
               image.setRGB(j,i,newColor.getRGB());
            }
         }
         
         File ouptut = new File("grayscale.jpg");
         ImageIO.write(image, "jpg", ouptut);
         
      } catch (Exception e) {}
   }
   
   static public void main(String args[]) throws Exception {
      GrayScale obj = new GrayScale();
   }
}

Production

Lorsque vous exécutez l'exemple donné, il convertit l'image digital_image_processing.jpg à son image équivalente en niveaux de gris et écrivez-la sur le disque dur avec le nom grayscale.jpg.

Image originale

Image en niveaux de gris

Dans ce chapitre, apprenez à améliorer le contraste d'une image à l'aide de l'égalisation d'histogramme.

Nous utilisons le OpenCV fonction equalizeHist()méthode. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

Imgproc.equalizeHist(source, destination);

Les paramètres sont décrits ci-dessous -

Sr.No. Paramètre et description
1

Source

Il s'agit d'une image source à canal unique 8 bits.

2

Destination

C'est l'image de destination.

En dehors de la méthode equalizeHist (), il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int ddepth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour améliorer le contraste d'une image -

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class Main {

   static int width;
   static int height;
   static double alpha = 2;
   static double beta = 50;
   
   public static void main( String[] args ) {
   
      try {
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         Mat source = Highgui.imread("grayscale.jpg", 
         Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         
         Imgproc.equalizeHist(source, destination);
         Highgui.imwrite("contrast.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Image contrastée améliorée

Dans ce chapitre, nous améliorons la luminosité d'une image en multipliant chaque pixel de l'image par une valeur alpha et en lui ajoutant une autre valeur bêta.

nous OpenCV fonction convertToqui effectue l'opération ci-dessus automatiquement. Il peut être trouvé sousMatpaquet. Sa syntaxe est donnée ci-dessous -

int alpha = 2;
int beta = 50;
sourceImage.convertTo(destination, rtype , alpha, beta);

Les paramètres sont décrits ci-dessous -

Sr.No. Paramètre et description
1

destination

C'est l'image de destination.

2

rtype

C'est le type de matrice de sortie souhaité ou, plutôt la profondeur, car le nombre de canaux est le même que celui de l'entrée. si rtype est négatif, la matrice de sortie aura le même type que l'entrée.

3

alpha

C'est un facteur d'échelle facultatif.

4

beta

Il s'agit d'un delta facultatif ajouté aux valeurs mises à l'échelle.

Outre la méthode convertTo, il existe d'autres méthodes fournies par la classe Mat. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

adjustROI(int dtop, int dbottom, int dleft, int dright)

Il ajuste la taille et la position d'une sous-matrice dans la matrice parente.

2

copyTo(Mat m)

Il copie la matrice sur une autre.

3

diag()

Il extrait une diagonale d'une matrice ou crée une matrice diagonale.

4

dot(Mat m)

Il calcule un produit scalaire de deux vecteurs.

5

reshape(int cn)

Il change la forme et / ou le nombre de canaux d'une matrice 2D sans copier les données.

6

submat(Range rowRange, Range colRange)

Il extrait une sous-matrice rectangulaire.

Exemple

L'exemple suivant montre l'utilisation de la classe Mat pour améliorer la luminosité d'une image -

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.highgui.Highgui;

public class Main {
   static int width;
   static int height;
   static double alpha = 2;
   static double beta = 50;
   
   public static void main( String[] args ) {
   
      try{
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         Mat source =  Highgui.imread("digital_image_processing.jpg",Highgui.CV_LOAD_IMAGE_COLOR);
         Mat destination = new Mat(source.rows(),source.cols(),
         
         source.type());
         source.convertTo(destination, -1, alpha, beta);
         Highgui.imwrite("brightWithAlpha2Beta50.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("error:" + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Image lumineuse améliorée (alpha = 1 et bêta = 50)

Image lumineuse améliorée (alpha = 2 et bêta = 50)

Dans ce chapitre, nous apprenons à augmenter la netteté d'une image à l'aide du filtre gaussien.

Nous utilisons d'abord OpenCV fonction GaussianBlur. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

Imgproc.GaussianBlur(source, destination, new Size(0,0), sigmaX);

Les paramètres sont décrits brièvement -

Sr.No. Paramètre et description
1

source

C'est l'image source.

2

destination

C'est l'image de destination.

3

Size

C'est la taille du noyau gaussien.

4

sigmaX

C'est l'écart type du noyau gaussien dans la direction X.

De plus, nous utilisons OpenCV fonction addWeightedpour appliquer un filigrane d'image à l'image. Il peut être trouvé sousCorepaquet. Sa syntaxe est donnée ci-dessous -

Core.addWeighted(InputArray src1, alpha, src2, beta, gamma, OutputArray dst);

Les paramètres de cette fonction sont décrits ci-dessous -

Sr.No. Paramètre et description
1

src1

C'est le premier tableau d'entrée.

2

alpha

C'est le poids des premiers éléments du tableau.

3

src2

C'est le deuxième tableau d'entrée de la même taille et du même numéro de canal que src1.

4

Beta

C'est le poids des deuxièmes éléments du tableau.

5

gamma

Il est scalaire ajouté à chaque somme.

6

dst

Il s'agit d'un tableau de sortie qui a la même taille et le même nombre de canaux que les tableaux d'entrée.

Outre la méthode GaussianBlur, il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant montre l'utilisation de la classe Imgproc et Core pour appliquer la netteté à une image -

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class Main {
   public static void main( String[] args ) {
      try{
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         Mat source = Highgui.imread("digital_image_processing.jpg",
         Highgui.CV_LOAD_IMAGE_COLOR);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         Imgproc.GaussianBlur(source, destination, new Size(0,0), 10);
         Core.addWeighted(source, 1.5, destination, -0.5, 0, destination);
         Highgui.imwrite("sharp.jpg", destination);
      } catch (Exception e) {
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Image nette

Une image peut facilement être compressée et stockée via Java. La compression d'image consiste à convertir une image en jpg et à la stocker.

Afin de compresser une image, nous lisons l'image et la convertissons en objet BufferedImage.

De plus, nous obtenons un ImageWriter de getImageWritersByFormatName()méthode trouvée dans la classe ImageIO. À partir de cet ImageWriter, créez unImageWriteParamobjet. Sa syntaxe est donnée ci-dessous -

Iterator<ImageWriter> list = ImageIO.getImageWritersByFormatName("jpg");
ImageWriteParam obj = writer_From_List.getDefaultWriteParam();

À partir de cet objet ImageWriteParam, vous pouvez définir la compression en appelant ces deux méthodes qui sont setCompressionMode() et setCompressionQuality(). Leurs syntaxes sont indiquées ci-dessous -

obj.setCompressionMode(ImageWriteParam.MODE_EXPLICIT);
obj.setCompressionQuality(0.05f);

La méthode setCompressionMode () prend Mode_EXPLICIT comme paramètre. Certains des autres MODES sont décrits brièvement -

Sr.No. Les modes
1

MODE_DEFAULT

Il s'agit d'une valeur constante qui peut être transmise aux méthodes pour activer cette fonctionnalité pour les futures écritures.

2

MODE_DISABLED

C'est une valeur constante qui peut être transmise aux méthodes pour désactiver cette fonctionnalité pour les futures écritures.

3

MODE_EXPLICIT

Il s'agit d'une valeur constante qui peut être transmise aux méthodes pour activer cette fonctionnalité pour les futures écritures.

Outre les méthodes de compression, il existe d'autres méthodes fournies par la classe ImageWriteParam. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

canOffsetTiles()

Il renvoie true si l'enregistreur peut effectuer une mosaïque avec des décalages de grille non nuls lors de l'écriture.

2

getBitRate(float quality)

Il renvoie un flottant indiquant une estimation du nombre de bits de données de sortie pour chaque bit de données d'image d'entrée au niveau de qualité donné.

3

getLocale()

Il retourne les paramètres régionaux actuellement définis, ou null si seuls les paramètres régionaux par défaut sont pris en charge.

4

isCompressionLossless()

Il renvoie true si le type de compression actuel fournit une compression sans perte.

5

unsetCompression()

Il supprime tout type de compression et paramètres de qualité précédents.

6

unsetTiling()

Il supprime tous les paramètres de grille de tuiles précédents spécifiés par les appels à setTiling.

Exemple

L'exemple suivant illustre l'utilisation de la classe ImageWriteParam pour compresser une image -

import java.io.*;
import java.util.*;
import java.awt.image.*;

import javax.imageio.*;
import javax.imageio.stream.ImageOutputStream;

class Compression {

   public static void main(String[] args) throws IOException {
   
      File input = new File("digital_image_processing.jpg");
      BufferedImage image = ImageIO.read(input);

      File compressedImageFile = new File("compress.jpg");
      OutputStream os =new FileOutputStream(compressedImageFile);

      Iterator<ImageWriter>writers =  ImageIO.getImageWritersByFormatName("jpg");
      ImageWriter writer = (ImageWriter) writers.next();

      ImageOutputStream ios = ImageIO.createImageOutputStream(os);
      writer.setOutput(ios);

      ImageWriteParam param = writer.getDefaultWriteParam();
      
      param.setCompressionMode(ImageWriteParam.MODE_EXPLICIT);
      param.setCompressionQuality(0.05f);
      writer.write(null, new IIOImage(image, null, null), param);
      
      os.close();
      ios.close();
      writer.dispose();
   }
}

Production

Lorsque vous exécutez le code donné, il compresse l'image digital_image_processing.jpg à son image compressée équivalente et l'écrit sur le disque dur avec le nom compress.jpg.

Image originale

Image compressée - Facteur de qualité - 0,05

Image compressée - Facteur de qualité - 0,5

Dans ce chapitre, nous apprenons à ajouter différents types de bordures à une image.

Nous utilisons OpenCV fonction copyMakeBorder. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

Imgproc.copyMakeBorder(source,destination,top,bottom,left,right,borderType);

Les paramètres sont décrits ci-dessous -

Sr.No. Paramètre et description
1

source

C'est l'image source.

2

destination

C'est l'image de destination.

3

top

C'est la longueur en pixels de la bordure en haut de l'image.

4

bottom

Longueur en pixels de la bordure en bas de l'image.

5

left

C'est la longueur en pixels de la bordure à gauche de l'image.

6

right

C'est la longueur en pixels de la bordure à droite de l'image.

sept

borderType

Il définit le type de bordure. Les frontières possibles sont BORDER_REPLICATE, BORDER_REFLECT, BORDER_WRAP, BORDER_CONSTANT etc.

En plus de la méthode copyMakeBorder (), il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant montre l'utilisation de la classe Imgproc pour ajouter une bordure à une image -

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class main {
   public static void main( String[] args ) {
   
      try {
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         Mat source = Highgui.imread("digital_image_processing.jpg",
         
         Highgui.CV_LOAD_IMAGE_COLOR);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         
         int top, bottom, left, right;
         int borderType;

         /// Initialize arguments for the filter
         top = (int) (0.05*source.rows()); 
         bottom = (int) (0.05*source.rows());
         left = (int) (0.05*source.cols()); 
         right = (int) (0.05*source.cols());

         destination = source;
         Imgproc.copyMakeBorder(source, destination, top, bottom, left, right, Imgproc.BORDER_WRAP);
         Highgui.imwrite("borderWrap.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Image de bordure isolée

Image de bordure enveloppée

Refléter l'image de la bordure

La pyramide d'images n'est rien d'autre qu'une méthode pour afficher une image multi-résolution. La couche la plus basse est une version de l'image à la plus haute résolution et la couche la plus haute est une version à la résolution la plus basse de l'image. Les pyramides d'images sont utilisées pour gérer l'image à différentes échelles.

Dans ce chapitre, nous effectuons un sous-échantillonnage et un échantillonnage à la hausse sur les images.

Nous utilisons OpenCV les fonctions pyrUp et pyrDown. Ils peuvent être trouvés sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

Imgproc.pyrUp(source, destination, destinationSize);
Imgproc.pyrDown(source, destination,destinationSize);

Les paramètres sont décrits ci-dessous -

Sr.No. Paramètre et description
1

source

C'est l'image source.

2

destination

C'est l'image de destination.

3

destinationSize

C'est la taille de l'image de sortie. Par défaut, il est calculé comme Size ((src.cols * 2), (src.rows * 2)).

Outre les méthodes pyrUp et pyrDown, il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour effectuer un échantillonnage ascendant et un échantillonnage inférieur sur une image.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.core.Size;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class main {
   public static void main( String[] args ) {
   
      try{
      
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         Mat source = Highgui.imread("digital_image_processing.jpg",
         Highgui.CV_LOAD_IMAGE_COLOR);
         
         Mat destination1 = new Mat(source.rows()*2, source.cols()*2,source.type());
         destination1 = source;
         
         Imgproc.pyrUp(source, destination1, new  Size(source.cols()*2   source.rows()*2));
         Highgui.imwrite("pyrUp.jpg", destination1);
         
         source = Highgui.imread("digital_image_processing.jpg", 
         Highgui.CV_LOAD_IMAGE_COLOR);
         
         Mat destination = new Mat(source.rows()/2,source.cols()/2, source.type());
         destination = source;
         Imgproc.pyrDown(source, destination, new Size(source.cols()/2,  source.rows()/2));
         Highgui.imwrite("pyrDown.jpg", destination);
         
      } catch (Exception e) { 
         System.out.println("error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Sur l'image d'origine, pyrUp (échantillonnage vers le haut) et pyrDown (échantillonnage vers le bas) sont exécutés. La sortie après échantillonnage est comme indiqué ci-dessous -

Image PyrUP

Image pyrDown

Le seuillage permet de réaliser la segmentation d'image de la manière la plus simple. La segmentation d'image signifie la division de l'image complète en un ensemble de pixels de telle sorte que les pixels de chaque ensemble aient des caractéristiques communes. La segmentation d'image est très utile pour définir les objets et leurs limites.

Dans ce chapitre, nous effectuons quelques opérations de seuillage de base sur les images.

Nous utilisons OpenCV fonction threshold. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

Imgproc.threshold(source, destination, thresh , maxval , type);

Les paramètres sont décrits ci-dessous -

Sr.No. Paramètre et description
1

source

C'est l'image source.

2

destination

C'est l'image de destination.

3

thresh

C'est la valeur seuil.

4

maxval

Il s'agit de la valeur maximale à utiliser avec les types de seuil THRESH_BINARY et THRESH_BINARY_INV.

5

type

Les types possibles sont THRESH_BINARY, THRESH_BINARY_INV, THRESH_TRUNC et THRESH_TOZERO.

Outre ces méthodes de seuillage, il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int ddepth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour effectuer des opérations de seuillage sur une image -

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class main {
   public static void main( String[] args ) {
   
      try{

         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         Mat source = Highgui.imread("digital_image_processing.jpg",  Highgui.CV_LOAD_IMAGE_COLOR);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());

         destination = source;
         Imgproc.threshold(source,destination,127,255,Imgproc.THRESH_TOZERO);
         Highgui.imwrite("ThreshZero.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Sur l'image originale ci-dessus, certaines opérations de seuillage sont effectuées, ce qui est indiqué dans la sortie ci-dessous -

Thresh Binaire

Inverser binaire Thresh

Thresh Zero

La forme de l'image peut facilement être modifiée en utilisant OpenCV. L'image peut être inversée, mise à l'échelle ou pivotée dans l'une des quatre directions.

Afin de changer la forme de l'image, nous lisons l'image et la convertissons en objet Mat. Sa syntaxe est donnée ci-dessous -

File input = new File("digital_image_processing.jpg");
BufferedImage image = ImageIO.read(input);
//convert Buffered Image to Mat.

Retourner une image

OpenCV permet trois types de flip codes qui sont décrits ci-dessous -

Sr.No. Flip Code et Description
1

0

0 signifie, retournement autour de l'axe x.

2

1

1 signifie basculement autour de l'axe y.

3

-1

-1 signifie, retournement autour des deux axes.

Nous passons le code flip approprié dans la méthode flip() dans le Coreclasse. Sa syntaxe est donnée ci-dessous -

Core.flip(source mat, destination mat1, flip_code);

La méthode flip() prend trois paramètres - la matrice d'image source, la matrice d'image de destination et le code de retournement.

En dehors de la méthode flip, il existe d'autres méthodes fournies par la classe Core. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

add(Mat src1, Mat src2, Mat dst)

Il calcule la somme par élément de deux tableaux ou d'un tableau et d'un scalaire.

2

bitwise_and(Mat src1, Mat src2, Mat dst)

Il calcule la conjonction bit par élément par élément de deux tableaux ou d'un tableau et d'un scalaire.

3

bitwise_not(Mat src, Mat dst)

Il inverse chaque bit d'un tableau.

4

circle(Mat img, Point center, int radius, Scalar color)

Il trace un cercle.

5

sumElems(Mat src)

Il brouille une image à l'aide d'un filtre gaussien.

6

subtract(Mat src1, Scalar src2, Mat dst, Mat mask)

Il calcule la différence par élément entre deux tableaux ou tableaux et un scalaire.

Exemple

L'exemple suivant illustre l'utilisation de la classe Core pour retourner une image -

import java.awt.image.BufferedImage;
import java.awt.image.DataBufferByte;

import java.io.File;
import javax.imageio.ImageIO;

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.imgproc.Imgproc;

public class Main {
   public static void main( String[] args ) {
   
      try {
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         File input = new File("digital_image_processing.jpg");
         BufferedImage image = ImageIO.read(input);	

         byte[] data = ((DataBufferByte) image.getRaster().  getDataBuffer()).getData();
         Mat mat = new Mat(image.getHeight(),image.getWidth(),CvType.CV_8UC3);
         mat.put(0, 0, data);

         Mat mat1 = new Mat(image.getHeight(),image.getWidth(),CvType.CV_8UC3);
         Core.flip(mat, mat1, -1);

         byte[] data1 = new byte[mat1.rows()*mat1.cols()*(int)(mat1.elemSize())];
         mat1.get(0, 0, data1);
         BufferedImage image1 = new BufferedImage(mat1.cols(), mat1.rows(), 5);
         image1.getRaster().setDataElements(0,0,mat1.cols(),mat1.rows(),data1);

         File ouptut = new File("hsv.jpg");
         ImageIO.write(image1, "jpg", ouptut);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez l'exemple ci-dessus, le nom d'une image est inversé digital_image_processing.jpg à son image d'espace colorimétrique HSV équivalente et écrivez-la sur le disque dur avec le nom flip.jpg.

Image originale

Image inversée

Dans ce chapitre, nous appliquons un filtre gaussien à une image qui brouille une image. Nous allons utiliser la fonction OpenCV GaussianBlur pour appliquer un filtre gaussien aux images. Il peut être trouvé sous le package Imgproc. Sa syntaxe est donnée ci-dessous -

Imgproc.GaussianBlur(source, destination,Size,SigmaX);

Les arguments de la fonction sont décrits ci-dessous -

Sr.No. Argument et description
1

source

C'est l'image source.

2

destination

C'est l'image de destination.

3

Size

C'est la taille du noyau gaussien.

4

SigmaX

C'est l'écart type du noyau gaussien dans la direction X.

Outre la méthode GaussianBlur, il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour appliquer un filtre gaussien à une image.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.core.Size;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;


public class Main {
   public static void main( String[] args ) {
   
      try {
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("digital_image_processing.jpg",
         Highgui.CV_LOAD_IMAGE_COLOR);
         
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         Imgproc.GaussianBlur(source, destination,new Size(45,45), 0);
         Highgui.imwrite("Gaussian45.jpg", destination);
      
      } catch (Exception e) {
         System.out.println("Error:" + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Lorsque cette image originale est convoluée avec le filtre gaussien de taille 11 et 45, la sortie suivante est vue.

Filtre gaussien de taille 11

Filtre gaussien de taille 45

Nous appliquons un filtre Box qui brouille une image. Un filtre Box peut être de dimensions 3x3, 5x5, 9x9 etc.

Nous utilisons OpenCV fonction filter2Dpour appliquer le filtre Box aux images. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

filter2D(src, dst, depth , kernel, anchor, delta, BORDER_DEFAULT );

Les arguments de la fonction sont décrits ci-dessous -

Sr.No. Argument et description
1

src

C'est l'image source.

2

dst

C'est l'image de destination.

3

depth

C'est la profondeur de dst. Une valeur négative (telle que -1) indique que la profondeur est la même que la source.

4

kernel

C'est le noyau à scanner à travers l'image.

5

anchor

C'est la position de l'ancre par rapport à son noyau. Le point de localisation (-1, -1) indique le centre par défaut.

6

delta

C'est une valeur à ajouter à chaque pixel lors de la convolution. Par défaut, il est 0.

sept

BORDER_DEFAULT

Nous laissons cette valeur par défaut.

En dehors de la méthode filter2D (), il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour appliquer le filtre Boîte à une image en niveaux de gris.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class convolution {
   public static void main( String[] args ) {
   
      try {
         int kernelSize = 9;
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("grayscale.jpg",  Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         Mat kernel = Mat.ones(kernelSize,kernelSize, CvType.CV_32F);	      
         
         for(int i=0; i<kernel.rows(); i++) {
            for(int j=0; j<kernel.cols(); j++) {
            
               double[] m = kernel.get(i, j);
               
               for(int k =0; k<m.length; k++) {
                  m[k] = m[k]/(kernelSize * kernelSize);
               }
               kernel.put(i,j, m);
            }
         }	   
         
         Imgproc.filter2D(source, destination, -1, kernel);
         Highgui.imwrite("output.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Dans cet exemple, nous convoluons notre image avec le filtre suivant (noyau). Ce filtre a pour effet de rendre l'image floue à mesure que sa taille augmente.

Cette image originale a été convoluée avec le filtre de boîte de taille 5, qui est donné ci-dessous -

Boîte filtre de taille 5

1/25 1/25 1/25 1/25 1/25
1/25 1/25 1/25 1/25 1/25
1/25 1/25 1/25 1/25 1/25
1/25 1/25 1/25 1/25 1/25
1/25 1/25 1/25 1/25 1/25

Image convolue (avec filtre de boîte de taille 5)

Image convoluée (avec filtre de boîte de taille 9)

Dans ce chapitre, nous apprenons à appliquer deux opérateurs de morphologie très courants: la dilatation et l'érosion.

Nous utilisons OpenCV fonction erode et dilate. Ils peuvent être trouvés sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

Imgproc.erode(source, destination, element);
Imgproc.dilate(source, destination, element);

Les paramètres sont décrits ci-dessous -

Sr.No. Paramètre et description
1

source

C'est l'image source.

2

destination

C'est l'image de destination.

3

element

C'est un élément structurant utilisé pour l'érosion et la dilatation, si element = Mat (), un élément structurant rectangulaire 3 x 3 est utilisé.

Outre les méthodes erode () et dilate (), il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour effectuer une érosion et une dilatation sur une image -

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class main {
   public static void main( String[] args ) {
   
      try{	
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         Mat source = Highgui.imread("digital_image_processing.jpg",  Highgui.CV_LOAD_IMAGE_COLOR);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         
         destination = source;

         int erosion_size = 5;
         int dilation_size = 5;
         
         Mat element = Imgproc.getStructuringElement(Imgproc.MORPH_RECT, new  Size(2*erosion_size + 1, 2*erosion_size+1));
         Imgproc.erode(source, destination, element);
         Highgui.imwrite("erosion.jpg", destination);

         source = Highgui.imread("digital_image_processing.jpg",  Highgui.CV_LOAD_IMAGE_COLOR);
         
         destination = source;
         
         Mat element1 = Imgproc.getStructuringElement(Imgproc.MORPH_RECT, new  Size(2*dilation_size + 1, 2*dilation_size+1));
         Imgproc.dilate(source, destination, element1);
         Highgui.imwrite("dilation.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("error:" + e.getMessage());
      } 
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Sur l'image originale ci-dessus, certaines opérations d'érosion et de dilatation ont été effectuées qui ont été montrées dans la sortie ci-dessous -

Érosion

Dilatation

Dans ce chapitre, nous apprenons deux façons d'appliquer un filigrane sur des images. Ces moyens sont -

  • Application d'un filigrane de texte
  • Application d'un filigrane d'image

Application d'un filigrane de texte

Nous utilisons OpenCV fonction putTextpour appliquer un filigrane de texte à l'image. Il peut être trouvé sousCorepaquet. Sa syntaxe est donnée ci-dessous -

Core.putText(source, Text, Point, fontFace ,fontScale , color);

Les paramètres de cette fonction sont décrits ci-dessous -

Sr.No. Paramètre et description
1

Source

C'est l'image source.

2

Text

C'est la chaîne de texte qui apparaîtrait sur l'image.

3

Point

C'est le point où le texte doit apparaître sur l'image.

4

fontFace

Type de police. Par exemple - FONT_HERSHEY_SIMPLEX, FONT_HERSHEY_PLAIN, FONT_HERSHEY_COMPLEX etc.

5

fontScale

C'est le facteur d'échelle de la police qui est multiplié par la taille de base spécifique à la police.

6

color

C'est la couleur du texte.

En dehors de la méthode putText, il existe d'autres méthodes fournies par la classe Core. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

normalize(Mat src, Mat dst, double alpha, double beta, int norm_type)

Il normalise la norme ou la plage de valeurs d'un tableau.

2

perspectiveTransform(Mat src, Mat dst, Mat m)

Il effectue la transformation matricielle de perspective des vecteurs.

3

phase(Mat x, Mat y, Mat angle)

Il calcule l'angle de rotation des vecteurs 2D.

4

rectangle(Mat img, Point pt1, Point pt2, Scalar color)

Il dessine un rectangle haut-droit simple, épais ou rempli.

5

reduce(Mat src, Mat dst, int dim, int rtype, int dtype)

Il réduit une matrice à un vecteur.

6

transform(Mat src, Mat dst, Mat m)

Il effectue la transformation matricielle de chaque élément du tableau.

Exemple

L'exemple suivant illustre l'utilisation de la classe Core pour appliquer un filigrane de texte à une image -

import org.opencv.core.Core;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class Main {
   public static void main( String[] args ) {
   
      try{
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         Mat source = Highgui.imread("digital_image_processing.jpg",  Highgui.CV_LOAD_IMAGE_COLOR);
         Mat destination = new Mat(source.rows(),source.cols(), source.type());  
         
         Core.putText(source, "Tutorialspoint.com", new Point  (source.rows()/2,source.cols()/2), Core.FONT_ITALIC,new Double(1),new  Scalar(255));

         Highgui.imwrite("watermarked.jpg", source);
         
      } catch (Exception e) {
         System.out.println("Error: "+e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Image en filigrane de texte

Application d'un filigrane d'image sur l'image

Nous allons utiliser OpenCV fonction addWeightedpour appliquer un filigrane d'image à l'image. Il peut être trouvé sousCorepaquet. Sa syntaxe est donnée ci-dessous -

Core.addWeighted(InputArray src1, alpha, src2 (Watermark image), beta, gamma, OutputArray dst);

Les paramètres de cette fonction sont décrits ci-dessous -

Sr.No. Paramètre et description
1

src1

C'est le premier tableau d'entrée.

2

alpha

C'est le poids des premiers éléments du tableau.

3

src2

C'est le deuxième tableau d'entrée de la même taille et du même numéro de canal que src1.

4

beta

C'est le poids des deuxièmes éléments du tableau.

5

gamma

C'est le scalaire ajouté à chaque somme.

6

dst

C'est le tableau de sortie qui a la même taille et le même nombre de canaux que les tableaux d'entrée.

Exemple

L'exemple suivant illustre l'utilisation de la classe Core pour appliquer un filigrane d'image à une image -

import org.opencv.core.Core;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class Main {
   public static void main( String[] args ) {
   
      try{
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("digital_image_processing.jpg",  Highgui.CV_LOAD_IMAGE_COLOR);
         Mat waterMark = Highgui.imread("watermark.png",  Highgui.CV_LOAD_IMAGE_COLOR);
         Rect ROI = new Rect(waterMark.rows() * 4,waterMark.cols(),  waterMark.cols(),waterMark.rows());
         
         Core.addWeighted(source.submat(ROI), 0.8, waterMark, 0.2, 1,  source.submat(ROI));
         Highgui.imwrite("watermarkedImage.jpg", source);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

L'image du filigrane

Image en filigrane

La convolution est une opération mathématique sur deux fonctions f et g. Les fonctions f et g dans ce cas sont des images, car une image est également une fonction bidimensionnelle.

Exécution de la convolution

Afin d'effectuer la convolution sur une image, les étapes suivantes sont effectuées -

  • Retournez le masque (horizontalement et verticalement) une seule fois.
  • Faites glisser le masque sur l'image.
  • Multipliez les éléments correspondants puis ajoutez-les.
  • Répétez cette procédure jusqu'à ce que toutes les valeurs de l'image aient été calculées.

Nous utilisons OpenCV fonction filter2Dpour appliquer la convolution aux images. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

filter2D(src, dst, depth , kernel, anchor, delta, BORDER_DEFAULT );

Les arguments de la fonction sont décrits ci-dessous -

Sr.No. Argument et description
1

src

C'est l'image source.

2

dst

C'est l'image de destination.

3

depth

C'est la profondeur de dst. Une valeur négative (telle que -1) indique que la profondeur est la même que la source.

4

kernel

C'est le noyau à scanner à travers l'image.

5

anchor

C'est la position de l'ancre par rapport à son noyau. Le point de localisation (-1, -1) indique le centre par défaut.

6

delta

C'est une valeur à ajouter à chaque pixel lors de la convolution. Par défaut, il est 0.

sept

BORDER_DEFAULT

Nous laissons cette valeur par défaut.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour effectuer la convolution sur une image en niveaux de gris.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class convolution {
   public static void main( String[] args ) {
   
      try {
         int kernelSize = 3;
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("grayscale.jpg",  Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         
         Mat kernel = new Mat(kernelSize,kernelSize, CvType.CV_32F) {
            {
               put(0,0,0);
               put(0,1,0);
               put(0,2,0);

               put(1,0,0);
               put(1,1,1);
               put(1,2,0);

               put(2,0,0);
               put(2,1,0);
               put(2,2,0);
            }
         };
         
         Imgproc.filter2D(source, destination, -1, kernel);
         Highgui.imwrite("original.jpg", destination);
         
      } catch (Exception e) {
          System.out.println("Error:" + e.getMessage());
      }
   }
}

Production

Dans cet exemple, nous convoluons notre image avec le filtre suivant (noyau). Ce filtre permet de produire l'image originale telle quelle -

0 0 0
0 1 0
0 0 0

Image originale

Image convoluée

L'opérateur Prewitt est utilisé pour la détection des contours dans une image. Il détecte deux types de bords: les bords verticaux et les bords horizontaux.

Nous utilisons OpenCV fonction filter2Dpour appliquer l'opérateur Prewitt aux images. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

filter2D(src, dst, depth , kernel, anchor, delta, BORDER_DEFAULT );

Les arguments de la fonction sont décrits ci-dessous -

Sr.No. Argument et description
1

src

C'est l'image source.

2

dst

C'est l'image de destination.

3

depth

C'est la profondeur de dst. Une valeur négative (telle que -1) indique que la profondeur est la même que la source.

4

kernel

C'est le noyau à scanner à travers l'image.

5

anchor

C'est la position de l'ancre par rapport à son noyau. Le point de localisation (-1, -1) indique le centre par défaut.

6

delta

C'est une valeur à ajouter à chaque pixel lors de la convolution. Par défaut, il est 0.

sept

BORDER_DEFAULT

Nous laissons cette valeur par défaut.

En dehors de la méthode filter2D, il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour appliquer l'opérateur Prewitt à une image de niveaux de gris.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class convolution {
   public static void main( String[] args ) {
      try {
         int kernelSize = 9;
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("grayscale.jpg", Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         
         Mat kernel = new Mat(kernelSize,kernelSize, CvType.CV_32F) {
            {
               put(0,0,-1);
               put(0,1,0);
               put(0,2,1);

               put(1,0-1);
               put(1,1,0);
               put(1,2,1);

               put(2,0,-1);
               put(2,1,0);
               put(2,2,1);
            }
         };	 
         
         Imgproc.filter2D(source, destination, -1, kernel);
         Highgui.imwrite("output.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Cette image originale est convoluée avec l'opérateur Prewitt des bords verticaux comme indiqué ci-dessous -

Direction verticale

-1 0 1
-1 0 1
-1 0 1

Image convolue (direction verticale)

Cette image originale a également été convoluée avec l'opérateur Prewitt des bords horizontaux, qui est donné ci-dessous -

Direction horizontale

-1 -1 -1
0 0 0
1 1 1

Image convoluée (direction horizontale)

L'opérateur Sobel est très similaire à l'opérateur Prewitt. C'est également un masque dérivé et est utilisé pour la détection des contours. L'opérateur Sobel est utilisé pour détecter deux types de bords dans une image: les bords de direction verticale et les bords de direction horizontale.

Nous allons utiliser OpenCV fonction filter2Dpour appliquer l'opérateur Sobel aux images. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

filter2D(src, dst, depth , kernel, anchor, delta, BORDER_DEFAULT );

Les arguments de la fonction sont décrits ci-dessous -

Sr.No. Argument
1

src

C'est l'image source.

2

dst

C'est l'image de destination.

3

depth

C'est la profondeur de dst. Une valeur négative (telle que -1) indique que la profondeur est la même que la source.

4

kernel

C'est le noyau à scanner à travers l'image.

5

anchor

C'est la position de l'ancre par rapport à son noyau. Le point de localisation (-1, -1) indique le centre par défaut.

6

delta

C'est une valeur à ajouter à chaque pixel lors de la convolution. Par défaut, il est 0.

sept

BORDER_DEFAULT

Nous laissons cette valeur par défaut.

En dehors de la méthode filter2D, il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour appliquer l'opérateur Sobel à une image en niveaux de gris.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class convolution {
   public static void main( String[] args ) {
   
      try {
         int kernelSize = 9;
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("grayscale.jpg",  Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         
         Mat kernel = new Mat(kernelSize,kernelSize, CvType.CV_32F) {
            {
               put(0,0,-1);
               put(0,1,0);
               put(0,2,1);

               put(1,0-2);
               put(1,1,0);
               put(1,2,2);

               put(2,0,-1);
               put(2,1,0);
               put(2,2,1);
            }
         };	      
         
         Imgproc.filter2D(source, destination, -1, kernel);
         Highgui.imwrite("output.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Cette image originale est convoluée avec l'opérateur Sobel des bords verticaux, qui est donné ci-dessous -

Direction verticale

-1 0 1
-2 0 2
-1 0 1

Image convolue (direction verticale)

Cet original est convolu avec l'opérateur Sobel d'arêtes horizontales, qui est donné ci-dessous -

Direction horizontale

-1 -2 -1
0 0 0
1 2 1

Image convoluée (direction horizontale)

Les masques de boussole de Kirsch sont encore un autre type de masque dérivé utilisé pour la détection des contours. Cet opérateur est également appelé masque de direction. Dans cet opérateur, nous prenons un masque et le faisons pivoter dans les huit directions de la boussole pour obtenir les bords des huit directions.

Nous allons utiliser OpenCV fonction filter2Dpour appliquer l'opérateur Kirsch aux images. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

filter2D(src, dst, depth , kernel, anchor, delta, BORDER_DEFAULT );

Les arguments de la fonction sont décrits ci-dessous -

Sr.No. Argument
1

src

C'est l'image source.

2

dst

C'est l'image de destination.

3

depth

C'est la profondeur de dst. Une valeur négative (telle que -1) indique que la profondeur est la même que la source.

4

kernel

C'est le noyau à scanner à travers l'image.

5

anchor

C'est la position de l'ancre par rapport à son noyau. Le point de localisation (-1, -1) indique le centre par défaut.

6

delta

C'est une valeur à ajouter à chaque pixel lors de la convolution. Par défaut, il est 0.

sept

BORDER_DEFAULT

Nous laissons cette valeur par défaut.

En dehors de la méthode filter2D (), il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour appliquer l'opérateur Kirsch à une image de niveaux de gris.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class convolution {
   public static void main( String[] args ) {
   
      try {
         int kernelSize = 9;
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("grayscale.jpg",  Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         
         Mat kernel = new Mat(kernelSize,kernelSize, CvType.CV_32F) {
            {
               put(0,0,-3);
               put(0,1,-3);
               put(0,2,-3);
      
               put(1,0-3);
               put(1,1,0);
               put(1,2,-3);

               put(2,0,5);
               put(2,1,5);
               put(2,2,5);
            }
         };	      
         
         Imgproc.filter2D(source, destination, -1, kernel);
         Highgui.imwrite("output.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Cette image originale est convoluée avec l'opérateur de Kirsch des bords est, qui, comme indiqué ci-dessous -

Kirsch Est

-3 -3 -3
-3 0 -3
5 5 5

Image convoluée (Kirsch Est)

Cette image originale est convoluée avec l'opérateur Kirsch des bords sud-ouest, qui, comme indiqué ci-dessous -

Kirsch Sud-Ouest

5 5 -3
5 0 -3
-3 -3 -3

Image convoluée (Kirsch Sud-Ouest)

Les masques de boussole Robinson sont encore un autre type de masques dérivés qui sont utilisés pour la détection des contours. Cet opérateur est également appelé masque de direction. Dans cet opérateur, nous prenons un masque et le faisons pivoter dans les huit directions principales pour obtenir les bords des huit directions.

Nous allons utiliser OpenCV fonction filter2Dpour appliquer l'opérateur Robinson aux images. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

filter2D(src, dst, depth , kernel, anchor, delta, BORDER_DEFAULT );

Les arguments de la fonction sont décrits ci-dessous -

Sr.No. Argument et description
1

src

C'est l'image source.

2

dst

C'est l'image de destination.

3

depth

C'est la profondeur de dst. Une valeur négative (telle que -1) indique que la profondeur est la même que la source.

4

kernel

C'est le noyau à scanner à travers l'image.

5

anchor

C'est la position de l'ancre par rapport à son noyau. Le point de localisation (-1, -1) indique le centre par défaut.

6

delta

C'est une valeur à ajouter à chaque pixel lors de la convolution. Par défaut, il est 0.

sept

BORDER_DEFAULT

Nous laissons cette valeur par défaut.

Outre la méthode filter2D, il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour appliquer l'opérateur Robinson à une image de niveaux de gris.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class convolution {
   public static void main( String[] args ) {
   
      try {
         int kernelSize = 9;
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("grayscale.jpg",  Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         
         Mat kernel = new Mat(kernelSize,kernelSize, CvType.CV_32F) {
            {
               put(0,0,-1);
               put(0,1,0);
               put(0,2,1);

               put(1,0-2);
               put(1,1,0);
               put(1,2,2);

               put(2,0,-1);
               put(2,1,0);
               put(2,2,1);
            }
         };	      
         
         Imgproc.filter2D(source, destination, -1, kernel);
         Highgui.imwrite("output.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Cette image originale est convoluée avec l'opérateur Robinson des arêtes nord comme indiqué ci-dessous -

Masque de direction nord

-1 0 1
-2 0 2
-1 0 1

Image convoluée (Robinson Nord)

Cette image originale a également été convoluée avec l'opérateur Robinson des bords est comme indiqué ci-dessous -

Masque de direction est

-1 -2 -1
0 0 0
1 2 1

Image convoluée (Robinson East)

L'opérateur laplacien est également un opérateur dérivé utilisé pour trouver les bords d'une image. La principale différence entre laplacien et d'autres opérateurs comme Prewitt, Sobel, Robinson et Kirsch est que ce sont tous des masques dérivés du premier ordre, mais le laplacien est un masque dérivé du second ordre.

Nous utilisons OpenCV fonction filter2Dpour appliquer l'opérateur laplacien aux images. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

filter2D(src, dst, depth , kernel, anchor, delta, BORDER_DEFAULT );

Les arguments de la fonction sont décrits ci-dessous -

Sr.No. Arguments
1

src

C'est l'image source.

2

dst

C'est l'image de destination.

3

depth

C'est la profondeur de dst. Une valeur négative (telle que -1) indique que la profondeur est la même que la source.

4

kernel

C'est le noyau à scanner à travers l'image.

5

anchor

C'est la position de l'ancre par rapport à son noyau. Le point de localisation (-1, -1) indique le centre par défaut.

6

delta

C'est une valeur à ajouter à chaque pixel lors de la convolution. Par défaut, il est 0.

sept

BORDER_DEFAULT

Nous laissons cette valeur par défaut.

En dehors de la méthode filter2D (), il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour appliquer l'opérateur laplacien à une image de niveaux de gris.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class convolution {
   public static void main( String[] args ) {
   
      try {
         int kernelSize = 9;
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("grayscale.jpg",  Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());

         Mat kernel = new Mat(kernelSize,kernelSize, CvType.CV_32F) {
            {
               put(0,0,0);
               put(0,1,-1)
               put(0,2,0);

               put(1,0-1);
               put(1,1,4);
               put(1,2,-1);

               put(2,0,0);
               put(2,1,-1);
               put(2,2,0);
            }
         };	      
         
         Imgproc.filter2D(source, destination, -1, kernel);
         Highgui.imwrite("output.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Cette image originale est convoluée avec l'opérateur Négatif Laplacien comme indiqué ci-dessous -

Négatif laplacien

0 -1 0
-1 4 -1
0 -1 0

Image convolue (négatif laplacien)

Cette image originale est convoluée avec l'opérateur positif laplacien comme indiqué ci-dessous -

Laplacien positif

0 1 0
1 -4 1
0 1 0

Image convoluée (Laplacian Positive)

Dans le filtre moyen pondéré, nous avons donné plus de poids à la valeur centrale, grâce à laquelle la contribution du centre devient plus importante que le reste des valeurs. Grâce au filtrage moyen pondéré, nous pouvons contrôler le flou de l'image.

Nous utilisons OpenCV fonction filter2Dpour appliquer un filtre moyen pondéré aux images. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

filter2D(src, dst, depth , kernel, anchor, delta, BORDER_DEFAULT );

Les arguments de la fonction sont décrits ci-dessous -

Sr.No. Argument et description
1

src

C'est l'image source.

2

dst

C'est l'image de destination.

3

ddepth

C'est la profondeur de dst. Une valeur négative (telle que -1) indique que la profondeur est la même que la source.

4

kernel

C'est le noyau à scanner à travers l'image.

5

anchor

C'est la position de l'ancre par rapport à son noyau. Le point de localisation (-1, -1) indique le centre par défaut.

6

delta

C'est une valeur à ajouter à chaque pixel lors de la convolution. Par défaut, il est 0.

sept

BORDER_DEFAULT

Nous laissons cette valeur par défaut.

En dehors de la méthode filter2D (), il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour appliquer un filtre moyen pondéré à une image de Graycale.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class convolution {
   public static void main( String[] args ) {
   
      try {
         int kernelSize = 9;
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("grayscale.jpg",  Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         
         Mat kernel = Mat.ones(kernelSize,kernelSize, CvType.CV_32F) {	      
         
         for(int i=0; i<kernel.rows(); i++) {
            for(int j=0; j<kernel.cols(); j++) {

               double[] m = kernel.get(i, j);

               for(int k =0; k<m.length; k++) {

                  if(i==1 && j==1) {
                     m[k] = 10/18;
                  }
                  else{
                     m[k] = m[k]/(18);
                  }
               }
               kernel.put(i,j, m);

               }
            }	
         };	      
         
         Imgproc.filter2D(source, destination, -1, kernel);
         Highgui.imwrite("output.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Cette image originale est convoluée avec le filtre moyen pondéré comme indiqué ci-dessous -

Filtre moyen pondéré

1 1 1
1 dix 1
1 1 1

Image convoluée

Le zoom est le processus d'agrandissement d'une image afin que les détails de l'image deviennent plus visibles et proéminents.

Nous utilisons OpenCV fonction resizepour appliquer le zoom aux images. Il peut être trouvé sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

Imgproc.resize(source,destination, destination.size(),zoomFactor,zoomFactor,Interpolation);

Dans la fonction de redimensionnement, nous transmettons l'image source, l'image de destination et sa taille, le facteur de zoom et la méthode d'interpolation à utiliser.

Les méthodes d'interpolation disponibles sont décrites ci-dessous -

Sr.No. Méthode d'interpolation et description
1

INTER_NEAREST

C'est l'interpolation du plus proche voisin.

2

INTER_LINEAR

Il s'agit d'une interpolation bilinéaire (utilisée par défaut).

3

INTER_AREA

Il rééchantillonne en utilisant la relation de zone de pixel. C'est peut-être une méthode préférée pour la décimation d'image, car elle donne des résultats plus libres.

4

INTER_CUBIC

Il s'agit d'une interpolation bi-cubique sur un voisinage de 4 x 4 pixels.

5

INTER_LANCZOS4

C'est une interpolation de Lanczos sur un voisinage de 8x8 pixels.

Outre la méthode de redimensionnement, il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int ddepth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour appliquer le zoom à une image.

import org.opencv.core.Core;
import org.opencv.core.Mat;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class Main {
   public static void main( String[] args ) {
   
      try {
         int zoomingFactor = 2;
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("image.jpg", Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows() * zoomingFactor, source.cols()*  zoomingFactor,source.type());  
         
         Imgproc.resize(source, destination, destination.size(),  zoomingFactor,zoomingFactor,Imgproc.INTER_NEAREST);
         Highgui.imwrite("zoomed.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("Error: "+e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Image agrandie (facteur de zoom - 2)

Dans ce chapitre, nous explorons certaines des bibliothèques de traitement d'images gratuites qui sont largement utilisées et peuvent être facilement intégrées dans le projet. Ces bibliothèques comprennent -

  • ImageJ
  • Fiji
  • Imagerie Commons
  • ImageMagick
  • Endrov
  • LeadTools
  • OpenCv

ImageJ

ImageJ est un programme de traitement d'image Java du domaine public inspiré de NIH Image pour Macintosh. Il peut afficher, éditer, analyser, traiter, enregistrer et imprimer des images 8 bits, 16 bits et 32 ​​bits.

Certaines des fonctionnalités de base d'ImageJ sont décrites ci-dessous -

Sr.No. Description des fonctions
1

Runs Everywhere

ImageJ est écrit en Java, ce qui lui permet de fonctionner sous Linux, Mac OS X et Windows, en modes 32 bits et 64 bits.

2

Open Source

ImageJ et son code source Java sont disponibles gratuitement et dans le domaine public.

3

Toolkit

Utilisez ImageJ comme boîte à outils de traitement d'image (bibliothèque de classes) pour développer des applets, des servlets ou des applications.

4

Data Types

Niveaux de gris 8 bits ou couleur indexée, entier non signé 16 bits, virgule flottante 32 bits et couleur RVB.

5

File Formats

Ouvrez et enregistrez les fichiers GIF, JPEG, BMP, PNG, PGM, FITS et ASCII. Ouvrez DICOM. Ouvrez les fichiers TIFF, GIF, JPEG, DICOM et les données brutes à l'aide d'une URL.

6

Selections

Créez des sélections de zones rectangulaires, elliptiques ou irrégulières. Créez des sélections de lignes et de points.

sept

Image Enhancement

Prend en charge le lissage, la netteté, la détection des contours, le filtrage médian et le seuillage sur les images en niveaux de gris 8 bits et RVB.

8

Color Processing

Divisez une image couleur 32 bits en composants RVB ou HSV. Fusionnez les composants 8 bits dans une image couleur.

Fidji

Fidji est un logiciel de traitement d'image. Il peut être décrit comme une distribution d'ImageJ (et ImageJ2) avec Java, Java3D et de nombreux plug-ins organisés dans une structure de menu cohérente. Fidji se compare à ImageJ comme Ubuntu se compare à Linux.

Outre les fonctionnalités de base d'ImageJ, certaines des fonctionnalités avancées de Fidji sont décrites ci-dessous -

Sr.No. Description des fonctions
1

Registering 3D images

Cela implique l'alignement et le montage élastiques, l'extraction de caractéristiques, le stabilisateur d'image, etc.

2

Segmenting images

Il propose plus de 35 types de segmentation.

3

Useful keyboard short cuts

Fuji propose de nombreux raccourcis clavier.

4

Scripting

Autoriser les scripts avec des macros, en JavaScript, JRuby, Jython, Clojure et Beanshell.

5

Developing Plug-ins

Utilisez l'éditeur de script pour commencer à développer des plug-ins, puis exécutez les plug-ins.

6

ImageJ Tricks

ImageJ est facile à utiliser, mais parfois vous souhaitez une fonction réellement implémentée, mais vous ne savez pas comment déclencher.

Imagerie Commons

Apache Commons Imaging, anciennement connu sous le nom d'Apache Commons Sanselan, est une bibliothèque qui lit et écrit une variété de formats d'image, y compris l'analyse rapide des informations d'image telles que (taille, couleur, espace, profil ICC, etc.) et les métadonnées.

Certaines des fonctionnalités de base d'ImageJ sont décrites ci-dessous -

Sr.No. Description des fonctions
1

Java

Apache Commons Imaging est écrit en Java 100% pur. Il s'exécute sur n'importe quelle JVM, et n'importe quelle plateforme, sans modification.

2

Image Formats

Il lit et écrit une grande variété de formats d'image et prend en charge certaines variations et encodages manqués par toutes ou la plupart des autres bibliothèques.

3

Metadata support

Il prend en charge la lecture et l'écriture d'une variété de métadonnées de manière structurée, y compris les métadonnées EXIF.

4

Network Friendly

Il est compatible avec le réseau. Commons Imaging ne lit que les données dont il a besoin et met en cache ce qui est lu afin qu'il ne soit pas trop lourd sur le réseau.

5

Easy to use

Il est conçu pour être très facile à utiliser. Il a une interface simple et propre. La plupart des opérations consistent en un seul appel de méthode de création d'image.

6

Transparent

Commons Imaging vise à être transparent. Il n'y a pas de tampons cachés à éliminer, pas de mémoire native à libérer, pas de threads d'arrière-plan.

sept

Open Source

C'est un logiciel libre / open source. Il est disponible sous la licence logicielle Apache.

8

Color Conversions

La classe ColorConversions propose des méthodes de conversion entre les espaces colorimétriques suivants - CIE-L * CH, CIE-L * ab, CIE-L * uv, CMY, CMYK, HSL, HSV, Hunter-Lab, RGB, XYZ et YXY.

ImageMagick

ImageMagick est une suite logicielle pour créer, éditer, composer ou convertir des images bitmap. Il peut lire et écrire des images dans plus de 100 formats, notamment DPX, EXR, GIF, JPEG, JPEG-2000, PDF, PNG, Postscript, SVG et TIFF. Utilisez ImageMagick pour redimensionner, retourner, mettre en miroir, faire pivoter, déformer, cisailler et transformer des images, ajuster les couleurs de l'image, appliquer divers effets spéciaux ou dessiner du texte, des lignes, des polygones, des ellipses et une courbe de Bézier.

Certaines des fonctionnalités de base d'ImageMagick sont décrites ci-dessous -

Sr.No. Description des fonctions
1

Format conversion

Il convertit une image d'un format à un autre (par exemple PNG en JPEG).

2

Transform

Il peut redimensionner, faire pivoter, recadrer, retourner ou rogner une image.

3

Transparency

Cela rend des parties d'une image invisibles.

4

Draw

Il ajoute des formes ou du texte à une image.

5

Decorate

Il ajoute une bordure ou un cadre à une image.

6

Special effects

Il peut rendre une image floue, accentuée, délimitée ou teintée.

sept

Animation

Il peut créer une séquence d'animation GIF à partir d'un groupe d'images.

8

Composite

Il peut chevaucher une image sur une autre.

9

Morphology of shapes

Il extrait les caractéristiques, décrit les formes et reconnaît les motifs des images.

dix

Encipher or decipher an image

Il convertit les images ordinaires en charabia inintelligible et inversement.

Endrov

Endrov est un programme d'analyse d'images polyvalent. Il est écrit de manière indépendante et conçu pour remédier à de nombreuses lacunes d'autres logiciels libres et de nombreux progiciels commerciaux.

Certaines des fonctionnalités de base d'Endrov sont décrites ci-dessous -

Sr.No. Description des fonctions
1

View data

Il visualise les données, en 2D et 3D. Conçu pour gérer des schémas de données 4D complexes et un nombre illimité de canaux, où chaque canal peut avoir sa propre résolution X, Y et Z.

2

Annotate your images

Il annote vos images, automatiquement ou à la main, pour les comprendre et obtenir des statistiques.

3

Undo and Redo

Il peut annuler et refaire pour toutes les opérations.

4

Lazy Evaluation

Il est conçu à partir du sol pour gérer de grands ensembles d'images. Endrov utilise l'évaluation paresseuse, un concept principalement disponible dans les langages de programmation de recherche.

5

Scripting language

Il prend en charge le langage de script graphique, ainsi que les scripts traditionnels.

6

Java

Écrit en Java. L'architecture de plug-in permet une extension facile avec de nouveaux plug-ins Java. Il peut interagir avec Matlab.

sept

Formats

Il accède à presque tous les formats de fichiers commerciaux et ouverts en utilisant des bio-formats.

8

Microscopic Processing

Il peut contrôler tous vos microscopes avec un seul programme et effectuer une analyse d'image à la volée.

OUTILS DE PLOMB

LEADTOOLS fournit plus de 200 fonctions de traitement d'image dans plusieurs catégories, notamment le nettoyage de documents, l'amélioration des images médicales, la conversion et la correction des couleurs, la réduction du bruit, la détection des contours, etc.

Certaines des fonctionnalités de base de LEADTOOLS sont décrites ci-dessous -

Sr.No. Description des fonctions
1

Scanned Document Image Processing

Cette puissante collection de fonctions peut lire des documents numérisés d'objets et d'imperfections tels que des trous perforés, des angles biaisés, des bordures, des taches de poussière, etc.

2

Medical Image Processing

Améliorez l'image ou mettez en évidence les détails en déplaçant, sélectionnant, soustrayant et supprimant l'arrière-plan pour de meilleurs visuels.

3

Geometric Transformation

Ces fonctions peuvent être utilisées pour nettoyer, aligner, corriger des images ou appliquer des effets 3D artistiques.

4

Brightness and Contrast

Ces fonctions peuvent être utilisées pour améliorer les images, appliquer des effets artistiques ou aider à l'évaluation diagnostique des images médicales.

5

Color Space Conversion

Ils peuvent ajouter une fonctionnalité d'espace colorimétrique d'image à des applications à un et à plusieurs threads, notamment les applications hébergées par IIS et Windows WF.

6

Color Correction

Ces fonctions sont utilisées pour corriger les images avec des canaux de couleur permutés, équilibrer les intensités de couleur ou effectuer diverses tâches d'analyse d'image.

sept

Image Enhancement

Ces fonctions sont utilisées pour corriger les erreurs courantes en photographie telles que les yeux rouges et les couleurs déséquilibrées, ainsi que pour aider à l'évaluation diagnostique des images médicales.

8

Region of Interest

Ces fonctions sont utilisées pour créer et modifier des régions d'intérêt dans les images pour exécuter des fonctions de traitement d'image sur des parties spécifiques d'une image, gagner du temps dans le code à barres et la reconnaissance OCR ou effectuer diverses tâches d'analyse d'image.

OpenCV

OpenCV est publié sous une licence BSD et est donc gratuit pour un usage académique et commercial. Il possède des interfaces C ++, C, Python et Java et prend en charge Windows, Linux, Mac OS, iOS et Android. OpenCV a été conçu pour une efficacité de calcul et avec un fort accent sur les applications en temps réel. Écrit en C / C ++ optimisé, la bibliothèque peut tirer parti du traitement multicœur.

Certaines fonctionnalités de base d'OpenCV sont décrites brièvement -

Sr.No. Description des fonctions
1

Smoothing Images

Cela implique l'application de Blur, GaussianBlur, medianBlur et bilatéral Filter.

2

Eroding and Dilating

Il peut appliquer deux opérateurs morphologiques très courants: la dilatation et l'érosion.

3

Morphology Transformations

OpenCV function morphologyEx pour appliquer une transformation morphologique telle que l'ouverture, la fermeture, TopHat et BlackHat, etc.

4

Image Pyramids

OpenCV fonctions pyrUp et pyrDown pour réduire ou augmenter l'échantillon d'une image donnée.

4

Basic Thresholding Operations

Effectuer des opérations de seuillage de base à l'aide du seuil de la fonction OpenCV.

5

Adding borders to your images

La fonction OpenCV copyMakeBorder est utilisée pour définir les bordures (remplissage supplémentaire de votre image).

sept

Remapping

Dans OpenCV, la fonction remapper offre une implémentation de remappage simple.

8

Histogram Calculation

Pour des raisons simples, OpenCV implémente la fonction calcHist, qui calcule l'histogramme d'un ensemble de tableaux (généralement des images ou des plans d'image). Il peut fonctionner avec jusqu'à 32 dimensions.

OpenCV est publié sous une licence BSD et est donc gratuit pour un usage académique et commercial. Il possède des interfaces C ++, C, Python et Java et prend en charge Windows, Linux, Mac OS, iOS et Android.

OpenCV a été conçu pour une efficacité de calcul et avec un fort accent sur les applications en temps réel. Écrit en C / C ++ optimisé, la bibliothèque peut tirer parti du traitement multicœur.

Certaines des fonctionnalités de base d'OpenCV sont décrites ci-dessous -

Sr.No. Description des fonctions
1

Smoothing Images

Cela implique l'application de Blur, GaussianBlur, medianBlur et bilatéral Filter.

2

Eroding and Dilating

Il peut appliquer deux opérateurs morphologiques très courants: la dilatation et l'érosion.

3

Morphology Transformations

OpenCV function morphologyEx pour appliquer une transformation morphologique telle que l'ouverture, la fermeture, TopHat et BlackHat, etc.

4

Image Pyramids

OpenCV fonctions pyrUp et pyrDown pour réduire ou augmenter l'échantillon d'une image donnée.

4

Basic Thresholding Operations

Il peut effectuer des opérations de seuillage de base en utilisant le seuil de la fonction OpenCV.

5

Adding borders to your images

La fonction OpenCV copyMakeBorder est utilisée pour définir les bordures (remplissage supplémentaire de votre image).

sept

Remapping

Dans OpenCV, la fonction remapper offre une implémentation de remappage simple.

8

Histogram Calculation

Pour des raisons simples, OpenCV implémente la fonction calcHist, qui calcule l'histogramme d'un ensemble de tableaux (généralement des images ou des plans d'image). Il peut fonctionner avec jusqu'à 32 dimensions.

Intégrer OpenCV

Les étapes suivantes expliquent comment intégrer OpenCV dans vos applications.

Télécharger OpenCV

Vous pouvez télécharger OpenCV depuis leur site officiel ici .

Créer une bibliothèque utilisateur

De plus, nous créons une bibliothèque utilisateur d'OpenCV, afin de pouvoir l'utiliser comme futur projet.

Lancez Eclipse

Sélectionnez Fenêtre -> Préférences dans le menu.

Naviguez sous Java -> Build Path -> User Libraries et cliquez sur New.

Entrez maintenant le nom de votre bibliothèque. Par exemple, OpenCV-2.4.6.

Ensuite, sélectionnez votre nouvelle bibliothèque utilisateur (c'est-à-dire OpenCV-2.4.6) et cliquez sur Ajouter des JAR externes.

Parcourez C: \ OpenCV-2.4.6 \ build \ java \ et sélectionnez opencv-246.jar. Après avoir ajouté le fichier jar, étendez l'opencv-246.jar et sélectionnez Emplacement de la bibliothèque native et appuyez sur Modifier.

Sélectionnez Dossier externe ... et recherchez le dossier C: \ OpenCV-2.4.6 \ build \ java \ x64. Si vous disposez d'un système 32 bits, vous devez sélectionner le dossier x86 au lieu de x64.

Appuyez sur Ok et vous avez terminé.

Maintenant, votre bibliothèque utilisateur est créée. Vous pouvez maintenant réutiliser cette configuration dans n'importe quel projet.

Créer un projet OpenCV

Créez un nouveau projet java dans eclipse.

À l'étape Paramètres Java, sous l'onglet Bibliothèques, sélectionnez Ajouter une bibliothèque ... et sélectionnez OpenCV-2.4.6, puis cliquez sur Terminer.

Cliquez sur Terminer et vous avez terminé.

Afin de convertir une image couleur en image en niveaux de gris à l'aide d'OpenCV, nous lisons l'image en BufferedImage et le convertir en MatObjet. Sa syntaxe est donnée ci-dessous -

File input = new File("digital_image_processing.jpg");
BufferedImage image = ImageIO.read(input);
//convert Buffered Image to Mat.

Ensuite, vous pouvez transformer l'image du format RVB au format Niveaux de gris en utilisant la méthode cvtColor() dans le Imgprocclasse. Sa syntaxe est donnée ci-dessous -

Imgproc.cvtColor(source mat, destination mat1, Imgproc.COLOR_RGB2GRAY);

La méthode cvtColor() prend trois paramètres qui sont la matrice d'image source, la matrice d'image de destination et le type de conversion des couleurs.

Outre la méthode cvtColor, il existe d'autres méthodes fournies par la classe Imgproc. Ils sont listés ci-dessous -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour convertir une image en niveaux de gris -

import java.awt.image.BufferedImage;
import java.awt.image.DataBufferByte;

import java.io.File;
import javax.imageio.ImageIO;

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.imgproc.Imgproc;

public class Main {
   public static void main( String[] args ) { 
   
      try {
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         File input = new File("digital_image_processing.jpg");
         BufferedImage image = ImageIO.read(input);	

         byte[] data = ((DataBufferByte) image.getRaster().getDataBuffer()).getData();
         Mat mat = new Mat(image.getHeight(), image.getWidth(), CvType.CV_8UC3);
         mat.put(0, 0, data);

         Mat mat1 = new Mat(image.getHeight(),image.getWidth(),CvType.CV_8UC1);
         Imgproc.cvtColor(mat, mat1, Imgproc.COLOR_RGB2GRAY);

         byte[] data1 = new byte[mat1.rows() * mat1.cols() * (int)(mat1.elemSize())];
         mat1.get(0, 0, data1);
         BufferedImage image1 = new BufferedImage(mat1.cols(),mat1.rows(), BufferedImage.TYPE_BYTE_GRAY);
         image1.getRaster().setDataElements(0, 0, mat1.cols(), mat1.rows(), data1);

         File ouptut = new File("grayscale.jpg");
         ImageIO.write(image1, "jpg", ouptut);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez l'exemple donné, il convertit un nom d'image digital_image_processing.jpg à son image équivalente en niveaux de gris et l'écrit sur le disque dur avec le nom grayscale.jpg.

Image originale

Image en niveaux de gris

Afin de changer l'espace colorimétrique d'une image à une autre en utilisant OpenCV, nous lisons l'image dans BufferedImage et le convertir en MatObjet. Sa syntaxe est donnée ci-dessous -

File input = new File("digital_image_processing.jpg");
BufferedImage image = ImageIO.read(input);
//convert Buffered Image to Mat.

OpenCv permet de nombreux types de conversion de couleur, qui peuvent tous être trouvés dans la classe Imgproc. Certains types sont décrits brièvement -

Sr.No. Type de conversion de couleur
1 COLOR_RGB2BGR
2 COLOR_RGB2BGRA
3 COLOR_RGB2GRAY
4 COLOR_RGB2HLS
5 COLOR_RGB2HSV
6 COLOR_RGB2Luv
sept COLOR_RGB2YUV
8 COLOR_RGB2Lab

À partir de n'importe quel type de conversion de couleur, passez simplement le type approprié dans la méthode cvtColor() dans le Imgprocclasse. Sa syntaxe est donnée ci-dessous -

Imgproc.cvtColor(source mat, destination mat1, Color_Conversion_Code);

La méthode cvtColor() prend trois paramètres qui sont la matrice d'image source, la matrice d'image de destination et le type de conversion des couleurs.

Outre la méthode cvtColor (), il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

Sr.No. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int ddepth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour convertir une image d'un espace colorimétrique à un autre.

import java.awt.image.BufferedImage;
import java.awt.image.DataBufferByte;

import java.io.File;
import javax.imageio.ImageIO;

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.imgproc.Imgproc;

public class Main {
   public static void main( String[] args ) {
   
      try {
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         File input = new File("digital_image_processing.jpg");
         BufferedImage image = ImageIO.read(input);	
         byte[] data = ((DataBufferByte) image.getRaster().getDataBuffer()).getData();
         Mat mat = new Mat(image.getHeight(),image.getWidth(), CvType.CV_8UC3);
         mat.put(0, 0, data);

         Mat mat1 = new Mat(image.getHeight(), image.getWidth(), CvType.CV_8UC3);
         Imgproc.cvtColor(mat, mat1, Imgproc.COLOR_RGB2HSV);

         byte[] data1 = new byte[mat1.rows()*mat1.cols()*(int)(mat1.elemSize())];
         mat1.get(0, 0, data1);
         BufferedImage image1 = new BufferedImage(mat1.cols(), mat1.rows(), 5);
         image1.getRaster().setDataElements(0, 0, mat1.cols(), mat1.rows(), data1);

         File ouptut = new File("hsv.jpg");
         ImageIO.write(image1, "jpg", ouptut);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez l'exemple donné, il convertit un nom d'image digital_image_processing.jpg à son image d'espace colorimétrique HSV équivalente et l'écrit sur le disque dur avec le nom hsv.jpg.

Image originale (RVB)

Image convertie (HSV)