2 Copyright (C) 2003, 2010 - Wolfire Games
3 Copyright (C) 2010-2016 - Lugaru contributors (see AUTHORS file)
5 This file is part of Lugaru.
7 Lugaru is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
12 Lugaru is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with Lugaru. If not, see <http://www.gnu.org/licenses/>.
25 #include "Quaternions.h"
28 /**> HEADER FILES <**/
30 #include "Quaternions.h"
34 #include "Animation/Animation.h"
38 leftshoulder, leftelbow, leftwrist, lefthand,
39 rightshoulder, rightelbow, rightwrist, righthand,
40 abdomen, lefthip, righthip, groin,
41 leftknee, leftankle, leftfoot,
42 rightknee, rightankle, rightfoot
93 int numverticesclothes;
103 float rotate1, rotate2, rotate3;
104 float lastrotate1, lastrotate2, lastrotate3;
105 float oldrotate1, oldrotate2, oldrotate3;
106 float newrotate1, newrotate2, newrotate3;
112 void DoConstraint(bool spinny);
115 const int max_joints = 50;
121 //Joint joints[max_joints];
126 //Muscle muscles[max_muscles];
132 int forwardjoints[3];
137 int lowforwardjoints[3];
140 XYZ specialforward[5];
141 int jointlabels[max_joints];
150 Model drawmodelclothes;
155 GLubyte skinText[512 * 512 * 3];
169 float DoConstraints(XYZ *coords, float *scale);
170 void DoGravity(float *scale);
171 void FindRotationJoint(int which);
172 void FindRotationJointSameTwist(int which);
173 void FindRotationMuscle(int which, int animation);
174 void Load(const std::string& fileName, const std::string& lowfileName, const std::string& clothesfileName, const std::string& modelfileName, const std::string& model2fileName, const std::string& model3fileName, const std::string& model4fileName, const std::string& model5fileNamee, const std::string& model6fileName, const std::string& model7fileName, const std::string& modellowfileName, const std::string& modelclothesfileName, bool aclothes);
178 void FindForwardsfirst();
179 void Draw(int muscleview);
180 void AddJoint(float x, float y, float z, int which);
181 void SetJoint(float x, float y, float z, int which, int whichjoint);
182 void DeleteJoint(int whichjoint);
183 void AddMuscle(int attach1, int attach2, float maxlength, float minlength, int type);
184 void DeleteMuscle(int whichmuscle);
193 // convenience functions
194 // only for Skeleton.cpp
195 inline Joint& joint(int bodypart) { return joints[jointlabels[bodypart]]; }
196 inline XYZ& jointPos(int bodypart) { return joint(bodypart).position; }
197 inline XYZ& jointVel(int bodypart) { return joint(bodypart).velocity; }