2023-08-16 19:52:35 +02:00
|
|
|
/*
|
|
|
|
godotVmcSharp
|
|
|
|
Copyright (C) 2023 Cassandra de la Cruz-Munoz
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Affero General Public License as published
|
|
|
|
by the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Affero General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
using Godot;
|
|
|
|
using godotOscSharp;
|
|
|
|
|
|
|
|
namespace godotVmcSharp
|
|
|
|
{
|
2023-08-16 19:55:42 +02:00
|
|
|
public class VmcExtDevicePos : VmcMessage
|
2023-08-16 19:52:35 +02:00
|
|
|
{
|
2023-09-24 19:06:26 +02:00
|
|
|
public readonly string Serial;
|
|
|
|
public readonly Transform3D Transform;
|
2023-08-16 19:52:35 +02:00
|
|
|
|
2023-08-17 20:48:26 +02:00
|
|
|
public VmcExtDevicePos(OscMessage m) : base(m.Address)
|
2023-08-16 19:52:35 +02:00
|
|
|
{
|
|
|
|
if (m.Data.Count != 8)
|
|
|
|
{
|
2023-08-18 00:22:27 +02:00
|
|
|
GD.Print($"Invalid number of arguments for {base.Addr}. Expected 8, received {m.Data.Count}.");
|
2023-08-16 19:52:35 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (m.Data[0].Type != 's')
|
|
|
|
{
|
2023-08-18 00:22:27 +02:00
|
|
|
GD.Print(InvalidArgumentType.GetErrorString(Addr, "serial", 's', m.Data[0].Type));
|
2023-08-16 19:52:35 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (m.Data[1].Type != 'f')
|
|
|
|
{
|
2023-08-18 00:22:27 +02:00
|
|
|
GD.Print(InvalidArgumentType.GetErrorString(Addr, "p.x", 'f', m.Data[1].Type));
|
2023-08-16 19:52:35 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (m.Data[2].Type != 'f')
|
|
|
|
{
|
2023-08-18 00:22:27 +02:00
|
|
|
GD.Print(InvalidArgumentType.GetErrorString(Addr, "p.y", 'f', m.Data[2].Type));
|
2023-08-16 19:52:35 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (m.Data[3].Type != 'f')
|
|
|
|
{
|
2023-08-18 00:22:27 +02:00
|
|
|
GD.Print(InvalidArgumentType.GetErrorString(Addr, "p.z", 'f', m.Data[3].Type));
|
2023-08-16 19:52:35 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (m.Data[4].Type != 'f')
|
|
|
|
{
|
2023-08-18 00:22:27 +02:00
|
|
|
GD.Print(InvalidArgumentType.GetErrorString(Addr, "q.x", 'f', m.Data[4].Type));
|
2023-08-16 19:52:35 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (m.Data[5].Type != 'f')
|
|
|
|
{
|
2023-08-18 00:22:27 +02:00
|
|
|
GD.Print(InvalidArgumentType.GetErrorString(Addr, "q.y", 'f', m.Data[5].Type));
|
2023-08-16 19:52:35 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (m.Data[6].Type != 'f')
|
|
|
|
{
|
2023-08-18 00:22:27 +02:00
|
|
|
GD.Print(InvalidArgumentType.GetErrorString(Addr, "q.z", 'f', m.Data[6].Type));
|
2023-08-16 19:52:35 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (m.Data[7].Type != 'f')
|
|
|
|
{
|
2023-08-18 00:22:27 +02:00
|
|
|
GD.Print(InvalidArgumentType.GetErrorString(Addr, "q.w", 'f', m.Data[7].Type));
|
2023-08-16 19:52:35 +02:00
|
|
|
return;
|
|
|
|
}
|
2023-08-17 20:48:26 +02:00
|
|
|
Serial = (string)m.Data[0].Value;
|
|
|
|
Transform = new Transform3D(new Basis(new Quaternion((float)m.Data[4].Value, (float)m.Data[5].Value, (float)m.Data[6].Value, (float)m.Data[7].Value)), new Vector3((float)m.Data[1].Value, (float)m.Data[2].Value, (float)m.Data[3].Value));
|
2023-08-16 19:52:35 +02:00
|
|
|
}
|
2023-08-17 01:34:48 +02:00
|
|
|
|
2023-08-18 00:22:27 +02:00
|
|
|
public VmcExtDevicePos(OscAddress Addr, string serial, Transform3D transform) : base(Addr)
|
2023-08-17 01:34:48 +02:00
|
|
|
{
|
2023-08-17 20:48:26 +02:00
|
|
|
Serial = serial;
|
|
|
|
Transform = transform;
|
2023-08-17 01:34:48 +02:00
|
|
|
}
|
2023-08-17 01:40:16 +02:00
|
|
|
|
2023-08-17 20:48:26 +02:00
|
|
|
public new OscMessage ToMessage()
|
2023-08-17 01:40:16 +02:00
|
|
|
{
|
2023-08-17 20:48:26 +02:00
|
|
|
var quat = Transform.Basis.GetRotationQuaternion();
|
2023-08-18 00:22:27 +02:00
|
|
|
return new OscMessage(Addr, new System.Collections.Generic.List<OscArgument>{
|
2023-08-17 20:48:26 +02:00
|
|
|
new OscArgument(Serial, 's'),
|
|
|
|
new OscArgument(Transform.Origin.X, 'f'),
|
|
|
|
new OscArgument(Transform.Origin.Y, 'f'),
|
|
|
|
new OscArgument(Transform.Origin.Z, 'f'),
|
|
|
|
new OscArgument(quat.X, 'f'),
|
|
|
|
new OscArgument(quat.Y, 'f'),
|
|
|
|
new OscArgument(quat.Z, 'f'),
|
|
|
|
new OscArgument(quat.W, 'f')
|
2023-08-17 01:40:16 +02:00
|
|
|
});
|
|
|
|
}
|
2023-08-16 19:52:35 +02:00
|
|
|
}
|
|
|
|
}
|