亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Java圖像處理技巧四則

2019-11-17 05:55:42
字體:
來源:轉載
供稿:網友

  下面代碼中用到的sourceImage是一個已經存在的Image對象

圖像剪切

  對于一個已經存在的Image對象,要得到它的一個局部圖像,可以使用下面的步驟:

//import java.awt.*;
//import java.awt.image.*;
Image croppedImage;
ImageFilter cropFilter;
CropFilter =new CropImageFilter(25,30,75,75); //四個參數分別為圖像起點坐標和寬高,即CropImageFilter(int x,int y,int width,int height),具體情況請參考API
CroppedImage= Toolkit.getDefaultToolkit().createImage(new FilteredImageSource(sourceImage.getSource(),cropFilter));


  假如是在Component的子類中使用,可以將上面的Toolkit.getDefaultToolkit().去掉。FilteredImageSource是一個ImagePRodUCer對象。

圖像縮放

  對于一個已經存在的Image對象,得到它的一個縮放的Image對象可以使用Image的getScaledInstance方法:

Image scaledImage=sourceImage. getScaledInstance(100,100, Image.SCALE_DEFAULT); //得到一個100X100的圖像
Image doubledImage=sourceImage. getScaledInstance(sourceImage.getWidth(this)*2,sourceImage.getHeight(this)*2, Image.SCALE_DEFAULT); //得到一個放大兩倍的圖像,這個程序一般在一個swing的組件中使用,而類Jcomponent實現了圖像觀察者接口ImageObserver,所有可以使用this。
//其它情況請參考API



灰度變換

  下面的程序使用三種方法對一個彩色圖像進行灰度變換,變換的效果都不一樣。一般而言,灰度變換的算法是將象素的三個顏色分量使用R*0.3+G*0.59+B*0.11得到灰度值,然后將之賦值給紅綠藍,這樣顏色取得的效果就是灰度的。另一種就是取紅綠藍三色中的最大值作為灰度值。java核心包也有一種算法,但是沒有看源代碼,不知道具體算法是什么樣的,效果和上述不同。

/* GrayFilter.java*/
/*@author:cherami */
/*email:cherami@163.net*/
import java.awt.image.*;

