亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? lensflarelayer.java

?? world wind java sdk 源碼
?? JAVA
字號:
package gov.nasa.worldwind.examples.sunlight;

import gov.nasa.worldwind.geom.*;
import gov.nasa.worldwind.layers.RenderableLayer;
import gov.nasa.worldwind.render.*;

import java.awt.*;
import java.awt.geom.*;
import java.awt.image.*;

/**
 * Displays a lens flare effect when the Sun is in view.
 *
 * @author Patrick Murris
 * @version $Id: LensFlareLayer.java 10406 2009-04-22 18:28:45Z patrickmurris $
 */
public class LensFlareLayer extends RenderableLayer
{
    public static class FlareImage extends ScreenAnnotation
    {
        private final BufferedImage image;
        private double scale = 1;
        private double position = 0; // 0=Sun, 1=viewport center, 2=opposite Sun from center...
        private double opacity = .5;

        public FlareImage(BufferedImage image, double scale, double position, double opacity)
        {
            super("", new Point(0, 0));
            this.image = image;
            this.scale = scale;
            this.position = position;
            this.opacity = opacity;
            this.initialize();
        }

        private void initialize()
        {
            AnnotationAttributes aa = this.getAttributes();
            aa.setBorderWidth(0);
            aa.setImageSource(this.image);
            aa.setAdjustWidthToText(Annotation.SIZE_FIXED);
            aa.setSize(new Dimension(this.image.getWidth(), this.image.getHeight()));
            aa.setBackgroundColor(new Color(0, 0, 0, 0));
            aa.setCornerRadius(0);
            aa.setInsets(new Insets(0, 0, 0, 0));
            aa.setDrawOffset(new Point(0, -this.image.getHeight() / 2));
        }

        public void update(Point sun, Point center)
        {
            double x = sun.x - (double)(sun.x - center.x) * position;
            double y = sun.y - (double)(sun.y - center.y) * position;
            this.setScreenPoint(new Point((int)x, (int)y));
            this.getAttributes().setScale(this.scale);
            this.getAttributes().setOpacity(this.opacity);
        }
    }

    //*** LensFlareLayer ***

    private static double SUN_DISTANCE = 149597892e3;

    private Vec4 sunDirection;
    private Vec4 sunPoint;

    public LensFlareLayer()
    {
        this.setName("Lens Flare");
        this.setPickEnabled(false);
    }

    public Vec4 getSunDirection()
    {
        return this.sunDirection;
    }

    public void setSunDirection(Vec4 direction)
    {
        if (direction != null)
        {
            this.sunDirection = direction.normalize3();
            this.sunPoint = this.sunDirection.multiply3(SUN_DISTANCE);
        }
        else
        {
            this.sunDirection = null;
            this.sunPoint = null;
        }
    }

    public void render(DrawContext dc)
    {
        if (sunPoint == null)
            return;

        if (dc.getView().getFrustumInModelCoordinates().getNear().distanceTo(sunPoint) < 0)
            return; // Sun is behind the eye

        Vec4 sunPos = dc.getView().project(this.sunPoint);
        if (sunPos == null)
            return; // Sun does not project at all

        Rectangle viewport = dc.getView().getViewport();
        if (!viewport.contains(sunPos.x, sunPos.y))
            return; // Sun is not in viewport

        // Test for terrain occlusion
        Line ray = new Line(dc.getView().getEyePoint(), this.sunDirection);
        if (dc.getSurfaceGeometry().intersect(ray) != null)
            return; // Some terrain is between the eye and the Sun

        Point center = new Point(viewport.width / 2, viewport.height / 2);
        Point sun = new Point((int)sunPos.x, (int)sunPos.y);

        // Update all flare images
        for (Renderable r : this.getRenderables())
            if (r instanceof FlareImage)
                ((FlareImage)r).update(sun, center);

        // Render
        super.render(dc);
    }

    //*** Presets ***

    public static final String PRESET_BOLD = "LensFlare.PresetBold";

