/*
* HaoRan ImageFilter Classes v0.1
* Copyright (C) 2012 Zhenjun Dai
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by the
* Free Software Foundation; either version 2.1 of the License, or (at your
* option) any later version.
*
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this library; if not, write to the Free Software Foundation.
*/
package com.marshalchen.common.uimodule.ImageFilter;
/**
* ������
* @author daizhj
*
*/
public class LightFilter extends RadialDistortionFilter{
/**
* ��������
*/
public float Light = 150.0f;
//@Override
public Image process(Image imageIn) {
int width = imageIn.getWidth();
int halfw = width / 2;
int height = imageIn.getHeight();
int halfh = height / 2;
int R = Math.min(halfw, halfh);
//���ĵ㣬������ֵ����ǿ�����ķ���ƫ��
Point point = new Point(halfw, halfh);
int r = 0, g = 0, b = 0;
for (int x = 0; x < width; x++) {
for (int y = 0; y < height; y++) {
float length = (float)Math.sqrt(Math.pow((x -point.X), 2) + Math.pow((y -point.Y), 2));
r = imageIn.getRComponent(x, y);
g = imageIn.getGComponent(x, y);
b = imageIn.getBComponent(x, y);
//λ�ڹ�����
if(length < R) {
float pixel = Light * (1.0f - length /R);
r = r + (int)pixel;
r = Math.max(0, Math.min(r, 255));
g = g + (int)pixel;
g = Math.max(0, Math.min(g, 255));
b = b + (int)pixel;
b = Math.max(0, Math.min(b, 255));
}
imageIn.setPixelColor(x, y, r, g, b);
}
}
return imageIn;
}
}