当前位置: 首页>>代码示例>>Java>>正文


Java Matrix4d.invert方法代码示例

本文整理汇总了Java中javax.vecmath.Matrix4d.invert方法的典型用法代码示例。如果您正苦于以下问题:Java Matrix4d.invert方法的具体用法?Java Matrix4d.invert怎么用?Java Matrix4d.invert使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在javax.vecmath.Matrix4d的用法示例。


在下文中一共展示了Matrix4d.invert方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: updateViewersTransformation

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
private void updateViewersTransformation()
{
       if ( mViewers .size() == 0 )
           return;
	Matrix4d trans = new Matrix4d();
	
	model .getViewTransform( trans, 0d );
       trans .invert();
       for ( int i = 0; i < mViewers .size(); i++ )
           mViewers .get( i ) .setViewTransformation( trans, Viewer .MONOCULAR );
	
       model .getStereoViewTransform( trans, Viewer .LEFT_EYE );
       trans .invert();
       for ( int i = 0; i < mViewers .size(); i++ )
           mViewers .get( i ) .setViewTransformation( trans, Viewer .LEFT_EYE );
       
       model .getStereoViewTransform( trans, Viewer .RIGHT_EYE );
       trans .invert();
       for ( int i = 0; i < mViewers .size(); i++ )
           mViewers .get( i ) .setViewTransformation( trans, Viewer .RIGHT_EYE );
}
 
开发者ID:vZome,项目名称:vzome-desktop,代码行数:22,代码来源:CameraController.java

示例2: invert

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
/**
     * Invert the transform, this object is inverted and returned.
     *
     * @return return this
     */
    public CellTransform invert() {
        // This invert for jme does not function when the scale != 1
//        Matrix3f rot = new Matrix3f();
//        rot.set(rotation);
//        float temp;
//        temp=rot.m01;
//        rot.m01=rot.m10;
//        rot.m10=temp;
//        temp=rot.m02;
//        rot.m02=rot.m20;
//        rot.m20=temp;
//        temp=rot.m21;
//        rot.m21=rot.m12;
//        rot.m12=temp;
//        rot.multLocal(1/scale);
//
//        rot.multLocal(translation);
//
//        translation.multLocal(-1);
//        scale = 1/scale;
//
//        rotation.fromRotationMatrix(rot);

        // Correctly compute the inversion, use Vecmath as the matrix invert
        // in JME does not function when scale!=1
        Quat4d q = new Quat4d(rotation.x, rotation.y, rotation.z, rotation.w);
        Vector3d t = new Vector3d(translation.x, translation.y, translation.z);
        Matrix4d m = new Matrix4d(q,t,scale);
        m.invert();

        m.get(q);
        m.get(t);
        scale = (float)m.getScale();
        rotation.set((float)q.x, (float)q.y, (float)q.z, (float)q.w);
        translation.set((float)t.x, (float)t.y, (float)t.z);

        return this;
    }
 
开发者ID:josmas,项目名称:openwonderland,代码行数:44,代码来源:CellTransform.java

示例3: setViewTransformation

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
@Override
public void setViewTransformation( Matrix4d trans, int eye )
{
	if ( eye == Viewer .MONOCULAR ) {
		Matrix3d justRotation3d = new Matrix3d();
		trans .get( justRotation3d );
		justRotation3d .invert(); // to match the invert() in the caller
		Matrix4d finalTransform = new Matrix4d();
		finalTransform .set( this .translation );
		finalTransform .setRotation( justRotation3d );
		finalTransform .invert(); // to match the invert() in the caller
		this .delegate .setViewTransformation( finalTransform, Viewer .MONOCULAR );
	}
}
 
开发者ID:vZome,项目名称:vzome-desktop,代码行数:15,代码来源:TrackballRenderingViewer.java

示例4: getWorldRotation

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
public void getWorldRotation( Quat4d q )
{
	Vector3d axis = new Vector3d( q.x, q.y, q.z );

	Matrix4d viewTrans = new Matrix4d();
	model .getViewTransform( viewTrans, 0d );
       viewTrans .invert();

	// now map the axis back to world coordinates
	viewTrans .transform( axis );
	q.x = axis.x; q.y = axis.y; q.z = axis.z;
}
 
开发者ID:vZome,项目名称:vzome-desktop,代码行数:13,代码来源:CameraController.java

示例5: mapViewToWorld

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
public void mapViewToWorld( Vector3f vector )
{
	Matrix4d viewTrans = new Matrix4d();
	model .getViewTransform( viewTrans, 0d );
       viewTrans .invert();
	viewTrans .transform( vector );
}
 