    public static LensFlareLayer getPresetInstance(String preset)
    {
        LensFlareLayer lensFlareLayer = new LensFlareLayer();
        BufferedImage sun = createDiskImage(64, Color.YELLOW);
        BufferedImage sunDisk = createHaloImage(64, new Color(1f, 1f, .8f), 2f);
        BufferedImage disk = createDiskImage(128, Color.WHITE);
        BufferedImage star = createStarImage(128, Color.WHITE);
        BufferedImage halo = createHaloImage(128, Color.WHITE);
        BufferedImage rainbow = createRainbowImage(128);
        BufferedImage rays = createRaysImage(128, 12, Color.WHITE);

        if (PRESET_BOLD.equals(preset))
        {
            // Image, scale, position, opacity
            // Sun dressing - pos = 0
            lensFlareLayer.addRenderable(new FlareImage(rays, 4, 0, .05));
            lensFlareLayer.addRenderable(new FlareImage(star, 1.4, 0, .1));
            lensFlareLayer.addRenderable(new FlareImage(star, 2.5, 0, .04));
            lensFlareLayer.addRenderable(new FlareImage(sunDisk, .6, 0, .9));
            lensFlareLayer.addRenderable(new FlareImage(halo, 1.0, 0, .9));
            lensFlareLayer.addRenderable(new FlareImage(halo, 4, 0, .9));
            lensFlareLayer.addRenderable(new FlareImage(rainbow, 2.2, 0, .03));
            lensFlareLayer.addRenderable(new FlareImage(rainbow, 1.2, 0, .04));
            // Diagonal flares - pos > 0 (center = 1)
            lensFlareLayer.addRenderable(new FlareImage(disk, .1, .4, .1));
            lensFlareLayer.addRenderable(new FlareImage(disk, .15, .6, .1));
            lensFlareLayer.addRenderable(new FlareImage(disk, .2, .7, .1));
            lensFlareLayer.addRenderable(new FlareImage(disk, .5, 1.1, .2));
            lensFlareLayer.addRenderable(new FlareImage(disk, .2, 1.3, .1));
            lensFlareLayer.addRenderable(new FlareImage(disk, .1, 1.4, .05));
            lensFlareLayer.addRenderable(new FlareImage(disk, .1, 1.5, .1));
            lensFlareLayer.addRenderable(new FlareImage(disk, .1, 1.6, .1));
            lensFlareLayer.addRenderable(new FlareImage(disk, .2, 1.65, .1));
            lensFlareLayer.addRenderable(new FlareImage(disk, .12, 1.71, .1));
            lensFlareLayer.addRenderable(new FlareImage(disk, 3, 2.2, .05));
            lensFlareLayer.addRenderable(new FlareImage(disk, .5, 2.4, .2));
            lensFlareLayer.addRenderable(new FlareImage(disk, .7, 2.6, .1));
            lensFlareLayer.addRenderable(new FlareImage(rainbow, 5, 3.0, .03));
            lensFlareLayer.addRenderable(new FlareImage(disk, .2, 3.5, .1));
        }
        
        return lensFlareLayer;
    }

    //*** Static utility methods ***

    public static BufferedImage createDiskImage(int size, Color color)
    {
        return PatternFactory.createPattern(PatternFactory.PATTERN_CIRCLE,
                new Dimension(size, size), .9f, color);
    }

    public static BufferedImage createBluredDiskImage(int size, Color color)
    {
        BufferedImage image = PatternFactory.createPattern(PatternFactory.PATTERN_CIRCLE,
                new Dimension(size, size), .6f, color);
        image = PatternFactory.blur(image, size / 5);
        image = PatternFactory.blur(image, 10);
        return image;
    }

    public static BufferedImage createStarImage(int size, Color color)
    {
        BufferedImage image = new BufferedImage(size, size, BufferedImage.TYPE_INT_ARGB);
        Graphics2D g2 = (Graphics2D)image.getGraphics();
        g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
        g2.setColor(color);
        float half = size / 2f;
        float r1 = half * .9f;
        float r2 = half * .1f;
        float r3 = half * .05f;

        // Four branch star
        GeneralPath path = new GeneralPath();
        path.moveTo(half - r1, half); // left
        path.lineTo(half - r2, half - r3);
        path.lineTo(half - r3, half - r2);
        path.lineTo(half, half - r1); // top
        path.lineTo(half + r3, half - r2);
        path.lineTo(half + r2, half - r3);
        path.lineTo(half + r1, half); // right
        path.lineTo(half + r2, half + r3);
        path.lineTo(half + r3, half + r2);
        path.lineTo(half, half + r1); // bottom
        path.lineTo(half - r3, half + r2);
        path.lineTo(half - r2, half + r3);
        path.lineTo(half - r1, half); // left
        g2.fill(path);

        // Second copy - smaller and rotated 45 deg.
        g2.translate(half, half);
        g2.rotate(Math.PI / 4);
        g2.scale(.7, .7);
        g2.translate(-half, -half);
        g2.fill(path);

        return image;
    }

