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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ogremayaskeleton.cpp

?? 赫赫大名的 OGRE 游戲引擎
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*
============================================================================
This source file is part of the Ogre-Maya Tools.
Distributed as part of Ogre (Object-oriented Graphics Rendering Engine).
Copyright (C) 2003 Fifty1 Software Inc., Bytelords

This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
or go to http://www.gnu.org/licenses/gpl.txt
============================================================================
*/
#include "OgreMayaSkeleton.h"
#include "OgreMayaOptions.h"

#include <maya/MString.h>
#include <maya/MArgList.h>
#include <maya/MAnimControl.h>

#include <maya/MFnMesh.h>
#include <maya/MFnIkJoint.h>
#include <maya/MFnDagNode.h>
#include <maya/MFnSkinCluster.h>
#include <maya/MFnMatrixData.h>
#include <maya/MFnSet.h>
#include <maya/MFnLambertShader.h>
#include <maya/MFnBlinnShader.h>
#include <maya/MFnPhongShader.h>

#include <maya/MItGeometry.h>
#include <maya/MItDag.h>
#include <maya/MItDependencyGraph.h>
#include <maya/MItDependencyNodes.h>
#include <maya/MItMeshVertex.h>
#include <maya/MItMeshPolygon.h>

#include <maya/MPlug.h>
#include <maya/MDagPathArray.h>
#include <maya/MFloatPointArray.h>
#include <maya/MFloatVectorArray.h>
#include <maya/MFloatArray.h>
#include <maya/MPointArray.h>
#include <maya/MMatrix.h>
#include <maya/MGlobal.h>
#include <maya/MStatus.h>

#include <iostream>

namespace OgreMaya {
	
	using namespace std;

    void printMMatrix(MMatrix const& m) {
        cout.setf(ios::showpos | ios::fixed);
        cout.precision(5);
        cout << "("<<m(0,0)<<", "<<m(0,1)<<", "<<m(0,2)<<", "<<m(0,3)<<")" << '\n';
        cout << "("<<m(1,0)<<", "<<m(1,1)<<", "<<m(1,2)<<", "<<m(1,3)<<")" << '\n';
        cout << "("<<m(2,0)<<", "<<m(2,1)<<", "<<m(2,2)<<", "<<m(2,3)<<")" << '\n';
        cout << "("<<m(3,0)<<", "<<m(3,1)<<", "<<m(3,2)<<", "<<m(3,3)<<")" << '\n';
    }

    void printMQuaternion(MQuaternion const& q) {
        cout.setf(ios::showpos | ios::fixed);
        cout.precision(5);
        cout << "("<<q[0]<<", "<<q[1]<<", "<<q[2]<<", "<<q[3]<<")" << '\n';
    }

    void printMVector(MVector const& v) {
        cout.setf(ios::showpos | ios::fixed);
        cout.precision(5);
        cout << "("<<v[0]<<", "<<v[1]<<", "<<v[2]<<")" << '\n';
    }

	//	--------------------------------------------------------------------------
	/** Standard constructor. Creates Ogre Mesh and defines known options.
	*/	
	//	--------------------------------------------------------------------------
	SkeletonGenerator::SkeletonGenerator() {
	}


	//	--------------------------------------------------------------------------
	/** Destructor.
	*/	
	//	--------------------------------------------------------------------------
	SkeletonGenerator::~SkeletonGenerator()
	{
	}


