com.sun.scenario.effect.impl.prism.PrReflectionPeer Maven / Gradle / Ivy
/*
* Copyright (c) 2011, 2014, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code 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 General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package com.sun.scenario.effect.impl.prism;
import com.sun.javafx.geom.Rectangle;
import com.sun.javafx.geom.transform.BaseTransform;
import com.sun.prism.Graphics;
import com.sun.prism.Texture;
import com.sun.scenario.effect.Effect;
import com.sun.scenario.effect.FilterContext;
import com.sun.scenario.effect.ImageData;
import com.sun.scenario.effect.Reflection;
import com.sun.scenario.effect.impl.EffectPeer;
import com.sun.scenario.effect.impl.Renderer;
import com.sun.scenario.effect.impl.state.RenderState;
public class PrReflectionPeer extends EffectPeer {
public PrReflectionPeer(FilterContext fctx, Renderer r, String uniqueName) {
super(fctx, r, uniqueName);
}
@Override
public ImageData filter(Effect effect,
RenderState rstate,
BaseTransform transform,
Rectangle outputClip,
ImageData... inputs)
{
FilterContext fctx = getFilterContext();
Reflection reflect = (Reflection)effect;
Rectangle inputbounds = inputs[0].getUntransformedBounds();
int srcW = inputbounds.width;
int srcH = inputbounds.height;
float refY = srcH + reflect.getTopOffset();
float refH = reflect.getFraction() * srcH;
int irefY1 = (int) Math.floor(refY);
int irefY2 = (int) Math.ceil(refY + refH);
int irefH = irefY2 - irefY1;
int dstH = (irefY2 > srcH) ? irefY2 : srcH;
// RT-27389: take clipping into account...
PrDrawable dst = (PrDrawable)getRenderer().getCompatibleImage(srcW, dstH);
if (!inputs[0].validate(fctx) || dst == null) {
return new ImageData(fctx, null, inputbounds);
}
PrDrawable src = (PrDrawable)inputs[0].getUntransformedImage();
Texture srctex = src.getTextureObject();
Graphics gdst = dst.createGraphics();
gdst.transform(inputs[0].getTransform());
float sx1 = 0f;
float sy1 = srcH-irefH;
float sx2 = srcW;
float sy2 = srcH;
gdst.drawTextureVO(srctex,
reflect.getBottomOpacity(),
reflect.getTopOpacity(),
0, irefY2, srcW, irefY1,
sx1, sy1, sx2, sy2);
gdst.drawTexture(srctex, 0, 0, srcW, srcH);
Rectangle newbounds =
new Rectangle(inputbounds.x, inputbounds.y, srcW, dstH);
return new ImageData(fctx, dst, newbounds);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy