⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 transform.cpp

📁 ROBOCUP 仿真3D server 源码
💻 CPP
字号:
/* -*- mode: c++; c-basic-offset: 4; indent-tabs-mode: nil -*-   this file is part of rcssserver3D   Fri May 9 2003   Copyright (C) 2002,2003 Koblenz University   Copyright (C) 2003 RoboCup Soccer Server 3D Maintenance Group   $Id: transform.cpp,v 1.9 2004/04/30 09:34:44 rollmark Exp $   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; version 2 of the License.   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., 675 Mass Ave, Cambridge, MA 02139, USA.*/#include "transform.h"#include "sceneserver.h"using namespace boost;using namespace oxygen;using namespace salt;using namespace zeitgeist;Transform::Transform() :    BaseNode(){    mChangedMark = -1;    mLocalTransform.Identity();    mOldLocalTransform.Identity();    mWorldTransform.Identity();    SetName("transform");}Transform::~Transform(){}int Transform::GetChangedMark() const{    return mChangedMark;}const salt::Matrix& Transform::GetLocalTransform() const{    return mLocalTransform;}const salt::Matrix& Transform::GetOldLocalTransform() const{    return mOldLocalTransform;}const salt::Matrix& Transform::GetWorldTransform() const{    return mWorldTransform;}void Transform::SetLocalTransform(const salt::Matrix &transform){    mChangedMark = SceneServer::GetTransformMark();    mOldLocalTransform = mLocalTransform;    mLocalTransform = transform;}void Transform::SetWorldTransform(const salt::Matrix &transform){    shared_ptr<BaseNode> parent = shared_static_cast<BaseNode>        (make_shared(mParent));    if (parent.get() == 0)        {            return;        }    mChangedMark = SceneServer::GetTransformMark();    mOldLocalTransform = mLocalTransform;    mLocalTransform = transform;    parent->SetWorldTransform(mIdentityMatrix);}void Transform::SetLocalPos(const salt::Vector3f &pos){    mChangedMark = SceneServer::GetTransformMark();    mOldLocalTransform = mLocalTransform;    mLocalTransform.Pos() = pos;    UpdateHierarchyInternal();}void Transform::SetLocalRotation(const salt::Vector3f &rot){    mChangedMark = SceneServer::GetTransformMark();    mOldLocalTransform = mLocalTransform;    Vector3f pos = mLocalTransform.Pos();    mLocalTransform.RotationX(gDegToRad(rot[0]));    mLocalTransform.RotateY(gDegToRad(rot[1]));    mLocalTransform.RotateZ(gDegToRad(rot[2]));    mLocalTransform.Pos() = pos;    UpdateHierarchyInternal();}void Transform::OnLink(){    UpdateHierarchyInternal();}void Transform::UpdateHierarchyInternal(){    shared_ptr<BaseNode> parent = shared_static_cast<BaseNode>(make_shared(mParent));    // no parent, return local transform    if (parent.get() == NULL)        {            mWorldTransform = mLocalTransform;        } else            {                mWorldTransform = parent->GetWorldTransform() * mLocalTransform;            }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -