图像渐变我们大体想一下思路无非是这样:将图像所有的像素点的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. 【DNN 系列】 MVC 分页

    MVC分页可采用插件形式, 有MvcPage那个插件但是我觉得那个是假分页 有点影响效率 所以网上找了一个例子来 做分页 1, PagerQuery.cs public class PagerQuer ...

  2. PostgreSQL源代码中插件的使用

    如果编译数据库时使用了gmake world和gmake install-world, 所有的插件都会被安装, 那么就不需要再次安装了. 插件目录 contrib 进入要安装的插件目录, 例如 cd ...

  3. windows gitbub使用

    1.安装git bush (windows没什么好说的 下一步,下一步,,) 2. 通过gitbush命令行生成密钥: (拷贝密钥) 3.密钥添加到github上面: 4.克隆项目: 5.提交: 查看 ...

  4. Debian9.5下ssh密钥登录配置步骤(免密码登录)和ssh-keygen 命令常用参数

    密钥登录步骤(免密码登录)ssh登录提供两种认证方式:口令(密码)认证方式和密钥认证方式.其中口令(密码)认证方式是我们最常用的一种,出于安全方面的考虑,介绍密钥认证方式登录到linux/unix的方 ...

  5. 洛谷 P2147 [SDOI2008]洞穴勘测 LCT

    Code: #include <cstdio> #include <algorithm> #include <string> #include <cstrin ...

  6. 洛谷1440 求m区间的最小值 单调队列

    题目描述 一个含有n项的数列(n<=2000000),求出每一项前的m个数到它这个区间内的最小值.若前面的数不足m项则从第1个数开始,若前面没有数则输出0. 输入格式: 第一行两个数n,m. 第 ...

  7. bzoj2124 等差子序列(树状数组+hash)

    题意 给你一个1~n排列,问有没有一个等差数列(长度至少为3) 题解 我居然自己想到了正解. 但我最后写挂了,所以我又看了题解. 我们维护了一个以权值为下标的01序列. 我们扫描整个序列.对于每一个正 ...

  8. [NOIP2010提高组]引水入城

    题目:洛谷P1514.Vijos P1777.codevs1066. 题目大意:有一个$n×m$的矩阵,每个点都有一个高度,可以在第一行的任意点建立蓄水厂.现在要把水输到最后一行的所有点上,规定水只能 ...

  9. Spring MVC框架一个实例的手动实现

    文件结构: SpringMVC05 // 应用程序名 ----index.html // 欢迎文件,主目录下的文件可以被URL直接访问到 ----WEB-INF // 这个目录下的文件将被保护起来不能 ...

  10. Python3 利用POP3与smtplib进行计算机远程控制

    初习,代码有不足之处,欢迎指出. 跟大家分享的是,通过发送端发送cmd命令,从而对接收端进行cmd命令的控制. #接收端代码 from poplib import POP3 import time,o ...