source: cpp/frams/neuro/impl/neuroimpl-body-sdk.h @ 946

Last change on this file since 946 was 922, checked in by sz, 5 years ago

bug fixed: missing 'power' in the dummy SolidMuscle? implementation

  • Property svn:eol-style set to native
File size: 2.9 KB
Line 
1// This file is a part of Framsticks SDK.  http://www.framsticks.com/
2// Copyright (C) 1999-2020  Maciej Komosinski and Szymon Ulatowski.
3// See LICENSE.txt for details.
4
5#ifndef _NEUROIMPLBODY_H_
6#define _NEUROIMPLBODY_H_
7
8#include <frams/neuro/neuroimpl.h>
9
10class NI_Gyro : public NeuroImpl
11{
12public:
13        NeuroImpl* makeNew() { return new NI_Gyro(); } // for NeuroFactory
14        int lateinit() { if (!neuro->joint) return 0; simorder = 0; return 1; }
15        void go() { setState(0); }
16};
17
18extern ParamEntry NI_Touch_tab[];
19class NI_Touch : public NeuroImpl
20{
21public:
22        double range;
23        NeuroImpl* makeNew() { return new NI_Touch(); } // for NeuroFactory
24        int lateinit() { if (!neuro->part) return 0; simorder = 0; return 1; }
25        void go() { setState(0); }
26        NI_Touch() :range(1) { paramentries = NI_Touch_tab; }
27};
28
29class NI_Smell : public NeuroImpl
30{
31public:
32        NeuroImpl* makeNew() { return new NI_Smell(); } // for NeuroFactory
33        void go() { setState(0); }
34        int lateinit() { if (!neuro->part) return 0; simorder = 0; return 1; }
35};
36
37extern ParamEntry NI_BendMuscle_tab[];
38class NI_BendMuscle : public NeuroImpl
39{
40public:
41        double power, bendrange;
42        NeuroImpl* makeNew() { return new NI_BendMuscle(); } // for NeuroFactory
43        NI_BendMuscle() { paramentries = NI_BendMuscle_tab; }
44        int lateinit() { if (!neuro->joint) return 0; simorder = 2; return 1; }
45        void go() {}
46};
47
48extern ParamEntry NI_RotMuscle_tab[];
49class NI_RotMuscle : public NeuroImpl
50{
51public:
52        double power;
53        NeuroImpl* makeNew() { return new NI_RotMuscle(); } // for NeuroFactory
54        NI_RotMuscle() { paramentries = NI_RotMuscle_tab; }
55        int lateinit() { if (!neuro->joint) return 0; simorder = 2; return 1; }
56        void go() {}
57};
58
59extern ParamEntry NI_SolidMuscle_tab[];
60class NI_SolidMuscle : public NeuroImpl
61{
62public:
63        paInt axis;
64        double power;
65        NeuroImpl* makeNew() { return new NI_SolidMuscle(); } // for NeuroFactory
66        NI_SolidMuscle() { paramentries = NI_SolidMuscle_tab; }
67        int lateinit() { if (!neuro->joint) return 0; simorder = 2; return 1; }
68        void go() {}
69};
70
71extern ParamEntry NI_LinearMuscle_tab[];
72class NI_LinearMuscle : public NeuroImpl
73{
74public:
75        double power;
76        NeuroImpl* makeNew() { return new NI_RotMuscle(); } // for NeuroFactory
77        NI_LinearMuscle() { paramentries = NI_RotMuscle_tab; }
78        int lateinit() { if (!neuro->joint) return 0; simorder = 2; return 1; }
79        void go() {}
80};
81
82class NI_Sticky : public NeuroImpl
83{
84public:
85        double power;
86        NeuroImpl* makeNew() { return new NI_Sticky(); } // for NeuroFactory
87        int lateinit() { if (!neuro->part) return 0; simorder = 0; return 1; }
88        void go() {}
89};
90
91class NI_WaterDetect : public NeuroImpl
92{
93public:
94        NeuroImpl* makeNew() { return new NI_WaterDetect(); } // for NeuroFactory
95        int lateinit() { if (!neuro->part) return 0; simorder = 0; return 1; }
96        void go() { setState(0); }
97};
98
99class NI_Energy : public NeuroImpl
100{
101public:
102        NeuroImpl* makeNew() { return new NI_Energy(); } // for NeuroFactory
103        void go() { setState(0); }
104};
105
106#endif
Note: See TracBrowser for help on using the repository browser.