File: actor_noclip.cpp

package info (click to toggle)
openmohaa 0.82.1%2Bdfsg-1
  • links: PTS, VCS
  • area: contrib
  • in suites: forky, sid
  • size: 34,192 kB
  • sloc: cpp: 315,720; ansic: 275,789; sh: 312; xml: 246; asm: 141; makefile: 7
file content (85 lines) | stat: -rw-r--r-- 2,449 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/*
===========================================================================
Copyright (C) 2023 the OpenMoHAA team

This file is part of OpenMoHAA source code.

OpenMoHAA source code is free software; you can redistribute it
and/or modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2 of the License,
or (at your option) any later version.

OpenMoHAA source code is distributed in the hope that it will be
useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with OpenMoHAA source code; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
===========================================================================
*/

// actor_noclip.cpp

#include "actor.h"

void Actor::InitNoClip(GlobalFuncs_t *func)
{
    func->ThinkState = &Actor::Think_NoClip;
    func->IsState    = &Actor::IsIdleState;
}

void Actor::Think_NoClip(void)
{
    float  frame_dist;
    vec3_t frame_offset;
    float  total_dist;
    vec3_t total_offset;
    Vector newOrigin;
    bool   done = false;

    m_pszDebugState = "";

    ContinueAnimationAllowNoPath();

    CheckUnregister();
    UpdateAngles();
    UpdateAnim();

    VectorSubtract(m_NoClipDest, origin, total_offset);
    total_dist = VectorNormalize2(total_offset, frame_offset);
    frame_dist = VectorLength(frame_delta);

    if (frame_dist > m_maxspeed * level.frametime) {
        frame_dist = m_maxspeed * level.frametime;
    }

    if (frame_dist < total_dist) {
        VectorScale(frame_offset, frame_dist, frame_offset);
        VectorAdd(origin, frame_offset, newOrigin);
    } else {
        VectorCopy(m_NoClipDest, newOrigin);
        done = true;
    }

    SafeSetOrigin(newOrigin);

    velocity[0] = frame_offset[0] / level.frametime;
    velocity[1] = frame_offset[1] / level.frametime;
    velocity[2] = frame_offset[2] / level.frametime;

    if (VectorLengthSquared(velocity) < 1) {
        VectorClear(velocity);
        done = true;
    }
    groundentity = NULL;

    if (done) {
        Com_Printf("(entnum %d, radnum %d) failsafe finished\n", entnum, radnum);
        EndCurrentThinkState();
    }

    UpdateBoneControllers();
    UpdateFootsteps();
}