Hinge2Joint.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 /* Desc: A hinge joint with 2 degrees of freedom
00018  * Author: Nate Keonig, Andrew Howard
00019  * Date: 21 May 2003
00020  */
00021 
00022 #ifndef HINGE2JOINT_HH
00023 #define HINGE2JOINT_HH
00024 
00025 #include "math/Angle.hh"
00026 #include "math/Vector3.hh"
00027 #include "physics/Joint.hh"
00028 
00029 namespace gazebo
00030 {
00031     namespace physics
00032   {
00035 
00036 
00038     template< class T>
00039     class Hinge2Joint : public T
00040     {
00042       public: Hinge2Joint() : T()
00043               { this->AddType(Base::HINGE2_JOINT); }
00044     
00046       public: virtual ~Hinge2Joint()
00047               { }
00048     
00050       protected: virtual void Load( sdf::ElementPtr &_sdf )
00051                  {
00052                    T::Load(_sdf);
00053 
00054                    this->SetAxis(0, 
00055                        _sdf->GetElement("axis")->GetValueVector3("xyz"));
00056 
00057                    this->SetAxis(1, 
00058                        _sdf->GetElement("axis2")->GetValueVector3("xyz"));
00059 
00060 
00061                    if (_sdf->GetElement("axis")->HasElement("limit"))
00062                    {
00063                      sdf::ElementPtr limitElem = _sdf->GetElement("axis")->GetElement("limit");
00064                      // Perform this three step ordering to ensure the parameters 
00065                      // are set properly. This is taken from the ODE wiki.
00066                      this->SetHighStop(0,limitElem->GetValueDouble("upper"));
00067                      this->SetLowStop( 0,limitElem->GetValueDouble("lower"));
00068                      this->SetHighStop(0,limitElem->GetValueDouble("upper"));
00069                    }
00070  
00071                    if (_sdf->GetElement("axis2")->HasElement("limit"))
00072                    {
00073                      sdf::ElementPtr limitElem = _sdf->GetElement("axis2")->GetElement("limit");
00074                      // Perform this three step ordering to ensure the parameters 
00075                      // are set properly. This is taken from the ODE wiki.
00076                      this->SetHighStop(1,limitElem->GetValueDouble("upper"));
00077                      this->SetLowStop( 1,limitElem->GetValueDouble("lower"));
00078                      this->SetHighStop(1,limitElem->GetValueDouble("upper"));
00079                    }
00080                  }
00081     
00082     };
00084   }
00085 }
00086 #endif
00087