當前位置: 首頁>>代碼示例>>Java>>正文


Java ImageMath類代碼示例

本文整理匯總了Java中com.jhlabs.image.ImageMath的典型用法代碼示例。如果您正苦於以下問題:Java ImageMath類的具體用法?Java ImageMath怎麽用?Java ImageMath使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ImageMath類屬於com.jhlabs.image包,在下文中一共展示了ImageMath類的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: evaluate

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
public float evaluate(float x, float y) {
	int ix = (int)x;
	int iy = (int)y;
	if (edgeAction == WRAP) {
		ix = ImageMath.mod(ix, width);
		iy = ImageMath.mod(iy, height);
	} else if (ix < 0 || iy < 0 || ix >= width || iy >= height) {
		if (edgeAction == ZERO)
			return 0;
		if (ix < 0)
			ix = 0;
		else if (ix >= width)
			ix = width-1;
		if (iy < 0)
			iy = 0;
		else if (iy >= height)
			iy = height-1;
	}
	return alpha ? ((pixels[iy*width+ix] >> 24) & 0xff) / 255.0f : PixelUtils.brightness(pixels[iy*width+ix]) / 255.0f;
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:21,代碼來源:ImageFunction2D.java

示例2: transformInverse

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
@Override
protected void transformInverse(int x, int y, float[] out) {
    float dx = x - cx;
    float dy = cy - y;
    double r = Math.sqrt(dx * dx + dy * dy);

    double radius = srcHeight * zoom / 2;
    double angle = Utils.transformAtan2AngleToIntuitive(FastMath.atan2(dy, dx)) + rotateResult;

    if (angle > (2 * Math.PI)) {
        angle -= 2 * Math.PI;
    }
    float nx = (float) ((angle * srcWidth) / (2 * Math.PI));
    float ratio = (float) (r / radius);
    float correctedRatio = ImageMath.bias(ratio, innerZoom);
    float ny = correctedRatio * srcHeight;
    if(!inverted) {
        ny = srcHeight - ny;
    }

    out[0] = nx;
    out[1] = ny;
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:24,代碼來源:LittlePlanetFilter.java

示例3: evaluate

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
@Override
public float evaluate(float x, float y) {
	int ix = (int)x;
	int iy = (int)y;
	if (edgeAction == WRAP) {
		ix = ImageMath.mod(ix, width);
		iy = ImageMath.mod(iy, height);
	} else if (ix < 0 || iy < 0 || ix >= width || iy >= height) {
		if (edgeAction == ZERO) {
                           return 0;
                       }
		if (ix < 0) {
                           ix = 0;
                       } else if (ix >= width) {
                           ix = width-1;
                       }
		if (iy < 0) {
                           iy = 0;
                       } else if (iy >= height) {
                           iy = height-1;
                       }
	}
	return alpha ? ((pixels[iy*width+ix] >> 24) & 0xff) / 255.0f : PixelUtils.brightness(pixels[iy*width+ix]) / 255.0f;
}
 
開發者ID:WebcamStudio,項目名稱:webcamstudio,代碼行數:25,代碼來源:ImageFunction2D.java

示例4: interpolateColor

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
public static Color interpolateColor(Color startColor, Color endColor, float progress) {
    int initialRGB = startColor.getRGB();
    int finalRGB = endColor.getRGB();

    // linear interpolation in the RGB space
    // possibly interpolating in HSB space would be better
    int interpolatedRGB = ImageMath.mixColors(progress, initialRGB, finalRGB);
    return new Color(interpolatedRGB);
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:10,代碼來源:ColorUtils.java

示例5: perlinNoise2D

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
/**
 * A 2D version of the algorithm from http://mrl.nyu.edu/~perlin/noise/
 */
private static float perlinNoise2D(float x, float y) {
    // find unit grid cell containing point + wrap the integer cells at 255
    int gridX = ((int) x) & 255;
    int gridY = ((int) y) & 255;

    // get relative coordinates of point within cell
    x -= ((int) x);
    y -= ((int) y);

    // compute the fade curves for x and y
    float u = fade(x);
    float v = fade(y);

    // calculate hashed gradient indices
    int a = p[gridX] + gridY;
    int aa = p[a];
    int ab = p[a + 1];
    int b = p[gridX + 1] + gridY;
    int ba = p[b];
    int bb = p[b + 1];

    float noiseSE = grad2D(p[aa], x, y);
    float noiseSW = grad2D(p[ba], x - 1, y);
    float noiseNE = grad2D(p[ab], x, y - 1);
    float noiseNW = grad2D(p[bb], x - 1, y - 1);

    float noiseS = ImageMath.lerp(u, noiseSE, noiseSW);
    float noiseN = ImageMath.lerp(u, noiseNE, noiseNW);

    float noise = ImageMath.lerp(v, noiseS, noiseN);

    // noise is in the range [-1..1]
    return noise;
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:38,代碼來源:Clouds.java

示例6: transformInverse

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
@Override
protected void transformInverse(int x, int y, float[] out) {
    float dx = x - cx;
    float dy = y - cy;
    double r = Math.sqrt(dx * dx + dy * dy);
    double angle = FastMath.atan2(dy, dx);

    double na = r / radialWL - phase;
    double fa;

    switch (waveType) {
        case WaveType.SINE:
            fa = FastMath.sin(na);
            break;
        case WaveType.SAWTOOTH:
            fa = ImageMath.sinLikeSawtooth(na);
            break;
        case WaveType.TRIANGLE:
            fa = ImageMath.sinLikeTriangle(na);
            break;
        case WaveType.NOISE:
            fa = Noise.sinLikeNoise1((float)na);
            break;
        default:
            throw new IllegalStateException("waveType = " + waveType);
    }

    angle += fa * amount;

    double zoomedR = r / zoom;
    float u = (float) (zoomedR * FastMath.cos(angle));
    float v = (float) (zoomedR * FastMath.sin(angle));

    out[0] = (u + cx);
    out[1] = (v + cy);
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:37,代碼來源:AngularWavesFilter.java

示例7: transformInverse

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
@Override
    protected void transformInverse(int x, int y, float[] out) {
        float dx = x - cx;
        float dy = y - cy;
        double r = Math.sqrt(dx * dx + dy * dy);
        double angle = FastMath.atan2(dy, dx);

//        double angularWL = 1.0 / angularDivision;
        double nr = angle * angularDivision - phase;
        double fr;

        switch (waveType) {
            case WaveType.SINE:
                fr = FastMath.sin(nr);
                break;
            case WaveType.SAWTOOTH:
                fr = ImageMath.sinLikeSawtooth(nr);
                break;
            case WaveType.TRIANGLE:
                fr = ImageMath.sinLikeTriangle(nr);
                break;
            case WaveType.NOISE:
                fr = Noise.sinLikeNoise1((float)nr);
                break;
            default:
                throw new IllegalStateException("waveType = " + waveType);
        }

        r += fr * radialAmplitude * r / maxSize;

        double zoomedR = r / zoom;
        float u = (float) (zoomedR * FastMath.cos(angle));
        float v = (float) (zoomedR * FastMath.sin(angle));

        out[0] = (u + cx);
        out[1] = (v + cy);
    }
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:38,代碼來源:RadialWavesFilter.java

示例8: getInterpolatedPositions

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
private float[] getInterpolatedPositions(float progress, GState grEndState) {
    float[] interpolatedPositions = new float[thumbPositions.length];
    for (int i = 0; i < thumbPositions.length; i++) {
        float initial = thumbPositions[i];
        float end = grEndState.thumbPositions[i];
        float interpolated = ImageMath.lerp(progress, initial, end);
        interpolatedPositions[i] = interpolated;
    }
    return interpolatedPositions;
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:11,代碼來源:GradientParam.java

示例9: interpolate

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
@Override
public ParamState interpolate(ParamState endState, double progress) {
    IPPState ippEndState = (IPPState) endState;
    double interpolatedX = ImageMath.lerp(progress, relativeX, ippEndState.relativeX);
    double interpolatedY = ImageMath.lerp(progress, relativeY, ippEndState.relativeY);
    return new IPPState(interpolatedX, interpolatedY);
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:8,代碼來源:ImagePositionParam.java

示例10: interpolate

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
@Override
public ParamState interpolate(ParamState endState, double progress) {
    GRState apEndState = (GRState) endState;

    double[] interpolatedValues = new double[values.length];
    for (int i = 0; i < values.length; i++) {
        interpolatedValues[i] = ImageMath.lerp(progress, values[i], apEndState.values[i]);
    }

    return new GRState(interpolatedValues);
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:12,代碼來源:GroupedRangeParam.java

示例11: sinLikeNoise1

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
/**
 * A noise function with a "period" of 2 PI and values between -1 and 1
 */
public static float sinLikeNoise1(float x) {
    return 2 * Noise.noise1(x / ImageMath.PI);
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:7,代碼來源:Noise.java

示例12: doTransform

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
@Override
public BufferedImage doTransform(BufferedImage src, BufferedImage dest) {
    ReseedSupport.reInitialize();
    Random rand = ReseedSupport.getRand();

    int[] srcData = ImageUtils.getPixelsAsArray(src);
    int[] destData = ImageUtils.getPixelsAsArray(dest);

    float opacityValueAsPercentage = opacity.getValueAsPercentage();
    int opacityValue = opacity.getValue();

    float saturationValueAsPercentage = saturation.getValueAsPercentage();
    int saturationValue = saturation.getValue();

    float coverageValue = coverage.getValueAsPercentage();

    boolean coverageAnim = method.getValue() == METHOD_COVERAGE_ANIM;

    for (int i = 0; i < destData.length; i++) {
        int srcRGB = srcData[i];

        int randomInt = 0;
        if (coverageAnim) {
            // generate random numbers for the discarded pixels as well
            randomInt = rand.nextInt();
        }

        float rn = rand.nextFloat();
        if (rn > coverageValue) {
            destData[i] = srcRGB;
            continue;
        }

        int sourceAlpha = 0xFF000000 & srcRGB;
        if (sourceAlpha == 0) { // for premultiplied
            destData[i] = 0;
            continue;
        }

        if (!coverageAnim) {
            // if coverage animation is not a requirement, then it is faster
            // to generate the random values only here, for the covered pixels
            randomInt = rand.nextInt();
        }

        if(saturationValue == 100) {
            // make the alpha channel the same as for the source
            randomInt |= sourceAlpha;
            if (opacityValue == 100) {
                destData[i] = randomInt;
            } else {
                destData[i] = ImageMath.mixColors(opacityValueAsPercentage, srcRGB, randomInt);
            }
        } else {
            int r = (randomInt >>> 16) & 0xFF;
            int g = (randomInt >>> 8) & 0xFF;
            int b = (randomInt) & 0xFF;

            Color.RGBtoHSB(r, g, b, tmpHSV);
            float newSaturation = ImageMath.lerp(saturationValueAsPercentage, 0.0f, tmpHSV[1]);
            randomInt = Color.HSBtoRGB(tmpHSV[0], newSaturation, tmpHSV[2]);

            // make the alpha channel the same as for the source
            randomInt |= sourceAlpha;

            if (opacityValue == 100) {
                destData[i] = randomInt;
            } else {
                destData[i] = ImageMath.mixColors(opacityValueAsPercentage, srcRGB, randomInt);
            }
        }
    }

    return dest;
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:76,代碼來源:AddNoise.java

示例13: interpolate

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
@Override
public ParamState interpolate(ParamState endState, double progress) {
    APState apEndState = (APState) endState;
    double interpolatedAngle = ImageMath.lerp(progress, angle, apEndState.angle);
    return new APState(interpolatedAngle);
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:7,代碼來源:AngleParam.java

示例14: interpolate

import com.jhlabs.image.ImageMath; //導入依賴的package包/類
@Override
public RPState interpolate(ParamState endState, double progress) {
    RPState rpEndState = (RPState) endState;
    double interpolated = ImageMath.lerp(progress, value, rpEndState.value);
    return new RPState(interpolated);
}
 
開發者ID:teddyted,項目名稱:iSeleda,代碼行數:7,代碼來源:RangeParam.java


注:本文中的com.jhlabs.image.ImageMath類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。