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


Java FastMath類代碼示例

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


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

示例1: updateAngle

import com.jme3.math.FastMath; //導入依賴的package包/類
private void updateAngle() {
    Vector3f temp, higher, lower;
    if (point2.y > point1.y) {
        temp = point2;
        higher = point2;
        lower = point1;
    } else {
        temp = point1;
        higher = point1;
        lower = point2;
    }
    temp = temp.clone().setY(lower.y);

    float angle = ((FastMath.asin(temp.distance(higher) / lower.distance(higher))) * FastMath.RAD_TO_DEG);

    angleText.setText(angle + " degrees");
    angleText.setLocalTranslation(new Vector3f().interpolateLocal(point1, point2, 0.5f));

    if (line.getParent() == null) {
        parent.attachChild(line);
        parent.attachChild(angleText);
    }
    ((Line) line.getMesh()).updatePoints(point1, point2);
}
 
開發者ID:jMonkeyEngine,項目名稱:sdk,代碼行數:25,代碼來源:SlopeTerrainTool.java

示例2: zoomCamera

import com.jme3.math.FastMath; //導入依賴的package包/類
protected void zoomCamera(float value){
    // derive fovY value
    float h = cam.getFrustumTop();
    float w = cam.getFrustumRight();
    float aspect = w / h;

    float near = cam.getFrustumNear();

    float fovY = FastMath.atan(h / near)
              / (FastMath.DEG_TO_RAD * .5f);
    fovY += value * 0.1f;

    h = FastMath.tan( fovY * FastMath.DEG_TO_RAD * .5f) * near;
    w = h * aspect;

    cam.setFrustumTop(h);
    cam.setFrustumBottom(-h);
    cam.setFrustumLeft(-w);
    cam.setFrustumRight(w);
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:21,代碼來源:FlyByCamera.java

示例3: doAnimUpdate

import com.jme3.math.FastMath; //導入依賴的package包/類
@Override
protected void doAnimUpdate(float interpolation) {
    
    TempVars tv = TempVars.get();
    Vector3f scale = tv.vect1;
    FastMath.extrapolateLinear(interpolation, startScale, endScale, scale);
    target.setLocalScale(scale);
    
    // 位置偏移,當設置了縮放偏移時需要處理縮放過程中的目標對象位置
    if (localScaleOffset != null) {
        FastMath.extrapolateLinear(interpolation, scaleStartPos, scaleEndPos, tv.vect2);
        target.setLocalTranslation(tv.vect2);
    }
    
    tv.release();
    
}
 
開發者ID:huliqing,項目名稱:LuoYing,代碼行數:18,代碼來源:ScaleAnim.java

示例4: checkSlope

import com.jme3.math.FastMath; //導入依賴的package包/類
protected void checkSlope() {
    if (this.getWalkDirection().length() > 0) {

        List<PhysicsRayTestResult> results = space.rayTest(
                rigidBody.getPhysicsLocation().add(0, 0.01f, 0),
                rigidBody.getPhysicsLocation().add(
                walkDirection.setY(0).normalize().mult(getFinalRadius())).add(0, 0.01f, 0));
        for (PhysicsRayTestResult physicsRayTestResult : results) {
            float angle = physicsRayTestResult
                    .getHitNormalLocal()
                    .normalize()
                    .angleBetween(
                    physicsRayTestResult.getHitNormalLocal()
                    .setY(0).normalize());

            if (Math.abs(angle * FastMath.RAD_TO_DEG - 90) > maxSlope && !physicsRayTestResult.getCollisionObject().equals(rigidBody)) {
                tooSteep = true;
                return;
            }
        }

    }
    tooSteep = false;

}
 
開發者ID:rockfireredmoon,項目名稱:iceclient,代碼行數:26,代碼來源:AdvancedCharacterControl.java

示例5: doZoomCamera

import com.jme3.math.FastMath; //導入依賴的package包/類
public void doZoomCamera(float amount) {
        amount = amount * 0.1f;
        amount = cam.getLocation().distance(focus) * amount;
        float dist = cam.getLocation().distance(focus);
        amount = dist - Math.max(0f, dist - amount);
        
        // 一個最小距離用於防止拉到0距離後縮放不回來的BUG
        if (amount >= dist) {
            amount -= minDistance;
        }
        
        Vector3f loc = cam.getLocation().clone();
        loc.scaleAdd(amount, cam.getDirection(), loc);
        cam.setLocation(loc);

        if (cam.isParallelProjection()) {
            float aspect = (float) cam.getWidth() / cam.getHeight();
            float h = FastMath.tan(45f * FastMath.DEG_TO_RAD * .5f) * dist;
            float w = h * aspect;
            cam.setFrustum(orthoNear, orthoFar, -w, w, h, -h);
        }
//        LOG.log(Level.INFO, "doZoomCamera, Camera location={0}", cam.getLocation());
    }
 
開發者ID:huliqing,項目名稱:LuoYing,代碼行數:24,代碼來源:BestEditCamera.java

示例6: dropRandomBlock

import com.jme3.math.FastMath; //導入依賴的package包/類
public void dropRandomBlock() {
	final ColorRGBA[] colors = new ColorRGBA[] { ColorRGBA.Red,
			ColorRGBA.Blue, ColorRGBA.Yellow, ColorRGBA.Green,
			ColorRGBA.Brown, ColorRGBA.Cyan, ColorRGBA.Magenta,
			ColorRGBA.Orange };
	Spatial s = factory.makeBlock(getUniqueId("largeblock"), 1.5f, 1.5f, 1.5f,
			colors[random.nextInt(colors.length)]);
	s.setLocalTranslation(
			(random.nextFloat() * 2 - 1) * (tableWidth / 2),
			10,
			(random.nextFloat() * 2 - 1) * (tableDepth / 2));
	s.setLocalRotation(new Quaternion().fromAngleAxis(
			FastMath.HALF_PI * random.nextFloat(),
			Vector3f.UNIT_XYZ));
	inventory.addItem(s, 1);
}
 
開發者ID:dwhuang,項目名稱:SMILE,代碼行數:17,代碼來源:Table.java

示例7: tryDetour

import com.jme3.math.FastMath; //導入依賴的package包/類
@Override
protected void tryDetour(int count) {
    if (count == 0) {
        direction = MathUtils.randomPON();
    }
    
    TempVars tv = TempVars.get();
    float angle = 30 * (count + 1) * FastMath.DEG_TO_RAD * direction;
    tv.vect1.set(actorService.getWalkDirection(actor));
    MathUtils.rotate(tv.vect1.normalizeLocal(), angle, Vector3f.UNIT_Y, tv.vect2);
    
    detour(tv.vect2);
    
    tv.release();
    
    float lockTime = count * 0.25f + 0.25f;
    action.lock(lockTime);
}
 
開發者ID:huliqing,項目名稱:LuoYing,代碼行數:19,代碼來源:TimeDetour.java

示例8: jSpinner1StateChanged

import com.jme3.math.FastMath; //導入依賴的package包/類
private void jSpinner1StateChanged(javax.swing.event.ChangeEvent evt) {//GEN-FIRST:event_jSpinner1StateChanged
    // This is called, when the spinner of the near plane has been changed.
    float near = ((float)jSlider1.getValue() / 1000f);
    float spin = (Float)jSpinner1.getValue();
    
    // Prevent an endless loop of state changes and don't change the slider when the spinner
    // has gone out of range, since this would lead to the slider's StateChanged overwriting the spinner again.
    // but we want the spinner to be a free-form field
    
    if (spin <= 2000f && spin >= 100f && !FastMath.approximateEquals((Float)(jSpinner1.getValue()), near)) {
        jSlider1.setValue((int)((Float)(jSpinner1.getValue()) * 1000f));
    }
    
    final Camera cam = SceneApplication.getApplication().getCamera();
    cam.setFrustumPerspective(45f, (float)cam.getWidth() / cam.getHeight(), spin, cam.getFrustumFar());
}
 
開發者ID:jMonkeyEngine,項目名稱:sdk,代碼行數:17,代碼來源:SceneComposerTopComponent.java

示例9: doToggleOrthoPerspMode

import com.jme3.math.FastMath; //導入依賴的package包/類
protected boolean doToggleOrthoPerspMode() {

        float aspect = (float) cam.getWidth() / cam.getHeight();
        if (!cam.isParallelProjection()) {
            cam.setParallelProjection(true);
            float h = cam.getFrustumTop();
            float w;
            float dist = cam.getLocation().distance(focus);
            float fovY = FastMath.atan(h) / (FastMath.DEG_TO_RAD * .5f);
            h = FastMath.tan(fovY * FastMath.DEG_TO_RAD * .5f) * dist;
            w = h * aspect;
            cam.setFrustum(-1000, 1000, -w, w, h, -h);
            return true;
        } else {
            cam.setParallelProjection(false);
            cam.setFrustumPerspective(45f, aspect, 1, 1000);
            return false;
        }
    }
 
開發者ID:jMonkeyEngine,項目名稱:sdk,代碼行數:20,代碼來源:AbstractCameraController.java

示例10: updateGeometry

import com.jme3.math.FastMath; //導入依賴的package包/類
protected void updateGeometry() {
    FloatBuffer positions = BufferUtils.createFloatBuffer(samples * 3);
    FloatBuffer normals = BufferUtils.createFloatBuffer(samples * 3);
    short[] indices = new short[samples * 2];
    float rate = FastMath.TWO_PI / samples;
    float angle = 0;
    int idc = 0;
    for (int i = 0; i < samples; i++) {
        float x = FastMath.cos(angle) * radius.x + center.x;
        float z = FastMath.sin(angle) * radius.y + center.y;
        positions.put(x).put(z).put(0);
        normals.put(new float[]{0, 1, 0});
        indices[idc++] = (short) i;
        if (i < samples - 1) {
            indices[idc++] = (short) (i + 1);
        } else {
            indices[idc++] = 0;
        }
        angle += rate;
    }
    setBuffer(VertexBuffer.Type.Position, 3, positions);
    setBuffer(VertexBuffer.Type.Normal, 3, normals);
    setBuffer(VertexBuffer.Type.Index, 2, indices);
    setBuffer(VertexBuffer.Type.TexCoord, 2, new float[]{0, 0, 1, 1});
    updateBound();
}
 
開發者ID:rockfireredmoon,項目名稱:icetone,代碼行數:27,代碼來源:Oval2d.java

示例11: setMeshes

import com.jme3.math.FastMath; //導入依賴的package包/類
@Override
public void setMeshes(List<Mesh> meshes) {
    this.vertices = new ArrayList<List<Vector3f>>(meshes.size());
    this.normals = new ArrayList<List<Vector3f>>(meshes.size());
    for (Mesh mesh : meshes) {
        Vector3f[] vertexTable = BufferUtils.getVector3Array(mesh.getFloatBuffer(Type.Position));
        int[] indices = new int[3];
        List<Vector3f> vertices = new ArrayList<Vector3f>(mesh.getTriangleCount() * 3);
        List<Vector3f> normals = new ArrayList<Vector3f>(mesh.getTriangleCount());
        for (int i = 0; i < mesh.getTriangleCount(); ++i) {
            mesh.getTriangle(i, indices);
            vertices.add(vertexTable[indices[0]]);
            vertices.add(vertexTable[indices[1]]);
            vertices.add(vertexTable[indices[2]]);
            normals.add(FastMath.computeNormal(vertexTable[indices[0]], vertexTable[indices[1]], vertexTable[indices[2]]));
        }
        this.vertices.add(vertices);
        this.normals.add(normals);
    }
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:21,代碼來源:EmitterMeshFaceShape.java

示例12: completeWrap

import com.jme3.math.FastMath; //導入依賴的package包/類
protected void completeWrap(int i) {
	lineWidth = Math.max(lnWidth, lineWidth);

	updateLineForAlignment(0, i, lineWidth);
	updateForAlign();

	Vector2f rotSize = rotation == 0 ? dimensions
			: MathUtil.rotatedBounds(dimensions, rotation * FastMath.RAD_TO_DEG);
	setOrigin(rotSize.x / 2, rotSize.y / 2);

	setOrigin(0, 0);
	mesh.update(0);
	mesh.updateBound();
	lineDisplay.update(0);
	if (textVAlign != null) {
		alignToBoundsV();
	}
}
 
開發者ID:rockfireredmoon,項目名稱:icetone,代碼行數:19,代碼來源:AnimText.java

示例13: getLowestRoot

import com.jme3.math.FastMath; //導入依賴的package包/類
private static float getLowestRoot(float a, float b, float c, float maxR) {
    float determinant = b * b - 4f * a * c;
    if (determinant < 0){
        return Float.NaN;
    }

    float sqrtd = FastMath.sqrt(determinant);
    float r1 = (-b - sqrtd) / (2f * a);
    float r2 = (-b + sqrtd) / (2f * a);

    if (r1 > r2){
        float temp = r2;
        r2 = r1;
        r1 = temp;
    }

    if (r1 > 0 && r1 < maxR){
        return r1;
    }

    if (r2 > 0 && r2 < maxR){
        return r2;
    }

    return Float.NaN;
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:27,代碼來源:SweepSphere.java

示例14: getTriangleAtPoint

import com.jme3.math.FastMath; //導入依賴的package包/類
/**
 * Get the triangle that the point is on.
 * 
 * @param x coordinate in local space to the geomap
 * @param z coordinate in local space to the geomap
 * @return triangle in local space to the geomap
 */
protected Triangle getTriangleAtPoint(float x, float z) {
    Triangle[] triangles = getGridTrianglesAtPoint(x, z);
    if (triangles == null) {
        System.out.println("x,z: " + x + "," + z);
        return null;
    }
    Vector2f point = new Vector2f(x, z);
    Vector2f t1 = new Vector2f(triangles[0].get1().x, triangles[0].get1().z);
    Vector2f t2 = new Vector2f(triangles[0].get2().x, triangles[0].get2().z);
    Vector2f t3 = new Vector2f(triangles[0].get3().x, triangles[0].get3().z);

    if (0 != FastMath.pointInsideTriangle(t1, t2, t3, point)) {
        return triangles[0];
    }

    t1.set(triangles[1].get1().x, triangles[1].get1().z);
    t1.set(triangles[1].get2().x, triangles[1].get2().z);
    t1.set(triangles[1].get3().x, triangles[1].get3().z);

    if (0 != FastMath.pointInsideTriangle(t1, t2, t3, point)) {
        return triangles[1];
    }

    return null;
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:33,代碼來源:LODGeomap.java

示例15: processGuestBondPointElement

import com.jme3.math.FastMath; //導入依賴的package包/類
private Spatial processGuestBondPointElement(Element elm) {
    String id = elm.getAttribute("id");
    id = getUniqueId(id);
    // Non-empty string; two parts must have the same type before they can be put together
    String type = elm.getAttribute("type");
    Vector3f location = parseVector3(elm.getAttribute("location"));
    Vector3f rotation = parseVector3(elm.getAttribute("rotation"));
    // The host bond point that this object (guest) is fastened to; ignored if is host
    String hostId = elm.getAttribute("initBondHostId");
    int hostTightness = Integer.parseInt(elm.getAttribute("initBondTightness"));

    Node node = new Node(id);
    node.setLocalTranslation(location);
    node.setLocalRotation(new Quaternion().fromAngles(
            rotation.x * FastMath.DEG_TO_RAD,
            rotation.y * FastMath.DEG_TO_RAD,
            rotation.z * FastMath.DEG_TO_RAD));
    node.setUserData("bondPoint", "guest");
    node.setUserData("bondType", type);
    if (!hostId.isEmpty()) {
        node.setUserData("initBondHostId", hostId);
        node.setUserData("initBondTightness", hostTightness);
    }
    
    return node;
}
 
開發者ID:dwhuang,項目名稱:SMILE,代碼行數:27,代碼來源:Table.java


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