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


Java FastMath.sqrt方法代碼示例

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


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

示例1: 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

示例2: createHeightSubBlock

import com.jme3.math.FastMath; //導入方法依賴的package包/類
public float[] createHeightSubBlock(float[] heightMap, int x,
                int y, int side) {
    float[] rVal = new float[side * side];
    int bsize = (int) FastMath.sqrt(heightMap.length);
    int count = 0;
    for (int i = y; i < side + y; i++) {
        for (int j = x; j < side + x; j++) {
            if (j < bsize && i < bsize)
                rVal[count] = heightMap[j + (i * bsize)];
            count++;
        }
    }
    return rVal;
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:15,代碼來源:TerrainQuad.java

示例3: addLineFault

import com.jme3.math.FastMath; //導入方法依賴的package包/類
protected void addLineFault(float[][] tempBuffer, Random random, float faultHeight, float range) {
    int x1 = random.nextInt(size);
    int x2 = random.nextInt(size);
    int y1 = random.nextInt(size);
    int y2 = random.nextInt(size);


    for (int i = 0; i < size; i++) {
        for (int j = 0; j < size; j++) {
            float dist = ((x2 - x1) * (j - y1) - (y2 - y1) * (i - x1))
                    / (FastMath.sqrt(FastMath.sqr(x2 - x1) + FastMath.sqr(y2 - y1)));
            tempBuffer[i][j] += calcHeight(dist, random, faultHeight, range);
        }
    }
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:16,代碼來源:FaultHeightMap.java

示例4: addCircleFault

import com.jme3.math.FastMath; //導入方法依賴的package包/類
protected void addCircleFault(float[][] tempBuffer, Random random, float faultHeight, float range) {
    float radius = random.nextFloat() * (maxRadius - minRadius) + minRadius;
    int intRadius = (int) FastMath.floor(radius);
    // Allox circle center to be out of map if not by more than radius.
    // Unlucky cases will put them in the far corner, with the circle
    // entirely outside heightmap
    int x = random.nextInt(size + 2 * intRadius) - intRadius;
    int y = random.nextInt(size + 2 * intRadius) - intRadius;

    for (int i = 0; i < size; i++) {
        for (int j = 0; j < size; j++) {
            float dist;
            if (i != x || j != y) {
                int dx = i - x;
                int dy = j - y;
                float dmag = FastMath.sqrt(FastMath.sqr(dx) + FastMath.sqr(dy));
                float rx = x + dx / dmag * radius;
                float ry = y + dy / dmag * radius;
                dist = FastMath.sign(dmag - radius)
                    * FastMath.sqrt(FastMath.sqr(i - rx) + FastMath.sqr(j - ry));
            } else {
                dist = 0;
            }
            tempBuffer[i][j] += calcHeight(dist, random, faultHeight, range);
        }
    }
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:28,代碼來源:FaultHeightMap.java

示例5: createCollisionHeightfield

import com.jme3.math.FastMath; //導入方法依賴的package包/類
protected void createCollisionHeightfield(float[] heightmap, Vector3f worldScale) {
	this.scale = worldScale;
	this.heightScale = 1;//don't change away from 1, we use worldScale instead to scale
	
	this.heightfieldData = heightmap;

	float min = heightfieldData[0];
	float max = heightfieldData[0];
	// calculate min and max height
	for (int i=0; i<heightfieldData.length; i++) {
		if (heightfieldData[i] < min)
			min = heightfieldData[i];
		if (heightfieldData[i] > max)
			max = heightfieldData[i];
	}
	// we need to center the terrain collision box at 0,0,0 for BulletPhysics. And to do that we need to set the
	// min and max height to be equal on either side of the y axis, otherwise it gets shifted and collision is incorrect.
	if (max < 0)
		max = -min;
	else {
		if (Math.abs(max) > Math.abs(min))
			min = -max;
		else
			max = -min;
	}
	this.minHeight = min;
	this.maxHeight = max;

	this.upAxis = HeightfieldTerrainShape.YAXIS;
	this.flipQuadEdges = false;

	heightStickWidth = (int) FastMath.sqrt(heightfieldData.length);
	heightStickLength = heightStickWidth;


	createShape();
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:38,代碼來源:HeightfieldCollisionShape.java

示例6: distanceToEdge

import com.jme3.math.FastMath; //導入方法依賴的package包/類
public float distanceToEdge(Vector3f point) {
    // compute coordinates of point in box coordinate system
    Vector3f closest = point.subtract(center);

    // project test point onto box
    float sqrDistance = 0.0f;
    float delta;

    if (closest.x < -xExtent) {
        delta = closest.x + xExtent;
        sqrDistance += delta * delta;
        closest.x = -xExtent;
    } else if (closest.x > xExtent) {
        delta = closest.x - xExtent;
        sqrDistance += delta * delta;
        closest.x = xExtent;
    }

    if (closest.y < -yExtent) {
        delta = closest.y + yExtent;
        sqrDistance += delta * delta;
        closest.y = -yExtent;
    } else if (closest.y > yExtent) {
        delta = closest.y - yExtent;
        sqrDistance += delta * delta;
        closest.y = yExtent;
    }

    if (closest.z < -zExtent) {
        delta = closest.z + zExtent;
        sqrDistance += delta * delta;
        closest.z = -zExtent;
    } else if (closest.z > zExtent) {
        delta = closest.z - zExtent;
        sqrDistance += delta * delta;
        closest.z = zExtent;
    }

    return FastMath.sqrt(sqrDistance);
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:41,代碼來源:BoundingBox.java

示例7: apply

import com.jme3.math.FastMath; //導入方法依賴的package包/類
@Override
public float apply (float a) {
	if (a <= 0.5f) {
		a *= 2;
		return (1 - FastMath.sqrt(1 - a * a)) / 2;
	}
	a--;
	a *= 2;
	return (FastMath.sqrt(1 - a * a) + 1) / 2;
}
 
開發者ID:rockfireredmoon,項目名稱:icetone,代碼行數:11,代碼來源:Interpolation.java

示例8: update

import com.jme3.math.FastMath; //導入方法依賴的package包/類
@Override
public void update() {
    //update the character state based on the needed components
    //first collect some necessary information
    PhysicsCharacter character = get(PhysicsCharacter.class);
    Vector2f move = get(PhysicsCharacterMovement.class).getDirection();
    set(new PhysicsCharacterMovementForce(new Vector3f(
            move.x*character.getMass()*character.getAcceleration(), 0,
            move.y*character.getMass()*character.getAcceleration())));
    float capsuleHeight = character.getHeight()-2*character.getRadius()-character.getStepHeight();
    float bodyHeight = capsuleHeight+2*character.getRadius();
    float jumpSpeed = FastMath.sqrt(2*9.81f*character.getJumpHeight());
    boolean jumping = get(PhysicsCharacterState.class).isJumping();
    boolean ducking = get(PhysicsCharacterState.class).isDucking();
    set(new PhysicsCharacterState(false, false)); //TODO remove
    int jumpCount = get(PhysicsCharacterJumpCount.class).getCount();
    boolean onGround = false;
    Vector3f velocity = get(LinearVelocity.class).getVelocity();
    PhysicsPosition pos = get(PhysicsPosition.class);

    //the most important part is the ray system which keeps the capsule floating
    //in the air over the ground
    List<PhysicsRayTestResult> rayTestResultList = bulletSystem.getPhysicsSpace()
            .rayTest(pos.getLocation(), pos.getLocation().add(0,-50,0));
    if(rayTestResultList.size() > 0){
        float len = 60;
        for (PhysicsRayTestResult physicsRayTestResult : rayTestResultList) {
            if(physicsRayTestResult.getHitFraction()*50 < len){
                len = physicsRayTestResult.getHitFraction()*50;
            }
        }
        //if the character is near the ground or below it push it to the min step height.
        if(len <= character.getStepHeight() + bodyHeight/2){
            float diff = character.getStepHeight() + bodyHeight/2-len;
            set(new WarpPosition(pos.getLocation().add(0, diff,  0), pos.getRotation()));
            if(velocity.y < 0) {
                set(new WarpVelocity(velocity.clone().setY(0), Vector3f.ZERO));
            }
            onGround = true;
            set(new PhysicsCharacterJumpCount(0));
            jumpCount = 0;
        }
    }

    Vector3f impulse = new Vector3f();
    //apply jump
    if(jumping && (onGround || jumpCount < character.getMaxJumpNumber())){
        set(new PhysicsCharacterJumpCount(jumpCount+1));
        impulse.addLocal(new Vector3f(0, character.getMass()*jumpSpeed, 0));
    }
    //slow the character down if no movement is applied
    if(onGround){
        Vector3f slowDownImpulse = new Vector3f();
        if(FastMath.approximateEquals(move.x, 0)){
            slowDownImpulse.setX(-velocity.x*character.getMass()*0.05f);
        }
        if(FastMath.approximateEquals(move.y, 0)){
            slowDownImpulse.setZ(-velocity.z*character.getMass()*0.05f);
        }
        impulse.addLocal(slowDownImpulse);
    }
    //TODO use combined impulse
    set(new Impulse(impulse, new Vector3f()));
}
 
開發者ID:jvpichowski,項目名稱:ZayES-Bullet,代碼行數:65,代碼來源:PhysicsCharacterMovementLogic.java

示例9: RawHeightMap

import com.jme3.math.FastMath; //導入方法依賴的package包/類
public RawHeightMap(float heightData[]) {
    this.heightData = heightData;
    this.size = (int) FastMath.sqrt(heightData.length);
    this.format = FORMAT_8BIT;
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:6,代碼來源:RawHeightMap.java

示例10: getPolar

import com.jme3.math.FastMath; //導入方法依賴的package包/類
private float[] getPolar(float vX, float vY) {
	return new float[] { FastMath.sqrt(vX * vX + vY * vY), FastMath.atan2(vY, vX) };
}
 
開發者ID:rockfireredmoon,項目名稱:icetone,代碼行數:4,代碼來源:ColorPaletteTab.java

示例11: terrain2mesh

import com.jme3.math.FastMath; //導入方法依賴的package包/類
public Mesh terrain2mesh(Terrain terr) {
    float[] heights = terr.getHeightMap();
    int length = heights.length;
    int side = (int) FastMath.sqrt(heights.length);
    float[] vertices = new float[length * 3];
    int[] indices = new int[(side - 1) * (side - 1) * 6];

    //Vector3f trans = ((Node) terr).getWorldTranslation().clone();
    Vector3f trans = new Vector3f(0,0,0);
    trans.x -= terr.getTerrainSize() / 2f;
    trans.z -= terr.getTerrainSize() / 2f;
    float offsetX = trans.x;
    float offsetZ = trans.z;

    // do vertices
    int i = 0;
    for (int z = 0; z < side; z++) {
        for (int x = 0; x < side; x++) {
            vertices[i++] = x + offsetX;
            vertices[i++] = heights[z * side + x];
            vertices[i++] = z + offsetZ;
        }
    }

    // do indexes
    i = 0;
    for (int z = 0; z < side - 1; z++) {
        for (int x = 0; x < side - 1; x++) {
            // triangle 1
            indices[i++] = z * side + x;
            indices[i++] = (z + 1) * side + x;
            indices[i++] = (z + 1) * side + x + 1;
            // triangle 2
            indices[i++] = z * side + x;
            indices[i++] = (z + 1) * side + x + 1;
            indices[i++] = z * side + x + 1;
        }
    }

    Mesh mesh2 = new Mesh();
    mesh2.setBuffer(Type.Position, 3, vertices);
    mesh2.setBuffer(Type.Index, 3, indices);
    mesh2.updateBound();
    mesh2.updateCounts();

    return mesh2;
}
 
開發者ID:jMonkeyEngine,項目名稱:sdk,代碼行數:48,代碼來源:NavMeshGenerator.java

示例12: setSphere

import com.jme3.math.FastMath; //導入方法依賴的package包/類
/**
 * Calculates the minimum bounding sphere of 2 points. Used in welzl's
 * algorithm.
 *
 * @param O
 *            The 1st point inside the sphere.
 * @param A
 *            The 2nd point inside the sphere.
 * @see #calcWelzl(java.nio.FloatBuffer)
 */
private void setSphere(Vector3f O, Vector3f A) {
    radius = FastMath.sqrt(((A.x - O.x) * (A.x - O.x) + (A.y - O.y)
            * (A.y - O.y) + (A.z - O.z) * (A.z - O.z)) / 4f) + RADIUS_EPSILON - 1f;
    center.interpolate(O, A, .5f);
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:16,代碼來源:BoundingSphere.java


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