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


Java Vector3f.subtractLocal方法代碼示例

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


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

示例1: onAnalog

import com.jme3.math.Vector3f; //導入方法依賴的package包/類
@Override
public void onAnalog( String name, float value, float tpf ) {
	CollisionResult cr = getClicked();

	Vector3f pos = null;
	
	if (cr != null) 
		pos = cr.getContactPoint();
	
	
	if (pos == null) {
		Vector3f dir = cam.getWorldCoordinates( getInputManager().getCursorPosition(), -10 );
		dir.subtractLocal( cam.getLocation() );
		new Ray( cam.getLocation(), dir ).intersectsWherePlane( new Plane(Jme3z.UP, 0), pos = new Vector3f() );
	}
	
	cursorPosition = Jme3z.from( pos );
	
	if (pos != null)
		point.setPosition( pos.add ( cam.getDirection().mult( -0.3f ) ));
}
 
開發者ID:twak,項目名稱:chordatlas,代碼行數:22,代碼來源:Tweed.java

示例2: getSurfaceSelected

import com.jme3.math.Vector3f; //導入方法依賴的package包/類
private Vector3f getSurfaceSelected(float dist) {
	CollisionResult cr = getClicked();
	
	Vector3f pos = null;
	
	if (cr != null) 
		pos = cr.getContactPoint();
	
	
	if (pos == null) {
		Vector3f dir = cam.getWorldCoordinates( getInputManager().getCursorPosition(), -dist );
		dir.subtractLocal( cam.getLocation() );
		new Ray( cam.getLocation(), dir ).intersectsWherePlane( new Plane(Jme3z.UP, 0), pos = new Vector3f() );
	}
	return pos;
}
 
開發者ID:twak,項目名稱:chordatlas,代碼行數:17,代碼來源:Tweed.java

示例3: renderDepth

import com.jme3.math.Vector3f; //導入方法依賴的package包/類
public BufferedImage renderDepth( File fout, float scale, Pano pano, Spatial scene, double minDepth, double maxDepth ) {
	
	BufferedImage out = new BufferedImage( (int) ( a.distance( b ) * scale ), (int) ( ( heightMax- heightMin) * scale ), BufferedImage.TYPE_3BYTE_BGR );
	
	Vector3f o = Jme3z.to ( pano.location );
	
	for ( int x = 0; x < out.getWidth(); x++ ) {
		for ( int y = 0; y < out.getHeight(); y++ ) {

			CollisionResults results = new CollisionResults();

			float[] target = uvToWorld( x / (float) out.getWidth(), 1 - ( y / (float) out.getHeight() ) );
			Vector3f ray = new Vector3f (target[0], target[1], target[2]);
			ray.subtractLocal( o );
			
			scene.collideWith(new Ray( o, ray), results);
			
			CollisionResult cr = results.getClosestCollision();
			double dist = maxDepth;
			
			if (cr != null) 
				dist = Math.min (maxDepth, cr.getDistance() );
			
			dist = Mathz.clamp ( ( dist - minDepth ) / ( maxDepth - minDepth ), 0, 1);
			
			int d = (int)(dist * 256);
			double r = dist*256 - d;
			
			int c = Colour.asInt(  
					Mathz.clamp ( d + (r > 0.25 ? 1 : 0), 0, 255),
					Mathz.clamp ( d + (r > 0.50 ? 1 : 0), 0, 255),
					Mathz.clamp ( d + (r > 0.75 ? 1 : 0), 0, 255) );
			
			out.setRGB( x, y, c );
		}
		System.out.println( x + " / " + out.getWidth() );
	}
	
	if ( fout != null )
		try {
			ImageIO.write( out, "png", fout );
		} catch ( IOException e1 ) {
			e1.printStackTrace();
		}
	return out;
}
 
開發者ID:twak,項目名稱:chordatlas,代碼行數:47,代碼來源:ImagePlaneGen.java

示例4: processTransform

import com.jme3.math.Vector3f; //導入方法依賴的package包/類
@Override
public void processTransform() {

    final EditorTransformSupport editorControl = getEditorControl();

    final LocalObjects local = LocalObjects.get();
    final Camera camera = editorControl.getCamera();
    final InputManager inputManager = EDITOR.getInputManager();
    final Transform transform = notNull(editorControl.getTransformCenter());

    // cursor position and selected position vectors
    final Vector2f cursorPos = inputManager.getCursorPosition();
    final Vector3f transformOnScreen = camera.getScreenCoordinates(transform.getTranslation(), local.nextVector());
    final Vector2f selectedCoords = local.nextVector(transformOnScreen.getX(), transformOnScreen.getY());

    // set new deltaVector if it's not set (scale tool stores position of a cursor)
    if (Float.isNaN(editorControl.getTransformDeltaX())) {
        editorControl.setTransformDeltaX(cursorPos.getX());
        editorControl.setTransformDeltaY(cursorPos.getY());
    }

    final Node parentNode = getParentNode();
    final Node childNode = getChildNode();

    // Picked vector
    final Spatial toTransform = notNull(editorControl.getToTransform());
    final TransformationMode transformationMode = editorControl.getTransformationMode();
    transformationMode.prepareToScale(parentNode, childNode, transform, camera);

    // scale according to distance
    final Vector3f deltaVector = local.nextVector(editorControl.getTransformDeltaX(), editorControl.getTransformDeltaY(), 0F);
    final Vector2f delta2d = local.nextVector(deltaVector.getX(), deltaVector.getY());
    final Vector3f baseScale = local.nextVector(transform.getScale()); // default scale
    final Vector3f pickedVector = local.nextVector(transformationMode.getScaleAxis(transform, editorControl.getPickedAxis(), camera));
    pickedVector.setX(abs(pickedVector.getX()));
    pickedVector.setY(abs(pickedVector.getY()));
    pickedVector.setZ(abs(pickedVector.getZ()));

    if (Config.DEV_TRANSFORMS_DEBUG) {
        System.out.println("Base scale " + baseScale + ", pickedVector " + pickedVector);
    }

    // scale object
    float disCursor = cursorPos.distance(selectedCoords);
    float disDelta = delta2d.distance(selectedCoords);
    float scaleValue = (float) (cursorPos.distance(delta2d) * 0.01f * Math.sqrt(baseScale.length()));

    if (disCursor > disDelta) {
        baseScale.addLocal(pickedVector.mult(scaleValue, local.nextVector()));
    } else {
        scaleValue = Math.min(scaleValue, 0.999f); // remove negateve values
        baseScale.subtractLocal(pickedVector.mult(scaleValue, local.nextVector()));
    }

    parentNode.setLocalScale(baseScale);

    if (Config.DEV_TRANSFORMS_DEBUG) {
        System.out.println("New scale " + baseScale + ", result world " + childNode.getWorldScale());
    }

    parentNode.setLocalScale(baseScale);
    toTransform.setLocalScale(childNode.getWorldScale());

    editorControl.notifyTransformed(toTransform);
}
 
開發者ID:JavaSaBr,項目名稱:jmonkeybuilder,代碼行數:66,代碼來源:ScaleToolControl.java


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