[go: up one dir, main page]

Menu

[2d94f2]: / geometry / Material.hpp  Maximize  Restore  History

Download this file

71 lines (61 with data), 2.5 kB

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
// Copyright (C) 2001-2019 Sam Varner
//
// This file is part of Vamos Automotive Simulator.
//
// Vamos is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Vamos is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Vamos. If not, see <http://www.gnu.org/licenses/>.
#ifndef _MATERIAL_H_
#define _MATERIAL_H_
#include "Three_Vector.hpp"
#include "Two_Vector.hpp"
#include <string>
namespace Vamos_Geometry
{
class Material
{
public:
enum Material_Type
{ RUBBER, METAL, ASPHALT, CONCRETE, KERB, GRASS, GRAVEL, DIRT, AIR, UNKNOWN };
Material(Material_Type type, double friction, double restitution, double rolling, double drag,
const Two_Vector &bump_amplitude, double bump_wavelength,
std::string texture_file_name, bool smooth, bool mip_map, double width, double height);
Material(Material_Type = UNKNOWN, double friction = 1.0, double restitution = 1.0);
std::string texture_file_name() const { return m_texture_file_name; }
double friction_factor() const { return m_friction_factor; }
double rolling_resistance_factor() const { return m_rolling_resistance_factor; }
double drag_factor() const { return m_drag_factor; }
double restitution_factor() const { return m_restitution_factor; }
Three_Vector bump(double x, double y) const;
Material_Type type() const { return m_type; }
bool smooth() const { return m_smooth; }
bool mip_map() const { return m_mip_map; }
double width() const { return m_width; }
double height() const { return m_height; }
private:
Material_Type m_type;
// The frictional properties of the car are muliplied by these factors
// for this particular surface. They should all be 1.0 for pavement.
double m_friction_factor;
double m_restitution_factor;
double m_rolling_resistance_factor;
double m_drag_factor;
Two_Vector m_bump_amplitude;
double m_bump_wavelength;
std::string m_texture_file_name;
bool m_smooth;
bool m_mip_map;
double m_width;
double m_height;
};
} // namespace Vamos_Geometry
#endif