Panda3D
fltTransformRotateAboutPoint.cxx
Go to the documentation of this file.
1 /**
2  * PANDA 3D SOFTWARE
3  * Copyright (c) Carnegie Mellon University. All rights reserved.
4  *
5  * All use of this software is subject to the terms of the revised BSD
6  * license. You should have received a copy of this license along
7  * with this source code in a file named "LICENSE."
8  *
9  * @file fltTransformRotateAboutPoint.cxx
10  * @author drose
11  * @date 2000-08-30
12  */
13 
15 #include "fltRecordReader.h"
16 #include "fltRecordWriter.h"
17 
18 TypeHandle FltTransformRotateAboutPoint::_type_handle;
19 
20 /**
21  *
22  */
23 FltTransformRotateAboutPoint::
24 FltTransformRotateAboutPoint(FltHeader *header) : FltTransformRecord(header) {
25  _center.set(0.0, 0.0, 0.0);
26  _axis.set(1.0, 0.0, 0.0);
27  _angle = 0.0;
28 }
29 
30 /**
31  * Defines the rotation. The angle is given in degrees, counterclockwise
32  * about the axis as seen from point a.
33  */
35 set(const LPoint3d &center, const LVector3 &axis, PN_stdfloat angle) {
36  _center = center;
37  _axis = axis;
38  _angle = angle;
39 
40  recompute_matrix();
41 }
42 
43 /**
44  *
45  */
46 const LPoint3d &FltTransformRotateAboutPoint::
47 get_center() const {
48  return _center;
49 }
50 
51 /**
52  *
53  */
54 const LVector3 &FltTransformRotateAboutPoint::
55 get_axis() const {
56  return _axis;
57 }
58 
59 /**
60  * Returns the angle of rotation, in degrees counterclockwise about the axis.
61  */
63 get_angle() const {
64  return _angle;
65 }
66 
67 /**
68  *
69  */
70 void FltTransformRotateAboutPoint::
71 recompute_matrix() {
72  if (_axis == LVector3::zero()) {
73  // Degenerate case.
74  _matrix = LMatrix4d::ident_mat();
75  } else {
76  LVector3d axis = LCAST(double, _axis);
77 
78  _matrix =
79  LMatrix4d::translate_mat(-_center) *
80  LMatrix4d::rotate_mat(_angle, axis, CS_zup_right) *
81  LMatrix4d::translate_mat(_center);
82  }
83 }
84 
85 /**
86  * Fills in the information in this record based on the information given in
87  * the indicated datagram, whose opcode has already been read. Returns true
88  * on success, false if the datagram is invalid.
89  */
90 bool FltTransformRotateAboutPoint::
91 extract_record(FltRecordReader &reader) {
92  if (!FltTransformRecord::extract_record(reader)) {
93  return false;
94  }
95 
96  nassertr(reader.get_opcode() == FO_rotate_about_point, false);
97  DatagramIterator &iterator = reader.get_iterator();
98 
99  iterator.skip_bytes(4); // Undocumented additional padding.
100 
101  _center[0] = iterator.get_be_float64();
102  _center[1] = iterator.get_be_float64();
103  _center[2] = iterator.get_be_float64();
104  _axis[0] = iterator.get_be_float32();
105  _axis[1] = iterator.get_be_float32();
106  _axis[2] = iterator.get_be_float32();
107  _angle = iterator.get_be_float32();
108 
109  recompute_matrix();
110 
111  check_remaining_size(iterator);
112  return true;
113 }
114 
115 /**
116  * Fills up the current record on the FltRecordWriter with data for this
117  * record, but does not advance the writer. Returns true on success, false if
118  * there is some error.
119  */
120 bool FltTransformRotateAboutPoint::
121 build_record(FltRecordWriter &writer) const {
122  if (!FltTransformRecord::build_record(writer)) {
123  return false;
124  }
125 
126  writer.set_opcode(FO_rotate_about_point);
127  Datagram &datagram = writer.update_datagram();
128 
129  datagram.pad_bytes(4); // Undocumented additional padding.
130 
131  datagram.add_be_float64(_center[0]);
132  datagram.add_be_float64(_center[1]);
133  datagram.add_be_float64(_center[2]);
134  datagram.add_be_float32(_axis[0]);
135  datagram.add_be_float32(_axis[1]);
136  datagram.add_be_float32(_axis[2]);
137  datagram.add_be_float32(_angle);
138 
139  return true;
140 }
PN_stdfloat get_angle() const
Returns the angle of rotation, in degrees counterclockwise about the axis.
This class writes a sequence of FltRecords to an ostream, handling opcode and size counts properly.
This class turns an istream into a sequence of FltRecords by reading a sequence of Datagrams and extr...
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
void check_remaining_size(const DatagramIterator &di, const std::string &name=std::string()) const
Checks that the iterator has no bytes left, as it should at the end of a successfully read record.
Definition: fltRecord.cxx:254
void set(const LPoint3d &center, const LVector3 &axis, PN_stdfloat angle)
Defines the rotation.
DatagramIterator & get_iterator()
Returns an iterator suitable for extracting data from the current record.
void pad_bytes(size_t size)
Adds the indicated number of zero bytes to the datagram.
Definition: datagram.cxx:99
This is the first bead in the file, the top of the bead hierarchy, and the primary interface to readi...
Definition: fltHeader.h:44
void add_be_float64(PN_float64 value)
Adds a 64-bit big-endian floating-point number to the datagram.
Definition: datagram.I:209
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
void add_be_float32(PN_float32 value)
Adds a 32-bit single-precision big-endian floating-point number to the datagram.
Definition: datagram.I:200
void skip_bytes(size_t size)
Skips over the indicated number of bytes in the datagram.
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
FltOpcode get_opcode() const
Returns the opcode associated with the current record.
A base class for a number of types of ancillary records that follow beads and indicate some kind of a...
A class to retrieve the individual data elements previously stored in a Datagram.
TypeHandle is the identifier used to differentiate C++ class types.
Definition: typeHandle.h:81
void set_opcode(FltOpcode opcode)
Sets the opcode associated with the current record.
Datagram & update_datagram()
Returns a modifiable reference to the datagram associated with the current record.
An ordered list of data elements, formatted in memory for transmission over a socket or writing to a ...
Definition: datagram.h:38