mirror of
https://github.com/panda3d/panda3d.git
synced 2025-10-03 18:31:55 -04:00
beginning JointVertexTransform
This commit is contained in:
parent
867b37b73a
commit
9c9a444209
@ -14,21 +14,24 @@
|
|||||||
characterJoint.h characterJointBundle.I \
|
characterJoint.h characterJointBundle.I \
|
||||||
characterJointBundle.h characterSlider.h computedVertices.I \
|
characterJointBundle.h characterSlider.h computedVertices.I \
|
||||||
computedVertices.h computedVerticesMorph.I \
|
computedVertices.h computedVerticesMorph.I \
|
||||||
computedVerticesMorph.h config_char.h dynamicVertices.h
|
computedVerticesMorph.h config_char.h dynamicVertices.h \
|
||||||
|
jointVertexTransform.I jointVertexTransform.h
|
||||||
|
|
||||||
#define INCLUDED_SOURCES \
|
#define INCLUDED_SOURCES \
|
||||||
character.cxx \
|
character.cxx \
|
||||||
characterJoint.cxx characterJointBundle.cxx \
|
characterJoint.cxx characterJointBundle.cxx \
|
||||||
characterSlider.cxx computedVertices.cxx \
|
characterSlider.cxx computedVertices.cxx \
|
||||||
computedVerticesMorph.cxx config_char.cxx \
|
computedVerticesMorph.cxx config_char.cxx \
|
||||||
dynamicVertices.cxx
|
dynamicVertices.cxx \
|
||||||
|
jointVertexTransform.cxx
|
||||||
|
|
||||||
#define INSTALL_HEADERS \
|
#define INSTALL_HEADERS \
|
||||||
character.I character.h \
|
character.I character.h \
|
||||||
characterJoint.h characterJointBundle.I \
|
characterJoint.h characterJointBundle.I \
|
||||||
characterJointBundle.h characterSlider.h computedVertices.I \
|
characterJointBundle.h characterSlider.h computedVertices.I \
|
||||||
computedVertices.h computedVerticesMorph.I computedVerticesMorph.h \
|
computedVertices.h computedVerticesMorph.I computedVerticesMorph.h \
|
||||||
config_char.h dynamicVertices.h
|
config_char.h dynamicVertices.h \
|
||||||
|
jointVertexTransform.I jointVertexTransform.h
|
||||||
|
|
||||||
#define IGATESCAN all
|
#define IGATESCAN all
|
||||||
|
|
||||||
|
@ -3,4 +3,5 @@
|
|||||||
#include "computedVertices.cxx"
|
#include "computedVertices.cxx"
|
||||||
#include "computedVerticesMorph.cxx"
|
#include "computedVerticesMorph.cxx"
|
||||||
#include "dynamicVertices.cxx"
|
#include "dynamicVertices.cxx"
|
||||||
|
#include "jointVertexTransform.cxx"
|
||||||
|
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
|
|
||||||
#include "characterJoint.h"
|
#include "characterJoint.h"
|
||||||
#include "config_char.h"
|
#include "config_char.h"
|
||||||
|
#include "jointVertexTransform.h"
|
||||||
|
|
||||||
#include "datagram.h"
|
#include "datagram.h"
|
||||||
#include "datagramIterator.h"
|
#include "datagramIterator.h"
|
||||||
@ -68,6 +69,16 @@ CharacterJoint(PartGroup *parent, const string &name,
|
|||||||
_initial_net_transform_inverse = invert(_net_transform);
|
_initial_net_transform_inverse = invert(_net_transform);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: CharacterJoint::Destructor
|
||||||
|
// Access: Public, Virtual
|
||||||
|
// Description:
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
CharacterJoint::
|
||||||
|
~CharacterJoint() {
|
||||||
|
nassertv(_vertex_transforms.empty());
|
||||||
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////
|
||||||
// Function: CharacterJoint::make_copy
|
// Function: CharacterJoint::make_copy
|
||||||
// Access: Public, Virtual
|
// Access: Public, Virtual
|
||||||
@ -118,15 +129,25 @@ update_internals(PartGroup *parent, bool self_changed, bool parent_changed) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (net_changed && !_net_transform_nodes.empty()) {
|
if (net_changed) {
|
||||||
CPT(TransformState) t = TransformState::make_mat(_net_transform);
|
if (!_net_transform_nodes.empty()) {
|
||||||
|
CPT(TransformState) t = TransformState::make_mat(_net_transform);
|
||||||
|
|
||||||
|
NodeList::iterator ai;
|
||||||
|
ai = _net_transform_nodes.begin();
|
||||||
|
while (ai != _net_transform_nodes.end()) {
|
||||||
|
PandaNode *node = *ai;
|
||||||
|
node->set_transform(t);
|
||||||
|
++ai;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
NodeList::iterator ai;
|
// Also tell our related JointVertexTransforms that they now need
|
||||||
ai = _net_transform_nodes.begin();
|
// to recompute themselves.
|
||||||
while (ai != _net_transform_nodes.end()) {
|
VertexTransforms::iterator vti;
|
||||||
PandaNode *node = *ai;
|
for (vti = _vertex_transforms.begin(); vti != _vertex_transforms.end(); ++vti) {
|
||||||
node->set_transform(t);
|
(*vti)->_matrix_stale = true;
|
||||||
++ai;
|
(*vti)->mark_modified();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -261,6 +282,18 @@ get_transform(LMatrix4f &transform) const {
|
|||||||
transform = _value;
|
transform = _value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: CharacterJoint::get_net_transform
|
||||||
|
// Access: Published
|
||||||
|
// Description: Copies the joint's current net transform (composed
|
||||||
|
// from the root of the character joint hierarchy) into
|
||||||
|
// the indicated matrix.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
void CharacterJoint::
|
||||||
|
get_net_transform(LMatrix4f &transform) const {
|
||||||
|
transform = _net_transform;
|
||||||
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////
|
||||||
// Function: CharacterJoint::write_datagram
|
// Function: CharacterJoint::write_datagram
|
||||||
// Access: Public
|
// Access: Public
|
||||||
|
@ -24,6 +24,8 @@
|
|||||||
#include "movingPartMatrix.h"
|
#include "movingPartMatrix.h"
|
||||||
#include "pandaNode.h"
|
#include "pandaNode.h"
|
||||||
|
|
||||||
|
class JointVertexTransform;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////
|
||||||
// Class : CharacterJoint
|
// Class : CharacterJoint
|
||||||
// Description : This represents one joint of the character's
|
// Description : This represents one joint of the character's
|
||||||
@ -37,6 +39,7 @@ protected:
|
|||||||
public:
|
public:
|
||||||
CharacterJoint(PartGroup *parent, const string &name,
|
CharacterJoint(PartGroup *parent, const string &name,
|
||||||
const LMatrix4f &initial_value);
|
const LMatrix4f &initial_value);
|
||||||
|
virtual ~CharacterJoint();
|
||||||
|
|
||||||
virtual PartGroup *make_copy() const;
|
virtual PartGroup *make_copy() const;
|
||||||
|
|
||||||
@ -55,12 +58,16 @@ PUBLISHED:
|
|||||||
void clear_local_transforms();
|
void clear_local_transforms();
|
||||||
|
|
||||||
void get_transform(LMatrix4f &transform) const;
|
void get_transform(LMatrix4f &transform) const;
|
||||||
|
void get_net_transform(LMatrix4f &transform) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
typedef pset< PT(PandaNode) > NodeList;
|
typedef pset< PT(PandaNode) > NodeList;
|
||||||
NodeList _net_transform_nodes;
|
NodeList _net_transform_nodes;
|
||||||
NodeList _local_transform_nodes;
|
NodeList _local_transform_nodes;
|
||||||
|
|
||||||
|
typedef pset<JointVertexTransform *> VertexTransforms;
|
||||||
|
VertexTransforms _vertex_transforms;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static void register_with_read_factory(void);
|
static void register_with_read_factory(void);
|
||||||
virtual void write_datagram(BamWriter* manager, Datagram &me);
|
virtual void write_datagram(BamWriter* manager, Datagram &me);
|
||||||
@ -104,6 +111,7 @@ private:
|
|||||||
static TypeHandle _type_handle;
|
static TypeHandle _type_handle;
|
||||||
|
|
||||||
friend class Character;
|
friend class Character;
|
||||||
|
friend class JointVertexTransform;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
#include "characterSlider.h"
|
#include "characterSlider.h"
|
||||||
#include "computedVertices.h"
|
#include "computedVertices.h"
|
||||||
#include "dynamicVertices.h"
|
#include "dynamicVertices.h"
|
||||||
|
#include "jointVertexTransform.h"
|
||||||
#include "dconfig.h"
|
#include "dconfig.h"
|
||||||
#include "lmatrix4.h"
|
#include "lmatrix4.h"
|
||||||
|
|
||||||
@ -65,6 +66,7 @@ init_libchar() {
|
|||||||
CharacterSlider::init_type();
|
CharacterSlider::init_type();
|
||||||
ComputedVertices::init_type();
|
ComputedVertices::init_type();
|
||||||
DynamicVertices::init_type();
|
DynamicVertices::init_type();
|
||||||
|
JointVertexTransform::init_type();
|
||||||
|
|
||||||
// This isn't defined in this package, but it *is* essential that it
|
// This isn't defined in this package, but it *is* essential that it
|
||||||
// be initialized. We have to do it explicitly here since template
|
// be initialized. We have to do it explicitly here since template
|
||||||
@ -79,5 +81,6 @@ init_libchar() {
|
|||||||
CharacterJointBundle::register_with_read_factory();
|
CharacterJointBundle::register_with_read_factory();
|
||||||
CharacterSlider::register_with_read_factory();
|
CharacterSlider::register_with_read_factory();
|
||||||
ComputedVertices::register_with_read_factory();
|
ComputedVertices::register_with_read_factory();
|
||||||
|
JointVertexTransform::register_with_read_factory();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
40
panda/src/char/jointVertexTransform.I
Normal file
40
panda/src/char/jointVertexTransform.I
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
// Filename: jointVertexTransform.I
|
||||||
|
// Created by: drose (24Mar05)
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// PANDA 3D SOFTWARE
|
||||||
|
// Copyright (c) 2001 - 2004, Disney Enterprises, Inc. All rights reserved
|
||||||
|
//
|
||||||
|
// All use of this software is subject to the terms of the Panda 3d
|
||||||
|
// Software license. You should have received a copy of this license
|
||||||
|
// along with this source code; you will also find a current copy of
|
||||||
|
// the license at http://etc.cmu.edu/panda3d/docs/license/ .
|
||||||
|
//
|
||||||
|
// To contact the maintainers of this program write to
|
||||||
|
// panda3d-general@lists.sourceforge.net .
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::get_from
|
||||||
|
// Access: Published
|
||||||
|
// Description: Returns the joint whose coordinate space this object
|
||||||
|
// moves vertices from.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
INLINE const CharacterJoint *JointVertexTransform::
|
||||||
|
get_from() const {
|
||||||
|
return _from;
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::get_to
|
||||||
|
// Access: Published
|
||||||
|
// Description: Returns the joint whose coordinate space this object
|
||||||
|
// moves vertices into.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
INLINE const CharacterJoint *JointVertexTransform::
|
||||||
|
get_to() const {
|
||||||
|
return _to;
|
||||||
|
}
|
161
panda/src/char/jointVertexTransform.cxx
Normal file
161
panda/src/char/jointVertexTransform.cxx
Normal file
@ -0,0 +1,161 @@
|
|||||||
|
// Filename: jointVertexTransform.cxx
|
||||||
|
// Created by: drose (24Mar05)
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// PANDA 3D SOFTWARE
|
||||||
|
// Copyright (c) 2001 - 2004, Disney Enterprises, Inc. All rights reserved
|
||||||
|
//
|
||||||
|
// All use of this software is subject to the terms of the Panda 3d
|
||||||
|
// Software license. You should have received a copy of this license
|
||||||
|
// along with this source code; you will also find a current copy of
|
||||||
|
// the license at http://etc.cmu.edu/panda3d/docs/license/ .
|
||||||
|
//
|
||||||
|
// To contact the maintainers of this program write to
|
||||||
|
// panda3d-general@lists.sourceforge.net .
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
#include "jointVertexTransform.h"
|
||||||
|
#include "datagram.h"
|
||||||
|
#include "datagramIterator.h"
|
||||||
|
#include "bamReader.h"
|
||||||
|
#include "bamWriter.h"
|
||||||
|
|
||||||
|
TypeHandle JointVertexTransform::_type_handle;
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::Default Constructor
|
||||||
|
// Access: Private
|
||||||
|
// Description: Constructs an invalid object; used only by the bam
|
||||||
|
// loader.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
JointVertexTransform::
|
||||||
|
JointVertexTransform() :
|
||||||
|
_matrix_stale(true)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::Constructor
|
||||||
|
// Access: Published
|
||||||
|
// Description: Constructs a new object that converts vertices from
|
||||||
|
// the indicated joint's coordinate space, into the
|
||||||
|
// other indicated joint's space.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
JointVertexTransform::
|
||||||
|
JointVertexTransform(CharacterJoint *from, CharacterJoint *to) :
|
||||||
|
_from(from),
|
||||||
|
_to(to),
|
||||||
|
_matrix_stale(true)
|
||||||
|
{
|
||||||
|
// Tell the "to" joint that we need to be informed when it moves.
|
||||||
|
_to->_vertex_transforms.insert(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::Destructor
|
||||||
|
// Access: Published, Virtual
|
||||||
|
// Description:
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
JointVertexTransform::
|
||||||
|
~JointVertexTransform() {
|
||||||
|
// Tell the "to" joint to stop informing us about its motion.
|
||||||
|
_to->_vertex_transforms.erase(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::get_matrix
|
||||||
|
// Access: Published, Virtual
|
||||||
|
// Description: Stores the transform's matrix in the indicated object.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
void JointVertexTransform::
|
||||||
|
get_matrix(LMatrix4f &matrix) const {
|
||||||
|
if (_matrix_stale) {
|
||||||
|
((JointVertexTransform *)this)->_matrix =
|
||||||
|
_from->_initial_net_transform_inverse *
|
||||||
|
_to->_net_transform;
|
||||||
|
((JointVertexTransform *)this)->_matrix_stale = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
matrix = _matrix;
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::output
|
||||||
|
// Access: Published, Virtual
|
||||||
|
// Description:
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
void JointVertexTransform::
|
||||||
|
output(ostream &out) const {
|
||||||
|
out << _to->get_name();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::register_with_read_factory
|
||||||
|
// Access: Public, Static
|
||||||
|
// Description: Tells the BamReader how to create objects of type
|
||||||
|
// JointVertexTransform.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
void JointVertexTransform::
|
||||||
|
register_with_read_factory() {
|
||||||
|
BamReader::get_factory()->register_factory(get_class_type(), make_from_bam);
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::write_datagram
|
||||||
|
// Access: Public, Virtual
|
||||||
|
// Description: Writes the contents of this object to the datagram
|
||||||
|
// for shipping out to a Bam file.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
void JointVertexTransform::
|
||||||
|
write_datagram(BamWriter *manager, Datagram &dg) {
|
||||||
|
VertexTransform::write_datagram(manager, dg);
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::complete_pointers
|
||||||
|
// Access: Public, Virtual
|
||||||
|
// Description: Receives an array of pointers, one for each time
|
||||||
|
// manager->read_pointer() was called in fillin().
|
||||||
|
// Returns the number of pointers processed.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
int JointVertexTransform::
|
||||||
|
complete_pointers(TypedWritable **p_list, BamReader *manager) {
|
||||||
|
int pi = VertexTransform::complete_pointers(p_list, manager);
|
||||||
|
|
||||||
|
return pi;
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::make_from_bam
|
||||||
|
// Access: Protected, Static
|
||||||
|
// Description: This function is called by the BamReader's factory
|
||||||
|
// when a new object of type JointVertexTransform is encountered
|
||||||
|
// in the Bam file. It should create the JointVertexTransform
|
||||||
|
// and extract its information from the file.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
TypedWritable *JointVertexTransform::
|
||||||
|
make_from_bam(const FactoryParams ¶ms) {
|
||||||
|
JointVertexTransform *object = new JointVertexTransform;
|
||||||
|
DatagramIterator scan;
|
||||||
|
BamReader *manager;
|
||||||
|
|
||||||
|
parse_params(params, scan, manager);
|
||||||
|
object->fillin(scan, manager);
|
||||||
|
|
||||||
|
return object;
|
||||||
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: JointVertexTransform::fillin
|
||||||
|
// Access: Protected
|
||||||
|
// Description: This internal function is called by make_from_bam to
|
||||||
|
// read in all of the relevant data from the BamFile for
|
||||||
|
// the new JointVertexTransform.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
void JointVertexTransform::
|
||||||
|
fillin(DatagramIterator &scan, BamReader *manager) {
|
||||||
|
VertexTransform::fillin(scan, manager);
|
||||||
|
}
|
91
panda/src/char/jointVertexTransform.h
Normal file
91
panda/src/char/jointVertexTransform.h
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
// Filename: jointVertexTransform.h
|
||||||
|
// Created by: drose (24Mar05)
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// PANDA 3D SOFTWARE
|
||||||
|
// Copyright (c) 2001 - 2004, Disney Enterprises, Inc. All rights reserved
|
||||||
|
//
|
||||||
|
// All use of this software is subject to the terms of the Panda 3d
|
||||||
|
// Software license. You should have received a copy of this license
|
||||||
|
// along with this source code; you will also find a current copy of
|
||||||
|
// the license at http://etc.cmu.edu/panda3d/docs/license/ .
|
||||||
|
//
|
||||||
|
// To contact the maintainers of this program write to
|
||||||
|
// panda3d-general@lists.sourceforge.net .
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
#ifndef JOINTVERTEXTRANSFORM_H
|
||||||
|
#define JOINTVERTEXTRANSFORM_H
|
||||||
|
|
||||||
|
#include "pandabase.h"
|
||||||
|
#include "characterJoint.h"
|
||||||
|
#include "vertexTransform.h"
|
||||||
|
#include "pointerTo.h"
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Class : JointVertexTransform
|
||||||
|
// Description : This is a specialization on VertexTransform that
|
||||||
|
// returns the relative transform from one joint's
|
||||||
|
// initial position to another joint's (or possibly the
|
||||||
|
// same joint's) current position. It is used to
|
||||||
|
// implement soft-skinned vertices for an animated
|
||||||
|
// character.
|
||||||
|
//
|
||||||
|
// This is part of the experimental Geom rewrite.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
class EXPCL_PANDA JointVertexTransform : public VertexTransform {
|
||||||
|
private:
|
||||||
|
JointVertexTransform();
|
||||||
|
|
||||||
|
PUBLISHED:
|
||||||
|
JointVertexTransform(CharacterJoint *from, CharacterJoint *to);
|
||||||
|
virtual ~JointVertexTransform();
|
||||||
|
|
||||||
|
INLINE const CharacterJoint *get_from() const;
|
||||||
|
INLINE const CharacterJoint *get_to() const;
|
||||||
|
|
||||||
|
virtual void get_matrix(LMatrix4f &matrix) const;
|
||||||
|
|
||||||
|
virtual void output(ostream &out) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
PT(CharacterJoint) _from;
|
||||||
|
PT(CharacterJoint) _to;
|
||||||
|
|
||||||
|
LMatrix4f _matrix;
|
||||||
|
bool _matrix_stale;
|
||||||
|
|
||||||
|
public:
|
||||||
|
static void register_with_read_factory();
|
||||||
|
virtual void write_datagram(BamWriter *manager, Datagram &dg);
|
||||||
|
virtual int complete_pointers(TypedWritable **plist, BamReader *manager);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
static TypedWritable *make_from_bam(const FactoryParams ¶ms);
|
||||||
|
void fillin(DatagramIterator &scan, BamReader *manager);
|
||||||
|
|
||||||
|
public:
|
||||||
|
static TypeHandle get_class_type() {
|
||||||
|
return _type_handle;
|
||||||
|
}
|
||||||
|
static void init_type() {
|
||||||
|
VertexTransform::init_type();
|
||||||
|
register_type(_type_handle, "JointVertexTransform",
|
||||||
|
VertexTransform::get_class_type());
|
||||||
|
}
|
||||||
|
virtual TypeHandle get_type() const {
|
||||||
|
return get_class_type();
|
||||||
|
}
|
||||||
|
virtual TypeHandle force_init_type() {init_type(); return get_class_type();}
|
||||||
|
|
||||||
|
private:
|
||||||
|
static TypeHandle _type_handle;
|
||||||
|
|
||||||
|
friend class CharacterJoint;
|
||||||
|
};
|
||||||
|
|
||||||
|
#include "jointVertexTransform.I"
|
||||||
|
|
||||||
|
#endif
|
@ -179,6 +179,20 @@ get_highest_index() const {
|
|||||||
return _highest_index;
|
return _highest_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
// Function: EggVertexPool::set_highest_index
|
||||||
|
// Access: Public
|
||||||
|
// Description: Artificially changes the "highest index number", so
|
||||||
|
// that a newly created vertex will begin at this number
|
||||||
|
// plus 1. This can be used to default a vertex pool to
|
||||||
|
// start counting at 1 (or any other index number),
|
||||||
|
// instead of the default of 0. Use with caution.
|
||||||
|
////////////////////////////////////////////////////////////////////
|
||||||
|
void EggVertexPool::
|
||||||
|
set_highest_index(int highest_index) {
|
||||||
|
_highest_index = highest_index;
|
||||||
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////
|
||||||
// Function: EggVertexPool::get_num_dimensions
|
// Function: EggVertexPool::get_num_dimensions
|
||||||
// Access: Public
|
// Access: Public
|
||||||
|
@ -91,6 +91,7 @@ PUBLISHED:
|
|||||||
|
|
||||||
// Returns 0 if the pool is empty.
|
// Returns 0 if the pool is empty.
|
||||||
int get_highest_index() const;
|
int get_highest_index() const;
|
||||||
|
void set_highest_index(int highest_index);
|
||||||
|
|
||||||
int get_num_dimensions() const;
|
int get_num_dimensions() const;
|
||||||
bool has_normals() const;
|
bool has_normals() const;
|
||||||
|
@ -791,10 +791,14 @@ vertex_pool:
|
|||||||
if (pool->has_defined_vertices()) {
|
if (pool->has_defined_vertices()) {
|
||||||
eggyywarning("Duplicate vertex pool name " + name);
|
eggyywarning("Duplicate vertex pool name " + name);
|
||||||
pool = new EggVertexPool(name);
|
pool = new EggVertexPool(name);
|
||||||
|
// The egg syntax starts counting at 1 by convention.
|
||||||
|
pool->set_highest_index(0);
|
||||||
vertex_pools[name] = pool;
|
vertex_pools[name] = pool;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
pool = new EggVertexPool(name);
|
pool = new EggVertexPool(name);
|
||||||
|
// The egg syntax starts counting at 1 by convention.
|
||||||
|
pool->set_highest_index(0);
|
||||||
vertex_pools[name] = pool;
|
vertex_pools[name] = pool;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2623,6 +2627,8 @@ vertex_pool_name:
|
|||||||
if (vpi == vertex_pools.end()) {
|
if (vpi == vertex_pools.end()) {
|
||||||
// This will become a forward reference.
|
// This will become a forward reference.
|
||||||
EggVertexPool *pool = new EggVertexPool(name);
|
EggVertexPool *pool = new EggVertexPool(name);
|
||||||
|
// The egg syntax starts counting at 1 by convention.
|
||||||
|
pool->set_highest_index(0);
|
||||||
vertex_pools[name] = pool;
|
vertex_pools[name] = pool;
|
||||||
$$ = pool;
|
$$ = pool;
|
||||||
} else {
|
} else {
|
||||||
|
@ -1173,7 +1173,7 @@ make_computed_vertices(qpGeomVertexData::CDWriter &cdata) {
|
|||||||
// array.
|
// array.
|
||||||
cdata->_computed_vertices = replace_data_type
|
cdata->_computed_vertices = replace_data_type
|
||||||
(InternalName::get_transform_blend(), 0, qpGeomVertexDataType::NT_uint16,
|
(InternalName::get_transform_blend(), 0, qpGeomVertexDataType::NT_uint16,
|
||||||
qpGeomUsageHint::UH_dynamic, false);
|
min(get_usage_hint(), qpGeomUsageHint::UH_dynamic), false);
|
||||||
|
|
||||||
// Now fill it up with the appropriate data.
|
// Now fill it up with the appropriate data.
|
||||||
update_computed_vertices(cdata);
|
update_computed_vertices(cdata);
|
||||||
|
@ -36,7 +36,7 @@ UserVertexTransform(const string &name) :
|
|||||||
////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////
|
||||||
// Function: UserVertexTransform::get_matrix
|
// Function: UserVertexTransform::get_matrix
|
||||||
// Access: Published, Virtual
|
// Access: Published, Virtual
|
||||||
// Description: Stores the transform's matrix in the indicated value.
|
// Description: Stores the transform's matrix in the indicated object.
|
||||||
////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////
|
||||||
void UserVertexTransform::
|
void UserVertexTransform::
|
||||||
get_matrix(LMatrix4f &matrix) const {
|
get_matrix(LMatrix4f &matrix) const {
|
||||||
@ -83,7 +83,7 @@ register_with_read_factory() {
|
|||||||
////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////
|
||||||
void UserVertexTransform::
|
void UserVertexTransform::
|
||||||
write_datagram(BamWriter *manager, Datagram &dg) {
|
write_datagram(BamWriter *manager, Datagram &dg) {
|
||||||
TypedWritable::write_datagram(manager, dg);
|
VertexTransform::write_datagram(manager, dg);
|
||||||
|
|
||||||
manager->write_cdata(dg, _cycler);
|
manager->write_cdata(dg, _cycler);
|
||||||
}
|
}
|
||||||
@ -117,7 +117,7 @@ make_from_bam(const FactoryParams ¶ms) {
|
|||||||
////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////
|
||||||
void UserVertexTransform::
|
void UserVertexTransform::
|
||||||
fillin(DatagramIterator &scan, BamReader *manager) {
|
fillin(DatagramIterator &scan, BamReader *manager) {
|
||||||
TypedWritable::fillin(scan, manager);
|
VertexTransform::fillin(scan, manager);
|
||||||
|
|
||||||
manager->read_cdata(scan, _cycler);
|
manager->read_cdata(scan, _cycler);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user