Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
import Praktikum3.citra3;
import Praktikum5.citra5;
import java.awt.Color;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.imageio.ImageIO;
import javax.swing.Icon;
import javax.swing.ImageIcon;
import javax.swing.JFileChooser;
import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartFrame;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.data.category.DefaultCategoryDataset;
import praktikum6.citra6;
/**
*
* @author Acer
*/
public class Citra7 extends javax.swing.JFrame {
BufferedImage image=null;
private int width;
private int height;
String input=null,
srcIm="flower1.jpg";
private Icon ImageIcon;
private int[] cdf;
private int[] hist;
private ImageIcon imageIcon;
/**
* Creates new form Citra7
*/
public Citra7() {
initComponents();
}
/**
* This method is called from within the constructor to initialize the form.
* WARNING: Do NOT modify this code. The content of this method is always
* regenerated by the Form Editor.
*/
@SuppressWarnings("unchecked")
// <editor-fold defaultstate="collapsed" desc="Generated Code">//GEN-BEGIN:initComponents
private void initComponents() {
setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
jButton1.setText("Load");
jButton1.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jButton1ActionPerformed(evt);
}
});
jButton2.setText("Grayscale");
jButton2.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jButton2ActionPerformed(evt);
}
});
jButton3.setText("Histogram");
jButton3.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jButton3ActionPerformed(evt);
}
});
jButton4.setText("CDF");
jButton4.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jButton4ActionPerformed(evt);
}
});
jButton5.setText("HisEqual");
jButton5.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jButton5ActionPerformed(evt);
}
});
jButton6.setText("AutoLevel");
jButton6.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jButton6ActionPerformed(evt);
}
});
.addContainerGap())
);
pack();
}// </editor-fold>//GEN-END:initComponents
/* int jes=chooser.showOpenDialog(this);
try {
if(jes==chooser.APPROVE_OPTION){
File input=chooser.getSelectedFile();
image = ImageIO.read(input);
}
} catch (IOException ex) {
java.util.logging.Logger.getLogger(Citra7.class.getName()).log(Level.SEVERE, null, ex);
}
ImageIcon imageIcon = new ImageIcon(image);
jLabel1.setIcon(imageIcon); */
}
ImageIcon imageIcon = new ImageIcon(image);
jLabel1.setIcon(imageIcon);
}//GEN-LAST:event_jButton1ActionPerformed
int red=(int)(w.getRed());
int blue=(int)(w.getBlue());
int green=(int)(w.getGreen());
int xg= (int) (red+green+blue)/3;
jLabel2.setIcon(imageIcon1);
} catch (IOException ex) {
java.util.logging.Logger.getLogger(Citra7.class.getName()).log(Level.SEVERE, null, ex);
}
}//GEN-LAST:event_jButton2ActionPerformed
int red=(int)(w.getRed());
int blue=(int)(w.getBlue());
int green=(int)(w.getGreen());
int xg= (int) (red+green+blue)/3;
hist[xg]+=1;
}
int red=(int)(w.getRed());
int blue=(int)(w.getBlue());
int green=(int)(w.getGreen());
int xg= (int) (red+green+blue)/3;
hist[xg]+=1;
}
}
int[] cdf =new int [256];
cdf[0]=hist[0];
for (int i = 1; i < 256; i++) {
cdf[i]=cdf[i-1]+hist[i];
}
DefaultCategoryDataset dataset=new DefaultCategoryDataset();
for (int i = 0; i < 256; i++) {
dataset.addValue(cdf[i], i+"", "");
}
JFreeChart chart= ChartFactory.createBarChart("Fungsi Distribusi Kumulatif", "grayscale",
"nilai",
dataset,PlotOrientation.VERTICAL,false,true,false);
ChartFrame frame=new ChartFrame("CDF", chart);
frame.setSize(600,400);
frame.setVisible(true);
frame.setLocationRelativeTo(null);
}//GEN-LAST:event_jButton4ActionPerformed
try{
image = ImageIO.read(input);
int xgmax=0;
int xgmin=255;
for (int i = 0; i <width ; i++) {
for (int j = 0; j < height; j++) {
Color w = new Color(image.getRGB(i, j));
// masing" warna menjadi grayscale
int red=(int)(w.getRed());
int blue=(int)(w.getBlue());
int green=(int)(w.getGreen());
//warna RGB digabungkan
int xg = (int) (red+green+blue)/3;
if (xg < xgmin) {
xgmin = xg;
}
if (xg > xgmax) {
xgmax = xg;
}
}
}
int red=(int)(w.getRed());
int blue=(int)(w.getBlue());
int green=(int)(w.getGreen());
int xg= (int) (red+green+blue)/3;
hist[xg]+=1;
}
}
int[] cdf =new int [256];
cdf[0]=hist[0];
for (int i = 1; i < 256; i++) {
cdf[i]=cdf[i-1]+hist[i];
}
int nx=width;
int ny=height;
int red=(int)(w.getRed());
int blue=(int)(w.getBlue());
int green=(int)(w.getGreen());
}//GEN-LAST:event_jButton5ActionPerformed
/**
* @param args the command line arguments
*/
public static void main(String args[]) {
/* Set the Nimbus look and feel */
//<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) ">
/* If Nimbus (introduced in Java SE 6) is not available, stay with the default look and feel.
}
});
}