    public static BufferedImage createRaysImage(int size, int rays, Color color)
    {
        BufferedImage image = new BufferedImage(size, size, BufferedImage.TYPE_INT_ARGB);
        Graphics2D g2 = (Graphics2D)image.getGraphics();
        g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
        g2.setColor(color);
        float half = size / 2f;
        float r1 = half * .9f;
        float r2 = half * .1f;

        GeneralPath path = new GeneralPath();
        path.moveTo(half, half); // center
        path.lineTo(half - r2, half - r1);
        path.lineTo(half + r2, half - r1);
        path.lineTo(half, half); // center

        Color c2 = new Color(color.getRed(), color.getGreen(), color.getBlue(), 0);
        GradientPaint gradient = new GradientPaint(half, half, color, half, half - r1, c2);
        g2.setPaint(gradient);

        for (int i = 0; i < rays; i++)
        {
            g2.translate(half, half);
            g2.rotate(Math.PI * 2 / rays);
            g2.translate(-half, -half);
            g2.fill(path);
        }

        return image;
    }

    public static BufferedImage createHaloImage(int size, Color color)
    {
        return createHaloImage(size, color, .2f);
    }

    public static BufferedImage createHaloImage(int size, Color color, float alphaExp)
    {
        BufferedImage image = new BufferedImage(size, size, BufferedImage.TYPE_INT_ARGB);
        Graphics2D g2 = (Graphics2D)image.getGraphics();
        g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
        g2.setStroke(new BasicStroke(1.5f));
        float[] colorComp = new float[4];
        color.getRGBComponents(colorComp);
        float half = size / 2f;
        float r1 = 0f;
        float r2 = half * .9f;
        for (float r = r1; r <= r2; r++)
        {
            float alpha = 1f - (float)Math.pow(r / r2, alphaExp);
            g2.setColor(new Color(colorComp[0], colorComp[1], colorComp[2], alpha));
            g2.drawOval((int)(half - r), (int)(half - r), (int)(r * 2), (int)(r * 2));
        }
        return image;
    }

