⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 robert.java.bak

📁 java实现图像处理各种常用操作
💻 BAK
字号:
//Robert.java
/*
	程序说明:对图像进行边缘提取,robert算子
	          公式为:robertRed=Math.abs(red5-red9)+Math.abs(red8-red6);
	
	程序修改:
	
	最后修改时间:2003-12
		
	作者:haibin
	
*/

import java.awt.*;
import java.awt.event.*;
import java.awt.image.*;
import javax.swing.*;

public class Robert extends Frame {
	Image im,tmp;
	int i,iw,ih;
	int[] pixels;
	boolean flag=false;
	
	//ImagePixel的构造方法
	public Robert(){
		this.setTitle("Robert边缘检测");
		Panel pdown;
		Button load,run,quit;
		//添加窗口监听事件
		addWindowListener(new WindowAdapter(){
			public void windowClosing(WindowEvent e){
				System.exit(0);
			}
		});
		
		pdown = new Panel();
		pdown.setBackground(Color.lightGray);
		
		load=new Button("装载图像");
		run = new Button("边缘检测");
		quit=new Button("退出");
		
		this.add(pdown,BorderLayout.SOUTH);
		
		pdown.add(load);
		pdown.add(run);
		pdown.add(quit);
		
		load.addActionListener(new ActionListener(){
			public void actionPerformed(ActionEvent e){
				jLoad_ActionPerformed(e);
			}
		});
		
		run.addActionListener(new ActionListener(){
			public void actionPerformed(ActionEvent e){
				jRun_ActionPerformed(e);
			}
		});
		
		quit.addActionListener(new ActionListener(){
			public void actionPerformed(ActionEvent e){
				jQuit_ActionPerformed(e);
			}
		});
	}
		
	public void jLoad_ActionPerformed(ActionEvent e){
		//利用MediaTracker跟踪图像的加载
		MediaTracker tracker = new MediaTracker(this);
		im=Toolkit.getDefaultToolkit().getImage("Miss.jpg");
		tracker.addImage(im,0);
	
		//等待图像的完全加载
		try{
		tracker.waitForID(0);
		}catch(InterruptedException e2){ e2.printStackTrace();}
	
		//获取图像的宽度iw和高度ih
		iw=im.getWidth(this);
		ih=im.getHeight(this);
		pixels=new int[iw*ih];
		
		try{
		PixelGrabber pg=new PixelGrabber(im,0,0,iw,ih,pixels,0,iw);
		pg.grabPixels();
		}catch (InterruptedException e3) {
			e3.printStackTrace();
		}
	
		//将数组中的象素产生一个图像
		ImageProducer ip=new MemoryImageSource(iw,ih,pixels,0,iw);
		tmp=createImage(ip);
		flag=true;
		repaint();
	}
	
public  void jRun_ActionPerformed(ActionEvent e){
	if(flag) {
	try{
	PixelGrabber pg=new PixelGrabber(im,0,0,iw,ih,pixels,0,iw);
	pg.grabPixels();
	}catch (InterruptedException e3) {
		e3.printStackTrace();
	}
			
	//对图像进行边缘提取,Alpha值保持不变
	ColorModel cm=ColorModel.getRGBdefault();
	for(i=1;i<ih-1;i++)
	{
		for(int j=1;j<iw-1;j++)
		{
		//对图像进行边缘提取
		int alpha=cm.getAlpha(pixels[i*iw+j]);
		int red5=cm.getRed(pixels[i*iw+j]);
		int red6=cm.getRed(pixels[i*iw+j+1]);
		int red8=cm.getRed(pixels[(i+1)*iw+j]);
		int red9=cm.getRed(pixels[(i+1)*iw+j+1]);
		
		int robertRed=Math.max(Math.abs(red5-red9),Math.abs(red8-red6));
		
		int green5=cm.getGreen(pixels[i*iw+j]);
		int green6=cm.getGreen(pixels[i*iw+j+1]);
		int green8=cm.getGreen(pixels[(i+1)*iw+j]);
		int green9=cm.getGreen(pixels[(i+1)*iw+j+1]);
		
		int robertGreen=Math.max(Math.abs(green5-green9),Math.abs(green8-green6));
		
		int blue5=cm.getBlue(pixels[i*iw+j]);
		int blue6=cm.getBlue(pixels[i*iw+j+1]);
		int blue8=cm.getBlue(pixels[(i+1)*iw+j]);
		int blue9=cm.getBlue(pixels[(i+1)*iw+j+1]);
		
		int robertBlue=Math.max(Math.abs(blue5-blue9),Math.abs(blue8-blue6));
		
		pixels[i*iw+j]=alpha<<24|robertRed<<16|robertGreen<<8|robertBlue;
		}
	}
	
	//将数组中的象素产生一个图像
	ImageProducer ip=new MemoryImageSource(iw,ih,pixels,0,iw);
	tmp=createImage(ip);
	repaint();
	}else{
	JOptionPane.showMessageDialog(null,"请先打开一幅图片!",
  		"Alert",JOptionPane.WARNING_MESSAGE);
	}
}
	public void jQuit_ActionPerformed(ActionEvent e){
		//System.exit(0);
		JOptionPane op =new JOptionPane();
		int exit=op.showConfirmDialog(this,"你要退出吗? ? ?","退出",JOptionPane.YES_NO_OPTION);
	
		if(exit==JOptionPane.YES_OPTION)
		{
			System.exit(0);
		
		}else{ }
	}
	
	//调用paint()方法,显示图像信息。
	public void paint(Graphics g){
		if(flag){
			g.drawImage(tmp,10,20,this);
		}else { }
	}
	
	//定义main方法,设置窗口的大小,显示窗口
	public static void main(String[] args) {
		Robert ro = new Robert();
		ro.setLocation(50,50);
		ro.setSize(500,400);
		ro.show();
	} 
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -