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


C++ Noise::turbulenceVector方法代码示例

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


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

示例1: result

MStatus mVec3dTurbulence::doIt( const MArgList& args )
{
	if (args.length() == 2)
	{
    	// vector array
		// get the arguments
	    MDoubleArray dblA, dblB;
    	unsigned int incA, incB, count;
		MStatus stat = getArgVecDbl(args, dblA, dblB, incA, incB, count);
		ERROR_FAIL(stat);
	
		// do the actual job
		unsigned int iterA, iterB;
		iterA = iterB = 0;

		MDoubleArray result(count*ELEMENTS_VEC);
		Noise noiseGen;
        float v[3];

        for(int i=0;i<count;i++)
        {
            int id = ELEMENTS_VEC *iterA;           
	    	noiseGen.turbulenceVector(float(dblA[id]), float(dblA[id+1]),float(dblA[id+2]),int(dblB[iterB]),false,NOISE_IMPROVED_PERLIN,v);
 
 			int rid = ELEMENTS_VEC * i;
            result[rid] = v[0];
			result[rid+1] = v[1];
			result[rid+2] = v[2]; 

            iterA += incA;
            iterB += incB;            
                       
        }
            
        setResult(result);
        
	}
	else if (args.length() == 4)
	{
		// get the arguments
	    MDoubleArray dblA, dblB, dblC,dblD;
    	unsigned int incA, incB, incC, incD, count;
		MStatus stat = getArgDblDblDblDbl(args, dblA, dblB, dblC,dblD, incA, incB, incC, incD,count);
		ERROR_FAIL(stat);
	
		// do the actual job
		unsigned int iterA, iterB, iterC,iterD;
		iterA = iterB = iterC =iterD = 0;

		MDoubleArray result(count*ELEMENTS_VEC);
		Noise noiseGen;
        float v[3];
        
		for (unsigned int i=0;i<count;i++)
		{
        	noiseGen.turbulenceVector(float(dblA[iterA]), float(dblB[iterB]),  float(dblC[iterC]), int(dblD[iterD]),false,NOISE_IMPROVED_PERLIN,v);

            int id = ELEMENTS_VEC *i;           
            
            result[id] = v[0];
			result[id+1] = v[1];
			result[id+2] = v[2]; 

			iterA += incA;
			iterB += incB;
			iterC += incC;            
			iterD += incD;                        
		}
		
        setResult(result);
	}
	else
	{
		USER_ERROR_CHECK(MS::kFailure,("mVec3dTurbulence: wrong number of arguments, should be 1 vecArray + 1 dblArray or 4 dblArrays!"));
	}
    
	return MS::kSuccess;

}
开发者ID:jonntd,项目名称:melfunctions,代码行数:79,代码来源:mNoiseCmd.cpp


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