|
@@ -20,22 +20,28 @@ namespace Controller
|
|
[RequireComponent(typeof(IBicycleController))]
|
|
[RequireComponent(typeof(IBicycleController))]
|
|
public class SensorBikeController : MonoBehaviour
|
|
public class SensorBikeController : MonoBehaviour
|
|
{
|
|
{
|
|
|
|
+ public enum SteeringMode { frontWheel, Leaning, HMD };
|
|
public PolarRotationMapping polarRotationMapping;
|
|
public PolarRotationMapping polarRotationMapping;
|
|
public FrontWheelTrackerConfig frontWheelTrackerConfig;
|
|
public FrontWheelTrackerConfig frontWheelTrackerConfig;
|
|
|
|
|
|
public bool steer = true;
|
|
public bool steer = true;
|
|
public bool accelerate = true;
|
|
public bool accelerate = true;
|
|
public bool lean = true;
|
|
public bool lean = true;
|
|
|
|
+ public SteeringMode steeringSelection;
|
|
|
|
|
|
private IBicycleController bicycleController;
|
|
private IBicycleController bicycleController;
|
|
private bool isFrontWheelTrackerNotNull;
|
|
private bool isFrontWheelTrackerNotNull;
|
|
private BikeSensorData sensorData;
|
|
private BikeSensorData sensorData;
|
|
|
|
+ private GameObject player;
|
|
|
|
|
|
private void Start()
|
|
private void Start()
|
|
{
|
|
{
|
|
isFrontWheelTrackerNotNull = frontWheelTrackerConfig.frontWheelTracker != null;
|
|
isFrontWheelTrackerNotNull = frontWheelTrackerConfig.frontWheelTracker != null;
|
|
bicycleController = GetComponent<IBicycleController>();
|
|
bicycleController = GetComponent<IBicycleController>();
|
|
sensorData = BikeSensorData.Instance;
|
|
sensorData = BikeSensorData.Instance;
|
|
|
|
+ player = GameObject.FindGameObjectWithTag("HMDTracker");
|
|
|
|
+ // Dummy assignment
|
|
|
|
+ steeringSelection = SteeringMode.HMD;
|
|
}
|
|
}
|
|
|
|
|
|
private void Update()
|
|
private void Update()
|
|
@@ -44,15 +50,30 @@ namespace Controller
|
|
|
|
|
|
if (speedData != null && accelerate) SetSpeed(speedData.Value);
|
|
if (speedData != null && accelerate) SetSpeed(speedData.Value);
|
|
|
|
|
|
- if (isFrontWheelTrackerNotNull && steer) SetSteer();
|
|
|
|
|
|
+ if (steer) SetSteer();
|
|
|
|
|
|
if (lean) SetLeaningAngle();
|
|
if (lean) SetLeaningAngle();
|
|
}
|
|
}
|
|
|
|
|
|
private void SetSteer()
|
|
private void SetSteer()
|
|
{
|
|
{
|
|
- bicycleController.CurrentSteerAngle =
|
|
|
|
- frontWheelTrackerConfig.AdjustedRotation;
|
|
|
|
|
|
+ Debug.Log("Updating Steering");
|
|
|
|
+ switch (steeringSelection) {
|
|
|
|
+ case SteeringMode.frontWheel:
|
|
|
|
+ if (isFrontWheelTrackerNotNull) {
|
|
|
|
+ bicycleController.CurrentSteerAngle = frontWheelTrackerConfig.AdjustedRotation;
|
|
|
|
+ }
|
|
|
|
+ break;
|
|
|
|
+ case SteeringMode.Leaning:
|
|
|
|
+ // TBD
|
|
|
|
+ bicycleController.CurrentSteerAngle = 0;
|
|
|
|
+ break;
|
|
|
|
+ case SteeringMode.HMD:
|
|
|
|
+ // TODO: Convert steering relative to bike
|
|
|
|
+ bicycleController.CurrentSteerAngle = player.transform.rotation.y;
|
|
|
|
+ Debug.Log("Updating Steering Angle to " + bicycleController.CurrentSteerAngle);
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
private void SetLeaningAngle()
|
|
private void SetLeaningAngle()
|
|
@@ -65,4 +86,4 @@ namespace Controller
|
|
bicycleController.CurrentSpeed = speedData.Speed;
|
|
bicycleController.CurrentSpeed = speedData.Speed;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
-}
|
|
|
|
|
|
+}
|