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


Java Vector3.normalize方法代碼示例

本文整理匯總了Java中org.sunflow.math.Vector3.normalize方法的典型用法代碼示例。如果您正苦於以下問題:Java Vector3.normalize方法的具體用法?Java Vector3.normalize怎麽用?Java Vector3.normalize使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.sunflow.math.Vector3的用法示例。


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

示例1: getSkyRGB

import org.sunflow.math.Vector3; //導入方法依賴的package包/類
private Color getSkyRGB(Vector3 dir) {
    if (dir.z < 0 && !groundExtendSky)
        return groundColor;
    if (dir.z < 0.001f)
        dir.z = 0.001f;
    dir.normalize();
    double theta = Math.acos(MathUtils.clamp(dir.z, -1, 1));
    double gamma = Math.acos(MathUtils.clamp(Vector3.dot(dir, sunDir), -1, 1));
    double x = perezFunction(perezx, theta, gamma, zenithx);
    double y = perezFunction(perezy, theta, gamma, zenithy);
    double Y = perezFunction(perezY, theta, gamma, zenithY) * 1e-4;
    XYZColor c = ChromaticitySpectrum.get((float) x, (float) y);
    // XYZColor c = new ChromaticitySpectrum((float) x, (float) y).toXYZ();
    float X = (float) (c.getX() * Y / c.getY());
    float Z = (float) (c.getZ() * Y / c.getY());
    return RGBSpace.SRGB.convertXYZtoRGB(X, (float) Y, Z);
}
 
開發者ID:d2fn,項目名稱:passage,代碼行數:18,代碼來源:SunSkyLight.java

示例2: modify

import org.sunflow.math.Vector3; //導入方法依賴的package包/類
public void modify(ShadingState state) {
    Point3 p = state.transformWorldToObject(state.getPoint());
    p.x *= size;
    p.y *= size;
    p.z *= size;
    Vector3 normal = state.transformNormalWorldToObject(state.getNormal());
    double f0 = f(p.x, p.y, p.z);
    double fx = f(p.x + .0001, p.y, p.z);
    double fy = f(p.x, p.y + .0001, p.z);
    double fz = f(p.x, p.y, p.z + .0001);

    normal.x -= scale * (fx - f0) / .0001;
    normal.y -= scale * (fy - f0) / .0001;
    normal.z -= scale * (fz - f0) / .0001;
    normal.normalize();

    state.getNormal().set(state.transformNormalObjectToWorld(normal));
    state.getNormal().normalize();
    state.setBasis(OrthoNormalBasis.makeFromW(state.getNormal()));
}
 
開發者ID:d2fn,項目名稱:passage,代碼行數:21,代碼來源:PerlinModifier.java

示例3: getRadiance

import org.sunflow.math.Vector3; //導入方法依賴的package包/類
public Color getRadiance(ShadingState state) {
    // don't use these - gather lights for sphere of directions
    // gather lights
    state.initLightSamples();
    state.initCausticSamples();
    Vector3 v = state.getRay().getDirection();
    v.negate();
    Vector3 h = new Vector3();
    Vector3 t = state.getBasis().transform(new Vector3(0, 1, 0));
    Color diff = Color.black();
    Color spec = Color.black();
    for (LightSample ls : state) {
        Vector3 l = ls.getShadowRay().getDirection();
        float dotTL = Vector3.dot(t, l);
        float sinTL = (float) Math.sqrt(1 - dotTL * dotTL);
        // float dotVL = Vector3.dot(v, l);
        diff.madd(sinTL, ls.getDiffuseRadiance());
        Vector3.add(v, l, h);
        h.normalize();
        float dotTH = Vector3.dot(t, h);
        float sinTH = (float) Math.sqrt(1 - dotTH * dotTH);
        float s = (float) Math.pow(sinTH, 10.0f);
        spec.madd(s, ls.getSpecularRadiance());
    }
    Color c = Color.add(diff, spec, new Color());
    // transparency
    return Color.blend(c, state.traceTransparency(), state.getV(), new Color());
}
 
開發者ID:d2fn,項目名稱:passage,代碼行數:29,代碼來源:Hair.java

示例4: DirectionalSpotlight

import org.sunflow.math.Vector3; //導入方法依賴的package包/類
public DirectionalSpotlight() {
    src = new Point3(0, 0, 0);
    dir = new Vector3(0, 0, -1);
    dir.normalize();
    basis = OrthoNormalBasis.makeFromW(dir);
    r = 1;
    r2 = r * r;
    radiance = Color.WHITE;
}
 
開發者ID:d2fn,項目名稱:passage,代碼行數:10,代碼來源:DirectionalSpotlight.java

示例5: generate

import org.sunflow.math.Vector3; //導入方法依賴的package包/類
private TriangleMesh generate(int[] tris, float[] verts, boolean smoothNormals) {
    ParameterList pl = new ParameterList();
    pl.addIntegerArray("triangles", tris);
    pl.addPoints("points", InterpolationType.VERTEX, verts);
    if (smoothNormals) {
        float[] normals = new float[verts.length]; // filled with 0's
        Point3 p0 = new Point3();
        Point3 p1 = new Point3();
        Point3 p2 = new Point3();
        Vector3 n = new Vector3();
        for (int i3 = 0; i3 < tris.length; i3 += 3) {
            int v0 = tris[i3 + 0];
            int v1 = tris[i3 + 1];
            int v2 = tris[i3 + 2];
            p0.set(verts[3 * v0 + 0], verts[3 * v0 + 1], verts[3 * v0 + 2]);
            p1.set(verts[3 * v1 + 0], verts[3 * v1 + 1], verts[3 * v1 + 2]);
            p2.set(verts[3 * v2 + 0], verts[3 * v2 + 1], verts[3 * v2 + 2]);
            Point3.normal(p0, p1, p2, n); // compute normal
            // add face normal to each vertex
            // note that these are not normalized so this in fact weights
            // each normal by the area of the triangle
            normals[3 * v0 + 0] += n.x;
            normals[3 * v0 + 1] += n.y;
            normals[3 * v0 + 2] += n.z;
            normals[3 * v1 + 0] += n.x;
            normals[3 * v1 + 1] += n.y;
            normals[3 * v1 + 2] += n.z;
            normals[3 * v2 + 0] += n.x;
            normals[3 * v2 + 1] += n.y;
            normals[3 * v2 + 2] += n.z;
        }
        // normalize all the vectors
        for (int i3 = 0; i3 < normals.length; i3 += 3) {
            n.set(normals[i3 + 0], normals[i3 + 1], normals[i3 + 2]);
            n.normalize();
            normals[i3 + 0] = n.x;
            normals[i3 + 1] = n.y;
            normals[i3 + 2] = n.z;
        }
        pl.addVectors("normals", InterpolationType.VERTEX, normals);
    }
    TriangleMesh m = new TriangleMesh();
    if (m.update(pl, null))
        return m;
    // something failed in creating the mesh, the error message will be
    // printed by the mesh itself - no need to repeat it here
    return null;
}
 
開發者ID:d2fn,項目名稱:passage,代碼行數:49,代碼來源:FileMesh.java


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