public class GrayFilter extends RGBImageFilter {
int modelStyle;
public GrayFilter() {
modelStyle=GrayModel.CS_MAX;
canFilterIndexColorModel=true;
}
public GrayFilter(int style) {
modelStyle=style;
canFilterIndexColorModel=true;
}
public void setColorModel(ColorModel cm) {
if (modelStyle==GrayModel
else if (modelStyle==GrayModel
}
public int filterRGB(int x,int y,int pixel) {
return pixel;
}
}

/* GrayModel.java*/
/*@author:cherami */
/*email:cherami@163.net*/

import java.awt.image.*;

public class GrayModel extends ColorModel {
public static final int CS_MAX=0;
public static final int CS_FLOAT=1;
ColorModel sourceModel;
int modelStyle;


 

public GrayModel(ColorModel sourceModel) {
super(sourceModel.getPixelSize());
this.sourceModel=sourceModel;
modelStyle=0;
}

public GrayModel(ColorModel sourceModel,int style) {

super(sourceModel.getPixelSize());
this.sourceModel=sourceModel;
modelStyle=style;
}

public void setGrayStyle(int style) {
modelStyle=style;
}

protected int getGrayLevel(int pixel) {
if (modelStyle==CS_MAX) {
return Math.max(sourceModel.getRed(pixel),Math.max(sourceModel.getGreen(pixel),sourceModel.getBlue(pixel)));
}
else if (modelStyle==CS_FLOAT){
return (int)(sourceModel.getRed(pixel)*0.3+sourceModel.getGreen(pixel)*0.59+sourceModel.getBlue(pixel)*0.11);
}
else {
return 0;
}
}

public int getAlpha(int pixel) {
return sourceModel.getAlpha(pixel);
}

public int getRed(int pixel) {
return getGrayLevel(pixel);
}

public int getGreen(int pixel) {
return getGrayLevel(pixel);
}

public int getBlue(int pixel) {
return getGrayLevel(pixel);
}

public int getRGB(int pixel) {
int gray=getGrayLevel(pixel);
return (getAlpha(pixel)<<24)+(gray<<16)+(gray<<8)+gray;
}
}


  假如你有自己的算法或者想取得非凡的效果,你可以修改類GrayModel的方法getGrayLevel()。

色彩變換

  根據上面的原理,我們也可以實現色彩變換,這樣的效果就很多了。下面是一個反轉變換的例子:

/* ReverseColorModel.java*/
/*@author:cherami */
/*email:cherami@163.net*/
import java.awt.image.*;

public class ReverseColorModel extends ColorModel {
ColorModel sourceModel;
public ReverseColorModel(ColorModel sourceModel) {
super(sourceModel.getPixelSize());
this.sourceModel=sourceModel;
}

public int getAlpha(int pixel) {
return sourceModel.getAlpha(pixel);
}

public int getRed(int pixel) {
return ~sourceModel.getRed(pixel);
}

public int getGreen(int pixel) {
return ~sourceModel.getGreen(pixel);
}

public int getBlue(int pixel) {
return ~sourceModel.getBlue(pixel);
}

public int getRGB(int pixel) {
return (getAlpha(pixel)<<24)+(getRed(pixel)<<16)+(getGreen(pixel)<<8)+getBlue(pixel);
}
}
/* ReverseColorModel.java*/
/*@author:cherami */
/*email:cherami@163.net*/

import java.awt.image.*;

public class ReverseFilter extends RGBImageFilter {
public ReverseFilter() {
canFilterIndexColorModel=true;
}

public void setColorModel(ColorModel cm) {
substituteColorModel(cm,new ReverseColorModel(cm));
}


public int filterRGB(int x,int y,int pixel) {
return pixel;
}
}


  要想取得自己的效果,需要修改ReverseColorModel.java中的三個方法,getRed、getGreen、getBlue。

  下面是上面的效果的一個總的演示程序。

/*GrayImage.java*/
/*@author:cherami */
/*email:cherami@163.net*/
import java.awt.*;
import java.awt.image.*;
import javax.swing.*;
import java.awt.color.*;

public class GrayImage extends JFrame{
Image source,gray,gray3,clip,bigimg;
BufferedImage bimg,gray2;
GrayFilter filter,filter2;
ImageIcon ii;
ImageFilter cropFilter;
int iw,ih;

public GrayImage() {
ii=new ImageIcon(/"images/11.gif/");
source=ii.getImage();
iw=source.getWidth(this);
ih=source.getHeight(this);
filter=new GrayFilter();
filter2=new GrayFilter(GrayModel.CS_FLOAT);
gray=createImage(new FilteredImageSource(source.getSource(),filter));
gray3=createImage(new FilteredImageSource(source.getSource(),filter2));
cropFilter=new CropImageFilter(5,5,iw-5,ih-5);
clip=createImage(new FilteredImageSource(source.getSource(),cropFilter));
bigimg=source.getScaledInstance(iw*2,ih*2,Image.SCALE_DEFAULT);
MediaTracker mt=new MediaTracker(this);
mt.addImage(gray,0);
try {
mt.waitForAll();
} catch (Exception e) {
}
}

public void paint(Graphics g) {
Graphics2D g2=(Graphics2D)g;
bimg=new BufferedImage(iw, ih, BufferedImage.TYPE_INT_RGB);
Graphics2D srcG = bimg.createGraphics();
RenderingHints rhs = g2.getRenderingHints();
srcG.setRenderingHints(rhs);
srcG.drawImage(source, 0, 0, null);
ColorSpace graySpace=ColorSpace.getInstance(ColorSpace.CS_GRAY);
ColorConvertOp op=new ColorConvertOp(graySpace,rhs);
gray2=new BufferedImage(iw, ih, BufferedImage.TYPE_INT_RGB);
op.filter(bimg,gray2);
g2.drawImage(source,40,40,this);
g2.drawImage(gray,80,40,this);
g2.drawImage(gray2,120,40,this);
g2.drawImage(gray3,160,40,this);
g2.drawImage(clip,40,80,this);
g2.drawImage(bigimg,80,80,this);
}

public void update(Graphics g) {
paint(g);
}

public static void main(String args[]) {
GrayImage m=new GrayImage();
m.setSize(400,400);
m.setVisible(true);
}
}




發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97久久精品国产| 欧美国产在线电影| 久久免费视频在线观看| 毛片精品免费在线观看| 91久久久亚洲精品| 欧美性生交xxxxx久久久| 亚洲乱码国产乱码精品精天堂| 成人精品视频99在线观看免费| 国产一区二区三区免费视频| 欧美高清性猛交| 日韩精品在线观看网站| 日韩网站免费观看高清| 欧美成人h版在线观看| 日韩黄色高清视频| 国产精品99久久久久久久久| 中日韩美女免费视频网站在线观看| 精品视频在线播放色网色视频| 北条麻妃一区二区在线观看| 91爱爱小视频k| 日韩一区二区久久久| 国产激情久久久久| 伊人一区二区三区久久精品| 久久亚洲精品中文字幕冲田杏梨| www.日韩系列| 欧美限制级电影在线观看| 国产一区二区精品丝袜| 久久频这里精品99香蕉| 欧美日韩亚洲一区二区三区| 97超碰色婷婷| 欧美国产日韩中文字幕在线| 国产精品极品尤物在线观看| 国产精品入口夜色视频大尺度| 日日摸夜夜添一区| 国产丝袜一区二区三区免费视频| 日韩成人在线视频| 欧美日韩国产va另类| 97视频人免费观看| 成人黄色大片在线免费观看| 欧美精品在线免费观看| 一区二区三区无码高清视频| 欧美激情综合色| 欧美亚洲另类在线| 色黄久久久久久| 欧美日韩激情网| 精品亚洲一区二区三区在线播放| 国产日韩在线播放| 日韩精品在线免费观看| 成人激情视频在线播放| 欧美理论电影在线观看| 国产精品扒开腿做爽爽爽视频| 成人黄色在线播放| 欧美成在线视频| 国产在线观看91精品一区| 亚洲最大的免费| 久久综合伊人77777尤物| 日本免费一区二区三区视频观看| 欧美第一页在线| 国产成人自拍视频在线观看| 国产精品男人爽免费视频1| 久久国产精品免费视频| 中文字幕一区电影| 91在线观看免费高清完整版在线观看| 国产午夜精品一区理论片飘花| 日韩av一区在线| 中文字幕在线视频日韩| 亚洲色无码播放| 中文字幕精品影院| 欧美精品一区二区免费| 亚洲综合中文字幕68页| 不卡伊人av在线播放| 欧美性xxxxhd| 全亚洲最色的网站在线观看| 欧美日韩电影在线观看| 国产精品一区二区三区毛片淫片| 亚洲乱码一区av黑人高潮| 亚洲成av人片在线观看香蕉| 亚洲人成欧美中文字幕| 国产精品自产拍在线观看中文| 精品久久久久久久久久久| 国产91色在线| 亚洲综合成人婷婷小说| 2025国产精品视频| 国产精品爽爽ⅴa在线观看| 国产精品视频在线观看| 亚洲国产小视频在线观看| 日韩电影中文字幕在线| 色综合91久久精品中文字幕| 91免费视频国产| 久久免费少妇高潮久久精品99| 国产成人精彩在线视频九色| 成人乱色短篇合集| 91日韩在线视频| 日韩天堂在线视频| 成人在线视频网| 日韩美女在线观看一区| 欧美理论电影在线播放| 日韩高清电影免费观看完整版| 精品视频久久久久久久| 亚洲图片欧美午夜| 国产精品露脸自拍| 色偷偷偷综合中文字幕;dd| 亚洲精品电影网站| 国产精品视频免费在线观看| 国产精品igao视频| 国产91色在线|免| 亚洲xxx大片| 久久久久久久久久久网站| 精品成人国产在线观看男人呻吟| 欧美另类精品xxxx孕妇| 久久久精品欧美| 亚洲www在线观看| 一道本无吗dⅴd在线播放一区| 国产香蕉97碰碰久久人人| 91亚洲人电影| 欧美日韩成人在线观看| 欧美精品久久久久久久久久| 国产精品99一区| 久久精品国产电影| 亚洲欧美日韩精品久久亚洲区| 精品久久久久久久久久久久| 色av吧综合网| 日本不卡免费高清视频| 北条麻妃在线一区二区| 欧美夫妻性视频| 精品亚洲一区二区三区在线观看| 国产丝袜一区二区三区| 欧美高清一级大片| 国产亚洲精品久久久优势| 日韩成人xxxx| 日本成人激情视频| 亚洲乱码av中文一区二区| 国产精品一香蕉国产线看观看| 日韩av电影手机在线| 欧美亚洲国产另类| 好吊成人免视频| 欧美日韩免费在线| 欧美一区二区视频97| www国产亚洲精品久久网站| 成人福利视频在线观看| 日韩av在线免播放器| 奇米成人av国产一区二区三区| 亚洲视频自拍偷拍| 国产不卡在线观看| 一区二区三区 在线观看视| 久久成人精品电影| 免费91在线视频| 亚洲人成电影在线播放| 亚洲精品理论电影| 国产999在线观看| 91精品免费视频| 91精品国产91久久久久久| 国产精品色视频| 成人性生交xxxxx网站| 欧美成人免费一级人片100| 久久久精品在线观看| 精品国偷自产在线视频99| 亚洲人成网站免费播放| 国产亚洲人成a一在线v站| 日韩在线免费av| 久久高清视频免费| 91精品免费久久久久久久久| 国模私拍视频一区| 久久亚洲电影天堂| 国产成人福利夜色影视|