BulletSim: an 'if' to suppress multiple setting of avatar orientation.
Looks like the viewer bombards the server with avatar orientation information (we're talking several hundred a second) when the avatar is being turned or when walking. This change just reduces the number of 'set' calls into unmanaged code.0.7.5-pf-bulletsim
parent
db6c0363f0
commit
0538096fa3
|
@ -558,12 +558,16 @@ public sealed class BSCharacter : BSPhysObject
|
||||||
public override OMV.Quaternion Orientation {
|
public override OMV.Quaternion Orientation {
|
||||||
get { return _orientation; }
|
get { return _orientation; }
|
||||||
set {
|
set {
|
||||||
_orientation = value;
|
// Orientation is set zillions of times when an avatar is walking. It's like
|
||||||
// m_log.DebugFormat("{0}: set orientation to {1}", LogHeader, _orientation);
|
// the viewer doesn't trust us.
|
||||||
PhysicsScene.TaintedObject("BSCharacter.setOrientation", delegate()
|
if (_orientation != value)
|
||||||
{
|
{
|
||||||
ForceOrientation = _orientation;
|
_orientation = value;
|
||||||
});
|
PhysicsScene.TaintedObject("BSCharacter.setOrientation", delegate()
|
||||||
|
{
|
||||||
|
ForceOrientation = _orientation;
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Go directly to Bullet to get/set the value.
|
// Go directly to Bullet to get/set the value.
|
||||||
|
|
Loading…
Reference in New Issue