ODEBoxShape.hh
00001 /* 00002 * Copyright 2011 Nate Koenig & Andrew Howard 00003 * 00004 * Licensed under the Apache License, Version 2.0 (the "License"); 00005 * you may not use this file except in compliance with the License. 00006 * You may obtain a copy of the License at 00007 * 00008 * http://www.apache.org/licenses/LICENSE-2.0 00009 * 00010 * Unless required by applicable law or agreed to in writing, software 00011 * distributed under the License is distributed on an "AS IS" BASIS, 00012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 00013 * See the License for the specific language governing permissions and 00014 * limitations under the License. 00015 * 00016 */ 00017 #ifndef ODEBOXSHAPE_HH 00018 #define ODEBOXSHAPE_HH 00019 00020 #include "math/Vector3.hh" 00021 00022 #include "physics/ode/ODEPhysics.hh" 00023 #include "physics/ode/ODETypes.hh" 00024 #include "physics/ode/ODECollision.hh" 00025 00026 #include "physics/PhysicsTypes.hh" 00027 #include "physics/BoxShape.hh" 00028 00029 namespace gazebo 00030 { 00031 namespace physics 00032 { 00035 00038 00040 class ODEBoxShape : public BoxShape 00041 { 00042 public: ODEBoxShape(ODECollisionPtr parent) : BoxShape(parent) {} 00043 public: virtual ~ODEBoxShape() {} 00044 public: virtual void SetSize(const math::Vector3 &size) 00045 { 00046 BoxShape::SetSize(size); 00047 00048 ODECollisionPtr oParent; 00049 oParent = boost::shared_dynamic_cast<ODECollision>( 00050 this->collisionParent); 00051 00052 if (oParent->GetCollisionId() == NULL) 00053 oParent->SetCollision(dCreateBox(0, size.x, size.y, size.z), true); 00054 else 00055 dGeomBoxSetLengths(oParent->GetCollisionId(), size.x, size.y, size.z); 00056 } 00057 }; 00060 } 00061 } 00062 #endif

1.7.5.1