	//	--------------------------------------------------------------------------
	/** Find and export all joints

		\return		True if exported ok, false otherwise
	*/	
	//	--------------------------------------------------------------------------
	bool SkeletonGenerator::exportAll()	{        

        if(!_querySkeleton())
            return false;

        if(!_querySkeletonAnim())
            return false;

        
        MGlobal::executeCommand("ikSystem -e -sol 0;");
        MGlobal::selectByName(root->name.c_str());
        MGlobal::executeCommand("dagPose -r -g -bp");
        MGlobal::executeCommand("dagPose -r -g -bp");
		//MGlobal::executeCommand("currentTime -edit 0");
        
        
/*        
        MGlobal::executeCommand("ikSystem -e -sol 0;");
	    MGlobal::executeCommand((string("select ")+root->name).c_str());
	    MGlobal::executeCommand("dagPose -r -g -bp");
*/
        
        /////////////////////////////////////////////

        
        {
            ofstream out(OPTIONS.outSkelFile.c_str());

            out.precision(5);
            out.setf(ios::fixed);

            out << "<skeleton>\n";

            
            //
            // BONES
            //
            out << "\t<bones>\n";


            SkeletonJointList::iterator it, end;
            MVector axis;
            double angle;

            for(it=jointList.begin(), end=jointList.end(); it!=end; ++it) {
                
                SkeletonJoint& j = **it;
                                
                /*
                cout << "* worldMatrix:\n";
                printMMatrix(j.worldMatrix);
                cout << "* relPos:\n";
                printMVector(j.relPos);
                cout << "* relRot:\n";
                printMQuaternion(j.relRot);
                cout << "----------------------------\n";
                */

                j.relRot.getAxisAngle(axis, angle);

                out << "\t\t<bone id=\""<<j.index<<"\" name=\""<<j.name<<"\">\n";
                out << "\t\t\t<position x=\""<<j.relPos.x<<"\" y=\""<<j.relPos.y<<"\" z=\""<<j.relPos.z<<"\"/>\n";
                out << "\t\t\t<rotation angle=\""<<((float)angle)<<"\">\n";
                out << "\t\t\t\t<axis x=\""<<axis.x<<"\" y=\""<<axis.y<<"\" z=\""<<axis.z<<"\"/>\n";
                out << "\t\t\t</rotation>\n";
                out << "\t\t</bone>\n";

            }

            out << "\t</bones>\n";

            
            //
            // HIERARCHY
            //
            out << "\t<bonehierarchy>\n";
            for(it=jointList.begin(), end=jointList.end(); it!=end; ++it) {
                SkeletonJoint& j = **it;
                if(j.hasParent) {
                    out << "\t\t<boneparent bone=\""<<j.name<<"\" parent=\""<<j.parentName<<"\"/>\n";
                }
            }

            out << "\t</bonehierarchy>\n";
            

            //
            // ANIMATIONS
            //
            out << "\t<animations>\n";
            AnimationMap::iterator animIt = animations.begin();
            AnimationMap::iterator animEnd = animations.end();
            for(; animIt!=animEnd; ++animIt) {
                string animName = (*animIt).first;
                Animation& anim = (*animIt).second;

                out << "\t\t<animation name=\""<<animName.c_str()<<"\" ";
                out << "length=\""<<anim.time<<"\">\n";
                out << "\t\t\t<tracks>\n";

                KeyframesMap::iterator keyframesIt = anim.keyframes.begin();
                KeyframesMap::iterator keyframesEnd = anim.keyframes.end();
                for(; keyframesIt!=keyframesEnd; ++keyframesIt) {
                    string boneName = (*keyframesIt).first;
                    KeyframeList& l = (*keyframesIt).second;

                    out << "\t\t\t\t<track bone=\""<<boneName.c_str()<<"\">\n";
                    out << "\t\t\t\t\t<keyframes>\n";

                    KeyframeList::iterator it  = l.begin();
                    KeyframeList::iterator end = l.end();
                    for(;it!=end; ++it) {
                        Keyframe& k = *it;

                        MVector axis;
                        double angle;
                        k.rot.getAxisAngle(axis, angle);

                        out << "\t\t\t\t\t\t<keyframe time=\""<<k.time<<"\">\n";                        
                        out << "\t\t\t\t\t\t\t<translate x=\""<<k.pos.x<<"\" y=\""<<k.pos.y<<"\" z=\""<<k.pos.z<<"\"/>\n";
                        out << "\t\t\t\t\t\t\t<rotate angle=\""<<((float)angle)<<"\">\n";
                        out << "\t\t\t\t\t\t\t\t<axis x=\""<<axis.x<<"\" y=\""<<axis.y<<"\" z=\""<<axis.z<<"\"/>\n";
                        out << "\t\t\t\t\t\t\t</rotate>\n";
                        out << "\t\t\t\t\t\t</keyframe>\n";
                    }

                    out << "\t\t\t\t\t</keyframes>\n";
                    out << "\t\t\t\t</track>\n";
                }                    

                out << "\t\t\t</tracks>\n";
                out << "\t\t</animation>\n";
            }
            out << "\t</animations>\n";


            out << "</skeleton>\n";
        }


        deleteAll(jointList.begin(), jointList.end());

        return true;
    }
        
