You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
67 lines
2.3 KiB
67 lines
2.3 KiB
1 year ago
|
using System.Collections;
|
||
|
using System.Collections.Generic;
|
||
|
using UnityEngine;
|
||
|
using com.rfilkov.kinect;
|
||
|
|
||
|
|
||
|
namespace com.rfilkov.components
|
||
|
{
|
||
|
public class JointAngleCalculator : MonoBehaviour
|
||
|
{
|
||
|
[Tooltip("Index of the player, tracked by this component. 0 means the 1st player, 1 - the 2nd one, 2 - the 3rd one, etc.")]
|
||
|
public int playerIndex = 0;
|
||
|
|
||
|
[Tooltip("First end joint.")]
|
||
|
public KinectInterop.JointType endJoint1 = KinectInterop.JointType.KneeRight;
|
||
|
|
||
|
[Tooltip("Middle joint.")]
|
||
|
public KinectInterop.JointType middleJoint = KinectInterop.JointType.AnkleRight;
|
||
|
|
||
|
[Tooltip("Second end joint.")]
|
||
|
public KinectInterop.JointType endJoint2 = KinectInterop.JointType.FootRight;
|
||
|
|
||
|
[Tooltip("UI Text to display the information messages.")]
|
||
|
public UnityEngine.UI.Text infoText;
|
||
|
|
||
|
|
||
|
// reference to the KinectManager
|
||
|
private KinectManager kinectManager;
|
||
|
|
||
|
|
||
|
void Start()
|
||
|
{
|
||
|
kinectManager = KinectManager.Instance;
|
||
|
}
|
||
|
|
||
|
// Update is called once per frame
|
||
|
void Update()
|
||
|
{
|
||
|
if (kinectManager && kinectManager.IsInitialized())
|
||
|
{
|
||
|
ulong userId = kinectManager.GetUserIdByIndex(playerIndex);
|
||
|
|
||
|
if (userId != 0 &&
|
||
|
kinectManager.IsJointTracked(userId, endJoint1) &&
|
||
|
kinectManager.IsJointTracked(userId, middleJoint) &&
|
||
|
kinectManager.IsJointTracked(userId, endJoint2))
|
||
|
{
|
||
|
Vector3 posEndJoint1 = kinectManager.GetJointPosition(userId, endJoint1);
|
||
|
Vector3 posMiddleJoint = kinectManager.GetJointPosition(userId, middleJoint);
|
||
|
Vector3 posEndJoint2 = kinectManager.GetJointPosition(userId, endJoint2);
|
||
|
|
||
|
Vector3 dirMidEnd1 = (posEndJoint1 - posMiddleJoint).normalized;
|
||
|
Vector3 dirMidEnd2 = (posEndJoint2 - posMiddleJoint).normalized;
|
||
|
float angleMidJoint = Vector3.Angle(dirMidEnd1, dirMidEnd2);
|
||
|
|
||
|
if (infoText != null)
|
||
|
{
|
||
|
infoText.text = string.Format("{0} angle: {1:F0} deg.", middleJoint, angleMidJoint);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
}
|
||
|
|