- 浏览: 131956 次
- 性别:
- 来自: 齐齐哈尔滨
-
文章分类
最新评论
-
sunstar356:
不错 有帮助
Java反射实体类属性(get ,set方法) -
DarkWingBoy:
好多银行网站都是SSH框架做的吧。。。
SSH框架的瓶颈在哪里? -
OnePiece_2012:
很好 多谢了
中科软面试笔试题 -
hzw2312:
.......!
够给力!
JavaScript 获得 汉字 的 完整 拼音 -
tkgguter88:
初学者。谢谢分享
JavaScript 获得 汉字 的 完整 拼音
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("添加成功"); } }
发表评论
-
Android原理揭秘系列之VacantCell缓存
2011-09-08 17:01 964操作过Android手机的朋友应该对在待机界面拖动图标的交互效 ... -
Hibernate 疑难杂症
2011-09-06 13:44 984作者:小生、我怕怕 网址:http://www.apk ... -
APKBank.NET 安卓银行隆重上线运营。
2011-09-01 10:10 967安卓银行(APKBank.NET)于2011年9月1 ... -
深入探讨 Java 类加载器
2011-08-17 13:43 1028作者:小生、我怕怕; Email:17zouguo@si ... -
navicat Oracle Instant Client Light: unsupported server character set CHS16GBK解决
2011-06-28 12:10 1614Navicat 连接 Oracle 出现 Instant Cl ... -
用Spring JMS使异步消息变得简单
2011-04-21 13:00 1387用Spring JMS使异步消息变得简单 ... -
通过Google获取天气预报信息
2011-04-19 16:31 1237Google提供获取天气预报信息的接口: http://ww ... -
Java堆和栈的区别
2011-04-19 15:11 828栈与堆都是Java用来在Ram ... -
解决办法:Access restriction: The type JPEGImageEncoder is not accessible due to rest
2011-04-15 13:20 1133在Eclipse中处理图片,需要引入两个包:import co ... -
Spring 3.0 注解注入详解
2011-04-12 14:48 12508一、各种注解方式 1.@Aut ... -
Spring事务配置的五种方式
2011-04-12 10:23 760前段时间对Spring ... -
Spring3.0+Struts2.1.8+Hibernate3.5整合
2011-04-02 10:03 1154Spring3.0+Struts2.1.8+Hibernate ... -
Java实现远程屏幕监视
2011-03-16 10:49 1190远程屏幕监视使 ... -
图片的切割和缩略
2011-03-02 18:56 847package com.supben.util; imp ... -
Java 图片水印+文字水印+缩图实现
2011-03-02 18:54 1084import java.awt.AlphaComposite; ... -
Java 实现截屏
2011-03-02 18:49 800import java.awt.Dimension; i ... -
java 缩略图
2011-03-02 18:48 0一、较清晰的方法: import java.awt.Grap ... -
PO,BO, VO, DTO, POJO, DAO的概念及区分
2011-02-24 21:36 1013O/R Mapping 是 Object Relation ... -
SSH struts、spring、hibernate 面试题
2011-02-24 16:03 1207Hibernate工作原理及为什么要用? 原理: ... -
数据压缩与传输
2011-01-07 13:11 1331FileServer: import java.net.*; ...
相关推荐
线性变化处理能改善由水印带来的对彩色图像明暗度的影响,同时利用一维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影像颜色相反,...