Added targeting to the tp command, also added home as an option for the tp location to
This commit is contained in:
parent
4e90ed1b03
commit
b9489f4bb4
2 changed files with 94 additions and 15 deletions
|
@ -12,8 +12,9 @@ cheat allgadgets
|
||||||
cheat spawn [id] ([amount])
|
cheat spawn [id] ([amount])
|
||||||
spawns given item for the given ammount
|
spawns given item for the given ammount
|
||||||
|
|
||||||
tp [DestinationPlayer]
|
tp [(optional)TargetPlayer] [DestinationPlayer]
|
||||||
Teleports the player that entered in the commant to the player entered
|
Teleports the player in spot 1 to player/destination entered
|
||||||
|
if spot 1 is empty the palayer that entered in the command in infered as the target
|
||||||
listplayers
|
listplayers
|
||||||
Prints the list of current players to the console
|
Prints the list of current players to the console
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,12 @@
|
||||||
using JetBrains.Annotations;
|
using JetBrains.Annotations;
|
||||||
using MonomiPark.SlimeRancher.Regions;
|
using MonomiPark.SlimeRancher.Regions;
|
||||||
using SRMultiplayer.Networking;
|
using SRMultiplayer.Networking;
|
||||||
|
using SRMultiplayer.Packets;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using System.Net.Sockets;
|
||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
|
|
||||||
namespace SRMultiplayer
|
namespace SRMultiplayer
|
||||||
|
@ -66,7 +68,7 @@ namespace SRMultiplayer
|
||||||
if (message == LastMessage)
|
if (message == LastMessage)
|
||||||
{
|
{
|
||||||
//do not process duplicate marks if the last item was not written
|
//do not process duplicate marks if the last item was not written
|
||||||
if(duplicateCount >0) duplicateCount++;
|
if (duplicateCount > 0) duplicateCount++;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -276,22 +278,97 @@ namespace SRMultiplayer
|
||||||
break;
|
break;
|
||||||
case "tp":
|
case "tp":
|
||||||
{
|
{
|
||||||
if (args.Length == 1)
|
if (args.Length < 1 || args.Length > 2)
|
||||||
{
|
{
|
||||||
var player = Globals.Players.Values.FirstOrDefault(p => p.Username.Equals(args[0], StringComparison.CurrentCultureIgnoreCase));
|
ConsoleLog("Usage: tp <(optional)target:username> <destination>");
|
||||||
if (player != null)
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//mark target and destination seperately
|
||||||
|
string target = args.Length == 2 ? args[0] : "";
|
||||||
|
string destination = args.Length == 2 ? args[1] : args[0];
|
||||||
|
|
||||||
|
//mark target transform location
|
||||||
|
PacketPlayerPosition packet = null;
|
||||||
|
|
||||||
|
//first check distination
|
||||||
|
switch (destination.ToLower())
|
||||||
|
{
|
||||||
|
case "home":
|
||||||
|
|
||||||
|
var home = SRSingleton<SceneContext>.Instance.GetWakeUpDestination();
|
||||||
|
packet = new PacketPlayerPosition()
|
||||||
|
{
|
||||||
|
Position = home.transform.position,
|
||||||
|
Rotation = home.transform.eulerAngles.y,
|
||||||
|
RegionSet = (byte)home.GetRegionSetId()
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
break;
|
||||||
|
default: //check for a player name
|
||||||
|
var play = Globals.Players.Values.FirstOrDefault(p => p.Username.Equals(destination, StringComparison.CurrentCultureIgnoreCase));
|
||||||
|
|
||||||
|
if (play == null)
|
||||||
|
{
|
||||||
|
ConsoleLog("Destination not found");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
packet = new PacketPlayerPosition()
|
||||||
|
{
|
||||||
|
Position = play.transform.position,
|
||||||
|
Rotation = play.transform.eulerAngles.y,
|
||||||
|
RegionSet = (byte)play.CurrentRegionSet
|
||||||
|
};
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (packet != null)
|
||||||
|
{
|
||||||
|
//set as not load destination
|
||||||
|
packet.OnLoad = false;
|
||||||
|
|
||||||
|
NetworkPlayer targetPlayer = null;
|
||||||
|
if (target.Length > 0)
|
||||||
{
|
{
|
||||||
SRSingleton<SceneContext>.Instance.player.transform.position = player.transform.position;
|
targetPlayer = Globals.Players.Values.FirstOrDefault(p => p.Username.Equals(target, StringComparison.CurrentCultureIgnoreCase));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ConsoleLog("Player not found");
|
targetPlayer = Globals.LocalPlayer;
|
||||||
}
|
}
|
||||||
|
//check if target is local user
|
||||||
|
if (targetPlayer == null)
|
||||||
|
{
|
||||||
|
ConsoleLog("Target Player not found");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (!targetPlayer.IsLocal)
|
||||||
|
{
|
||||||
|
//if a target is located and is not the local player send the teleport command
|
||||||
|
packet.WeaponY = targetPlayer.GetWeaponLocation();
|
||||||
|
packet.Send();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//if we have have made it here the tp in question is for the instances player
|
||||||
|
//so move that player
|
||||||
|
SRSingleton<SceneContext>.Instance.player.transform.position = packet.Position;
|
||||||
|
SRSingleton<SceneContext>.Instance.player.transform.eulerAngles = new Vector3(0, packet.Rotation, 0);
|
||||||
|
SRSingleton<SceneContext>.Instance.PlayerState.model.SetCurrRegionSet((RegionRegistry.RegionSetId)packet.RegionSet);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ConsoleLog("Usage: tp <username>");
|
ConsoleLog("Destination not found");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case "listplayers":
|
case "listplayers":
|
||||||
|
@ -318,7 +395,7 @@ namespace SRMultiplayer
|
||||||
break;
|
break;
|
||||||
case "console": //add toggle option for turning on and off logging types
|
case "console": //add toggle option for turning on and off logging types
|
||||||
|
|
||||||
if (args.Length > 1 && (args[0] == "enable"|| args[0] == "disable"))
|
if (args.Length > 1 && (args[0] == "enable" || args[0] == "disable"))
|
||||||
{
|
{
|
||||||
bool enable = args[0] == "enable";
|
bool enable = args[0] == "enable";
|
||||||
//double check type
|
//double check type
|
||||||
|
@ -347,7 +424,8 @@ namespace SRMultiplayer
|
||||||
if (blockLogs.Contains(logMessage)) blockLogs.Add(logMessage);
|
if (blockLogs.Contains(logMessage)) blockLogs.Add(logMessage);
|
||||||
ConsoleLog(logMessage.ToString() + " Log Messages Disabled");
|
ConsoleLog(logMessage.ToString() + " Log Messages Disabled");
|
||||||
}
|
}
|
||||||
}else if (args[1].Equals("stacktrace", StringComparison.InvariantCultureIgnoreCase) || args[1].Equals("stack_trace", StringComparison.InvariantCultureIgnoreCase))
|
}
|
||||||
|
else if (args[1].Equals("stacktrace", StringComparison.InvariantCultureIgnoreCase) || args[1].Equals("stack_trace", StringComparison.InvariantCultureIgnoreCase))
|
||||||
{
|
{
|
||||||
if (enable)
|
if (enable)
|
||||||
{
|
{
|
||||||
|
@ -359,7 +437,7 @@ namespace SRMultiplayer
|
||||||
DisplayTrace = false;
|
DisplayTrace = false;
|
||||||
ConsoleLog("Stack Trace Information Disabled");
|
ConsoleLog("Stack Trace Information Disabled");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ConsoleLog("Invalid Feed back Type");
|
ConsoleLog("Invalid Feed back Type");
|
||||||
|
|
Loading…
Reference in a new issue