开发者ID:vZome,项目名称:vzome-desktop,代码行数:8,代码来源:CameraController.java

示例6: mapViewToWorld

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
public void mapViewToWorld( Camera view, Vector3f vector )
{
    Matrix4d viewTrans = new Matrix4d();
    view .getViewTransform( viewTrans, 0d );
    viewTrans .invert();
    viewTrans .transform( vector );
}
 
开发者ID:vZome,项目名称:vzome-core,代码行数:8,代码来源:POVRayExporter.java

示例7: analyze

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
/**
 * This method is the main function call to extract all step parameters, pairing parameters, and sequence
 * information from the Structure object provided to the constructor.
 * @return This same object with the populated data, convenient for output
 *  (e.g. <i>log.info(new BasePairParameters(structure).analyze());</i>)
 */
public BasePairParameters analyze() {
    if (structure == null) {
        pairingParameters = null;
        stepParameters = null;
        return this;
    }
    List<Chain> nucleics = this.getNucleicChains(nonredundant);
    List<Pair<Group>> pairs = this.findPairs(nucleics);
    this.pairingParameters = new double[pairs.size()][6];
    this.stepParameters = new double[pairs.size()][6];
    Matrix4d lastStep;
    Matrix4d currentStep = null;
    for (int i = 0; i < pairs.size(); i++) {
        lastStep = currentStep;
        currentStep = this.basePairReferenceFrame(pairs.get(i));
        referenceFrames.add((Matrix4d)currentStep.clone());
        for (int j = 0; j < 6; j++) pairingParameters[i][j] = pairParameters[j];
        if (i != 0) {
            lastStep.invert();
            lastStep.mul(currentStep);
            double[] sparms = calculateTp(lastStep);
            for (int j = 0; j < 6; j++) stepParameters[i][j] = sparms[j];
        }
    }
    return this;
}
 
开发者ID:biojava,项目名称:biojava,代码行数:33,代码来源:BasePairParameters.java

示例8: getSymmetryAxes

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
/**
 * Recursive helper
 * @param symmAxes output list
 * @param prior transformation aligning the first repeat of this axis with the first overall
 * @param level current level
 */
private void getSymmetryAxes(List<Axis> symmAxes, Matrix4d prior, int level, int firstRepeat) {
	if(level >= getNumLevels() ) {
		return;
	}

	Axis elem = axes.get(level);
	Matrix4d elemOp = elem.getOperator();

	// Current axis:
	// elementary maps B -> A
	// prior maps I -> A and J -> B
	// want J -> I = J -> B -> A <- I= inv(prior) * elementary * prior
	Matrix4d currAxisOp = new Matrix4d(prior);
	currAxisOp.invert();
	currAxisOp.mul(elemOp);
	currAxisOp.mul(prior);
	Axis currAxis = new Axis(currAxisOp,elem.getOrder(),elem.getSymmType(),level,firstRepeat);
	symmAxes.add(currAxis);
	
	//Remember that all degrees are at least 2
	getSymmetryAxes(symmAxes,prior,level+1,firstRepeat);
	//New prior is elementary^d*prior
	Matrix4d newPrior = new Matrix4d(elemOp);
	newPrior.mul(prior);
	int childSize = getNumRepeats(level+1);
	getSymmetryAxes(symmAxes,newPrior,level+1,firstRepeat+childSize);
	for(int d=2;d<elem.getOrder();d++) {
		newPrior.mul(elemOp,newPrior);
		getSymmetryAxes(symmAxes,newPrior,level+1,firstRepeat+childSize*d);
	}
}
 
开发者ID:biojava,项目名称:biojava,代码行数:38,代码来源:SymmetryAxes.java

示例9: intersect

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
@Override
public final void intersect(final Ray ray, final IntersectResult result,
    final double tMin, final double tMax) {
  final Ray transformedRay = new Ray(ray);
  if (transform != null) {
    final Matrix4d mInv = transform.getMinv();
    mInv.transform(transformedRay.eyePoint);
    transformedRay.viewDirection = (Vector3d) ray.viewDirection.clone();
    mInv.transform(transformedRay.viewDirection);
  }

  final IntersectResult subResult = new IntersectResult();
  IntersectResult closestResult = null;
  // Find closest intersection
  for (final AbstractSurfaceXml surf : children) {
    surf.intersect(transformedRay, subResult, tMin, tMax);
    if (subResult.p != null
        && (result.p == null || subResult.tIn < result.tIn)) {
      closestResult = subResult;
    }
  }
  // Set result to closest intersection
  if (closestResult != null) {
    final IntersectResult transformedResult = new IntersectResult();
    transformedResult.set(closestResult);
    if (transform != null) {
      final Matrix4d m = transform.getM();
      m.transform(transformedResult.p);
      final Matrix4d transposed = new Matrix4d();
      transposed.transpose(m);
      transposed.invert();
      transposed.transform(transformedResult.n);
      transformedResult.n.normalize();
    }
    result.set(transformedResult);
    if (material != null) {
      result.material = material;
    }
  }
}
 
