图像渐变我们大体想一下思路无非是这样:将图像所有的像素点的RBG,每个点就减去相同的量,而且这个量是个渐变的量。是的,就是这样,我们的程序也是这个思路,不过就是没有单纯的“想”这么简单了。我这里只编写了纵向渐变,还没有写其他复杂的渐变,以后慢慢研究吧。先看效果:

原始图片:

图像变暗渐变:

图像变暗渐变:

图像变亮渐变:

图像变亮渐变:

我们以图像渐变暗举例,渐变亮同样的道理,无非是一个减,一个加。 
1.我们要先拿到图片,这个不赘述了,就是获得图像的BufferedImage。 
2.获得图像的宽度,高度,像素值,并创建一个存储图像像素信息DirectColorModel类dem。然后我们从dem中每一个像素值。我们给每一个像素都减去一个相同的像素值。并且伴随着图片的高度不同,每个像素点减去的值也是一个渐变的值。这里需要说明一下的是float

beginPart,beginPart是渐变开始的位置,默认为1,就是从图像中间开始,beginPart<1从图像的中间偏上开始渐变,越小越偏上。beginPart>1从图像的中间偏下开始渐变,越大越偏上。 
代码如下:

  1. private int[] darkerPixels(BufferedImage originalPic, float beginPart) {
  2. // 得到图片的宽度。
  3. int imageWidth = originalPic.getWidth();
  4. // 得到图片的高度。
  5. int imageHeight = originalPic.getHeight();
  6. // 得到图片的像素值。
  7. int totalBlocks = imageWidth * imageHeight;
  8. // 创建相处值的存储空间。
  9. int[] pixels = new int[totalBlocks];
  10. // 存储图像像素信息。
  11. DirectColorModel dem = new DirectColorModel(24, 0xff0000, 0x00ff00,
  12. 0x0000ff);
  13. float inc = 255f / imageHeight / beginPart;
  14. int int_inc = 100;
  15. float float_inc = 0;
  16. for (int i = 0; i < totalBlocks; i++) {
  17. if (i % imageHeight == 0 && i != 0) {
  18. float_inc = float_inc + inc;
  19. int_inc = (int) (float_inc);
  20. if (0 > int_inc) {
  21. int_inc = 0;
  22. }
  23. if (255 < int_inc) {
  24. int_inc = 255;
  25. }
  26. }
  27. int a = dem.getAlphaMask() / 2;
  28. int r = dem.getRed(pixels[i]) - int_inc;
  29. if (r < 0) {
  30. r = 0;
  31. }
  32. int g = dem.getGreen(pixels[i]) - int_inc;
  33. if (g < 0) {
  34. g = 0;
  35. }
  36. int b = dem.getBlue(pixels[i]) - int_inc;
  37. if (b < 0) {
  38. b = 0;
  39. }
  40. pixels[i] = a << 24 | r << 16 | g << 8 | b;
  41. }
  42. return pixels;
  43. }

3.利用改变后的像素点,生成一副新的图片。代码如下:

    1. public final BufferedImage getGradualImg(BufferedImage originalPic) {
    2. // 设置渐变的开发位置,1为中间位置,小于1开始位置偏上,大于1开始位置偏下。
    3. float beginPart = 1f;
    4. // 得到图片的所有渐变后的像素点。
    5. int[] pixels = darkerPixels(originalPic, beginPart);
    6. int imageWidth = originalPic.getWidth();
    7. int imageHeight = originalPic.getHeight();
    8. MemoryImageSource memoryimagesource = new MemoryImageSource(imageWidth,
    9. imageHeight, new DirectColorModel(24, 0xff0000, 0x00ff00,
    10. 0x0000ff), pixels, 0, imageWidth);
    11. Image imageBuf = null;
    12. try {
    13. memoryimagesource.setAnimated(true);
    14. memoryimagesource.setFullBufferUpdates(true);
    15. imageBuf = this.createImage(memoryimagesource);
    16. // 生成新的图像
    17. memoryimagesource.newPixels();
    18. } catch (NoSuchMethodError e) {
    19. e.printStackTrace();
    20. }
    21. BufferedImage changedImage = new BufferedImage(imageWidth, imageHeight,
    22. BufferedImage.TYPE_3BYTE_BGR);
    23. Graphics2D g2d = changedImage.createGraphics();
    24. g2d.drawImage(imageBuf, 0, 0, this);
    25. return changedImage;
    26. }

