该程序主要实现水平方向上的灰度图像重采样。重采样通过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
分享到:
相关推荐
重采样是图像处理中的一个重要概念,它涉及到改变图像的分辨率,通常用于减小文件大小或适应不同的显示需求。GDAL提供了多种重采样算法,如最近邻、双线性、三次卷积等。对于大图片,重采样可以有效地降低图像的像素...
而重采样(Resampling)是遥感图像处理中的重要环节,用于将不同空间分辨率、时间分辨率或辐射分辨率的数据调整到统一的标准。本教程主要围绕如何利用IDL(Interactive Data Language)编程语言对MODIS影像进行重...
"JAVA基本数字图像处理"这个项目旨在通过Java语言实现一系列基本的图像操作,以帮助开发者理解图像处理的基本原理并掌握其实践技巧。下面将详细介绍这些知识点。 首先,我们要了解数字图像的基础。数字图像实质上是...
在图像处理领域,重采样是一项关键的技术,用于改变图像的分辨率或像素排列方式。"em.zip_EM_重采样检测_重采样检测_图像重采样_"这个压缩包文件,显然包含了与图像重采样检测相关的资料,特别是通过EM(Expectation...
重采样是图像处理中的关键步骤,它涉及改变图像的像素数量。在缩小图像时,多于的像素需要被平均或者插值处理;在放大图像时,需要在原始像素之间插入新的像素值。IDL中的`interpolate`函数是完成这一任务的关键工具...
在IT领域,图像处理是至关重要的一环,而“C++图像重采样构造影像金字塔”这一主题涉及到几个关键概念和技术。首先,让我们深入理解这些概念。 **图像重采样**是指改变图像的分辨率,即调整图像像素的数量。这通常...
在这个主题中,我们将深入探讨四种重采样技术:随机重采样、多项式重采样、系统重采样和残差重采样,它们在粒子群优化中的应用。 1. **随机重采样**(Random Resampling):在粒子群优化中,随机重采样是更新粒子...
图像重采样是图像处理中的一个关键步骤,它涉及到像素值的重新分布,通常用于改变图像的尺寸、分辨率或坐标系。在MATLAB环境中,我们可以利用其强大的图像处理工具箱来实现这一操作。MATLAB提供的函数使我们能够方便...
本文介绍了如何使用Java语言开发一款InSAR影像降采样处理软件,通过科学的降采样处理,以期得到准确的断层几何参数和滑动分布。InSAR技术,即合成孔径雷达干涉测量技术,是一种利用雷达影像复数数据中的相位信息提取...
综上所述,"光谱数据重采样"项目涉及了光谱数据分析的关键技术,包括多种重采样策略、插值方法和数据处理流程,对于学习遥感和图像处理的学者来说,是一个极具价值的学习资源。通过实际操作和研究这些MATLAB代码,...
在实际应用中,重采样广泛应用于音频处理、图像处理、通信系统和数据分析等领域。例如,在音频处理中,重采样允许不同格式和采样率的音频文件相互转换;在通信系统中,可以调整信号的传输速率以适应不同的信道条件。...
在图像处理领域,重采样是一项重要的技术,用于改变图像的分辨率或像素密度。在MATLAB环境中,可以使用各种方法来实现图像的重采样。本示例代码涉及的是一个基于EM(期望最大化)算法的图像重采样过程,它主要用于图像...
方向关系模型是人工智能和图像处理领域中一个重要的概念,它涵盖了物体的方向属性、相对位置以及可能的相互影响。 为了构建这样一个模型,论文中提出了一系列的定义和定理。这些定义和定理在数学上定义了物体间方向...
这个项目对于学习图像处理和Java编程都是很好的实践,可以帮助理解采样原理,并掌握Java在图像处理中的应用。同时,它也提供了扩展的机会,比如添加滤镜效果、支持更多图像格式,或者优化性能以处理大型图像。
音频重采样是数字信号处理领域中的一个关键概念,它涉及到将数字音频信号从一个采样率转换到另一个采样率。在Xilinx FPGA或ASIC设计中,这种技术尤为重要,因为硬件实现可以提供实时、高效的音频处理能力。本文将...
线性重采样demo代码,可实现8K/16K转32K/48K,16bit精度转32bit精度,可使用线性算法也可简单复制,自测有效,音频测试可采用。
音频重采样是数字音频处理中的一个重要环节,它涉及到将音频数据从一个采样率转换到另一个采样率。在本示例中,我们关注的是使用Speex库进行音频重采样的C++代码Demo。Speex是一种开源的音频编码库,它不仅提供了...
但是,编写自己的下采样程序可以帮助理解图像处理的基本原理,同时提供自定义和优化的可能性。 在使用这个程序时,用户可能需要对输入图像进行预处理,如调整大小或转换格式,然后调用这个下采样函数,得到下采样后...
基于双线性内插法的图像重采样,程序使用matlab编写,可对原始图像做任意方式的分辨率变换。 在图像的放大和缩小的过程中,需要计算新图像像素点在原图的位置,如果计算的位置不是整数,就需要用到图像的内插,我们...