Statistics
| Branch: | Tag: | Revision:

hlrc / client / python / hlrc_client / RobotEmotion.py @ b50b7f8b

History | View | Annotate | Download (1.706 KB)

1
"""
2
This file is part of hlrc
3

4
Copyright(c) sschulz <AT> techfak.uni-bielefeld.de
5
http://opensource.cit-ec.de/projects/hlrc
6

7
This file may be licensed under the terms of the
8
GNU General Public License Version 3 (the ``GPL''),
9
or (at your option) any later version.
10

11
Software distributed under the License is distributed
12
on an ``AS IS'' basis, WITHOUT WARRANTY OF ANY KIND, either
13
express or implied. See the GPL for the specific language
14
governing rights and limitations.
15

16
You should have received a copy of the GPL along with this
17
program. If not, go to http://www.gnu.org/licenses/gpl.html
18
or write to the Free Software Foundation, Inc.,
19
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
20

21
The development of this software was supported by the
22
Excellence Cluster EXC 277 Cognitive Interaction Technology.
23
The Excellence Cluster EXC 277 is a grant of the Deutsche
24
Forschungsgemeinschaft (DFG) in the context of the German
25
Excellence Initiative.
26
"""
27

    
28
class RobotEmotion:
29
        TYPE_DEFAULT = 0
30
        TYPE_CURRENT = 1
31
        
32
        NEUTRAL   = 0
33
        HAPPY     = 1
34
        SAD       = 2
35
        ANGRY     = 3
36
        SURPRISED = 4
37
        FEAR      = 5
38

    
39
        def __init__(self, emotion = NEUTRAL):
40
                self.value = emotion
41
                self.time_ms = 1000
42

    
43
        def value_as_str(self):
44
                if (self.value == RobotEmotion.NEUTRAL):
45
                        return "neutral"
46
                elif (self.value == RobotEmotion.HAPPY):
47
                        return "happy"
48
                elif (self.value == RobotEmotion.SAD):
49
                        return "sad"
50
                elif (self.value == RobotEmotion.ANGRY):
51
                        return "angry"
52
                elif (self.value == RobotEmotion.SURPRISED):
53
                        return "surprised"
54
                elif (self.value == RobotEmotion.FEAR):
55
                        return "fear"
56
                else:
57
                        return "INVALID EMOTION TYPE"
58
                
59
        def __str__(self):
60
                return "RobotEmotion = { value='%s', time_ms=%d }" % (self.value_as_str(), self.time_ms)
61