Java图像渐变的更多相关文章

  1. 以小时候玩的贪吃蛇为例,对于Java图像界面的学习感悟

    简介 正文 01.JFrame是啥? 02.JPanel 03. KeyListener 04.Runnable 05.游戏Running 06.游戏初始类编写 07.main 简介: 一直以来用代码 ...

  2. ps图像渐变

    整理自:http://zhidao.baidu.com/question/16374167.html 1.用ps打开图片 2.在切换至英文输入法状态下(下面的操作均如此)按q 快捷键q的作用是切换标准 ...

  3. Java图像灰度化的实现过程解析

    概要 本文主要介绍了灰度化的几种方法,以及如何使用Java实现灰度化.同时分析了网上一种常见却并不妥当的Java灰度化实现,以及证明了opencv的灰度化是使用“加权灰度化”法 24位彩色图与8位灰度 ...

  4. JAVA 图像操作辅助类

    package util; import java.awt.Component; import java.awt.Image; import java.awt.MediaTracker; import ...

  5. JAVA图像缩放处理

    http://www.blogjava.net/kinkding/archive/2009/05/23/277552.html ———————————————————————————————————— ...

  6. java 图像灰度化与二值化

    转载:http://www.chinasb.org/archives/2013/01/5053.shtml 1: package org.chinasb.client; 2: 3: import ja ...

  7. java图像加密

    0 前言 为了保护服务器的图像数据,需要用一个图像加密算法来加密服务器的图像:一开始找了一种基于混沌的图像加密算法,效果还是很理想的,是把矩阵图像上的像素点进行上下左右的混乱:后来发现加密后图像会变大 ...

  8. <JAVA图像学习笔记>十字路口交通模拟--操作系统模拟课后小项目

    项目的要求很简单: 模拟出十字路口的交通控制情况: 秒. 当东西(或南北)方向红灯时,所有车辆(除了消防车.救护车.警车)均排队等待,当东西(或南北)方向绿灯时,所有车辆按序行驶(不准超车). 制作这 ...

  9. <JAVA图像学习笔记>关于Graphics/Graphics2D以及简单的几何图像制作(一个简单钟表的实现)

    题外话:正好赶上OperatingSystem的作业要做一个模拟线程/进程调度的问题,决定用JAVA实现才发现这些内容和之前学过的GUI制作是两码事儿- -b 通过学习java.swing库的Acti ...

随机推荐

  1. 11.字符,字符常见开发,_itoa函数

    各种字符所占字节 wchar_t wch = L'我'; //占4个字节 char ch;//占1个字节 printf("%d\n", sizeof("A")) ...

  2. [学习笔记]BS架构与CS架构

    整理自:http://www.iteye.com/problems/102411 前两天面试的时候被问到这个问题,没有回答上来因此在这里学习整理一下. B/S架构 B/S架构的全称为Browser/S ...

  3. MySQL格式化日期参数

    MySQL格式化日期参数 %a 缩写星期名 %b 缩写月名 %c 月,数值 %D 带有英文前缀的月中的天 %d 月的天,数值(00-31) %e 月的天,数值(0-31) %f 微秒 %H 小时 (0 ...

  4. OGG切换步骤

    步骤描述 提前准备好切换方案:以及其他相关人员的配合 切换至容灾数据库: (1)停止前端业务,确认目标端数据已经追平 (2)数据校验,确认数据一致 (3)停止生产库OGG进程(停止后可以直接删除) ( ...

  5. 洛谷 P3804 【模板】后缀自动机 统计单词出现次数

    后缀自动机模板题. 关键时求解每个节点的 $right$ 大小. 由于后缀自动机在构建时会保证点和点的 $right$ 只可能没有交集,或者一个是另一个的真子集,我们可以不重复的对 $right$ 进 ...

  6. POJ 3630 Phone List(字典树)

    题意 题意:t个case(1<=t<=40),给你n个电话号码(电话号码长度<10)(1 ≤ n ≤ 10000),如果有电话号码是另一个电话号码的前缀,则称这个通讯录是不相容的,判 ...

  7. CF GYM 100781A(菊花图+直径)

    题目大意 给出若干颗树用最少的边把它们连成一个无向连通图,同时使图的直径最小.输出最小直径. 题解 我们定义树的半径为(树的直径+1)/2.符合题意的连接方式为.所有树的“中点”连在直径最长的树的中点 ...

  8. OpenGl 坐标转换

    1. OpenGL 渲染管线 OpenGL渲染管线分为两大部分,模型观測变换(ModelView Transformation)和投影变换(Projection Transformation). 做个 ...

  9. bzoj1066【SCOI2007】蜥蜴

    1066: [SCOI2007]蜥蜴 Time Limit: 1 Sec  Memory Limit: 162 MB Submit: 2512  Solved: 1238 [Submit][Statu ...

  10. PostgreSQL数据库创建/删除

    方法1 - 系统命令 sudo su - postgres #切换到postgres用户(系统用户) createdb weichen #创建数据库 psql #直接訪问数据库(默认进入本地postg ...