31 bool wrt,
const LVecBase3 hprOffset) :
32 CConstraintInterval(name, duration),
37 _quatOffset.set_hpr(hprOffset);
47 check_started(get_class_type(),
"priv_step");
51 if(! _target.is_empty()) {
53 if(! _node.is_same_graph(_target)){
54 interval_cat.warning()
55 <<
"Unable to copy orientation in CConstrainHprInterval::priv_step;\n"
56 <<
"node (" << _node.get_name()
57 <<
") and target (" << _target.get_name()
58 <<
") are not in the same graph.\n";
61 _target.set_quat(_node, _quatOffset);
63 _target.set_quat(_quatOffset*_node.get_quat());
71void CConstrainHprInterval::
72output(std::ostream &out)
const {
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
virtual void priv_step(double t)
Advances the time on the interval.
CConstrainHprInterval(const std::string &name, double duration, const NodePath &node, const NodePath &target, bool wrt, const LVecBase3 hprOffset=LVector3::zero())
Constructs a constraint interval that will constrain the orientation of one node to the orientation o...
get_name
Returns the interval's name.
get_duration
Returns the duration of the interval in seconds.
NodePath is the fundamental system for disambiguating instances, and also provides a higher-level int...
TypeHandle is the identifier used to differentiate C++ class types.
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.