mirror of
https://github.com/TrinityCore/TrinityCore.git
synced 2026-01-22 18:15:31 +01:00
--HG-- branch : trunk rename : opt/cleanup/tab2spaces.sh => contrib/cleanup/tab2spaces.sh rename : opt/cleanup/whitespace.sh => contrib/cleanup/whitespace.sh rename : opt/conf_merge/README => contrib/conf_merge/README rename : opt/conf_merge/index.php => contrib/conf_merge/index.php rename : opt/conf_merge/merge.php => contrib/conf_merge/merge.php rename : doc/AuctionHouseBot.txt => docs/AuctionHouseBot.txt rename : doc/DocStructure.dox => docs/DocStructure.dox rename : doc/Doxyfile.in => docs/Doxyfile.in rename : doc/EventAI.txt => docs/EventAI.txt rename : doc/HowToScript.txt => docs/HowToScript.txt rename : doc/TextTables.txt => docs/TextTables.txt rename : doc/UnixInstall.txt => docs/UnixInstall.txt rename : externals/jemalloc/include/internal/arena.h => externals/jemalloc/jemalloc/internal/arena.h rename : externals/jemalloc/include/internal/base.h => externals/jemalloc/jemalloc/internal/base.h rename : externals/jemalloc/include/internal/chunk.h => externals/jemalloc/jemalloc/internal/chunk.h rename : externals/jemalloc/include/internal/chunk_dss.h => externals/jemalloc/jemalloc/internal/chunk_dss.h rename : externals/jemalloc/include/internal/chunk_mmap.h => externals/jemalloc/jemalloc/internal/chunk_mmap.h rename : externals/jemalloc/include/internal/chunk_swap.h => externals/jemalloc/jemalloc/internal/chunk_swap.h rename : externals/jemalloc/include/internal/ckh.h => externals/jemalloc/jemalloc/internal/ckh.h rename : externals/jemalloc/include/internal/ctl.h => externals/jemalloc/jemalloc/internal/ctl.h rename : externals/jemalloc/include/internal/extent.h => externals/jemalloc/jemalloc/internal/extent.h rename : externals/jemalloc/include/internal/hash.h => externals/jemalloc/jemalloc/internal/hash.h rename : externals/jemalloc/include/internal/huge.h => externals/jemalloc/jemalloc/internal/huge.h rename : externals/jemalloc/include/internal/jemalloc_internal.h => externals/jemalloc/jemalloc/internal/jemalloc_internal.h rename : externals/jemalloc/include/internal/jemalloc_internal.h.in => externals/jemalloc/jemalloc/internal/jemalloc_internal.h.in rename : externals/jemalloc/include/internal/mb.h => externals/jemalloc/jemalloc/internal/mb.h rename : externals/jemalloc/include/internal/mutex.h => externals/jemalloc/jemalloc/internal/mutex.h rename : externals/jemalloc/include/internal/prof.h => externals/jemalloc/jemalloc/internal/prof.h rename : externals/jemalloc/include/internal/ql.h => externals/jemalloc/jemalloc/internal/ql.h rename : externals/jemalloc/include/internal/qr.h => externals/jemalloc/jemalloc/internal/qr.h rename : externals/jemalloc/include/internal/rb.h => externals/jemalloc/jemalloc/internal/rb.h rename : externals/jemalloc/include/internal/stats.h => externals/jemalloc/jemalloc/internal/stats.h rename : externals/jemalloc/include/internal/tcache.h => externals/jemalloc/jemalloc/internal/tcache.h rename : externals/jemalloc/include/internal/totally_not_p_r_n.h => externals/jemalloc/jemalloc/internal/totally_not_p_r_n.h rename : externals/jemalloc/include/jemalloc.h => externals/jemalloc/jemalloc/jemalloc.h rename : externals/jemalloc/include/jemalloc.h.in => externals/jemalloc/jemalloc/jemalloc.h.in rename : externals/jemalloc/include/jemalloc_defs.h => externals/jemalloc/jemalloc/jemalloc_defs.h rename : externals/jemalloc/include/jemalloc_defs.h.in => externals/jemalloc/jemalloc/jemalloc_defs.h.in
133 lines
3.3 KiB
C++
133 lines
3.3 KiB
C++
/**
|
|
@file UprightFrame.cpp
|
|
Box class
|
|
|
|
@maintainer Morgan McGuire, http://graphics.cs.williams.edu
|
|
|
|
@created 2007-05-02
|
|
@edited 2007-05-05
|
|
*/
|
|
|
|
#include "G3D/UprightFrame.h"
|
|
#include "G3D/BinaryInput.h"
|
|
#include "G3D/BinaryOutput.h"
|
|
|
|
namespace G3D {
|
|
|
|
UprightFrame::UprightFrame(const CoordinateFrame& cframe) {
|
|
Vector3 look = cframe.lookVector();
|
|
|
|
yaw = G3D::pi() + atan2(look.x, look.z);
|
|
pitch = asin(look.y);
|
|
|
|
translation = cframe.translation;
|
|
}
|
|
|
|
|
|
CoordinateFrame UprightFrame::toCoordinateFrame() const {
|
|
CoordinateFrame cframe;
|
|
|
|
Matrix3 P(Matrix3::fromAxisAngle(Vector3::unitX(), pitch));
|
|
Matrix3 Y(Matrix3::fromAxisAngle(Vector3::unitY(), yaw));
|
|
|
|
cframe.rotation = Y * P;
|
|
cframe.translation = translation;
|
|
|
|
return cframe;
|
|
}
|
|
|
|
|
|
UprightFrame UprightFrame::operator+(const UprightFrame& other) const {
|
|
return UprightFrame(translation + other.translation, pitch + other.pitch, yaw + other.yaw);
|
|
}
|
|
|
|
|
|
UprightFrame UprightFrame::operator*(const float k) const {
|
|
return UprightFrame(translation * k, pitch * k, yaw * k);
|
|
}
|
|
|
|
|
|
void UprightFrame::unwrapYaw(UprightFrame* a, int N) {
|
|
// Use the first point to establish the wrapping convention
|
|
for (int i = 1; i < N; ++i) {
|
|
const float prev = a[i - 1].yaw;
|
|
float& cur = a[i].yaw;
|
|
|
|
// No two angles should be more than pi (i.e., 180-degrees) apart.
|
|
if (abs(cur - prev) > G3D::pi()) {
|
|
// These angles must have wrapped at zero, causing them
|
|
// to be interpolated the long way.
|
|
|
|
// Find canonical [0, 2pi] versions of these numbers
|
|
float p = wrap(prev, twoPi());
|
|
float c = wrap(cur, twoPi());
|
|
|
|
// Find the difference -pi < diff < pi between the current and previous values
|
|
float diff = c - p;
|
|
if (diff < -G3D::pi()) {
|
|
diff += twoPi();
|
|
} else if (diff > G3D::pi()) {
|
|
diff -= twoPi();
|
|
}
|
|
|
|
// Offset the current from the previous by the difference
|
|
// between them.
|
|
cur = prev + diff;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
void UprightFrame::serialize(class BinaryOutput& b) const {
|
|
translation.serialize(b);
|
|
b.writeFloat32(pitch);
|
|
b.writeFloat32(yaw);
|
|
}
|
|
|
|
|
|
void UprightFrame::deserialize(class BinaryInput& b) {
|
|
translation.deserialize(b);
|
|
pitch = b.readFloat32();
|
|
yaw = b.readFloat32();
|
|
}
|
|
|
|
|
|
void UprightSpline::serialize(class BinaryOutput& b) const {
|
|
b.writeBool8(cyclic);
|
|
|
|
b.writeInt32(control.size());
|
|
for (int i = 0; i < control.size(); ++i) {
|
|
control[i].serialize(b);
|
|
}
|
|
b.writeInt32(time.size());
|
|
for (int i = 0; i < time.size(); ++i) {
|
|
b.writeFloat32(time[i]);
|
|
}
|
|
}
|
|
|
|
|
|
void UprightSpline::deserialize(class BinaryInput& b) {
|
|
cyclic = b.readBool8();
|
|
|
|
control.resize(b.readInt32());
|
|
for (int i = 0; i < control.size(); ++i) {
|
|
control[i].deserialize(b);
|
|
}
|
|
|
|
if (b.hasMore()) {
|
|
time.resize(b.readInt32());
|
|
for (int i = 0; i < time.size(); ++i) {
|
|
time[i] = b.readFloat32();
|
|
}
|
|
debugAssert(time.size() == control.size());
|
|
} else {
|
|
// Import legacy path
|
|
time.resize(control.size());
|
|
for (int i = 0; i < time.size(); ++i) {
|
|
time[i] = i;
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|