    public static BufferedImage createRainbowImage(int size)
    {
        BufferedImage image = new BufferedImage(size, size, BufferedImage.TYPE_INT_ARGB);
        Graphics2D g2 = (Graphics2D)image.getGraphics();
        g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
        float half = size / 2f;
        float r1 = half * .7f;
        float r2 = half * .9f;
        for (float r = r1; r <= r2; r++)
        {
            float hue = (r - r1) / (r2 - r1);
            g2.setColor(new Color(Color.HSBtoRGB(hue, 1, 1)));
            g2.drawOval((int)(half - r), (int)(half - r), (int)(r * 2), (int)(r * 2));
        }
        return image;
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产a区久久久| 97精品国产露脸对白| 亚洲六月丁香色婷婷综合久久 | 欧美在线不卡视频| 国产精品亚洲一区二区三区在线| 亚洲天堂免费看| 精品第一国产综合精品aⅴ| 欧美性猛交xxxx黑人交| 成人av免费在线观看| 狠狠色狠狠色合久久伊人| 婷婷综合在线观看| 亚洲乱码国产乱码精品精的特点 | 91在线观看下载| 老司机午夜精品99久久| 亚洲成人免费av| 亚洲猫色日本管| 国产精品人妖ts系列视频| 日韩精品专区在线影院重磅| 精品视频全国免费看| 色一情一乱一乱一91av| 成人免费看的视频| 国产精品123| 国产在线国偷精品产拍免费yy| 日本强好片久久久久久aaa| 亚洲国产成人va在线观看天堂| 国产精品久久久久影院亚瑟| 久久久99精品免费观看不卡| 精品久久久网站| 亚洲精品一区二区三区蜜桃下载| 欧美一区在线视频| 91精品国产91综合久久蜜臀| 欧美日韩一二区| 欧美日韩中文字幕一区| 欧美唯美清纯偷拍| 欧美日韩国产a| 欧美群妇大交群中文字幕| 在线观看一区不卡| 欧美吞精做爰啪啪高潮| 精品视频在线免费观看| 欧美猛男gaygay网站| 欧美日韩日日骚| 欧美日韩久久一区| 56国语精品自产拍在线观看| 欧美精品乱码久久久久久按摩| 欧美日韩三级一区| 日韩一级欧美一级| 精品国产凹凸成av人网站| 久久久99精品免费观看不卡| 日本一区二区久久| 亚洲欧美国产毛片在线| 亚洲综合在线免费观看| 日韩中文字幕1| 久久se精品一区二区| 国产 欧美在线| 97久久精品人人做人人爽| 色哟哟国产精品免费观看| 欧美日韩一区二区三区四区五区| 制服视频三区第一页精品| 精品国产乱码久久久久久老虎 | 色狠狠一区二区| 欧美亚洲综合一区| 欧美成人一区二区三区在线观看| 久久久精品国产99久久精品芒果| 一区在线播放视频| 视频在线观看一区| 国产精品77777| 色久优优欧美色久优优| 日韩午夜精品电影| 国产日本欧美一区二区| 亚洲黄色小视频| 蜜桃av一区二区三区电影| 国产精品2024| 在线观看成人小视频| 2023国产一二三区日本精品2022| 亚洲视频在线一区观看| 亚洲国产精品欧美一二99| 六月丁香婷婷色狠狠久久| 成人免费av在线| 正在播放亚洲一区| 国产精品久久久久久久久久免费看 | 午夜欧美视频在线观看| 国产精品综合一区二区三区| 在线欧美一区二区| 久久久精品中文字幕麻豆发布| 亚洲乱码中文字幕综合| 精品在线观看免费| 一本色道综合亚洲| 精品福利在线导航| 亚洲午夜视频在线| 国产69精品久久久久777| 欧美丰满少妇xxxbbb| 成人欧美一区二区三区小说| 蜜臀av性久久久久蜜臀av麻豆| 懂色av一区二区三区免费观看| 欧美精品日韩一区| 亚洲欧洲精品天堂一级| 国产在线精品一区二区夜色| 欧美区一区二区三区| 亚洲欧洲www| 国产精品亚洲综合一区在线观看| 91精品国产综合久久国产大片| 国产精品夫妻自拍| 九色综合狠狠综合久久| 欧美日韩大陆一区二区| 亚洲欧美日韩在线| 国产精品77777竹菊影视小说| 91精品国产乱| 亚洲成人av福利| 色婷婷综合久久久久中文| 久久女同互慰一区二区三区| 日本欧美一区二区| 欧美三级韩国三级日本一级| 亚洲欧美视频在线观看视频| 国产成人在线视频网址| 精品久久久久香蕉网| 日本aⅴ亚洲精品中文乱码| 欧美特级限制片免费在线观看| 亚洲日本欧美天堂| kk眼镜猥琐国模调教系列一区二区| 久久嫩草精品久久久精品一| 老司机精品视频在线| 91精品国产综合久久久久久久| 亚洲最色的网站| 色狠狠色狠狠综合| 亚洲人成网站色在线观看| 不卡一区中文字幕| 国产精品护士白丝一区av| 成人精品视频一区二区三区尤物| 久久久www免费人成精品| 国产揄拍国内精品对白| 欧美精品一区二区高清在线观看| 秋霞午夜鲁丝一区二区老狼| 在线播放视频一区| 日本vs亚洲vs韩国一区三区 | 亚洲v中文字幕| 欧美中文一区二区三区| 亚洲国产日韩一区二区| 欧美三级资源在线| 婷婷久久综合九色综合伊人色| 欧美视频一区二区三区在线观看 | 亚洲婷婷综合色高清在线| 99国产精品99久久久久久| 亚洲精品国产无天堂网2021| 欧美主播一区二区三区| 丝袜美腿亚洲色图| 欧美tk丨vk视频| 风流少妇一区二区| 欧美韩日一区二区三区四区| 99精品热视频| 亚洲一区视频在线观看视频| 欧美日韩国产色站一区二区三区| 午夜亚洲国产au精品一区二区| 日韩一区二区三区在线视频| 极品少妇xxxx精品少妇偷拍| 欧美极品xxx| 日本乱码高清不卡字幕| 亚洲成人av电影在线| 日韩欧美你懂的| 国产成人综合自拍| 一区二区三区在线播放| 欧美精品第1页| 国产麻豆精品视频| 最新国产精品久久精品| 精品视频一区二区不卡| 精品制服美女丁香| 综合欧美亚洲日本| 在线成人小视频| 国产91在线观看丝袜| 一区二区三区蜜桃| 精品国产乱码久久久久久蜜臀| 99久久综合精品| 日韩一区欧美二区| 国产精品入口麻豆原神| 欧美精三区欧美精三区| 高清av一区二区| 日韩精品午夜视频| 国产欧美一区二区精品性色| 欧美日韩综合在线免费观看| 国产麻豆视频精品| 亚洲午夜在线视频| 国产午夜精品美女毛片视频| 欧美性淫爽ww久久久久无| 国模无码大尺度一区二区三区| 亚洲毛片av在线| 久久精品亚洲一区二区三区浴池| 91国偷自产一区二区三区观看 | 极品瑜伽女神91| 一区二区三区四区在线播放| 精品国产凹凸成av人网站| 欧美自拍丝袜亚洲| 成人久久视频在线观看| 久久99精品一区二区三区 | 国产在线麻豆精品观看| 亚洲成人tv网| 亚洲日本va午夜在线电影| 精品国产三级a在线观看| 欧美在线观看一区| 成年人国产精品| 国产精品亚洲人在线观看| 奇米888四色在线精品|