亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? max2nmocs301.cpp

?? 3dmax導出3d模型二次開發(fā)插件
?? CPP
字號:
//************************************************************************** 
//* Max2NmoCS312.cpp	- Virtools File Exporter
//*
//* Romain Sididris - Copyright (c) Virtools 2001
//*
//* - This file contains some the same code than MAx2Nmo312.cpp
//* but use the 3.00 version of character studio header files
//*
//* In the case of Max 4.2 (Character Studio 3.2) , Only this file is used...
//***************************************************************************
#include "Precomp.h"
#include "Max2Nmo.h"

#ifdef MAX42
	#include "PhyExp.h"
#else
	#include "PhyExpCS300.h"
#endif


int AddBoneToArray(XVoidArray* bones,void* bone);

// Try to find if a skin modifier is in the modifier stack of a node
Modifier* Max2Nmo::FindSkinModifierCS300 (INode* node)
{
	// Get object from node. Abort if no object.
	Object* pObj = node->GetObjectRef();
	if (!pObj) return NULL;

	// Is derived object ?
	SClass_ID sid = pObj->SuperClassID();
	while (pObj->SuperClassID() == GEN_DERIVOB_CLASS_ID)
	{
		// Yes -> Cast.
		IDerivedObject* pDerObj = static_cast<IDerivedObject*>(pObj);

		// Iterate over all entries of the modifier stack.
		int ModStackIndex = 0;
		while (ModStackIndex < pDerObj->NumModifiers()) {
			// Get current modifier.
			Modifier* mod = pDerObj->GetModifier(ModStackIndex);
			// Is this Skin ?
			if (mod->ClassID() == SKIN_CLASSID ) {
				return mod;
			}
			// Next modifier stack entry.
			ModStackIndex++;
		}
		pObj = pDerObj->GetObjRef();
	}
	return NULL;
}



// Try to find if a physique modifier is in the modifier stack of a node
Modifier* Max2Nmo::FindPhysiqueModifierCS300 (INode* node)
{
	// Get object from node. Abort if no object.
	Object* pObj = node->GetObjectRef();
	if (!pObj) return NULL;

	// Is derived object ?
	SClass_ID sid = pObj->SuperClassID();
	while (pObj->SuperClassID() == GEN_DERIVOB_CLASS_ID) {
		// Yes -> Cast.
		IDerivedObject* pDerObj = static_cast<IDerivedObject*>(pObj);

		// Iterate over all entries of the modifier stack.
		int ModStackIndex = 0;
		while (ModStackIndex < pDerObj->NumModifiers())
		{
			// Get current modifier.
			Modifier* mod = pDerObj->GetModifier(ModStackIndex);

			// Is this Physique ?
			if (mod->ClassID() == Class_ID(PHYSIQUE_CLASS_ID_A, PHYSIQUE_CLASS_ID_B) )	{
				return mod;
			}
			// Next modifier stack entry.
			ModStackIndex++;
		}
		pObj = pDerObj->GetObjRef();
	}
	// Not found.
	return NULL;
}


/********************************************************************

********************************************************************/
BOOL Max2Nmo::ExportPhysiqueMeshCS300(INode* node,CK3dEntity* ent)
{
	Modifier *PhysiqueModifier = FindPhysiqueModifier(node);
	if (!PhysiqueModifier) return FALSE;
	
	IPhysiqueExport *phyInterface = (IPhysiqueExport *)( PhysiqueModifier->GetInterface(I_PHYINTERFACE) );
	if (!phyInterface) return FALSE;

	IPhyContextExport* context=phyInterface->GetContextInterface(node);
	if (!context) return FALSE;
	
	VirtoolsTransitionMesh* tmp_mesh= VirtoolsExporter->GetTransitionMesh(node);
	context->AllowBlending(TRUE);
	context->ConvertToRigid(TRUE);

	CKMesh* mesh=ent->GetCurrentMesh();
	if (!mesh) return FALSE;


	Report(REPORT_HLEVEL,"%s : Converting Physique modifier to Skinning\r\n",node->GetName());

	Matrix3 InitTM;
	VxMatrix Mat;
	CKSkin* skin		= ent->CreateSkin();
	int NbPhyVertices	= context->GetNumberVertices();
	int VertexCount		= mesh->GetModifierVertexCount();
	
	XVoidArray bones;

	CKDWORD Stride=0;
	BYTE* pts=mesh->GetModifierVertices(&Stride);
	CKDWORD NStride=0;
	BYTE* norms=(BYTE*)mesh->GetNormalsPtr(&NStride);
	

	BOOL DoNormal = (mesh->GetClassID() != CKCID_PATCHMESH);
	skin->SetVertexCount(VertexCount);
	if (DoNormal) {
		skin->SetNormalCount(VertexCount);
	}
	

	//----- Convert vertices info to skin data			
	for(int j = 0 ; j < VertexCount ; j++,pts+=Stride,norms+=NStride)  {
		int MaxVertexIndex = tmp_mesh ? tmp_mesh->m_VirtoolsVertices[j].OriginalPosIndex : j;

		IPhyVertexExport* vert=context->GetVertexInterface(MaxVertexIndex);

		CKSkinVertexData* vertexdata = skin->GetVertexData(j);
		if (vert)
		if (vert->GetVertexType()==RIGID_NON_BLENDED_TYPE) {
			IPhyRigidVertex* rvert=(IPhyRigidVertex*)vert;
		
			vertexdata->SetBoneCount(1);
			vertexdata->SetBone(0,AddBoneToArray(&bones,rvert->GetNode()));
			vertexdata->SetWeight(0,1.0f);
			vertexdata->SetInitialPos(*(VxVector *)pts);
			if (DoNormal) {
				skin->SetNormal(j,*(VxVector *)norms);
			}
		} else
		if (vert->GetVertexType()==RIGID_BLENDED_TYPE)	{
			// RIGID_BLENDED_TYPE
			IPhyBlendedRigidVertex* bvert=(IPhyBlendedRigidVertex*)vert;
			int nbbones = bvert->GetNumberNodes();

			vertexdata->SetBoneCount(nbbones);
			vertexdata->SetInitialPos(*(VxVector *)pts);
			if (DoNormal) {
				skin->SetNormal(j,*(VxVector *)norms);
			}

			float sum = 0;
			for (int k=0;k<nbbones;++k)	{
				sum += bvert->GetWeight(k);
			}
			sum = 1.0f/sum;

			for (k=0;k<nbbones;++k)	{
				vertexdata->SetBone(k,AddBoneToArray(&bones,bvert->GetNode(k)));
				vertexdata->SetWeight(k,sum * bvert->GetWeight(k));
			}
		} else {
			Report(REPORT_HLEVEL,"%s : Invalid skin vertex type (Not Rigid)\r\n",node->GetName());
		}
		context->ReleaseVertexInterface(vert);
	}

	//----- Create Bones
	int NbBones=bones.Size();
	skin->SetBoneCount(NbBones);
	for(j = 0 ; j < NbBones; j++) {
		INode* bone=(INode *)bones[j];
		CK3dEntity* ent = VirtoolsExporter->GetEntityByKey(bone);
		
		CKSkinBoneData* bonedata = skin->GetBoneData(j);

		bonedata->SetBone(ent);
		
		if (ent) {
			bonedata->SetBoneInitialInverseMatrix(ent->GetInverseWorldMatrix());
		}
	}
	
	InitTM=node->GetNodeTM(0);
	ConvertMaxMatrix2Virtools(InitTM, Mat);
	skin->SetObjectInitMatrix(Mat);
				
	phyInterface->ReleaseContextInterface(context);
	PhysiqueModifier->ReleaseInterface(I_PHYINTERFACE,phyInterface);
	return TRUE;
}	

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品一卡二卡| 精品国产亚洲一区二区三区在线观看| 欧美影院一区二区三区| 日韩欧美国产小视频| 中文字幕一区视频| 人人精品人人爱| 99这里都是精品| 国产亚洲精品中文字幕| 亚洲午夜影视影院在线观看| 国产成人午夜高潮毛片| 制服丝袜激情欧洲亚洲| 一区二区在线观看视频在线观看| 九色porny丨国产精品| 欧美三级三级三级| 亚洲视频免费看| 国产精品白丝jk黑袜喷水| 欧美日韩高清一区| 一区二区久久久久| 99久久综合国产精品| 久久人人爽爽爽人久久久| 久久精品国产99| 欧美一区二区三区性视频| 无吗不卡中文字幕| 欧美日韩国产首页在线观看| 亚洲乱码日产精品bd| 成人av电影免费观看| 国产精品毛片久久久久久久| 国产成人午夜视频| 国产精品卡一卡二卡三| 不卡一二三区首页| 国产精品美女久久久久高潮| www.性欧美| 国产精品久久久久久久久免费桃花 | 欧美极品xxx| 日韩和欧美一区二区三区| 91久久免费观看| 最近日韩中文字幕| 国产一区二区三区日韩| 欧美日韩国产不卡| 亚洲一区二区三区在线播放| 国产99精品在线观看| 精品成人私密视频| 精品亚洲aⅴ乱码一区二区三区| 欧美美女一区二区三区| 一区二区免费看| 91久久精品一区二区三| 亚洲精品视频在线观看免费| 成人一道本在线| 最新热久久免费视频| 国产成人精品www牛牛影视| 欧美色电影在线| 亚洲图片欧美一区| 欧美日韩亚洲综合一区 | 日本强好片久久久久久aaa| 欧美日韩精品高清| 亚洲成av人影院| 91精品国产综合久久久久久久 | 一区二区国产盗摄色噜噜| 99精品国产热久久91蜜凸| 欧美韩国日本一区| 成人精品视频一区二区三区| 国产精品久久久久久久久免费相片| 成人黄色大片在线观看| 亚洲丝袜美腿综合| 欧美日韩一区二区三区在线看 | av在线播放不卡| 亚洲老司机在线| 欧美欧美午夜aⅴ在线观看| 污片在线观看一区二区| 日韩一级免费观看| 九九久久精品视频| 国产日韩欧美一区二区三区综合| 国产电影精品久久禁18| 亚洲一区二区在线观看视频| 欧美精品日韩综合在线| 美女视频黄免费的久久| 国产清纯美女被跳蛋高潮一区二区久久w| 国产成人精品免费在线| 亚洲婷婷国产精品电影人久久| 日本高清不卡在线观看| 免费美女久久99| 国产精品久久久久久久久搜平片| 日本韩国欧美在线| 蜜芽一区二区三区| 中日韩免费视频中文字幕| 欧美亚洲综合另类| 奇米888四色在线精品| 亚洲免费观看视频| 欧美精品一区二区三| 91在线视频免费91| 精品在线免费视频| 一区二区三区中文字幕电影| 精品久久久久久久久久久久久久久| 成人av中文字幕| 奇米精品一区二区三区四区 | 国产精品久久久久永久免费观看 | 9191精品国产综合久久久久久| 午夜视频久久久久久| 国产清纯在线一区二区www| 欧美一区二区三区在线| 91丨九色丨蝌蚪丨老版| 紧缚奴在线一区二区三区| 亚洲欧美另类小说| 久久精品人人做人人爽97| 欧美高清www午色夜在线视频| 成人蜜臀av电影| 国产美女娇喘av呻吟久久| 亚洲成人av免费| 国产精品成人网| 国产精品亲子伦对白| 日韩一区二区电影在线| 欧美日韩一区二区在线观看| 99在线精品一区二区三区| 国产在线日韩欧美| 日本vs亚洲vs韩国一区三区| 亚洲一区二三区| 国产精品福利一区二区| 国产亚洲人成网站| 欧美亚洲精品一区| 国产成人精品午夜视频免费| 国精产品一区一区三区mba视频| 午夜在线成人av| 亚洲一区二区3| 一区二区三区丝袜| 亚洲三级视频在线观看| 国产精品夫妻自拍| 国产精品高潮呻吟久久| 日韩欧美国产1| 欧美电影在线免费观看| 91精品国产色综合久久不卡电影| 欧美亚洲一区二区在线观看| 91免费视频网址| 91黄视频在线观看| 色妞www精品视频| 日本精品裸体写真集在线观看| 99久久99久久精品国产片果冻| 懂色av中文字幕一区二区三区| 精品一区二区免费视频| 日本不卡一区二区三区| 美女国产一区二区三区| 久久99久久99| 大胆亚洲人体视频| av综合在线播放| 色国产综合视频| 精品视频一区三区九区| 欧美另类z0zxhd电影| 欧美一级黄色片| 久久婷婷色综合| 国产精品美女久久久久aⅴ| 国产精品高潮久久久久无| 亚洲精品v日韩精品| 天堂一区二区在线| 久久成人羞羞网站| 成人午夜在线视频| 91亚洲大成网污www| 欧美精品日韩一本| 国产精品免费网站在线观看| 国产精品动漫网站| 视频一区在线播放| 国产成人亚洲精品青草天美| 国产精品一区二区在线观看网站 | 国产成人在线观看免费网站| 91视频观看免费| 欧美精品国产精品| 久久精品人人做| 国产精品久久久久久久久图文区 | 色天天综合色天天久久| 欧美一区二区三区在线看| 国产蜜臀av在线一区二区三区| 亚洲男女毛片无遮挡| 欧美a级理论片| 国产一区视频网站| 91免费视频网址| 亚洲精品一区二区精华| 亚洲日本中文字幕区| 蜜臀av性久久久久av蜜臀妖精| 国产精品白丝jk黑袜喷水| 欧洲一区在线观看| 久久免费电影网| 亚洲成人激情综合网| 国产成a人亚洲精| 26uuu国产日韩综合| 亚洲一区二区3| 成人污污视频在线观看| 欧美日本一区二区三区四区| 久久久久久久久久久久久夜| 一区二区在线观看免费视频播放| 国产精品影视在线| 欧美精三区欧美精三区| 国产亚洲短视频| 国内精品嫩模私拍在线| 欧美日韩五月天| 亚洲欧美一区二区久久| 国产美女精品在线| 日韩免费观看高清完整版 | 国产福利91精品一区| 欧美丰满高潮xxxx喷水动漫| 亚洲欧美日韩国产成人精品影院| 国产一区二区91| 亚洲精品一区二区三区香蕉|