亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? fftfilterdlg.java

?? 圖象編輯器
?? JAVA
字號:
/*
 * FFTFilterDlg.java
 *
 * Created on 2005年2月24日, 下午1:51
 */

/**
 *
 * @author  Bluewater
 */
package imageapp;
 
import javax.swing.*;
import java.awt.*;
import java.awt.image.*;
import java.awt.event.*;

public class FFTFilterDlg extends javax.swing.JDialog {

    /** Creates new form FFTFilterDlg */
    public FFTFilterDlg(java.awt.Frame parent, boolean modal) {
        super(parent, modal);
        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.
     */
    private void initComponents() {
    	imagePanel = new FFTImagePane(fftImage);
        scrollPane = new javax.swing.JScrollPane(imagePanel);
        jPanel1 = new javax.swing.JPanel();
        innerSlider = new javax.swing.JSlider();
        outterSlider = new javax.swing.JSlider();
        cancelBtn = new javax.swing.JButton();
        okBtn = new javax.swing.JButton();
        jLabel2 = new javax.swing.JLabel();
        jLabel3 = new javax.swing.JLabel();
        
        getContentPane().add(scrollPane, java.awt.BorderLayout.CENTER);
        
        jPanel1.setLayout(new java.awt.GridBagLayout());
        java.awt.GridBagConstraints gridBagConstraints1;
        
        gridBagConstraints1 = new java.awt.GridBagConstraints();
        gridBagConstraints1.gridx = 1;
        gridBagConstraints1.gridy = 0;
        gridBagConstraints1.insets = new java.awt.Insets(15, 3, 3, 10);
        jPanel1.add(innerSlider, gridBagConstraints1);
        innerSlider.addChangeListener(new javax.swing.event.ChangeListener() {
            public void stateChanged(javax.swing.event.ChangeEvent evt) {
                innerChanged(evt);
            }
        });
        
        gridBagConstraints1 = new java.awt.GridBagConstraints();
        gridBagConstraints1.gridx = 1;
        gridBagConstraints1.gridy = 1;
        gridBagConstraints1.insets = new java.awt.Insets(3, 3, 15, 10);
        jPanel1.add(outterSlider, gridBagConstraints1);
        outterSlider.addChangeListener(new javax.swing.event.ChangeListener() {
            public void stateChanged(javax.swing.event.ChangeEvent evt) {
                outterChanged(evt);
            }
        });
        
        cancelBtn.setText("取消(C)");
        cancelBtn.setMnemonic('C');
        gridBagConstraints1 = new java.awt.GridBagConstraints();
        gridBagConstraints1.gridx = 2;
        gridBagConstraints1.gridy = 1;
        gridBagConstraints1.insets = new java.awt.Insets(0, 0, 10, 15);
        jPanel1.add(cancelBtn, gridBagConstraints1);
        cancelBtn.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				cancelPerformed(e);
			}
		});
        
        okBtn.setText("確定(O)");
        okBtn.setMnemonic('O');
        gridBagConstraints1 = new java.awt.GridBagConstraints();
        gridBagConstraints1.gridx = 2;
        gridBagConstraints1.gridy = 0;
        gridBagConstraints1.insets = new java.awt.Insets(12, 0, 0, 15);
        jPanel1.add(okBtn, gridBagConstraints1);
        okBtn.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				okPerformed(e);
			}
		});
        
        jLabel2.setText("內(nèi)半徑a");
        gridBagConstraints1 = new java.awt.GridBagConstraints();
        gridBagConstraints1.gridx = 0;
        gridBagConstraints1.gridy = 0;
        gridBagConstraints1.insets = new java.awt.Insets(15, 15, 0, 3);
        jPanel1.add(jLabel2, gridBagConstraints1);
        
        jLabel3.setText("外半徑b");
        gridBagConstraints1 = new java.awt.GridBagConstraints();
        gridBagConstraints1.gridx = 0;
        gridBagConstraints1.gridy = 1;
        gridBagConstraints1.insets = new java.awt.Insets(3, 15, 15, 3);
        jPanel1.add(jLabel3, gridBagConstraints1);
        
        getContentPane().add(jPanel1, java.awt.BorderLayout.SOUTH);
        
        setSize(new Dimension(640, 480));
        setTitle("傅立葉帶通濾波");
    }

    /** Closes the dialog */
    private void closeDialog(java.awt.event.WindowEvent evt) {
        setVisible(false);
        dispose();
    }

    private void okPerformed(java.awt.event.ActionEvent evt) {
        modResult = JOptionPane.OK_OPTION;
        destImage = filterImage();
		dispose();
    }

    private void cancelPerformed(java.awt.event.ActionEvent evt) {
        modResult = JOptionPane.CANCEL_OPTION;
		dispose();
    }
    
    private void innerChanged(javax.swing.event.ChangeEvent evt) {
    	int a = innerSlider.getValue();
    	imagePanel.setA(a);
    }
    
    private void outterChanged(javax.swing.event.ChangeEvent evt) {
    	int b = outterSlider.getValue();
    	imagePanel.setB(b);		
    }
    
    public int showModal() {
    	show();
    	return modResult;
    }
    
    public int modResult() {
    	return modResult;
    }
    
    public BufferedImage getDestImage() {
    	return destImage;
    }
    
    public void setImage(BufferedImage image) {
    	srcImage = image;
    	fftImage = createFFTImage();
    	
    	int a = 0;
    	int b = (int)Math.round(Math.sqrt(xsize*xsize/4+ysize*ysize/4))+2;
    	innerSlider.setMaximum(b);
    	innerSlider.setValue(a);
    	outterSlider.setMaximum(b);
    	outterSlider.setValue(b);
    	imagePanel.setImage(fftImage);
    	imagePanel.setA(a);
    	imagePanel.setB(b);
    }
    
    private BufferedImage createFFTImage() {
		int i, j;
		int width = srcImage.getWidth();
		int height = srcImage.getHeight();
		xsize = 1;
		for(i=width/2; i>0; i/=2) xsize *= 2;
		xsize = xsize > 1 ? xsize : 0;
		ysize = 1;
		for(i=height/2; i>0; i/=2) ysize *= 2;
		ysize = ysize > 1 ? ysize : 0;
		BufferedImage fftImage = new BufferedImage(xsize, ysize, BufferedImage.TYPE_INT_RGB);
		
		int srcRGBs[] = srcImage.getRGB(0, 0, xsize, ysize, null, 0, xsize);
		arl = new float[ysize][];
		aim = new float[ysize][];
		float amp[][] = new float[ysize][];
		for(i=0; i<ysize; i++) {
			arl[i] = new float[xsize];
			aim[i] = new float[xsize];
			amp[i] = new float[xsize];
		}
		
		int rgb[] = new int[3];
		float yhs[] = new float[3];
		for(i=0; i<ysize; i++) {
			for(j=0; j<xsize; j++){
				ImageUtil.convertRGBToYHS(srcRGBs[i*xsize+j], yhs);
				arl[i][j] = yhs[0];
				aim[i][j] = 0;
			}
		}
		
		FFTTransform.fft2d(arl, aim, FFTTransform.DFT, xsize, ysize);
		
		float min = Float.POSITIVE_INFINITY;
		float max = Float.NEGATIVE_INFINITY;
		for(i=0; i<ysize; i++) {
			for(j=0; j<xsize; j++) {
				float norm = arl[i][j]*arl[i][j]+aim[i][j]*aim[i][j];
				if(norm != 0.0) norm = (float)Math.log(norm)/2;
				else norm = 0.0f;
				amp[i][j] = norm;
				if(amp[i][j] > max) max = amp[i][j];
				if(amp[i][j] < min) min = amp[i][j];
			}
		}
		
		for(i=0; i<ysize; i++) {
			for(j=0; j<xsize; j++) {
				rgb[0] = (int)((amp[i][j]-min)*255/(max-min));
				rgb[1] = rgb[2] = rgb[0];
				fftImage.setRGB(j, i, ImageUtil.encodeColor(rgb));
			}
		}
		
		return fftImage;
	}
	
	private BufferedImage filterImage() {
		float a = innerSlider.getValue();
		float b = outterSlider.getValue();
		int width = srcImage.getWidth();
		int height = srcImage.getHeight();
		int srcRGBs[] = srcImage.getRGB(0, 0, width, height, null, 0, width);
		BufferedImage destImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
		destImage.setRGB(0, 0, width, height, srcRGBs, 0, width);
		
		for(int i=0; i<ysize; i++) {
			for(int j=0; j<xsize; j++) {
				float r = (float)Math.sqrt((j-xsize/2)*(j-xsize/2)+(i-ysize/2)*(i-ysize/2));
				if(r < a || r > b) {
					arl[i][j] = 0;
					aim[i][j] = 0;
				}
			}
		}
		
		FFTTransform.fft2d(arl, aim, FFTTransform.IDFT, xsize, ysize);
		
		float max = 0, min = 500;
		for(int i=0; i<ysize; i++) {
			for(int j=0; j<xsize; j++) {
				if(max < arl[i][j]) max = arl[i][j];
				if(min > arl[i][j]) min = arl[i][j];
			}
		}
		
		float yhs[] = new float[3];
		for(int i=0; i<ysize; i++) {
			for(int j=0; j<xsize; j++) {
				ImageUtil.convertRGBToYHS(srcRGBs[i*width+j], yhs);
				yhs[0] = (arl[i][j]-min)*255/(max-min);
				destImage.setRGB(j, i, ImageUtil.convertYHSToRGB(yhs));	
			}
		}
		
		return destImage;
	}


    // Variables declaration - do not modify
    private javax.swing.JScrollPane scrollPane;
    FFTImagePane imagePanel;
    private javax.swing.JPanel jPanel1;
    private javax.swing.JSlider innerSlider;
    private javax.swing.JSlider outterSlider;
    private javax.swing.JButton cancelBtn;
    private javax.swing.JButton okBtn;
    private javax.swing.JLabel jLabel2;
    private javax.swing.JLabel jLabel3;
    // End of variables declaration
    
    private int modResult = JOptionPane.CANCEL_OPTION;
    private BufferedImage srcImage;
    private BufferedImage destImage;
    private BufferedImage fftImage;
    private int xsize, ysize;
    float arl[][], aim[][];

}

