用java对彩色图片进行灰度变换

用java对彩色图片进行灰度变换

ID:16276856

大小:33.50 KB

页数:4页

时间:2018-08-08

用java对彩色图片进行灰度变换_第1页
用java对彩色图片进行灰度变换_第2页
用java对彩色图片进行灰度变换_第3页
用java对彩色图片进行灰度变换_第4页
资源描述:

《用java对彩色图片进行灰度变换》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、用Java对彩色图片进行灰度变换我们在网页设计过程中,有时为了模拟单色VGA的显示效果或为了进行某种形象的夸张设计,而将彩色图形画面变为黑白显示,这就需要使用彩色到黑白的灰度变换技术。    灰度变换的算法其实很简单,只要提取每个象素点的红、绿、蓝三原色,然后根据公式:灰度值=红色亮度值*30%+绿色亮度值*59%+蓝色亮度值*11%,计算出一个灰度值,并将其作为红,绿,蓝三原色的新值重新写回显存即可。    具体步骤如下:    一,调用Graphics对象的drawImage()方法,在applet中显示出一幅名为TEST.JPG的彩色图象,drawImage()的

2、调用形式为:g.drawImage(name,x,y,width,heigth,this)。    二,定义一个数组存放这幅彩色图像的RGB值,数组大小就是图像的象素个数。使用PixelGrabber()获取每个象素点的RGB值。    三,使用灰度变换公式计算出每个象素点的灰度值,并将其作为新的RGB值存放回数组中,再调用createImage()方法构造出新的黑白图象。    四,显示出该黑白图片。为了防止变换过程中的闪烁现象,  程序中还使用了双缓冲技术,即先在虚屏中画好图象,再一  次性的显示出来。    程序中使用鼠标来控制彩色到黑白的变换。    灰度变换的

3、tt4.java源程序如下所示:  importjava.applet.*;importjava.awt.*;importjava.awt.image.*;publicclassRgb2GrayextendsApplet{Imageart,Buf;intonced=0;booleanis_color=true;GraphicsBufg;//使用双缓冲区技术抑制闪烁;Dimensionxy=null;publicvoidinit(){art=getImage(getDocumentBase(),"test.jpg");resize(640,480);//装入图片;}pub

4、licvoidpaint(Graphicsg){//如果是第一次装入图片,则直接显示;if(onced==0){g.drawImage(art,0,0,this);}//如果正在进行灰度变换,则提示等待;if((onced==1)

5、

6、(onced==2)){g.setColor(newColor(255,200,0));g.drawString("running!",1,30);}//如果灰度变换完毕,则显示结果;if(onced==3){if(is_color)g.drawImage(Buf,0,0,this);elseg.drawImage(art,0,0,this

7、);is_color=!is_color;//在彩色与黑白之间变化;}}publicbooleanmouseDown(Eventevt,intx,inty){if(onced==0){onced=1;}repaint();//用鼠标触发事件;returntrue;}publicbooleanmouseUp(Eventevt,intx,inty){if(onced==1){onced=2;intwd=art.getWidth(this);//取得图片宽;intht=art.getHeight(this);//取得图片高;GetPixels(art,0,0,wd,ht);/

8、/调用灰度变换方法;}returntrue;}publicvoidGetPixels(Imageimg,intx,inty,intw,inth){int[]pixels=newint[w*h];//定义一块内存空间;intgray;PixelGrabberpg=newPixelGrabber(img,x,y,w,h,pixels,0,w);try{pg.grabPixels();}catch(InterruptedExceptione){System.err.println("interruptedwaitingforpixels!");return;}for(intj

9、=0;j>16)&0xff)*0.3);gray+=(int)(((pixels[w*j+i]>>8)&0xff)*0.59);gray+=(int)(((pixels[w*j+i])&0xff)*0.11);//由红,绿,蓝值得到灰度值;pixels[w*j+i]=(255<<24)

10、(gray<<16)

11、(gray<<8)

12、gray;}}Imagepic=createImage(newMemoryImageSource(w,h

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。