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

1.7.5.1