implementation of drecon in unity 2022 lts forked from: https://github.com/joanllobera/marathon-envs

178 lines
6.9 KiB

10 months ago
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using UnityEngine;
public class DebugJoints : MonoBehaviour
{
public float SphereSize = 0.03f;
static Color[] _axisColor = {
new Color(219f / 255, 62f / 255, 29f / 255, .93f),
new Color(154f / 255, 243f / 255, 72f / 255, .93f),
new Color(58f / 255, 122f / 255, 248f / 255, .93f)};
static Vector3[] _axisVector = { Vector3.right, Vector3.up, Vector3.forward };
ArticulationBody _body;
ArticulationBody _parentBody;
MarathonTestBedController _debugController;
// Start is called before the first frame update
ManyWorlds.SpawnableEnv _spawnableEnv;
MocapControllerArtanim _mocapController;
Rigidbody _target;
public Vector3 TargetRotationInJointSpace;
public Vector3 RotationInJointSpace;
public Vector3 RotationInJointSpaceError;
public Vector3 RotationInJointSpaceErrorRad;
public Vector3 JointPositionDeg;
public Vector3 JointTargetDeg;
public Vector3 JointPositionRad;
public Vector3 JointTargetRad;
void Start()
{
_body = GetComponent<ArticulationBody>();
_parentBody = _body.transform.parent.GetComponentInParent<ArticulationBody>();
_debugController = FindObjectOfType<MarathonTestBedController>();
_spawnableEnv = GetComponentInParent<ManyWorlds.SpawnableEnv>();
_mocapController = _spawnableEnv.GetComponentInChildren<MocapControllerArtanim>();
var mocapBodyParts = _mocapController.GetComponentsInChildren<Rigidbody>().ToList();
_target = mocapBodyParts.First(x=>x.name == _body.name);
}
// Update is called once per frame
void FixedUpdate()
{
if (_body == null)
return;
if (_body.jointType != ArticulationJointType.SphericalJoint)
return;
RotationInJointSpace = -(Quaternion.Inverse(_body.anchorRotation) * Quaternion.Inverse(_body.transform.localRotation) * _body.parentAnchorRotation).eulerAngles;
TargetRotationInJointSpace = -(Quaternion.Inverse(_body.anchorRotation) * Quaternion.Inverse(_target.transform.localRotation) * _body.parentAnchorRotation).eulerAngles;
RotationInJointSpaceError = TargetRotationInJointSpace-RotationInJointSpace;
RotationInJointSpace = new Vector3(
Mathf.DeltaAngle(0, RotationInJointSpace.x),
Mathf.DeltaAngle(0, RotationInJointSpace.y),
Mathf.DeltaAngle(0, RotationInJointSpace.z));
TargetRotationInJointSpace = new Vector3(
Mathf.DeltaAngle(0, TargetRotationInJointSpace.x),
Mathf.DeltaAngle(0, TargetRotationInJointSpace.y),
Mathf.DeltaAngle(0, TargetRotationInJointSpace.z));
RotationInJointSpaceError = new Vector3(
Mathf.DeltaAngle(0, RotationInJointSpaceError.x),
Mathf.DeltaAngle(0, RotationInJointSpaceError.y),
Mathf.DeltaAngle(0, RotationInJointSpaceError.z));
RotationInJointSpaceErrorRad = RotationInJointSpaceError * Mathf.Deg2Rad;
JointTargetDeg.x = TargetRotationInJointSpace.y;
JointTargetDeg.y = TargetRotationInJointSpace.z;
JointTargetDeg.z = TargetRotationInJointSpace.x;
var jointPosition = _body.jointPosition;
JointPositionDeg = Vector3.zero;
int i = 0;
if (_body.twistLock == ArticulationDofLock.LimitedMotion)
JointPositionDeg.x = jointPosition[i++];
if (_body.swingYLock == ArticulationDofLock.LimitedMotion)
JointPositionDeg.y = jointPosition[i++];
if (_body.swingZLock == ArticulationDofLock.LimitedMotion)
JointPositionDeg.z = jointPosition[i++];
float stiffness = 1000f;
float damping = 100f;
JointPositionDeg *= Mathf.Rad2Deg;
bool dontUpdateMotor = _debugController.DontUpdateMotor;
dontUpdateMotor &= _debugController.isActiveAndEnabled;
dontUpdateMotor &= _debugController.gameObject.activeInHierarchy;
if(dontUpdateMotor)
{
// var drive = _body.yDrive;
// drive.stiffness = stiffness;
// drive.damping = damping;
// drive.target = JointTargetDeg.x;
// _body.yDrive = drive;
// drive = _body.zDrive;
// drive.stiffness = stiffness;
// drive.damping = damping;
// drive.target = JointTargetDeg.y;
// _body.zDrive = drive;
// drive = _body.xDrive;
// drive.stiffness = stiffness;
// drive.damping = damping;
// drive.target = JointTargetDeg.z;
// _body.xDrive = drive;
var drive = _body.xDrive;
drive.stiffness = stiffness;
drive.damping = damping;
drive.target = JointTargetDeg.x;
_body.xDrive = drive;
drive = _body.yDrive;
drive.stiffness = stiffness;
drive.damping = damping;
drive.target = JointTargetDeg.y;
_body.yDrive = drive;
drive = _body.zDrive;
drive.stiffness = stiffness;
drive.damping = damping;
drive.target = JointTargetDeg.z;
_body.zDrive = drive;
}
else
{
// var drive = _body.yDrive;
// JointTargetDeg = Vector3.zero;
// JointTargetDeg.x = drive.target;
// drive = _body.zDrive;
// JointTargetDeg.y = drive.target;
// drive = _body.xDrive;
// JointTargetDeg.z = drive.target;
var drive = _body.xDrive;
JointTargetDeg = Vector3.zero;
JointTargetDeg.x = drive.target;
drive = _body.yDrive;
JointTargetDeg.y = drive.target;
drive = _body.zDrive;
JointTargetDeg.z = drive.target;
}
JointPositionRad = JointPositionDeg * Mathf.Deg2Rad;
JointTargetRad = JointTargetDeg * Mathf.Deg2Rad;
}
public static Quaternion FromToRotation(Quaternion from, Quaternion to) {
if (to == from) return Quaternion.identity;
return to * Quaternion.Inverse(from);
}
// void OnDrawGizmos()
void OnDrawGizmosSelected()
{
if (_body == null)
return;
Gizmos.color = Color.white;
Vector3 position = _body.transform.TransformPoint(_body.anchorPosition);
Quaternion rotation = _body.transform.rotation * _body.anchorRotation;
for (int i = 0; i < _axisColor.Length; i++)
{
var axisColor = _axisColor[i];
var axis = _axisVector[i];
Gizmos.color = axisColor;
// Vector3 rotationEul = _body.transform.TransformDirection(_body.anchorRotation * axis);
Vector3 rotationEul = rotation * axis;
Gizmos.DrawSphere(position, SphereSize);
Vector3 direction = rotationEul;
Gizmos.DrawRay(position, direction);
}
}
}