Class
List
Hierarchy
Modules
Common
Events
Math
Messages
Physics
Rendering
Sensors
Transport
Links
Gazebo Website
Wiki
Tutorials
Download
Report Documentation Issues
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Groups
Pages
gazebo
physics
Contact.hh
Go to the documentation of this file.
1
/*
2
* Copyright (C) 2012-2014 Open Source Robotics Foundation
3
*
4
* Licensed under the Apache License, Version 2.0 (the "License");
5
* you may not use this file except in compliance with the License.
6
* You may obtain a copy of the License at
7
*
8
* http://www.apache.org/licenses/LICENSE-2.0
9
*
10
* Unless required by applicable law or agreed to in writing, software
11
* distributed under the License is distributed on an "AS IS" BASIS,
12
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
* See the License for the specific language governing permissions and
14
* limitations under the License.
15
*
16
*/
17
/* Desc: Specification of a contact
18
* Author: Nate Koenig
19
* Date: 10 Nov 2009
20
*/
21
22
#ifndef _CONTACT_HH_
23
#define _CONTACT_HH_
24
25
#include <vector>
26
#include <string>
27
28
#include "
gazebo/msgs/msgs.hh
"
29
30
#include "
gazebo/physics/PhysicsTypes.hh
"
31
#include "
gazebo/common/Time.hh
"
32
#include "
gazebo/math/Vector3.hh
"
33
#include "
gazebo/physics/JointWrench.hh
"
34
#include "
gazebo/util/system.hh
"
35
36
// For the sake of efficiency, use fixed size arrays for collision
37
// MAX_COLLIDE_RETURNS limits contact detection, needs to be large
38
// for proper contact dynamics.
39
// MAX_CONTACT_JOINTS truncates <max_contacts> specified in SDF
40
#define MAX_COLLIDE_RETURNS 250
41
#define MAX_CONTACT_JOINTS 32
42
43
namespace
gazebo
44
{
45
namespace
physics
46
{
47
class
Collision;
50
54
class
GAZEBO_VISIBLE
Contact
55
{
57
public
:
Contact
();
58
61
public
:
Contact
(
const
Contact
&_contact);
62
64
public
:
virtual
~
Contact
();
65
69
public
:
Contact
&operator =(
const
Contact
&_contact);
70
74
public
:
Contact
&operator =(
const
msgs::Contact &_contact);
75
78
public
:
void
FillMsg(msgs::Contact &_msg)
const
;
79
82
public
: std::string DebugString()
const
;
83
85
public
:
void
Reset();
86
88
public
:
Collision
*
collision1
;
89
91
public
:
Collision
*
collision2
;
92
96
public
:
JointWrench
wrench[
MAX_CONTACT_JOINTS
];
97
99
public
:
math::Vector3
positions[
MAX_CONTACT_JOINTS
];
100
102
public
:
math::Vector3
normals[
MAX_CONTACT_JOINTS
];
103
105
public
:
double
depths[
MAX_CONTACT_JOINTS
];
106
108
public
:
int
count
;
109
111
public
:
common::Time
time
;
112
114
public
:
WorldPtr
world
;
115
};
117
}
118
}
119
#endif