ODECylinderShape.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 ODECYLINDERSHAPE_HH
00018 #define ODECYLINDERSHAPE_HH
00019 
00020 #include "physics/CylinderShape.hh"
00021 #include "physics/ode/ODEPhysics.hh"
00022 
00023 namespace gazebo
00024 {
00025     namespace physics
00026   {
00029     
00032 
00034     class ODECylinderShape : public CylinderShape
00035     {
00036       public: ODECylinderShape(CollisionPtr parent) : CylinderShape(parent) {}
00037       public: virtual ~ODECylinderShape() {}
00038       public: void SetSize(const double &radius, const double &length)
00039       {
00040         CylinderShape::SetSize(radius, length);
00041         ODECollisionPtr oParent;
00042         oParent =
00043           boost::shared_dynamic_cast<ODECollision>(this->collisionParent);
00044   
00045         if (oParent->GetCollisionId() == NULL)
00046           oParent->SetCollision(dCreateCylinder( 0, radius, length ), true );
00047         else
00048           dGeomCylinderSetParams(oParent->GetCollisionId(), radius, length);
00049       }
00050     };
00051 
00054   }
00055 }
00056 #endif