开发者ID:billohreally,项目名称:ray-tracer,代码行数:41,代码来源:SceneNodeXml.java

示例10: postSet

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
public void postSet() {
  final Matrix4d m = getM();
  if (translation != null) {
    final Matrix4d t = new Matrix4d();
    t.set(translation);
    m.mul(t);
  }
  if (rotation != null) {
    final Matrix4d r = new Matrix4d();
    r.rotX(Math.toRadians(rotation.x));
    m.mul(r);
    r.rotY(Math.toRadians(rotation.y));
    m.mul(r);
    r.rotZ(Math.toRadians(rotation.z));
    m.mul(r);
  }
  if (scale != null) {
    final Matrix4d s = new Matrix4d();
    s.setIdentity();
    s.setElement(0, 0, scale.x);
    s.setElement(1, 1, scale.y);
    s.setElement(2, 2, scale.z);
    m.mul(s);
  }
  final Matrix4d minv = getMinv();
  minv.invert(getM());
}
 
开发者ID:billohreally,项目名称:ray-tracer,代码行数:28,代码来源:TransformXml.java

示例11: getInverseTransform

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
/**
 * Computes the inverse affine transform.
 */
public AffineTransform3D getInverseTransform() {
    Matrix4d invertedMatrix = new Matrix4d(matrix);
    invertedMatrix.invert();
    return new AffineTransform3D(invertedMatrix);
}
 
开发者ID:kefik,项目名称:Pogamut3,代码行数:9,代码来源:AffineTransform3D.java

示例12: doAlign

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
private void doAlign() {
		
		if (alignMarkers[0] == null || alignMarkers[1] == null || otherMarkers[0] == null || otherMarkers[1] == null) {
			JOptionPane.showMessageDialog( null, "click meshes to create align markers" );
			return;
		}
		
		Matrix4d toOrigin = buildFrame( alignMarkers );
		toOrigin.invert();
		
		Matrix4d o = buildFrame( otherMarkers );
		toOrigin.mul( o, toOrigin );

		toOrigin.m13 += vOffset;
		
		Transform t = new Transform();
		t.fromTransformMatrix( Jme3z.toJme ( toOrigin ) );
		
		toAlign.moveTo( t );
		
//		System.out.println ( "bounds "+ toAlign.gNode.getWorldBound() );
		
	}
 
开发者ID:twak,项目名称:chordatlas,代码行数:24,代码来源:AlignTool.java

示例13: convertToMini

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
public static void convertToMini( Iterable<File> bigObj, File outfile, Matrix4d transform ) {

		outfile.mkdirs();

		ObjDump src = new ObjDump( bigObj );//.iterator().next() );
		
		src.centerVerts();
		src.transform (transform);
		
		long count = src.material2Face.entrySet().stream().mapToInt( x -> x.getValue().size() ).sum();
		double[] bounds = src.orderVert.stream().collect( new InaxPoint3dCollector() );
		long targetCount = 5000;

		double volume = ( bounds[ 1 ] - bounds[ 0 ] ) * ( bounds[ 3 ] - bounds[ 2 ] ) * ( bounds[ 5 ] - bounds[ 4 ] );

		double edgeLength = Math.pow( volume / ( count / targetCount ), 0.3333 );

		int 
				xc = (int) Math.ceil( ( bounds[ 1 ] - bounds[ 0 ] ) / edgeLength ), 
				yc = (int) Math.ceil( ( bounds[ 3 ] - bounds[ 2 ] ) / edgeLength ), 
				zc = (int) Math.ceil( ( bounds[ 5 ] - bounds[ 4 ] ) / edgeLength );

		Set<Face>[][][] faces = new Set[xc][yc][zc];

		for ( Entry<Material, List<Face>> e : src.material2Face.entrySet() )
			for ( Face f : e.getValue() ) {

				Tuple3d vt = src.orderVert.get( f.vtIndexes.get( 0 ) );

				int ix = (int) ( ( vt.x - bounds[ 0 ] ) / edgeLength );
				int iy = (int) ( ( vt.y - bounds[ 2 ] ) / edgeLength );
				int iz = (int) ( ( vt.z - bounds[ 4 ] ) / edgeLength );

				if ( faces[ ix ][ iy ][ iz ] == null )
					faces[ ix ][ iy ][ iz ] = new HashSet();

				faces[ ix ][ iy ][ iz ].add( f );
			}

		int dir = 0;
		MiniTransform mt = new MiniTransform();

		for ( int x = 0; x < xc; x++ )
			for ( int y = 0; y < yc; y++ )
				for ( int z = 0; z < zc; z++ ) {

					Set<Face> miniF = faces[ x ][ y ][ z ];
					if ( miniF == null )
						continue;

					Matrix4d trans = new Matrix4d();
					trans.setIdentity();
					trans.setScale( edgeLength / 255 );
					trans.setTranslation( new Vector3d(
							x * edgeLength + bounds[0],
							y * edgeLength + bounds[2],
							z * edgeLength + bounds[4]
							) );
					
					Matrix4d pack = new Matrix4d( trans );
					pack.invert();
					
					ObjDump mini = new ObjDump();
					miniF.stream().forEach( f -> mini.addFaceFrom( f, src ) );
					mini.transform( pack );
					
					mini.dump( new File( new File( outfile, "" + dir ), OBJ ) );
					mt.index.put( dir, trans );

					dir++;
				}

		try {
			new XStream().toXML( mt, new FileWriter( new File( outfile, INDEX ) ) );
		} catch ( IOException e1 ) {
			e1.printStackTrace();
		}

		System.out.println( "wrote " + count + " faces to " + dir + " meshes" );

	}
 
开发者ID:twak,项目名称:chordatlas,代码行数:82,代码来源:MiniTransform.java

示例14: testOrientation

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
/**
 * Test {@link UnitQuaternions#orientation(javax.vecmath.Point3d[])}.
 * <p>
 * Tests the identity orientation, orientation around one coordinate axis
 * and orientation around a non-coordinate axis.
 * 
 * @throws StructureException
 * @throws IOException
 */
@Test
public void testOrientation() throws IOException, StructureException {

	// Get points from a structure. It is difficult to generate points
	// with no bias in their distribution (too uniform, ie).
	Structure pdb = StructureIO.getStructure("4hhb.A");
	Point3d[] cloud = Calc.atomsToPoints(StructureTools
			.getRepresentativeAtomArray(pdb));

	// Center the cloud at the origin
	CalcPoint.center(cloud);

	// Orient its principal axes to the coordinate axis
	Quat4d orientation = UnitQuaternions.orientation(cloud);
	Matrix4d transform = new Matrix4d();
	transform.set(orientation);
	transform.invert();
	CalcPoint.transform(transform, cloud);

	// The orientation found now should be 0 (it has been re-oriented)
	orientation = UnitQuaternions.orientation(cloud);
	AxisAngle4d axis = new AxisAngle4d();
	axis.set(orientation);

	// No significant rotation
	assertEquals(orientation.x, 0.0, 0.01);
	assertEquals(orientation.y, 0.0, 0.01);
	assertEquals(orientation.z, 0.0, 0.01);
	assertEquals(axis.angle, 0.0, 0.01);

	// Now try to recover an orientation
	Quat4d quat = new Quat4d(0.418, 0.606, 0.303, 0.606);

	Matrix4d mat = new Matrix4d();
	mat.set(quat);

	CalcPoint.transform(mat, cloud);

	orientation = UnitQuaternions.orientation(cloud);

	// Test recovering the quaternion (q and -q same rotation)
	assertEquals(Math.abs(orientation.x), quat.x, 0.01);
	assertEquals(Math.abs(orientation.y), quat.y, 0.01);
	assertEquals(Math.abs(orientation.z), quat.z, 0.01);
	assertEquals(Math.abs(orientation.w), quat.w, 0.01);
}
 
开发者ID:biojava,项目名称:biojava,代码行数:56,代码来源:TestUnitQuaternions.java

示例15: getCameraToWorldTransform

import javax.vecmath.Matrix4d; //导入方法依赖的package包/类
/**
 * Give the matrix used to tranform a Camera Coordinate to a World
 * Coordinate.
 * 
 * @return The matrix for the transformation.
 */
public Matrix4d getCameraToWorldTransform() {
	Matrix4d temp = (Matrix4d) matrix.clone();
	temp.invert();
	return temp;
}
 
开发者ID:guiguito,项目名称:SiJaRayCluster,代码行数:12,代码来源:Camera.java


注:本文中的javax.vecmath.Matrix4d.invert方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。