`
hello_wangfeng
  • 浏览: 32550 次
社区版块
存档分类
最新评论

实现水平方向重采样的java图像处理程序

阅读更多
该程序主要实现水平方向上的灰度图像重采样。重采样通过3个for循环控制完成。原始lena图如下所示:



水平方向每8个点采集一个点的lena图像如下所示:



package p01;

import java.awt.*;
import java.awt.event.*;
import java.awt.image.*;
import java.io.File;
import java.io.IOException;
import javax.imageio.ImageIO;
import javax.swing.*;

public class chongcaiyang extends Frame{
	Image im, tmp;
	int iw, ih;
	int[] pixels;
	boolean flag_load = false;
	//构造方法
	public chongcaiyang(){
		super("chongcaiyang");
		Panel pdown;
    	Button load, run, save, 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("重采样");
    	save = new Button("保存");
    	quit = new Button("退出");
    	
    	this.add(pdown, BorderLayout.SOUTH);
    	//添加按钮 此处的顺序为案板上的左->右的顺序
    	pdown.add(load);    
    	pdown.add(run);
    	pdown.add(save);
    	pdown.add(quit);
        //按钮的动作程序  装载图像
    	load.addActionListener(new ActionListener(){    
    		public void actionPerformed(ActionEvent e){
    			try {
					jLoad_ActionPerformed(e);
				} catch (IOException e1) {	
					e1.printStackTrace();
				}
    		}
    	});
    	//按钮的动作程序  重采样
    	run.addActionListener(new ActionListener(){    
    		public void actionPerformed(ActionEvent e){
    			try {
					jRun_ActionPerformed(e);
				} catch (IOException e1) {
					// TODO Auto-generated catch block
					e1.printStackTrace();
				}
    		}
    	});
    	//按钮的动作程序 保存
    	save.addActionListener(new ActionListener(){    
    		public void actionPerformed(ActionEvent e){
    			try {
					jSave_ActionPerformed(e);
				} catch (IOException e1) {
					e1.printStackTrace();
				}
    		}
    	});
    	//按钮的动作程序  退出
    	quit.addActionListener(new ActionListener(){    
    		public void actionPerformed(ActionEvent e){
    			jQuit_ActionPerformed(e);
    		}
    	});
	}
	//按钮动作的实现  加载图像
    public void jLoad_ActionPerformed(ActionEvent e) throws IOException{    
    	File inputFile = new File("E:\\f2\\sc\\lena_grey.jpg");
        BufferedImage input = ImageIO.read(inputFile);
		tmp = input;
        flag_load = true;
        repaint();
	}
  //按钮动作的实现  重采样
  	public void jRun_ActionPerformed(ActionEvent e) throws IOException{    
  		if(flag_load){
  			File inputFile = new File("E:\\f2\\sc\\lena_grey.jpg");
  	        BufferedImage input = ImageIO.read(inputFile);
  	        iw = input.getWidth(this);
  	        ih = input.getHeight(this); 
  		//设定N值
  		int N = iw;
  		String s = JOptionPane.showInputDialog(null,"请输入N值(512/256/128/64/32/16/8)");
  		if(s!= null&& !s.equals("")){
  			N = Integer.parseInt(s);
  		}	
  		//检查输入是否正确
  		if((N>512)|(N<8)){
  			N = 512;
  			JOptionPane.showMessageDialog(null, "输入不正确,请重新输入!");
  		}
               //图像重采样
  		BufferedImage grayImage = new BufferedImage(iw, ih, 
					BufferedImage.TYPE_BYTE_GRAY);
  		//kao!三个循环就就能搞定,不就是重采样吗?
		for(int i=0; i<ih-1; i++){
			for(int j=0; j<iw-1; j=j+(ih/N)){
				for(int k=0; k<(ih/N); k++){
					int rgb = input.getRGB(i, j);  
	  				int grey = (int) (0.3*((rgb&0xff0000)>>16)+0.59*((rgb&0xff00)>>8)+0.11*((rgb&0xff)));
	  				rgb = 255<<24|grey<<16|grey<<8|grey;
	  				grayImage.setRGB(i, j+k, rgb);
				}
			}
		}	
                //产生图像
  		tmp = grayImage;
  		flag_load = true;
  		repaint();
  	}else{
  		JOptionPane.showMessageDialog(null, "先点击“装载图像”,3Q!","提示:",
  		        JOptionPane.WARNING_MESSAGE);
  		}
  	}
  //按钮动作的实现保存 
  	public void jSave_ActionPerformed(ActionEvent e) throws IOException{    
        if(flag_load){
        	
    		BufferedImage bi = new BufferedImage(tmp.getWidth(null),tmp.getHeight(null), 
    				BufferedImage.TYPE_INT_RGB);
            Graphics g = bi.getGraphics();
            g.drawImage(tmp,0, 0,null);
            g.dispose();
    		
  		    File save_path=new File("E:\\f2\\sc\\save_t01.jpg");
            ImageIO.write(bi, "JPG", save_path);

  	}else{
  		JOptionPane.showMessageDialog(null, "先点击“装载图像”,3Q!","提示:",
  				JOptionPane.WARNING_MESSAGE);
  		}
  	}
  //按钮动作的实现  退出
  	public void jQuit_ActionPerformed(ActionEvent e){
  		System.exit(0);
  	}
  //绘图函数
  	public void paint(Graphics g){
  		//if(flag_Load){
  			g.drawImage(tmp,50,50,this);
  		//}else{}
  	}
  	
	public static void main(String[] args) {
		chongcaiyang ti = new chongcaiyang();
		ti.setSize(1000,860);
		ti.setVisible(true);
	}
}
  • 大小: 218.6 KB
  • 大小: 25 KB
分享到:
评论

相关推荐

    java结合gdal对大图片进行重采样

    重采样是图像处理中的一个重要概念,它涉及到改变图像的分辨率,通常用于减小文件大小或适应不同的显示需求。GDAL提供了多种重采样算法,如最近邻、双线性、三次卷积等。对于大图片,重采样可以有效地降低图像的像素...

    利用IDL程序重采样(resample)MODIS影像.rar_IDL重采样代码_MODIS_modis重采样_重采样_重采样

    而重采样(Resampling)是遥感图像处理中的重要环节,用于将不同空间分辨率、时间分辨率或辐射分辨率的数据调整到统一的标准。本教程主要围绕如何利用IDL(Interactive Data Language)编程语言对MODIS影像进行重...

    JAVA基本数字图像处理

    "JAVA基本数字图像处理"这个项目旨在通过Java语言实现一系列基本的图像操作,以帮助开发者理解图像处理的基本原理并掌握其实践技巧。下面将详细介绍这些知识点。 首先,我们要了解数字图像的基础。数字图像实质上是...

    em.zip_EM_重采样检测_重采样检测_图像重采样_

    在图像处理领域,重采样是一项关键的技术,用于改变图像的分辨率或像素排列方式。"em.zip_EM_重采样检测_重采样检测_图像重采样_"这个压缩包文件,显然包含了与图像重采样检测相关的资料,特别是通过EM(Expectation...

    IDL重采样JPG图像

    重采样是图像处理中的关键步骤,它涉及改变图像的像素数量。在缩小图像时,多于的像素需要被平均或者插值处理;在放大图像时,需要在原始像素之间插入新的像素值。IDL中的`interpolate`函数是完成这一任务的关键工具...

    C++图像重采样构造影像金字塔

    在IT领域,图像处理是至关重要的一环,而“C++图像重采样构造影像金字塔”这一主题涉及到几个关键概念和技术。首先,让我们深入理解这些概念。 **图像重采样**是指改变图像的分辨率,即调整图像像素的数量。这通常...

    粒子群包括随机重采样、多项式重采样、系统重采样、残差重采样程序

    在这个主题中,我们将深入探讨四种重采样技术:随机重采样、多项式重采样、系统重采样和残差重采样,它们在粒子群优化中的应用。 1. **随机重采样**(Random Resampling):在粒子群优化中,随机重采样是更新粒子...

    图像重采样

    图像重采样是图像处理中的一个关键步骤,它涉及到像素值的重新分布,通常用于改变图像的尺寸、分辨率或坐标系。在MATLAB环境中,我们可以利用其强大的图像处理工具箱来实现这一操作。MATLAB提供的函数使我们能够方便...

    基于java开发实现InSAR影像降采样处理.pdf

    本文介绍了如何使用Java语言开发一款InSAR影像降采样处理软件,通过科学的降采样处理,以期得到准确的断层几何参数和滑动分布。InSAR技术,即合成孔径雷达干涉测量技术,是一种利用雷达影像复数数据中的相位信息提取...

    光谱数据重采样

    综上所述,"光谱数据重采样"项目涉及了光谱数据分析的关键技术,包括多种重采样策略、插值方法和数据处理流程,对于学习遥感和图像处理的学者来说,是一个极具价值的学习资源。通过实际操作和研究这些MATLAB代码,...

    C编写的重采样代码

    在实际应用中,重采样广泛应用于音频处理、图像处理、通信系统和数据分析等领域。例如,在音频处理中,重采样允许不同格式和采样率的音频文件相互转换;在通信系统中,可以调整信号的传输速率以适应不同的信道条件。...

    图像的重采样

    在图像处理领域,重采样是一项重要的技术,用于改变图像的分辨率或像素密度。在MATLAB环境中,可以使用各种方法来实现图像的重采样。本示例代码涉及的是一个基于EM(期望最大化)算法的图像重采样过程,它主要用于图像...

    论文研究-基于最优空间重采样的图像压缩算法.pdf

    方向关系模型是人工智能和图像处理领域中一个重要的概念,它涵盖了物体的方向属性、相对位置以及可能的相互影响。 为了构建这样一个模型,论文中提出了一系列的定义和定理。这些定义和定理在数学上定义了物体间方向...

    用Java语言写成的图像采样模拟程序

    这个项目对于学习图像处理和Java编程都是很好的实践,可以帮助理解采样原理,并掌握Java在图像处理中的应用。同时,它也提供了扩展的机会,比如添加滤镜效果、支持更多图像格式,或者优化性能以处理大型图像。

    audio resample(音频重采样)

    音频重采样是数字信号处理领域中的一个关键概念,它涉及到将数字音频信号从一个采样率转换到另一个采样率。在Xilinx FPGA或ASIC设计中,这种技术尤为重要,因为硬件实现可以提供实时、高效的音频处理能力。本文将...

    c语言实现线性重采样

    线性重采样demo代码,可实现8K/16K转32K/48K,16bit精度转32bit精度,可使用线性算法也可简单复制,自测有效,音频测试可采用。

    音频重采样Demo(Speex)

    音频重采样是数字音频处理中的一个重要环节,它涉及到将音频数据从一个采样率转换到另一个采样率。在本示例中,我们关注的是使用Speex库进行音频重采样的C++代码Demo。Speex是一种开源的音频编码库,它不仅提供了...

    图像下采样程序

    但是,编写自己的下采样程序可以帮助理解图像处理的基本原理,同时提供自定义和优化的可能性。 在使用这个程序时,用户可能需要对输入图像进行预处理,如调整大小或转换格式,然后调用这个下采样函数,得到下采样后...

    基于双线性内插法的图像重采样(matlab)

    基于双线性内插法的图像重采样,程序使用matlab编写,可对原始图像做任意方式的分辨率变换。 在图像的放大和缩小的过程中,需要计算新图像像素点在原图的位置,如果计算的位置不是整数,就需要用到图像的内插,我们...

Global site tag (gtag.js) - Google Analytics