open-dis-cpp
AcousticEmitterSystem.h
1 #pragma once
2 
3 #include <dis6/utils/DataStream.h>
4 #include <dis6/opendis6_export.h>
5 
6 
7 namespace DIS
8 {
9 // 5.3.35: Information about a particular UA emitter shall be represented using an Acoustic Emitter System record. This record shall consist of three fields: Acoustic Name, Function, and Acoustic ID Number
10 
11 // Copyright (c) 2007-2009, MOVES Institute, Naval Postgraduate School. All rights reserved.
12 //
13 // @author DMcG, jkg
14 
15 class OPENDIS6_EXPORT AcousticEmitterSystem
16 {
17 protected:
19  unsigned short _acousticName;
20 
22  unsigned char _acousticFunction;
23 
25  unsigned char _acousticID;
26 
27 
28  public:
30  virtual ~AcousticEmitterSystem();
31 
32  virtual void marshal(DataStream& dataStream) const;
33  virtual void unmarshal(DataStream& dataStream);
34 
35  unsigned short getAcousticName() const;
36  void setAcousticName(unsigned short pX);
37 
38  unsigned char getAcousticFunction() const;
39  void setAcousticFunction(unsigned char pX);
40 
41  unsigned char getAcousticID() const;
42  void setAcousticID(unsigned char pX);
43 
44 
45 virtual int getMarshalledSize() const;
46 
47  bool operator ==(const AcousticEmitterSystem& rhs) const;
48 };
49 }
50 
51 // Copyright (c) 1995-2009 held by the author(s). All rights reserved.
52 // Redistribution and use in source and binary forms, with or without
53 // modification, are permitted provided that the following conditions
54 // are met:
55 //
56 // * Redistributions of source code must retain the above copyright
57 // notice, this list of conditions and the following disclaimer.
58 // * Redistributions in binary form must reproduce the above copyright
59 // notice, this list of conditions and the following disclaimer
60 // in the documentation and/or other materials provided with the
61 // distribution.
62 // * Neither the names of the Naval Postgraduate School (NPS)
63 // Modeling Virtual Environments and Simulation (MOVES) Institute
64 // (http://www.nps.edu and http://www.MovesInstitute.org)
65 // nor the names of its contributors may be used to endorse or
66 // promote products derived from this software without specific
67 // prior written permission.
68 //
69 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
70 // AS IS AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
71 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
72 // FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
73 // COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
74 // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
75 // BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
76 // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
77 // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
78 // LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
79 // ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
80 // POSSIBILITY OF SUCH DAMAGE.
Symbolic names as defined in 5.1.4.
Definition: AcknowledgePdu.h:8
a class to support managing a network buffer.
Definition: DataStream.h:28
unsigned char _acousticID
This field shall specify the UA emitter identification number relative to a specific system...
Definition: AcousticEmitterSystem.h:25
Definition: AcousticEmitterSystem.h:15
unsigned short _acousticName
This field shall specify the system for a particular UA emitter.
Definition: AcousticEmitterSystem.h:19
unsigned char _acousticFunction
This field shall describe the function of the acoustic system.
Definition: AcousticEmitterSystem.h:22