rj-action-library/Runtime/VirtualCameras/MouseEditorCamera.cs

343 lines
7.0 KiB
C#

using System.Diagnostics;
using System.Collections;
using System.Collections.Generic;
using System;
using Godot;
namespace Rokojori
{
[Tool]
[GlobalClass]
public partial class MouseEditorCamera:VirtualCamera3D
{
[Export]
public Vector3 target;
[Export]
public float yaw = 0;
[Export]
public float pitch = 0;
[Export]
public float distance = 10;
float _smoothDistance = 10;
public float smoothDistance => _smoothDistance;
[Export]
public float minPitch = -89;
[Export]
public float maxPitch = 89;
[Export]
public float minDistance = 0.001f;
[Export]
public float maxDistance = 200f;
[Export]
public float zoomSmoothingCoefficient = 0.1f;
Smoother smoother = new Smoother();
public Vector3 moveDirection = Vector3.Zero;
[Export]
public MouseEditorCameraInputSettings keyboardMouseInputs;
[Export]
public MouseEditorCameraInputSettings controllerInputs;
float _cachedDistance = -1;
public void CacheDistance()
{
if ( _cachedDistance < 0 )
{
return;
}
_cachedDistance = distance;
GlobalPosition = target;
distance = minDistance;
this.LogInfo( "Cached Distance", _cachedDistance );
}
public void RestoreDistance()
{
if ( _cachedDistance < 0 )
{
return;
}
this.LogInfo( "Restored Distance", _cachedDistance );
target = GlobalPosition + GlobalBasis.Z * _cachedDistance;
distance = _cachedDistance;
_cachedDistance = -1;
}
/*
[ExportGroup("Orbit")]
[Export]
public float yawSpeed = 1;
[Export]
public float pitchSpeed = 1;
[Export]
public Sensor mouseMovementOrbitButton;
[Export]
public Sensor[] orbitModifierButtons = [];
[Export]
public float yawButtonsSpeed = 1;
[Export]
public Sensor yawDecreaseButton;
[Export]
public Sensor yawIncreaseButton;
[Export]
public float pitchButtonsSpeed = 1;
[Export]
public Sensor pitchDecreaseButton;
[Export]
public Sensor pitchIncreaseButton;
[ExportGroup("Pan")]
[Export]
public float panSpeedX = 0.01f;
[Export]
public float panSpeedY = 0.01f;
[Export]
public Sensor mouseMovementPanButton;
[Export]
public Sensor[] panModifierButtons = new Sensor[ 0 ];
[ExportGroup("Zoom")]
[Export]
public float zoomStepInPercentage = 10;
[Export]
public float minDistance = 0.001f;
[Export]
public float maxDistance = 200f;
[Export]
public Sensor zoomInButton;
[Export]
public Sensor[] zoomInModifierButtons = new Sensor[ 0 ];
[Export]
public Sensor zoomOutButton;
[Export]
public Sensor[] zoomOutModifierButtons = new Sensor[ 0 ];
[Export]
public Sensor continousZoomInButton;
[Export]
public Sensor continousZoomOutButton;
[Export]
public float continousZoomStepInPercentage = 1;
[ExportGroup("Move")]
[Export]
public Sensor forwardButton;
[Export]
public Sensor backwardsButton;
[Export]
public Sensor leftButton;
[Export]
public Sensor rightButton;
[Export]
public Sensor upButton;
[Export]
public Sensor downButton;
[Export]
public float moveSpeed = 1;
*/
[Export]
public float running = 0;
public override void _Process( double delta )
{
keyboardMouseInputs?.Orbit( this );
controllerInputs?.Orbit( this );
keyboardMouseInputs?.Pan( this );
controllerInputs?.Pan( this );
keyboardMouseInputs?.Zoom( this );
controllerInputs?.Zoom( this );
moveDirection = Vector3.Zero;
keyboardMouseInputs?.Move( this );
controllerInputs?.Move( this );
Apply( (float) delta );
if ( ! hasMotionDelta )
{
_motionDelta.X = 0;
_motionDelta.Y = 0;
}
hasMotionDelta = false;
}
bool hasMotionDelta = false;
Vector2 _motionDelta = Vector2.Zero;
public Vector2 motionDelta => _motionDelta;
public override void _Input( InputEvent inputEvent )
{
var mouseMotionEvent = inputEvent as InputEventMouseMotion;
if ( mouseMotionEvent == null )
{
return;
}
_motionDelta = mouseMotionEvent.ScreenRelative;
hasMotionDelta = true;
}
void Apply( float delta )
{
_smoothDistance = smoother.SmoothWithCoefficient( _smoothDistance, distance, zoomSmoothingCoefficient, delta );
GlobalRotation = new Vector3( Mathf.DegToRad( pitch ), Mathf.DegToRad( yaw ), 0 );
var forward = Math3D.GetGlobalForward( this ) * _smoothDistance;
target -= moveDirection * delta;
GlobalPosition = target + forward;
}
/*
void OrbitByMouse()
{
if ( ! Sensors.IsActive( mouseMovementOrbitButton ) )
{
return;
}
yaw += _motionDelta.X * yawSpeed;
pitch += _motionDelta.Y * pitchSpeed;
pitch = Mathf.Clamp( pitch, minPitch, maxPitch );
}
void Orbit()
{
OrbitByMouse();
yaw += Sensors.PolarAxis( yawDecreaseButton, yawIncreaseButton ) * yawButtonsSpeed;
pitch += Sensors.PolarAxis( pitchDecreaseButton, pitchIncreaseButton ) * pitchButtonsSpeed;
}
void Pan()
{
if ( ! Sensors.IsActive( mouseMovementPanButton ) )
{
return;
}
var xAmount = _motionDelta.X * _smoothDistance * GlobalBasis.X * panSpeedX;
var yAmount = _motionDelta.Y * _smoothDistance * GlobalBasis.Y * panSpeedY;
target += xAmount + yAmount;
}
void Zoom()
{
if ( Sensors.IsActive( zoomInButton ) )
{
distance *= Mathf.Pow( 1 + zoomStepInPercentage / 100f, 1 );
}
if ( Sensors.IsActive( zoomOutButton ) )
{
distance *= Mathf.Pow( 1 + zoomStepInPercentage / 100f, -1 );
}
if ( Sensors.IsActive( continousZoomInButton ) )
{
distance *= Mathf.Pow( 1 + continousZoomStepInPercentage / 100f, 1 );
}
if ( Sensors.IsActive( continousZoomOutButton ) )
{
distance *= Mathf.Pow( 1 + continousZoomStepInPercentage / 100f, -1 );
}
distance = Mathf.Clamp( distance, minDistance, maxDistance );
}
void Move()
{
moveDirection = Vector3.Zero;
if ( Sensors.IsActive( forwardButton ) || Sensors.IsActive( backwardsButton ) )
{
moveDirection = ( Sensors.GetValue( forwardButton ) - Sensors.GetValue( backwardsButton ) ) * this.GlobalForward();
}
if ( Sensors.IsActive( rightButton ) || Sensors.IsActive( leftButton ) )
{
moveDirection = ( Sensors.GetValue( rightButton ) - Sensors.GetValue( leftButton ) ) * this.GlobalRight();
}
if ( Sensors.IsActive( upButton ) || Sensors.IsActive( downButton ) )
{
moveDirection = ( Sensors.GetValue( downButton ) - Sensors.GetValue( upButton ) ) * this.GlobalUp();
}
moveDirection = moveDirection.Normalized() * moveSpeed;
}
*/
}
}