package image;import java.awt.alphacomposite;import java.awt.color;import java.awt.font;import java.awt.graphics;import java.awt.graphics2d;import java.awt.image;import java.awt.image.bufferedimage;import java.awt.image.colormodel;import java.awt.image.pixelgrabber;import java.io.file;import java.io.fileoutputstream;import javax.imageio.imageio;import com.sun.image.codec.jpeg.jpegcodec;import com.sun.image.codec.jpeg.jpegimageencoder;public class watermark { /** * 获取指定矩形中的像素的矩阵 * * @param imagesrc * @param startx * @param starty * @param w * @param h * @return */ private int[] getpixarray(image imagesrc, int startx, int starty, int w, int h) { int[] pix = new int[(w - startx) * (h - starty)]; /*下面是别人程序中的一段,我实在不明白为何要加这一段,因为我去掉也没有问题,加上还会报错*/ pixelgrabber pg = null; try { pg = new pixelgrabber(imagesrc, startx, starty, w-startx, h-starty, pix, 0, w); if (pg.grabpixels() != true) { try { throw new java.awt.awtexception("pg error" + pg.status()); } catch (exception eq) { eq.printstacktrace(); } } } catch (exception ex) { ex.printstacktrace(); } return pix; } /** * 将1张图片和另1张图片的指定区域重合。可用于制作水印。图片的左上角坐标为0,0 * * @param lightnesswaterimg * 颜色比较亮的水印图片,适合底色比较暗的情况 * @param darknesswaterimg * 颜色比较暗的水印图片,适合底色比较亮的情况,如果不想区分,则输入null,平均灰度边界同时失效。 * @param targetimg * 源图片 * @param startx * @param starty * @param x * @param y * @param alpha * 透明度,0f为全透明,1f为完全不透明,0.5f为半透明 * @param averagegray * 平均灰度边界(0-255),大于此值,则打暗的水印图片,小于此值则打亮的水印图片。 * 默认值128。超过范围,按默认值进行。 */ private final void pressimage(string lightnesswaterimg, string darknesswaterimg, string targetimg, int startx, int starty, int x, int y, float alpha, float averagegray) { try { // 先判断亮水印和源文件的值是否为null,否则抛出异常 if (lightnesswaterimg == null || lightnesswaterimg == "" || targetimg == null || targetimg == "") { throw new exception("亮水印或者源图片的地址不能为空"); } // 再判断平均灰度边界是否越界 if (averagegray>255||averagegray<0) { averagegray = 128; } // 装载源图片 file _file = new file(targetimg); // 图片装入内存 bufferedimage src = imageio.read(_file); // 获取图片的尺寸 int width = src.getwidth(null); int height = src.getheight(null); // 根据源图片尺寸,设置预装载的一个图片,默认是rgb格式的 bufferedimage image = new bufferedimage(width, height, bufferedimage.type_int_rgb); graphics2d graphics = image.creategraphics(); // 绘制内存中的源图片至指定的矩形内 graphics.drawimage(src, 0, 0, width, height, null); // 在已经绘制的图片中加入透明度通道 graphics.setcomposite(alphacomposite.getinstance( alphacomposite.src_atop, alpha)); // 获取源图片中和设定的同样大小的区域内的像素集合 int[] pixels = getpixarray(src, startx, starty, x, y); //查询此集合的平均灰度 float average = getaveragegrap(x-startx,y-starty,pixels); // 如果平均灰度大于130,则说明此区域比较亮,否则则比较暗 system.out.println(average); //装载水印图片所需参数 file water; bufferedimage bufferwater; // 根据设定的平均灰度边界来装载不同的水印 if (darknesswaterimg == null||average>=averagegray) { // 装载亮水印文件 water = new file(darknesswaterimg); }else{ // 装载暗水印文件 water = new file(lightnesswaterimg); } // 装入内存 bufferwater = imageio.read(water); graphics.drawimage(bufferwater, startx, starty, x, y, null); // 水印文件结束 graphics.dispose(); fileoutputstream out = new fileoutputstream(targetimg); jpegimageencoder encoder = jpegcodec.createjpegencoder(out); // 绘制新的文件 encoder.encode(image); out.close(); } catch (exception e) { e.printstacktrace(); } } /** * 查询某个区域的平均灰度 * @param width * @param height * @param pixels * @return */ private float getaveragegrap(int width,int height,int[] pixels){ /* 下面是开始算这个区域的亮度了,灰度等同于亮度 */ colormodel colormodel = colormodel.getrgbdefault(); int i = 0; int j = 0; int k = 0; int r = 0; int g = 0; int b = 0; int gray = 0; float average = 0;// 平均灰度 for (i = 0; i < height; i++) { for (j = 0; j < width; j++) { // 定位像素点 k = i * width + j; r = colormodel.getred(pixels[k]); g = colormodel.getgreen(pixels[k]); b = colormodel.getblue(pixels[k]); // 计算灰度值 gray = (r * 38 + g * 75 + b * 15) >> 7; average = average + gray; } } // 计算平均灰度 average = average / ((i - 1) * (j - 1)); return average; } public static void main(string[] args) { watermark watermark = new watermark(); watermark.pressimage("f:\\a2.png", "a1.png", "2.jpg", 520, 500, 900, 800, 0.5f, 50); system.out.print("添加成功"); }}
分享到:
相关推荐
线性变化处理能改善由水印带来的对彩色图像明暗度的影响,同时利用一维Tent混沌的特性构成混沌二维置换网络,只需要一个初值,使算法更加简单。由实验结果表明该算法对JPEG压缩稳健,而对恶意操作敏感,同时水印提取...
色调是指图像的明暗度,饱和度是色彩的纯度,色相即颜色本身,亮度则是人眼对图像明暗的感觉。对比度(Contrast)是图像中颜色或明暗度的对比差异。此外,色彩通道(Color Channels)描述了原色信息的混合和处理方式...
此外,它还能调节模型明暗度,创建路径漫游高清视频,以及多瓦片选择操作,使模型展示更加直观。 CCViewer则侧重于创建动画、视频和漫游场景,可以生成高分辨率的平剖图和透视图。它有一个直观的、基于时间的漫游...
3. 光源调节,调节模型明暗度,优化模型效果 4. 路径漫游高清视频输出,自定义漫游路径,按照飞行路线输出高清视频,突破显示器分辨率限制,以达到清晰流畅的模型展示效果,解决第三方软件录制时的加载卡顿模糊等...
范例5-1-2使用ConvertTo及GUI元件调整影像明暗度 110 范例5-1-3使用addWeighted及GUI元件调整影像明亮度 111 范例5-1-4改变影像的每1个像素调整影像明亮度 112 范例5-2-1全彩图转灰阶图 113 范例5-3-1影像颜色相反,...