class FFTImagePane extends ImagePanel {
	int a, b;
	public FFTImagePane(Image image) {
        super(image);
    }
    
    public void setA(int a) {
    	this.a = a;
    	repaint();
    }
    
    public void setB(int b) {
    	this.b = b;
    	repaint();
    }
    
    public void paintComponent(Graphics g) {
        super.paintComponent(g);
        
        int x0 = image.getWidth(null)/2;
        int y0 = image.getHeight(null)/2;
        
        g.setClip(0, 0, 2*x0, 2*y0);
        if(a > 0) {
        	g.setColor(Color.red);
        	g.drawOval(x0-a, y0-a, 2*a, 2*a);
        }
        
        if(b > 0) {
        	g.setColor(Color.green);
        	g.drawOval(x0-b, y0-b, 2*b, 2*b);
        }
    }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美疯狂做受xxxx富婆| 久久综合av免费| 国产成人免费视频网站| 一区二区三区四区不卡视频| 欧美成人aa大片| 欧美三级资源在线| av欧美精品.com| 极品少妇xxxx精品少妇| 亚洲成人激情综合网| 国产精品久久久久久久久久免费看| 日韩视频国产视频| 欧美日韩在线播放| 91麻豆国产福利精品| 国产一区二区不卡| 免费成人美女在线观看| 另类小说一区二区三区| 亚洲精品免费电影| 中文字幕在线观看一区| 欧美精品一区二区蜜臀亚洲| 91麻豆精品久久久久蜜臀| 91成人国产精品| 一本一道波多野结衣一区二区| 国产成人亚洲综合a∨婷婷| 久久精品免费观看| 久久国产人妖系列| 美女脱光内衣内裤视频久久网站 | 亚洲人成小说网站色在线| 久久毛片高清国产| 日韩欧美的一区| 欧美一级国产精品| 欧美一区永久视频免费观看| 欧美三级三级三级| 在线视频一区二区三区| 不卡一二三区首页| 北岛玲一区二区三区四区| 风间由美一区二区av101| 国产成人免费视频精品含羞草妖精| 国产综合成人久久大片91| 国模套图日韩精品一区二区| 国内外成人在线视频| 韩国成人精品a∨在线观看| 极品美女销魂一区二区三区| 美女视频黄久久| 国产一区美女在线| 国产成人综合在线播放| 成人一级视频在线观看| www.日韩av| 日本乱码高清不卡字幕| 欧美最猛性xxxxx直播| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 色综合天天综合狠狠| 欧美日韩一级片在线观看| 欧美日韩国产精选| 精品三级av在线| 久久精品视频网| 国产精品国产成人国产三级| 一区二区三区日韩| 天天操天天色综合| 老司机午夜精品99久久| 国产精品一区二区三区乱码| 成人午夜精品在线| 在线精品视频一区二区| 欧美一卡2卡3卡4卡| 久久一日本道色综合| 欧美国产精品v| 亚洲精品成人悠悠色影视| 五月天国产精品| 激情五月婷婷综合| 99久久精品免费看国产免费软件| 色天天综合久久久久综合片| 91精品国产综合久久久蜜臀图片| 国产欧美日韩久久| 亚洲午夜一区二区| 国产麻豆精品在线观看| 91久久香蕉国产日韩欧美9色| 4438成人网| 亚洲国产精品二十页| 国产精品中文有码| 99re亚洲国产精品| 69堂成人精品免费视频| 久久久久久久免费视频了| 亚洲欧美在线观看| 美女精品一区二区| 91丨九色丨尤物| 精品黑人一区二区三区久久| 亚洲美女淫视频| 国产一区二区日韩精品| 欧美视频中文字幕| 国产欧美一区二区精品性色| 午夜电影一区二区三区| 国产69精品久久777的优势| 欧美日韩精品一区二区| 国产精品人妖ts系列视频| 日韩国产精品大片| 色综合中文字幕| 久久久99久久| 日本一不卡视频| 91蜜桃网址入口| 久久久久久久免费视频了| 午夜久久电影网| 91麻豆免费观看| 国产亚洲精品7777| 麻豆精品一区二区综合av| 日本二三区不卡| 国产精品全国免费观看高清 | 91精品婷婷国产综合久久竹菊| 国产欧美日本一区二区三区| 日本怡春院一区二区| 日本韩国欧美国产| 中文字幕日韩欧美一区二区三区| 蜜桃av噜噜一区二区三区小说| 欧美综合一区二区三区| 国产精品国产自产拍高清av | 日韩一区二区麻豆国产| 亚洲一区在线看| 色综合婷婷久久| 国产精品欧美极品| 国产精品一级二级三级| 精品国产一区二区精华| 日韩制服丝袜先锋影音| 欧美日韩精品系列| 一区二区三区四区国产精品| jlzzjlzz亚洲日本少妇| 欧美激情一区不卡| 国产成人亚洲精品青草天美| 精品伦理精品一区| 加勒比av一区二区| 精品国免费一区二区三区| 乱一区二区av| 久久婷婷国产综合国色天香| 国产一区二区在线观看视频| 日韩美女视频在线| 久久99精品视频| 久久综合九色综合欧美亚洲| 九九久久精品视频| 精品欧美黑人一区二区三区| 狂野欧美性猛交blacked| 精品欧美乱码久久久久久 | 欧美视频一区二区三区| 无码av免费一区二区三区试看| 欧美亚洲国产一区二区三区va| 一区二区三区日韩精品| 欧美日本国产视频| 欧美aaaaa成人免费观看视频| 国产精品青草久久| 高清beeg欧美| 亚洲精品中文字幕在线观看| 91成人网在线| 日本亚洲电影天堂| 久久一日本道色综合| 国产mv日韩mv欧美| 中文字幕一区二区不卡| 91色婷婷久久久久合中文| 一区二区三区日韩欧美精品| 欧美电影在哪看比较好| 乱中年女人伦av一区二区| 国产丝袜美腿一区二区三区| 99在线视频精品| 性欧美疯狂xxxxbbbb| 欧美成人video| 成人激情免费电影网址| 一区二区三区四区五区视频在线观看| 欧美日韩精品一区二区在线播放| 久久国产免费看| 国产精品精品国产色婷婷| 欧洲生活片亚洲生活在线观看| 蜜桃av一区二区在线观看| 亚洲国产成人午夜在线一区| 欧美午夜片在线观看| 蜜臀av一区二区三区| 中文字幕第一区第二区| 在线免费观看日本一区| 麻豆freexxxx性91精品| 中文字幕亚洲欧美在线不卡| 91麻豆精品久久久久蜜臀| 国产精一品亚洲二区在线视频| 玉米视频成人免费看| 精品国产免费人成电影在线观看四季 | 国产一区欧美日韩| 亚洲乱码国产乱码精品精小说| 6080yy午夜一二三区久久| 成人午夜电影小说| 天堂一区二区在线| 中文一区一区三区高中清不卡| 欧美午夜一区二区| 盗摄精品av一区二区三区| 亚洲大片一区二区三区| 国产精品麻豆99久久久久久| 欧美精品自拍偷拍| 欧美日韩一区二区三区四区五区 | 精品久久久久久久久久久院品网| 91福利精品视频| 日韩你懂的在线观看| 精品国产污污免费网站入口| 日本一区二区三区国色天香| 国产精品国产馆在线真实露脸 | 97久久久精品综合88久久| 日韩欧美国产1| 一区二区三区在线观看动漫 | 亚洲二区在线视频|