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

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

?? shinydiffuseshader.java

?? Sunflow是一個照片級的渲染系統(tǒng)
?? JAVA
字號:
package org.sunflow.core.shader;

import org.sunflow.SunflowAPI;
import org.sunflow.core.ParameterList;
import org.sunflow.core.Ray;
import org.sunflow.core.Shader;
import org.sunflow.core.ShadingState;
import org.sunflow.image.Color;
import org.sunflow.math.OrthoNormalBasis;
import org.sunflow.math.Vector3;

public class ShinyDiffuseShader implements Shader {
    private Color diff;
    private float refl;

    public ShinyDiffuseShader() {
        diff = Color.GRAY;
        refl = 0.5f;
    }

    public boolean update(ParameterList pl, SunflowAPI api) {
        diff = pl.getColor("diffuse", diff);
        refl = pl.getFloat("shiny", refl);
        return true;
    }

    public Color getDiffuse(ShadingState state) {
        return diff;
    }

    public Color getRadiance(ShadingState state) {
        // make sure we are on the right side of the material
        state.faceforward();
        // direct lighting
        state.initLightSamples();
        state.initCausticSamples();
        Color d = getDiffuse(state);
        Color lr = state.diffuse(d);
        if (!state.includeSpecular())
            return lr;
        float cos = state.getCosND();
        float dn = 2 * cos;
        Vector3 refDir = new Vector3();
        refDir.x = (dn * state.getNormal().x) + state.getRay().getDirection().x;
        refDir.y = (dn * state.getNormal().y) + state.getRay().getDirection().y;
        refDir.z = (dn * state.getNormal().z) + state.getRay().getDirection().z;
        Ray refRay = new Ray(state.getPoint(), refDir);
        // compute Fresnel term
        cos = 1 - cos;
        float cos2 = cos * cos;
        float cos5 = cos2 * cos2 * cos;

        Color ret = Color.white();
        Color r = d.copy().mul(refl);
        ret.sub(r);
        ret.mul(cos5);
        ret.add(r);
        return lr.add(ret.mul(state.traceReflection(refRay, 0)));
    }

