Java图像渐变
图像渐变我们大体想一下思路无非是这样:将图像所有的像素点的RBG,每个点就减去相同的量,而且这个量是个渐变的量。是的,就是这样,我们的程序也是这个思路,不过就是没有单纯的“想”这么简单了。我这里只编写了纵向渐变,还没有写其他复杂的渐变,以后慢慢研究吧。先看效果:
原始图片:
图像变暗渐变:
图像变暗渐变:
图像变亮渐变:
图像变亮渐变:
我们以图像渐变暗举例,渐变亮同样的道理,无非是一个减,一个加。
1.我们要先拿到图片,这个不赘述了,就是获得图像的BufferedImage。
2.获得图像的宽度,高度,像素值,并创建一个存储图像像素信息DirectColorModel类dem。然后我们从dem中每一个像素值。我们给每一个像素都减去一个相同的像素值。并且伴随着图片的高度不同,每个像素点减去的值也是一个渐变的值。这里需要说明一下的是float
beginPart,beginPart是渐变开始的位置,默认为1,就是从图像中间开始,beginPart<1从图像的中间偏上开始渐变,越小越偏上。beginPart>1从图像的中间偏下开始渐变,越大越偏上。
代码如下:
- private int[] darkerPixels(BufferedImage originalPic, float beginPart) {
- // 得到图片的宽度。
- int imageWidth = originalPic.getWidth();
- // 得到图片的高度。
- int imageHeight = originalPic.getHeight();
- // 得到图片的像素值。
- int totalBlocks = imageWidth * imageHeight;
- // 创建相处值的存储空间。
- int[] pixels = new int[totalBlocks];
- // 存储图像像素信息。
- DirectColorModel dem = new DirectColorModel(24, 0xff0000, 0x00ff00,
- 0x0000ff);
- float inc = 255f / imageHeight / beginPart;
- int int_inc = 100;
- float float_inc = 0;
- for (int i = 0; i < totalBlocks; i++) {
- if (i % imageHeight == 0 && i != 0) {
- float_inc = float_inc + inc;
- int_inc = (int) (float_inc);
- if (0 > int_inc) {
- int_inc = 0;
- }
- if (255 < int_inc) {
- int_inc = 255;
- }
- }
- int a = dem.getAlphaMask() / 2;
- int r = dem.getRed(pixels[i]) - int_inc;
- if (r < 0) {
- r = 0;
- }
- int g = dem.getGreen(pixels[i]) - int_inc;
- if (g < 0) {
- g = 0;
- }
- int b = dem.getBlue(pixels[i]) - int_inc;
- if (b < 0) {
- b = 0;
- }
- pixels[i] = a << 24 | r << 16 | g << 8 | b;
- }
- return pixels;
- }
3.利用改变后的像素点,生成一副新的图片。代码如下:
- public final BufferedImage getGradualImg(BufferedImage originalPic) {
- // 设置渐变的开发位置,1为中间位置,小于1开始位置偏上,大于1开始位置偏下。
- float beginPart = 1f;
- // 得到图片的所有渐变后的像素点。
- int[] pixels = darkerPixels(originalPic, beginPart);
- int imageWidth = originalPic.getWidth();
- int imageHeight = originalPic.getHeight();
- MemoryImageSource memoryimagesource = new MemoryImageSource(imageWidth,
- imageHeight, new DirectColorModel(24, 0xff0000, 0x00ff00,
- 0x0000ff), pixels, 0, imageWidth);
- Image imageBuf = null;
- try {
- memoryimagesource.setAnimated(true);
- memoryimagesource.setFullBufferUpdates(true);
- imageBuf = this.createImage(memoryimagesource);
- // 生成新的图像
- memoryimagesource.newPixels();
- } catch (NoSuchMethodError e) {
- e.printStackTrace();
- }
- BufferedImage changedImage = new BufferedImage(imageWidth, imageHeight,
- BufferedImage.TYPE_3BYTE_BGR);
- Graphics2D g2d = changedImage.createGraphics();
- g2d.drawImage(imageBuf, 0, 0, this);
- return changedImage;
- }
Java图像渐变的更多相关文章
- 以小时候玩的贪吃蛇为例,对于Java图像界面的学习感悟
简介 正文 01.JFrame是啥? 02.JPanel 03. KeyListener 04.Runnable 05.游戏Running 06.游戏初始类编写 07.main 简介: 一直以来用代码 ...
- ps图像渐变
整理自:http://zhidao.baidu.com/question/16374167.html 1.用ps打开图片 2.在切换至英文输入法状态下(下面的操作均如此)按q 快捷键q的作用是切换标准 ...
- Java图像灰度化的实现过程解析
概要 本文主要介绍了灰度化的几种方法,以及如何使用Java实现灰度化.同时分析了网上一种常见却并不妥当的Java灰度化实现,以及证明了opencv的灰度化是使用“加权灰度化”法 24位彩色图与8位灰度 ...
- JAVA 图像操作辅助类
package util; import java.awt.Component; import java.awt.Image; import java.awt.MediaTracker; import ...
- JAVA图像缩放处理
http://www.blogjava.net/kinkding/archive/2009/05/23/277552.html ———————————————————————————————————— ...
- java 图像灰度化与二值化
转载:http://www.chinasb.org/archives/2013/01/5053.shtml 1: package org.chinasb.client; 2: 3: import ja ...
- java图像加密
0 前言 为了保护服务器的图像数据,需要用一个图像加密算法来加密服务器的图像:一开始找了一种基于混沌的图像加密算法,效果还是很理想的,是把矩阵图像上的像素点进行上下左右的混乱:后来发现加密后图像会变大 ...
- <JAVA图像学习笔记>十字路口交通模拟--操作系统模拟课后小项目
项目的要求很简单: 模拟出十字路口的交通控制情况: 秒. 当东西(或南北)方向红灯时,所有车辆(除了消防车.救护车.警车)均排队等待,当东西(或南北)方向绿灯时,所有车辆按序行驶(不准超车). 制作这 ...
- <JAVA图像学习笔记>关于Graphics/Graphics2D以及简单的几何图像制作(一个简单钟表的实现)
题外话:正好赶上OperatingSystem的作业要做一个模拟线程/进程调度的问题,决定用JAVA实现才发现这些内容和之前学过的GUI制作是两码事儿- -b 通过学习java.swing库的Acti ...
随机推荐
- BZOJ 1797 网络流的可行边&必须边
求完网络流以后 tarjan一发 判一判 //By SiriusRen #include <queue> #include <bitset> #include <cstd ...
- Android RecyclerView实现横向滚动
我相信很久以前,大家在谈横向图片轮播是时候,优先会选择具有HorizontalScrollView效果和ViewPager来做,不过自从Google大会之后,系统为我们提供了另一个控件Recycler ...
- YYDispatchQueuePool阅读笔记
阅读了开源大神的YYDispatchQueuePool,在此记下一些从中学到的东西. 首先YYDispatchQueuePool.m文件中有如下类型对应: static inline dispatch ...
- pip源
阿里云 http://mirrors.aliyun.com/pypi/simple/ 中国科技大学 https://pypi.mirrors.ustc.edu.cn/simple/ 豆瓣(do ...
- 使用 validate 进行输入验证
validate 官方教程网址: http://www.runoob.com/jquery/jquery-plugin-validate.html 在表单页面引入两个核心 js 文件 #官方的两个文件 ...
- bzoj1604 牛的邻居 STL
Description 了解奶牛们的人都知道,奶牛喜欢成群结队.观察约翰的N(1≤N≤100000)只奶牛,你会发现她们已经结成了几个“群”.每只奶牛在吃草的时候有一个独一无二的位置坐标Xi,Yi(l ...
- POJ2976 Dropping tests(01分数规划)
题意 给你n次测试的得分情况b[i]代表第i次测试的总分,a[i]代表实际得分. 你可以取消k次测试,得剩下的测试中的分数为 问分数的最大值为多少. 题解 裸的01规划. 然后ans没有清0坑我半天. ...
- 紫书 习题 10-7 UVa 10539(long long + 素数筛)
注意要开long long 如果int * int会炸 那么久改成long long * int #include<cstdio> #include<vector> #incl ...
- 9 hbase源码系列(九)StoreFile存储格式
hbase源码系列(九)StoreFile存储格式 从这一章开始要讲Region Server这块的了,但是在讲Region Server这块之前得讲一下StoreFile,否则后面的不好讲下去 ...
- php实现简单算法2
php实现简单算法2 去弄php手册,里面有数据结构,有数据结构就好办了,我的算法基础那么好. 而且的话有数据结构的话再配合我脑中的那些算法了,我就都ok啦. 在手册里面搜索php数据结构就好 路径如 ...