package test;
import java.awt.Color;
import java.awt.Frame;
import java.awt.Graphics;
import java.awt.Image;
import java.awt.MediaTracker;
import java.awt.Panel;
import java.awt.image.BufferedImage;
import java.awt.image.MemoryImageSource;
import java.awt.image.PixelGrabber;
import javax.imageio.ImageIO;
import java.io.File;
import java.awt.Toolkit;
/*******************************************************************************
* //** * Title: LoonFramework
*
*
* Description:Java图形程序水纹倒映效果
*
*
* Copyright: Copyright (c) 2007
*
*
* Company: LoonFramework
*
*
* @author chenpeng
* @email:ceponline@yahoo.com.cn
* @version 0.1
*/
public class ImageWave extends Panel implements Runnable {
/** */
/**
*
*/
private static final long serialVersionUID = 1L;
private Thread thread;
private Image _image;
private MediaTracker _mt;
private int _delay;
private Graphics _bg;
private Image _screen;
private boolean _playing;
private int _pixels[];
private int _mpixels[];
private int _wpixels[];
private final static int _WIDTH = 600;
private final static int _HEIGHT = 700;
private Image _images[];
private int _sleep;
private int _frame;
/** */
/**
* 构造函数,注入背景图与延迟时间
*
* @param img
* @param delay
*/
public ImageWave(Image img, int delay) {
_delay = delay;
init(img, delay);
}
public void init(Image img, int delay) {
setBackground(Color.BLACK);
_image = img;
_mt = new MediaTracker(this);
_mt.addImage(_image, 0);
_mt.checkAll(true);
_frame = 10;
_screen = new BufferedImage(_WIDTH, _HEIGHT, 1);
_bg = _screen.getGraphics();
thread = new Thread(this);
thread.start();
}
public void run() {
Thread.currentThread().setPriority(1);
long l = System.currentTimeMillis();
while (Thread.currentThread() == thread)
try {
repaint();
_sleep++;
l += _delay;
Thread.sleep(Math.max(0L, l - System.currentTimeMillis()));
} catch (InterruptedException _ex) {
return;
}
}
/** */
/**
* 绘制图象
*/
public void paint(Graphics g) {
if (!_playing) {
if (_mt.checkAll()) {
_playing = true;
_bg.drawImage(_image, 0, 0, this);
_pixels = new int[(_WIDTH * _HEIGHT) / 2];
_mpixels = new int[(_WIDTH * _HEIGHT) / 2];
_wpixels = new int[((_WIDTH * _HEIGHT) / 2) * _frame];
PixelGrabber pixelgrabber = new PixelGrabber(_image, 0, 0,
_WIDTH, _HEIGHT / 2, _pixels, 0, _WIDTH);
try {
pixelgrabber.grabPixels();
} catch (InterruptedException _ex) {
}
blure();
_images = new Image[_frame];
for (int i = 0; i < _frame; i++)
_images[i] = createMirrorImage(i);
}
} else {
if (_sleep > _frame - 1)
_sleep = 0;
_bg.drawImage(_images[_sleep], 0, _HEIGHT / 2, this);
}
g.drawImage(_screen, 0, 0, this);
}
public void update(Graphics g) {
paint(g);
}
/** */
/**
* 创建波纹反射图片
*
* @param i
* @return
*/
Image createMirrorImage(int i) {
int k1 = _HEIGHT / 2;
int j1 = i * _WIDTH * k1;
for (int k = 0; k < k1; k++) {
int l = k * _WIDTH;
int i1 = k1 - k - 1;
i1 += (int) ((double) ((k * 5) / k1 + 2) * Math
.sin((25.132741228718345D * (double) i1 * (double) i1)
/ (double) k1 / (double) k1
- (6.2831853071795862D * (double) i)
/ (double) _frame));
if (i1 < 0)
i1 = 0;
if (i1 > k1 - 1)
i1 = k1 - 1;
i1 *= _WIDTH;
for (int j = 0; j < _WIDTH; j++)
_wpixels[j1 + j + l] = _mpixels[j + i1];
}
Image image = createImage(new MemoryImageSource(_WIDTH, k1, _wpixels,
j1, _WIDTH));
return image;
}
/** */
/**
* 模糊化反射图片
*
*/
void blure() {
int l = _HEIGHT / 2;
for (int j = 0; j < l; j++) {
int k = j * _WIDTH;
for (int i = 0; i < _WIDTH; i++) {
int i1 = _pixels[i + k];
int j1;
if (i != _WIDTH - 1)
j1 = _pixels[i + k + 1];
else
j1 = _pixels[(i + k) - 1];
int k1 = 0;
if (j != l - 1)
k1 = _pixels[i + k + _WIDTH];
else
k1 = _pixels[(i + k) - _WIDTH];
int l1 = 0;
if (j != l - 1 && i != _WIDTH - 1)
l1 = _pixels[i + k + _WIDTH + 1];
else
l1 = _pixels[i + k];
int i2 = (i1 >> 16 & 0xff) + (j1 >> 16 & 0xff)
+ (k1 >> 16 & 0xff) + (l1 >> 16 & 0xff);
int j2 = (i1 >> 8 & 0xff) + (j1 >> 8 & 0xff) + (k1 >> 8 & 0xff)
+ (l1 >> 8 & 0xff);
int k2 = (i1 & 0xff) + (j1 & 0xff) + (k1 & 0xff) + (l1 & 0xff);
i2 >>= 3;
j2 = (j2 >> 3) + (j2 >> 4);
k2 = (k2 >> 3) + (k2 >> 4);
_mpixels[i + k] = i1 & 0xff000000 | i2 << 16 | j2 << 8 | k2;
}
}
}
public static void main(String[] args) {
Frame frm = new Frame();
frm.setSize(_WIDTH, _HEIGHT + 20);
frm.setResizable(false);
Image im = Toolkit.getDefaultToolkit().createImage("C:/media/pic/123.jpg");
frm.add(new ImageWave(im, 100));
frm.setVisible(true);
}
}
分享到:
相关推荐
Java与图片处理相关的一些资料与工具。 java pic。
基于Java Web技术的图片管理系统 的设计与实现 本科毕业设计 目 录 第1章 引言 6 1.1 课题研究目的及意义 6 1.2 课题研究的内容 7 2.1 用户功能需求 7 图片收藏数据库查询系统图片收藏数据库查询系统是方便用户对...
一个图片由多个图片合在一起。本程序实现对该图片进行切分,生成多个图片
压缩包里包含了必要的docx4j.jar、commons-io-1.4.jar、slf4j-api-1.7.17.jar、freemrkker.jar等架包,导入到到项目后重新build path,然后运行InsertPicture.java文件,(ps:文件的参数替换成自己本地的),便可以...
java项目-第90期基于ssm的嘟嘟二手书商城系统 1、项目简述 该项目是二手书城商城系统,包含普通用户和管理员两个角色。普通用户可以购买对应的二手书...在FileServiceImpl配置图片路径,比如我的是D:\\picture\\book。
百度地图开发java源码 picture_dx 欢迎能来到这里(详情见demo,代码可直接拿到,如有用麻烦start一下) 1,主工程:App(包含zxing扫一扫功能,view拖拽,) 2,基础类库:BaseLibrary 3,测试类练市搭建:...
与‘资金管理系统1.0.0.0版本’相比‘资金管理系统1.1.0.1版本’做了...增加了picture文件夹,用于保存附加图片。如果这个目录不存在,程序在需要时 会尝试创建 <br>3.修改了单据查看账户显示不正确的缺陷。
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、...
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、...
免积分下载,详细介绍可以访问http://javaapk.com/android-seventeen-kinds-of-picture-effects.html
1. 激活相册或是文件管理器,来获取相片,代码如下: private static final int TAKE_PICTURE_FROM_ALBUM = 1; private void takePictureFromAlbum() { Intent intent = new Intent(Intent.ACTION_GET_CONTENT);...
主要介绍了Vue+elementUI实现多图片上传与回显功能(含回显后继续上传或删除),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
9.1.1 Java中文处理的理论知识 9.1.2 中文处理的解决方案 9.1.3 中文处理技术程序实例 9.2 数据查询结果的分页显示技术 9.2.1 使用JavaBean和连接池实现数据分页显示 9.2.2 不用连接池不用JavaBean的分页显示 ...
不带裁剪、不带压缩、不带权限管理,没有冗余的第三方库,只为最纯粹的使用,让你更灵活与其他裁剪、压缩库组合使用。 如果你喜欢毛玻璃效果、如果你想拥有最大化的自定义,那么这个库你不容错过。 如果需要图片裁剪...
图片管理员这是一个android应用程序。它将显示手机中的所有图片。 它使用grideview。