    public void scatterPhoton(ShadingState state, Color power) {
        Color diffuse;
        // make sure we are on the right side of the material
        state.faceforward();
        diffuse = getDiffuse(state);
        state.storePhoton(state.getRay().getDirection(), power, diffuse);
        float d = diffuse.getAverage();
        float r = d * refl;
        double rnd = state.getRandom(0, 0, 1);
        if (rnd < d) {
            // photon is scattered
            power.mul(diffuse).mul(1.0f / d);
            OrthoNormalBasis onb = state.getBasis();
            double u = 2 * Math.PI * rnd / d;
            double v = state.getRandom(0, 1, 1);
            float s = (float) Math.sqrt(v);
            float s1 = (float) Math.sqrt(1.0 - v);
            Vector3 w = new Vector3((float) Math.cos(u) * s, (float) Math.sin(u) * s, s1);
            w = onb.transform(w, new Vector3());
            state.traceDiffusePhoton(new Ray(state.getPoint(), w), power);
        } else if (rnd < d + r) {
            float cos = -Vector3.dot(state.getNormal(), state.getRay().getDirection());
            power.mul(diffuse).mul(1.0f / d);
            // photon is reflected
            float dn = 2 * cos;
            Vector3 dir = new Vector3();
            dir.x = (dn * state.getNormal().x) + state.getRay().getDirection().x;
            dir.y = (dn * state.getNormal().y) + state.getRay().getDirection().y;
            dir.z = (dn * state.getNormal().z) + state.getRay().getDirection().z;
            state.traceReflectionPhoton(new Ray(state.getPoint(), dir), power);
        }
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品在线免费视频| 不卡在线视频中文字幕| 国产精品天美传媒| 欧美卡1卡2卡| 色老汉一区二区三区| 国产一区二区三区高清播放| 亚洲国产一区视频| 中文字幕色av一区二区三区| www日韩大片| 欧美福利视频导航| 色哟哟在线观看一区二区三区| 久草精品在线观看| 日本伊人色综合网| 亚洲一区视频在线| 亚洲欧美一区二区在线观看| 精品动漫一区二区三区在线观看| 欧美日韩一区在线| 欧美性受xxxx黑人xyx| 91麻豆国产福利在线观看| 国产精品影视网| 美腿丝袜亚洲综合| 日韩在线a电影| 亚洲va欧美va国产va天堂影院| 国产精品免费视频网站| 久久这里只有精品6| 日韩欧美在线一区二区三区| 欧美日韩精品一区二区| 在线中文字幕一区二区| 91在线porny国产在线看| 成人免费高清视频| 国产精品亚洲一区二区三区妖精| 欧美一区二区三区视频免费播放| 91色在线porny| 成人看片黄a免费看在线| 国产美女精品一区二区三区| 韩国欧美一区二区| 亚洲天堂网中文字| 99久久精品费精品国产一区二区| 国产精品电影院| 93久久精品日日躁夜夜躁欧美| 国产精品网曝门| 成人av网址在线| 亚洲男人的天堂av| 欧美亚日韩国产aⅴ精品中极品| 亚洲国产精品久久人人爱蜜臀| 欧美日韩三级视频| 日韩黄色免费网站| 久久午夜电影网| 成人av影院在线| 亚洲一区二区中文在线| 日韩写真欧美这视频| 另类调教123区 | 99免费精品在线| 一区二区在线免费观看| 欧美日韩国产色站一区二区三区| 麻豆国产欧美日韩综合精品二区 | 欧美片在线播放| 激情综合色综合久久综合| 国产欧美日韩综合| 欧美系列亚洲系列| 国产美女在线精品| 亚洲狼人国产精品| 精品国产三级电影在线观看| www.激情成人| 日本色综合中文字幕| 亚洲国产精品成人综合| 精品视频在线视频| 福利一区福利二区| 视频一区在线播放| 国产精品你懂的| 日韩精品一区二区在线| 91蝌蚪porny九色| 另类欧美日韩国产在线| 一区二区三区精品视频在线| 精品蜜桃在线看| 在线精品视频一区二区| 东方aⅴ免费观看久久av| 日精品一区二区| 日韩理论电影院| 久久影院电视剧免费观看| 欧美日韩三级在线| 99久久精品情趣| 韩日欧美一区二区三区| 亚洲aⅴ怡春院| 中文字幕中文字幕在线一区| 日韩美女视频在线| 欧美日本免费一区二区三区| 99精品国产视频| 国产精品一二三四五| 婷婷丁香激情综合| 一区二区三区精品久久久| 国产精品无圣光一区二区| 欧美成人vps| 欧美一区二区三区系列电影| 一本到高清视频免费精品| 成人性生交大片免费看中文| 免费看精品久久片| 奇米影视一区二区三区小说| 亚洲一区二区免费视频| 亚洲丝袜美腿综合| 国产精品二区一区二区aⅴ污介绍| 精品国产伦一区二区三区观看体验 | 国产精品欧美一区喷水| 精品国产在天天线2019| 日韩一区二区三区观看| 91精品国产aⅴ一区二区| 欧美色倩网站大全免费| 欧美色图片你懂的| 欧美怡红院视频| 在线视频国产一区| 欧美日韩一区中文字幕| 欧美性猛交一区二区三区精品| 99精品欧美一区二区蜜桃免费 | 久久草av在线| 久久99国产精品成人| 精品在线一区二区| 国产麻豆成人精品| 成人免费av资源| 91浏览器入口在线观看| 91黄色激情网站| 欧美日韩一区三区| 91精品一区二区三区久久久久久| 91精品国产综合久久久久久久 | 狠狠久久亚洲欧美| 懂色av一区二区在线播放| 高清在线成人网| 色综合久久88色综合天天6| 欧美中文字幕一区二区三区| 欧美肥妇毛茸茸| 欧美videos中文字幕| 欧美国产丝袜视频| 亚洲精品ww久久久久久p站| 亚洲成人7777| 国产在线观看一区二区 | 国产在线视视频有精品| 国产精品亚洲第一区在线暖暖韩国| 福利一区二区在线| 欧美三级韩国三级日本一级| 欧美一区二区人人喊爽| 欧美国产一区在线| 亚洲一二三四在线| 久久国产精品一区二区| 成人av网址在线| 7777精品伊人久久久大香线蕉 | 精品久久国产97色综合| 国产精品久久久久天堂| 亚洲成a人片在线观看中文| 国产在线视频一区二区三区| 91美女片黄在线| 欧美va日韩va| 亚洲精品国产第一综合99久久| 久久精品国产成人一区二区三区| 国产传媒一区在线| 欧美浪妇xxxx高跟鞋交| 国产精品污网站| 日本欧美一区二区在线观看| 成人av在线一区二区| 日韩一区二区三区精品视频 | 欧美在线视频全部完| 精品国产一区二区亚洲人成毛片| 亚洲人成亚洲人成在线观看图片| 蜜臀av一级做a爰片久久| 一本大道av一区二区在线播放| 精品久久久久一区二区国产| 亚洲少妇屁股交4| 韩国视频一区二区| 欧美精品成人一区二区三区四区| 国产精品卡一卡二卡三| 日本不卡一二三| 欧美亚洲国产一区在线观看网站| 国产亚洲精品资源在线26u| 亚洲成人免费电影| 色综合天天综合网天天狠天天 | 欧美大度的电影原声| 亚洲精品高清视频在线观看| 国产成人综合精品三级| 日韩一区二区三区免费看| 亚洲国产裸拍裸体视频在线观看乱了| 大胆亚洲人体视频| 久久在线免费观看| 蜜臀av一区二区在线观看 | 一本色道久久综合狠狠躁的推荐| 久久久久97国产精华液好用吗| 蜜桃精品在线观看| 在线电影欧美成精品| 亚洲午夜精品17c| 一本久道久久综合中文字幕| 中文字幕一区日韩精品欧美| 国产成人亚洲精品青草天美| 欧美成人a视频| 精品一区二区在线免费观看| 91.com在线观看| 日本不卡123| 日韩午夜三级在线| 蜜乳av一区二区| 日韩欧美aaaaaa| 韩国成人在线视频| 久久久久高清精品| 不卡电影免费在线播放一区| 亚洲欧洲av色图|