图像渐变我们大体想一下思路无非是这样:将图像所有的像素点的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. BZOJ 1797 网络流的可行边&必须边

    求完网络流以后 tarjan一发 判一判 //By SiriusRen #include <queue> #include <bitset> #include <cstd ...

  2. Android RecyclerView实现横向滚动

    我相信很久以前,大家在谈横向图片轮播是时候,优先会选择具有HorizontalScrollView效果和ViewPager来做,不过自从Google大会之后,系统为我们提供了另一个控件Recycler ...

  3. YYDispatchQueuePool阅读笔记

    阅读了开源大神的YYDispatchQueuePool,在此记下一些从中学到的东西. 首先YYDispatchQueuePool.m文件中有如下类型对应: static inline dispatch ...

  4. pip源

    阿里云 http://mirrors.aliyun.com/pypi/simple/   中国科技大学 https://pypi.mirrors.ustc.edu.cn/simple/   豆瓣(do ...

  5. 使用 validate 进行输入验证

    validate 官方教程网址: http://www.runoob.com/jquery/jquery-plugin-validate.html 在表单页面引入两个核心 js 文件 #官方的两个文件 ...

  6. bzoj1604 牛的邻居 STL

    Description 了解奶牛们的人都知道,奶牛喜欢成群结队.观察约翰的N(1≤N≤100000)只奶牛,你会发现她们已经结成了几个“群”.每只奶牛在吃草的时候有一个独一无二的位置坐标Xi,Yi(l ...

  7. POJ2976 Dropping tests(01分数规划)

    题意 给你n次测试的得分情况b[i]代表第i次测试的总分,a[i]代表实际得分. 你可以取消k次测试,得剩下的测试中的分数为 问分数的最大值为多少. 题解 裸的01规划. 然后ans没有清0坑我半天. ...

  8. 紫书 习题 10-7 UVa 10539(long long + 素数筛)

    注意要开long long 如果int * int会炸 那么久改成long long * int #include<cstdio> #include<vector> #incl ...

  9. 9 hbase源码系列(九)StoreFile存储格式

    hbase源码系列(九)StoreFile存储格式    从这一章开始要讲Region Server这块的了,但是在讲Region Server这块之前得讲一下StoreFile,否则后面的不好讲下去 ...

  10. php实现简单算法2

    php实现简单算法2 去弄php手册,里面有数据结构,有数据结构就好办了,我的算法基础那么好. 而且的话有数据结构的话再配合我脑中的那些算法了,我就都ok啦. 在手册里面搜索php数据结构就好 路径如 ...