Added targeting to the tp command, also added home as an option for the tp location to

This commit is contained in:
Twirlbug 2023-07-02 21:01:40 -05:00
parent 4e90ed1b03
commit b9489f4bb4
2 changed files with 94 additions and 15 deletions

View file

@ -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

View file

@ -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())
{ {
SRSingleton<SceneContext>.Instance.player.transform.position = player.transform.position; 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)
{
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 else
{ {
ConsoleLog("Usage: tp <username>"); //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
{
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)
{ {