    //	--------------------------------------------------------------------------
	/** Finds and exports all joints

		\return		True if exported ok, false otherwise
	*/	

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜久久久影院| 一区二区三区在线视频观看58| 欧美综合亚洲图片综合区| 欧美美女黄视频| 亚洲女厕所小便bbb| 亚洲国产精品久久人人爱蜜臀| 国产精品99精品久久免费| 欧美精品丝袜中出| 一区二区三区中文字幕精品精品| 久久99国内精品| 7777女厕盗摄久久久| 综合精品久久久| 国产精品一区2区| 精品国产91乱码一区二区三区 | 一本色道久久加勒比精品 | 亚洲国产视频在线| voyeur盗摄精品| 久久久99免费| 韩国三级中文字幕hd久久精品| 911国产精品| 亚洲r级在线视频| 欧美日韩在线精品一区二区三区激情| 久久免费看少妇高潮| 美女在线一区二区| 91精品国产黑色紧身裤美女| 亚洲三级电影全部在线观看高清| 国产精品1区2区| 26uuu欧美| 国产美女在线观看一区| 精品美女在线观看| 亚洲国产精品人人做人人爽| 一本大道久久精品懂色aⅴ | 国产精品资源在线观看| 欧美一区二区三区男人的天堂| 午夜成人在线视频| 欧美日韩午夜在线| 日本成人中文字幕在线视频 | 久久久精品日韩欧美| 另类的小说在线视频另类成人小视频在线| 欧美综合色免费| 日本大胆欧美人术艺术动态| 欧美一区二区精品久久911| 久久精品99国产精品| 久久久亚洲精品一区二区三区 | 久久精品二区亚洲w码| 日韩视频在线你懂得| 韩国v欧美v日本v亚洲v| 国产无一区二区| 91免费观看视频在线| 亚洲网友自拍偷拍| 精品粉嫩超白一线天av| 成人综合激情网| 亚洲精品少妇30p| 欧美一区二区在线视频| 国产美女精品在线| 一区二区三区国产豹纹内裤在线| 欧美丰满少妇xxxbbb| 国产美女娇喘av呻吟久久| 中文字幕欧美激情一区| 欧美亚洲动漫另类| 国产综合久久久久影院| 亚洲三级免费电影| 精品日韩99亚洲| 一本大道综合伊人精品热热 | 欧美精品高清视频| 国产一区亚洲一区| 亚洲综合999| 国产欧美日韩不卡| 欧美日本高清视频在线观看| 国产在线精品视频| 亚洲一区二区三区四区在线 | 粉嫩绯色av一区二区在线观看| 亚洲欧洲制服丝袜| 日韩欧美国产一区在线观看| 99在线精品免费| 久久激情五月婷婷| 亚洲女厕所小便bbb| www成人在线观看| 欧洲av一区二区嗯嗯嗯啊| 国产精品亚洲综合一区在线观看| 亚洲综合色噜噜狠狠| 国产清纯美女被跳蛋高潮一区二区久久w| 色呦呦国产精品| 成人一区二区三区| 麻豆成人综合网| 亚洲成人动漫在线免费观看| 中文字幕不卡一区| 日韩一区二区三区在线观看| av亚洲产国偷v产偷v自拍| 久久99精品国产麻豆不卡| 亚洲成人av电影| 亚洲黄色小视频| 中文字幕一区二区三区不卡 | 亚洲一级在线观看| 亚洲视频在线观看三级| 国产亚洲人成网站| 精品成人私密视频| 在线播放欧美女士性生活| 色婷婷综合久久久| yourporn久久国产精品| 国产成人在线色| 国产激情视频一区二区三区欧美| 欧美a级理论片| 日韩高清中文字幕一区| 亚洲一区二区三区四区五区中文 | 久久精品免费在线观看| 日韩久久免费av| 91精品国产综合久久精品图片| 在线观看日韩毛片| 在线中文字幕一区二区| 一本高清dvd不卡在线观看| bt欧美亚洲午夜电影天堂| 成人一区二区三区视频在线观看| 国产福利一区二区三区视频| 国产a精品视频| 成av人片一区二区| 99久久99久久综合| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 国产一区二区看久久| 久久精品国产在热久久| 麻豆精品视频在线观看免费| 久久精品国产亚洲高清剧情介绍| 久久不见久久见免费视频7| 另类小说欧美激情| 国产91综合网| 9人人澡人人爽人人精品| 色综合久久综合中文综合网| 在线观看日韩电影| 欧美一区二区三区公司| 久久久久免费观看| 成人欧美一区二区三区1314| 一区二区三区四区不卡在线| 午夜国产精品一区| 国产在线精品视频| 99re这里都是精品| 欧美丰满少妇xxxxx高潮对白| 精品剧情在线观看| 中文字幕国产一区| 亚洲成人你懂的| 国产精品自拍av| 欧美性高清videossexo| 欧美一级理论性理论a| 久久精品亚洲乱码伦伦中文| 亚洲欧洲www| 美女免费视频一区二区| 成人一道本在线| 欧美日韩国产成人在线91| 亚洲精品一区在线观看| 亚洲欧美日韩中文字幕一区二区三区| 一区二区国产盗摄色噜噜| 久久精品国产99| 91福利视频久久久久| 日韩三级视频中文字幕| 国产精品家庭影院| 热久久国产精品| 91美女片黄在线| 精品久久国产字幕高潮| 亚洲激情中文1区| 国产一区二区中文字幕| 在线亚洲免费视频| 久久网站热最新地址| 亚洲精品国产无天堂网2021| 国产一区啦啦啦在线观看| 色婷婷精品久久二区二区蜜臀av| 精品久久一区二区三区| 夜夜操天天操亚洲| 丁香亚洲综合激情啪啪综合| 这里只有精品免费| 亚洲裸体在线观看| 国产精品66部| 日韩一级大片在线| 亚洲国产精品一区二区尤物区| 国产成人免费高清| 精品国产污网站| 天堂一区二区在线免费观看| 91麻豆福利精品推荐| 国产亚洲精久久久久久| 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲成人1区2区| 91女厕偷拍女厕偷拍高清| 久久久久高清精品| 九色|91porny| 日韩午夜av电影| 午夜精品免费在线| 在线观看亚洲精品视频| 中文字幕佐山爱一区二区免费| 国产精品一区三区| 精品久久一区二区| 精品无码三级在线观看视频| 欧美一区二区三区视频免费| 亚洲成人免费在线| 欧美视频在线观看一区| 亚洲福利国产精品| 欧美三级蜜桃2在线观看| 亚洲黄色片在线观看| 色欧美日韩亚洲| 亚洲自拍都市欧美小说| 精品视频在线免费看| 性做久久久久久久免费看| 欧美日韩国产首页|