Compare commits
14 Commits
Author | SHA1 | Date | |
---|---|---|---|
39b780e518 | |||
4a54851c51 | |||
f0eefa575c | |||
3fc813b2d8 | |||
fbff72ff14 | |||
4e52407591 | |||
4e6fde129d | |||
92e1a970a8 | |||
d0eb0b7818 | |||
14151d7b2c | |||
1f8d70a520 | |||
2cb5baf5f7 | |||
34e33937e2 | |||
9287aba0f9 |
21
.github/workflows/nightly-build.yaml
vendored
21
.github/workflows/nightly-build.yaml
vendored
@ -28,8 +28,6 @@ jobs:
|
|||||||
run: dotnet publish RageCoop.Server/RageCoop.Server.csproj --self-contained -p:PublishSingleFile=true -p:PublishTrimmed=false -r win-x64 -o bin/Release/Server/win-x64 -c Release
|
run: dotnet publish RageCoop.Server/RageCoop.Server.csproj --self-contained -p:PublishSingleFile=true -p:PublishTrimmed=false -r win-x64 -o bin/Release/Server/win-x64 -c Release
|
||||||
- name: Build server linux-x64
|
- name: Build server linux-x64
|
||||||
run: dotnet publish RageCoop.Server/RageCoop.Server.csproj --self-contained -p:PublishSingleFile=true -p:PublishTrimmed=false -r linux-x64 -o bin/Release/Server/linux-x64 -c Release
|
run: dotnet publish RageCoop.Server/RageCoop.Server.csproj --self-contained -p:PublishSingleFile=true -p:PublishTrimmed=false -r linux-x64 -o bin/Release/Server/linux-x64 -c Release
|
||||||
- name: Build server linux-arm
|
|
||||||
run: dotnet publish RageCoop.Server/RageCoop.Server.csproj --self-contained -p:PublishSingleFile=true -p:PublishTrimmed=false -r linux-arm -o bin/Release/Server/linux-arm -c Release
|
|
||||||
- uses: vimtor/action-zip@v1
|
- uses: vimtor/action-zip@v1
|
||||||
with:
|
with:
|
||||||
files: bin/Release/Client
|
files: bin/Release/Client
|
||||||
@ -45,11 +43,6 @@ jobs:
|
|||||||
files: bin/Release/Server/linux-x64
|
files: bin/Release/Server/linux-x64
|
||||||
dest: RageCoop.Server-linux-x64.zip
|
dest: RageCoop.Server-linux-x64.zip
|
||||||
|
|
||||||
- uses: vimtor/action-zip@v1
|
|
||||||
with:
|
|
||||||
files: bin/Release/Server/linux-arm
|
|
||||||
dest: RageCoop.Server-linux-arm.zip
|
|
||||||
|
|
||||||
- uses: WebFreak001/deploy-nightly@v1.1.0
|
- uses: WebFreak001/deploy-nightly@v1.1.0
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # automatically provided by github actions
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # automatically provided by github actions
|
||||||
@ -82,17 +75,3 @@ jobs:
|
|||||||
asset_name: RageCoop.Server-linux-x64.zip
|
asset_name: RageCoop.Server-linux-x64.zip
|
||||||
asset_content_type: application/zip
|
asset_content_type: application/zip
|
||||||
max_releases: 7
|
max_releases: 7
|
||||||
|
|
||||||
|
|
||||||
- uses: WebFreak001/deploy-nightly@v1.1.0
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # automatically provided by github actions
|
|
||||||
with:
|
|
||||||
upload_url: https://uploads.github.com/repos/RAGECOOP/RAGECOOP-V/releases/70603992/assets{?name,label}
|
|
||||||
release_id: 70603992
|
|
||||||
asset_path: RageCoop.Server-linux-arm.zip
|
|
||||||
asset_name: RageCoop.Server-linux-arm.zip
|
|
||||||
asset_content_type: application/zip
|
|
||||||
max_releases: 7
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@ RAGECOOP brings multiplayer experience to the story mode, you can complete missi
|
|||||||
|
|
||||||
# 👁 Requirements
|
# 👁 Requirements
|
||||||
- ScriptHookV
|
- ScriptHookV
|
||||||
- ScriptHookVDotNet 3.5.1 or later
|
- ScriptHookVDotNet 3.6.0 or later
|
||||||
- .NET Framework 4.8 Runtime or SDK
|
- .NET Framework 4.8 Runtime or SDK
|
||||||
|
|
||||||
# 📋 Building the project
|
# 📋 Building the project
|
||||||
@ -49,7 +49,7 @@ Then run `dotnet build` in the solution directory, built binaries are in the `bi
|
|||||||
5. Decent compatibility with other mods, set up a private modded server to have some fun!
|
5. Decent compatibility with other mods, set up a private modded server to have some fun!
|
||||||
6. Weaponized vehicle sync(WIP).
|
6. Weaponized vehicle sync(WIP).
|
||||||
7. Optimization for high-Ping condition, play with friends around the world!
|
7. Optimization for high-Ping condition, play with friends around the world!
|
||||||
8. Powerful scripting API and resource system, easily [add multiplayer functionality to your mod](HTTPS://docs.ragecoop.online).
|
8. Powerful scripting API and resource system, easily [add multiplayer functionality to your mod](HTTPS://docs.ragecoop.com).
|
||||||
|
|
||||||
# ⚠ Known issues
|
# ⚠ Known issues
|
||||||
|
|
||||||
|
@ -170,7 +170,7 @@ namespace RageCoop.Client
|
|||||||
P.Health = 1;
|
P.Health = 1;
|
||||||
Game.Player.WantedLevel = 0;
|
Game.Player.WantedLevel = 0;
|
||||||
Main.Logger.Debug("Player died.");
|
Main.Logger.Debug("Player died.");
|
||||||
Scripting.API.Events.InvokePlayerDied();
|
Scripting.API.Events.InvokePlayerDied(KillMessage());
|
||||||
}
|
}
|
||||||
GTA.UI.Screen.StopEffects();
|
GTA.UI.Screen.StopEffects();
|
||||||
}
|
}
|
||||||
@ -181,7 +181,7 @@ namespace RageCoop.Client
|
|||||||
}
|
}
|
||||||
else if (P.IsDead && !_lastDead)
|
else if (P.IsDead && !_lastDead)
|
||||||
{
|
{
|
||||||
Scripting.API.Events.InvokePlayerDied();
|
Scripting.API.Events.InvokePlayerDied(KillMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
_lastDead = P.IsDead;
|
_lastDead = P.IsDead;
|
||||||
@ -326,6 +326,7 @@ namespace RageCoop.Client
|
|||||||
WorldThread.Traffic(true);
|
WorldThread.Traffic(true);
|
||||||
Function.Call(Hash.SET_ENABLE_VEHICLE_SLIPSTREAMING, false);
|
Function.Call(Hash.SET_ENABLE_VEHICLE_SLIPSTREAMING, false);
|
||||||
CoopMenu.DisconnectedMenuSetting();
|
CoopMenu.DisconnectedMenuSetting();
|
||||||
|
if (reason != "Abort")
|
||||||
GTA.UI.Notification.Show("~r~Disconnected: " + reason);
|
GTA.UI.Notification.Show("~r~Disconnected: " + reason);
|
||||||
LocalPlayerID = default;
|
LocalPlayerID = default;
|
||||||
});
|
});
|
||||||
@ -393,5 +394,15 @@ namespace RageCoop.Client
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private string KillMessage()
|
||||||
|
{
|
||||||
|
if (P.Killer != null)
|
||||||
|
{
|
||||||
|
var killer = EntityPool.GetPedByHandle(P.Killer.Handle);
|
||||||
|
if (killer != null && killer.ID == killer.Owner.ID)
|
||||||
|
return $"~h~{PlayerList.GetPlayer(LocalPlayerID).Username}~h~ was killed by ~h~{killer.Owner.Username}~h~ ({P.CauseOfDeath})";
|
||||||
|
}
|
||||||
|
return $"~h~{PlayerList.GetPlayer(LocalPlayerID).Username}~h~ died";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -50,7 +50,7 @@ namespace RageCoop.Client.Menus
|
|||||||
{
|
{
|
||||||
|
|
||||||
Menu.Banner.Color = Color.FromArgb(225, 0, 0, 0);
|
Menu.Banner.Color = Color.FromArgb(225, 0, 0, 0);
|
||||||
Menu.Title.Color = Color.FromArgb(255, 165, 0);
|
Menu.BannerText.Color = Color.FromArgb(255, 165, 0);
|
||||||
|
|
||||||
_usernameItem.Activated += UsernameActivated;
|
_usernameItem.Activated += UsernameActivated;
|
||||||
_passwordItem.Activated += _passwordActivated;
|
_passwordItem.Activated += _passwordActivated;
|
||||||
|
@ -25,7 +25,7 @@ namespace RageCoop.Client
|
|||||||
static DebugMenu()
|
static DebugMenu()
|
||||||
{
|
{
|
||||||
Menu.Banner.Color = Color.FromArgb(225, 0, 0, 0);
|
Menu.Banner.Color = Color.FromArgb(225, 0, 0, 0);
|
||||||
Menu.Title.Color = Color.FromArgb(255, 165, 0);
|
Menu.BannerText.Color = Color.FromArgb(255, 165, 0);
|
||||||
|
|
||||||
|
|
||||||
DiagnosticMenu.Opening += (sender, e) =>
|
DiagnosticMenu.Opening += (sender, e) =>
|
||||||
|
@ -22,7 +22,7 @@ namespace RageCoop.Client
|
|||||||
static DevToolMenu()
|
static DevToolMenu()
|
||||||
{
|
{
|
||||||
Menu.Banner.Color = Color.FromArgb(225, 0, 0, 0);
|
Menu.Banner.Color = Color.FromArgb(225, 0, 0, 0);
|
||||||
Menu.Title.Color = Color.FromArgb(255, 165, 0);
|
Menu.BannerText.Color = Color.FromArgb(255, 165, 0);
|
||||||
|
|
||||||
enableItem.Activated += enableItem_Activated;
|
enableItem.Activated += enableItem_Activated;
|
||||||
enableItem.Checked = false;
|
enableItem.Checked = false;
|
||||||
|
@ -30,7 +30,7 @@ namespace RageCoop.Client.Menus
|
|||||||
static ServersMenu()
|
static ServersMenu()
|
||||||
{
|
{
|
||||||
Menu.Banner.Color = Color.FromArgb(225, 0, 0, 0);
|
Menu.Banner.Color = Color.FromArgb(225, 0, 0, 0);
|
||||||
Menu.Title.Color = Color.FromArgb(255, 165, 0);
|
Menu.BannerText.Color = Color.FromArgb(255, 165, 0);
|
||||||
|
|
||||||
Menu.Opening += (object sender, System.ComponentModel.CancelEventArgs e) =>
|
Menu.Opening += (object sender, System.ComponentModel.CancelEventArgs e) =>
|
||||||
{
|
{
|
||||||
@ -76,7 +76,7 @@ namespace RageCoop.Client.Menus
|
|||||||
foreach (ServerInfo server in serverList)
|
foreach (ServerInfo server in serverList)
|
||||||
{
|
{
|
||||||
string address = $"{server.address}:{server.port}";
|
string address = $"{server.address}:{server.port}";
|
||||||
NativeItem tmpItem = new NativeItem($"[{server.country}] {server.name}", $"~b~{address}~s~~n~~g~Version {server.version}.x~s~") { AltTitle = $"[{server.players}/{server.maxPlayers}]" };
|
NativeItem tmpItem = new NativeItem($"[{server.country}] {server.name}", $"~b~{address}~s~~n~~g~Version {server.version}~s~") { AltTitle = $"[{server.players}/{server.maxPlayers}]" };
|
||||||
tmpItem.Activated += (object sender, EventArgs e) =>
|
tmpItem.Activated += (object sender, EventArgs e) =>
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
|
@ -17,6 +17,8 @@ namespace RageCoop.Client.Menus
|
|||||||
private static readonly NativeCheckboxItem _disableTrafficItem = new NativeCheckboxItem("Disable Traffic (NPCs/Vehicles)", "Local traffic only", Main.Settings.DisableTraffic);
|
private static readonly NativeCheckboxItem _disableTrafficItem = new NativeCheckboxItem("Disable Traffic (NPCs/Vehicles)", "Local traffic only", Main.Settings.DisableTraffic);
|
||||||
private static readonly NativeCheckboxItem _flipMenuItem = new NativeCheckboxItem("Flip menu", Main.Settings.FlipMenu);
|
private static readonly NativeCheckboxItem _flipMenuItem = new NativeCheckboxItem("Flip menu", Main.Settings.FlipMenu);
|
||||||
private static readonly NativeCheckboxItem _disablePauseAlt = new NativeCheckboxItem("Disable Alternate Pause", "Don't freeze game time when Esc pressed", Main.Settings.DisableAlternatePause);
|
private static readonly NativeCheckboxItem _disablePauseAlt = new NativeCheckboxItem("Disable Alternate Pause", "Don't freeze game time when Esc pressed", Main.Settings.DisableAlternatePause);
|
||||||
|
private static readonly NativeCheckboxItem _showBlip = new NativeCheckboxItem("Show player blip", "Show other player's blip on map", Main.Settings.ShowPlayerBlip);
|
||||||
|
private static readonly NativeCheckboxItem _showNametag = new NativeCheckboxItem("Show player nametag", "Show other player's nametag on your screen", Main.Settings.ShowPlayerNameTag);
|
||||||
private static readonly NativeCheckboxItem _disableVoice = new NativeCheckboxItem("Enable voice", "Check your GTA:V settings to find the right key on your keyboard for PushToTalk and talk to your friends", Main.Settings.Voice);
|
private static readonly NativeCheckboxItem _disableVoice = new NativeCheckboxItem("Enable voice", "Check your GTA:V settings to find the right key on your keyboard for PushToTalk and talk to your friends", Main.Settings.Voice);
|
||||||
|
|
||||||
private static readonly NativeItem _menuKey = new NativeItem("Menu Key", "The key to open menu", Main.Settings.MenuKey.ToString());
|
private static readonly NativeItem _menuKey = new NativeItem("Menu Key", "The key to open menu", Main.Settings.MenuKey.ToString());
|
||||||
@ -26,7 +28,7 @@ namespace RageCoop.Client.Menus
|
|||||||
static SettingsMenu()
|
static SettingsMenu()
|
||||||
{
|
{
|
||||||
Menu.Banner.Color = Color.FromArgb(225, 0, 0, 0);
|
Menu.Banner.Color = Color.FromArgb(225, 0, 0, 0);
|
||||||
Menu.Title.Color = Color.FromArgb(255, 165, 0);
|
Menu.BannerText.Color = Color.FromArgb(255, 165, 0);
|
||||||
|
|
||||||
_disableTrafficItem.CheckboxChanged += DisableTrafficCheckboxChanged;
|
_disableTrafficItem.CheckboxChanged += DisableTrafficCheckboxChanged;
|
||||||
_disablePauseAlt.CheckboxChanged += DisablePauseAltCheckboxChanged;
|
_disablePauseAlt.CheckboxChanged += DisablePauseAltCheckboxChanged;
|
||||||
@ -35,6 +37,16 @@ namespace RageCoop.Client.Menus
|
|||||||
_menuKey.Activated += ChaneMenuKey;
|
_menuKey.Activated += ChaneMenuKey;
|
||||||
_passengerKey.Activated += ChangePassengerKey;
|
_passengerKey.Activated += ChangePassengerKey;
|
||||||
_vehicleSoftLimit.Activated += VehicleSoftLimitActivated;
|
_vehicleSoftLimit.Activated += VehicleSoftLimitActivated;
|
||||||
|
_showBlip.Activated += (s, e) =>
|
||||||
|
{
|
||||||
|
Main.Settings.ShowPlayerBlip = _showBlip.Checked;
|
||||||
|
Util.SaveSettings();
|
||||||
|
};
|
||||||
|
_showNametag.Activated += (s, e) =>
|
||||||
|
{
|
||||||
|
Main.Settings.ShowPlayerNameTag = _showNametag.Checked;
|
||||||
|
Util.SaveSettings();
|
||||||
|
};
|
||||||
|
|
||||||
Menu.Add(_disableTrafficItem);
|
Menu.Add(_disableTrafficItem);
|
||||||
Menu.Add(_disablePauseAlt);
|
Menu.Add(_disablePauseAlt);
|
||||||
@ -43,6 +55,8 @@ namespace RageCoop.Client.Menus
|
|||||||
Menu.Add(_menuKey);
|
Menu.Add(_menuKey);
|
||||||
Menu.Add(_passengerKey);
|
Menu.Add(_passengerKey);
|
||||||
Menu.Add(_vehicleSoftLimit);
|
Menu.Add(_vehicleSoftLimit);
|
||||||
|
Menu.Add(_showBlip);
|
||||||
|
Menu.Add(_showNametag);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void DisableVoiceCheckboxChanged(object sender, EventArgs e)
|
private static void DisableVoiceCheckboxChanged(object sender, EventArgs e)
|
||||||
|
@ -30,16 +30,16 @@ namespace RageCoop.Client
|
|||||||
public static void ToggleConnection(string address, string username = null, string password = null, PublicKey publicKey = null)
|
public static void ToggleConnection(string address, string username = null, string password = null, PublicKey publicKey = null)
|
||||||
{
|
{
|
||||||
Menus.CoopMenu.Menu.Visible = false;
|
Menus.CoopMenu.Menu.Visible = false;
|
||||||
Peer?.Shutdown("Bye");
|
if (IsConnecting)
|
||||||
if (IsOnServer)
|
|
||||||
{
|
|
||||||
// ?
|
|
||||||
}
|
|
||||||
else if (IsConnecting)
|
|
||||||
{
|
{
|
||||||
_publicKeyReceived.Set();
|
_publicKeyReceived.Set();
|
||||||
IsConnecting = false;
|
IsConnecting = false;
|
||||||
Notification.Show("Connection has been canceled");
|
Main.QueueAction(() => Notification.Show("Connection has been canceled"));
|
||||||
|
Peer?.Shutdown("Bye");
|
||||||
|
}
|
||||||
|
else if (IsOnServer)
|
||||||
|
{
|
||||||
|
Peer?.Shutdown("Bye");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -159,6 +159,7 @@ namespace RageCoop.Client
|
|||||||
Main.Logger.Error(ex);
|
Main.Logger.Error(ex);
|
||||||
Peer.Shutdown($"Packet Error [{packetType}]");
|
Peer.Shutdown($"Packet Error [{packetType}]");
|
||||||
#endif
|
#endif
|
||||||
|
_recycle = false;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -293,7 +294,7 @@ namespace RageCoop.Client
|
|||||||
{
|
{
|
||||||
recycle = false;
|
recycle = false;
|
||||||
// Dispatch to script thread
|
// Dispatch to script thread
|
||||||
Main.QueueAction(() => { SyncEvents.HandleEvent(packetType, msg); Peer.Recycle(msg); return true; });
|
Main.QueueAction(() => { SyncEvents.HandleEvent(packetType, msg); return true; });
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -305,7 +306,9 @@ namespace RageCoop.Client
|
|||||||
if (c == null)
|
if (c == null)
|
||||||
{
|
{
|
||||||
// Main.Logger.Debug($"Creating character for incoming sync:{packet.ID}");
|
// Main.Logger.Debug($"Creating character for incoming sync:{packet.ID}");
|
||||||
|
if (EntityPool.allPeds.Length < Main.Settings.GlobalPedSoftLimit || PlayerList.Players.ContainsKey(packet.ID))
|
||||||
EntityPool.ThreadSafe.Add(c = new SyncedPed(packet.ID));
|
EntityPool.ThreadSafe.Add(c = new SyncedPed(packet.ID));
|
||||||
|
else return;
|
||||||
}
|
}
|
||||||
PedDataFlags flags = packet.Flags;
|
PedDataFlags flags = packet.Flags;
|
||||||
c.ID = packet.ID;
|
c.ID = packet.ID;
|
||||||
@ -353,7 +356,9 @@ namespace RageCoop.Client
|
|||||||
SyncedVehicle v = EntityPool.GetVehicleByID(packet.ID);
|
SyncedVehicle v = EntityPool.GetVehicleByID(packet.ID);
|
||||||
if (v == null)
|
if (v == null)
|
||||||
{
|
{
|
||||||
|
if (EntityPool.allVehicles.Length < Main.Settings.GlobalVehicleSoftLimit)
|
||||||
EntityPool.ThreadSafe.Add(v = new SyncedVehicle(packet.ID));
|
EntityPool.ThreadSafe.Add(v = new SyncedVehicle(packet.ID));
|
||||||
|
else return;
|
||||||
}
|
}
|
||||||
if (v.IsLocal) { return; }
|
if (v.IsLocal) { return; }
|
||||||
v.ID = packet.ID;
|
v.ID = packet.ID;
|
||||||
@ -393,7 +398,9 @@ namespace RageCoop.Client
|
|||||||
{
|
{
|
||||||
if (packet.Flags.HasProjDataFlag(ProjectileDataFlags.Exploded)) { return; }
|
if (packet.Flags.HasProjDataFlag(ProjectileDataFlags.Exploded)) { return; }
|
||||||
// Main.Logger.Debug($"Creating new projectile: {(WeaponHash)packet.WeaponHash}");
|
// Main.Logger.Debug($"Creating new projectile: {(WeaponHash)packet.WeaponHash}");
|
||||||
|
if (EntityPool.allProjectiles.Length < Main.Settings.GlobalProjectileSoftLimit)
|
||||||
EntityPool.ThreadSafe.Add(p = new SyncedProjectile(packet.ID));
|
EntityPool.ThreadSafe.Add(p = new SyncedProjectile(packet.ID));
|
||||||
|
else return;
|
||||||
}
|
}
|
||||||
p.Flags = packet.Flags;
|
p.Flags = packet.Flags;
|
||||||
p.Position = packet.Position;
|
p.Position = packet.Position;
|
||||||
|
@ -15,8 +15,8 @@ using System.Resources;
|
|||||||
[assembly: AssemblyCulture("")]
|
[assembly: AssemblyCulture("")]
|
||||||
|
|
||||||
|
|
||||||
// Version informationr(
|
// Version information
|
||||||
[assembly: AssemblyVersion("1.5.4.4")]
|
[assembly: AssemblyVersion("1.5.4.6")]
|
||||||
[assembly: AssemblyFileVersion("1.5.4.4")]
|
[assembly: AssemblyFileVersion("1.5.4.6")]
|
||||||
[assembly: NeutralResourcesLanguageAttribute( "en-US" )]
|
[assembly: NeutralResourcesLanguageAttribute( "en-US" )]
|
||||||
|
|
||||||
|
@ -90,7 +90,7 @@
|
|||||||
<Reference Include="ICSharpCode.SharpZipLib, Version=1.3.3.11, Culture=neutral, PublicKeyToken=1b03e6acf1164f73, processorArchitecture=MSIL">
|
<Reference Include="ICSharpCode.SharpZipLib, Version=1.3.3.11, Culture=neutral, PublicKeyToken=1b03e6acf1164f73, processorArchitecture=MSIL">
|
||||||
<HintPath>..\packages\SharpZipLib.1.3.3\lib\net45\ICSharpCode.SharpZipLib.dll</HintPath>
|
<HintPath>..\packages\SharpZipLib.1.3.3\lib\net45\ICSharpCode.SharpZipLib.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="LemonUI.SHVDN3, Version=1.7.0.0, Culture=neutral, processorArchitecture=AMD64">
|
<Reference Include="LemonUI.SHVDN3, Version=1.10.0.0, Culture=neutral, processorArchitecture=AMD64">
|
||||||
<SpecificVersion>False</SpecificVersion>
|
<SpecificVersion>False</SpecificVersion>
|
||||||
<HintPath>..\libs\LemonUI.SHVDN3.dll</HintPath>
|
<HintPath>..\libs\LemonUI.SHVDN3.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
|
@ -91,7 +91,7 @@ namespace RageCoop.Client.Scripting
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// The local player is dead
|
/// The local player is dead
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static event EmptyEvent OnPlayerDied;
|
public static event EventHandler<string> OnPlayerDied;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// A local vehicle is spawned
|
/// A local vehicle is spawned
|
||||||
@ -133,7 +133,7 @@ namespace RageCoop.Client.Scripting
|
|||||||
internal static void InvokeVehicleDeleted(SyncedVehicle v) { OnVehicleDeleted?.Invoke(null, v); }
|
internal static void InvokeVehicleDeleted(SyncedVehicle v) { OnVehicleDeleted?.Invoke(null, v); }
|
||||||
internal static void InvokePedSpawned(SyncedPed p) { OnPedSpawned?.Invoke(null, p); }
|
internal static void InvokePedSpawned(SyncedPed p) { OnPedSpawned?.Invoke(null, p); }
|
||||||
internal static void InvokePedDeleted(SyncedPed p) { OnPedDeleted?.Invoke(null, p); }
|
internal static void InvokePedDeleted(SyncedPed p) { OnPedDeleted?.Invoke(null, p); }
|
||||||
internal static void InvokePlayerDied() { OnPlayerDied?.Invoke(); }
|
internal static void InvokePlayerDied(string m) { OnPlayerDied?.Invoke(null, m); }
|
||||||
internal static void InvokeTick() { OnTick?.Invoke(); }
|
internal static void InvokeTick() { OnTick?.Invoke(); }
|
||||||
|
|
||||||
internal static void InvokeKeyDown(object s, KeyEventArgs e) { OnKeyDown?.Invoke(s, e); }
|
internal static void InvokeKeyDown(object s, KeyEventArgs e) { OnKeyDown?.Invoke(s, e); }
|
||||||
|
@ -16,7 +16,7 @@ namespace RageCoop.Client.Scripting
|
|||||||
{
|
{
|
||||||
API.Events.OnPedDeleted += (s, p) => { API.SendCustomEvent(CustomEvents.OnPedDeleted, p.ID); };
|
API.Events.OnPedDeleted += (s, p) => { API.SendCustomEvent(CustomEvents.OnPedDeleted, p.ID); };
|
||||||
API.Events.OnVehicleDeleted += (s, p) => { API.SendCustomEvent(CustomEvents.OnVehicleDeleted, p.ID); };
|
API.Events.OnVehicleDeleted += (s, p) => { API.SendCustomEvent(CustomEvents.OnVehicleDeleted, p.ID); };
|
||||||
API.Events.OnPlayerDied += () => { API.SendCustomEvent(CustomEvents.OnPlayerDied); };
|
API.Events.OnPlayerDied += (s, m) => { API.SendCustomEvent(CustomEvents.OnPlayerDied, m); };
|
||||||
|
|
||||||
API.RegisterCustomEventHandler(CustomEvents.SetAutoRespawn, SetAutoRespawn);
|
API.RegisterCustomEventHandler(CustomEvents.SetAutoRespawn, SetAutoRespawn);
|
||||||
API.RegisterCustomEventHandler(CustomEvents.SetDisplayNameTag, SetDisplayNameTag);
|
API.RegisterCustomEventHandler(CustomEvents.SetDisplayNameTag, SetDisplayNameTag);
|
||||||
@ -31,7 +31,7 @@ namespace RageCoop.Client.Scripting
|
|||||||
API.RegisterCustomEventHandler(CustomEvents.UpdatePedBlip, UpdatePedBlip);
|
API.RegisterCustomEventHandler(CustomEvents.UpdatePedBlip, UpdatePedBlip);
|
||||||
API.RegisterCustomEventHandler(CustomEvents.IsHost, (e) => { _isHost = (bool)e.Args[0]; });
|
API.RegisterCustomEventHandler(CustomEvents.IsHost, (e) => { _isHost = (bool)e.Args[0]; });
|
||||||
API.RegisterCustomEventHandler(CustomEvents.WeatherTimeSync, WeatherTimeSync);
|
API.RegisterCustomEventHandler(CustomEvents.WeatherTimeSync, WeatherTimeSync);
|
||||||
API.RegisterCustomEventHandler(CustomEvents.OnPlayerDied, (e) => { GTA.UI.Notification.Show($"~h~{e.Args[0]}~h~ died."); });
|
API.RegisterCustomEventHandler(CustomEvents.OnPlayerDied, (e) => { GTA.UI.Notification.Show((string)e.Args[0]); });
|
||||||
Task.Run(() =>
|
Task.Run(() =>
|
||||||
{
|
{
|
||||||
while (true)
|
while (true)
|
||||||
|
@ -67,6 +67,22 @@ namespace RageCoop.Client
|
|||||||
/// The game won't spawn more NPC traffic if the limit is exceeded. -1 for unlimited (not recommended).
|
/// The game won't spawn more NPC traffic if the limit is exceeded. -1 for unlimited (not recommended).
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public int WorldPedSoftLimit { get; set; } = 30;
|
public int WorldPedSoftLimit { get; set; } = 30;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The mod won't sync more vehicles if the limit is exceeded.
|
||||||
|
/// </summary>
|
||||||
|
public int GlobalVehicleSoftLimit { get; set; } = 100;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The mod won't sync more peds if the limit is exceeded.
|
||||||
|
/// </summary>
|
||||||
|
public int GlobalPedSoftLimit { get; set; } = 100;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// The mod won't sync more projectiles if the limit is exceeded.
|
||||||
|
/// </summary>
|
||||||
|
public int GlobalProjectileSoftLimit { get; set; } = 100;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// The directory where log and resources downloaded from server will be placed.
|
/// The directory where log and resources downloaded from server will be placed.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -76,5 +92,15 @@ namespace RageCoop.Client
|
|||||||
/// Show the owner name of the entity you're aiming at
|
/// Show the owner name of the entity you're aiming at
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public bool ShowEntityOwnerName { get; set; } = false;
|
public bool ShowEntityOwnerName { get; set; } = false;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Show other player's nametag on your screen
|
||||||
|
/// </summary>
|
||||||
|
public bool ShowPlayerNameTag { get; set; } = true;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Show other player's blip on map
|
||||||
|
/// </summary>
|
||||||
|
public bool ShowPlayerBlip { get; set; } = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -28,7 +28,7 @@ namespace RageCoop.Client
|
|||||||
MainPed = p;
|
MainPed = p;
|
||||||
OwnerID = Main.LocalPlayerID;
|
OwnerID = Main.LocalPlayerID;
|
||||||
|
|
||||||
Function.Call(Hash.SET_PED_IS_IGNORED_BY_AUTO_OPEN_DOORS, false);
|
//Function.Call(Hash.SET_PED_IS_IGNORED_BY_AUTO_OPEN_DOORS, false);
|
||||||
MainPed.SetConfigFlag((int)PedConfigFlags.CPED_CONFIG_FLAG_DisableHurt, true);
|
MainPed.SetConfigFlag((int)PedConfigFlags.CPED_CONFIG_FLAG_DisableHurt, true);
|
||||||
// MainPed.SetConfigFlag((int)PedConfigFlags.CPED_CONFIG_FLAG_DisableMelee, true);
|
// MainPed.SetConfigFlag((int)PedConfigFlags.CPED_CONFIG_FLAG_DisableMelee, true);
|
||||||
|
|
||||||
@ -76,12 +76,13 @@ namespace RageCoop.Client
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (((byte)BlipColor == 255) && (PedBlip != null))
|
if (!Main.Settings.ShowPlayerBlip && (byte)BlipColor != 255) BlipColor = (BlipColor)255;
|
||||||
|
if ((byte)BlipColor == 255 && PedBlip != null)
|
||||||
{
|
{
|
||||||
PedBlip.Delete();
|
PedBlip.Delete();
|
||||||
PedBlip = null;
|
PedBlip = null;
|
||||||
}
|
}
|
||||||
else if (((byte)BlipColor != 255) && PedBlip == null)
|
else if ((byte)BlipColor != 255 && PedBlip == null)
|
||||||
{
|
{
|
||||||
PedBlip = MainPed.AddBlip();
|
PedBlip = MainPed.AddBlip();
|
||||||
|
|
||||||
@ -170,7 +171,7 @@ namespace RageCoop.Client
|
|||||||
|
|
||||||
private void RenderNameTag()
|
private void RenderNameTag()
|
||||||
{
|
{
|
||||||
if (!Owner.DisplayNameTag || (MainPed == null) || !MainPed.IsVisible || !MainPed.IsInRange(Main.PlayerPosition, 40f))
|
if (!Owner.DisplayNameTag || !Main.Settings.ShowPlayerNameTag || MainPed == null || !MainPed.IsVisible || !MainPed.IsInRange(Main.PlayerPosition, 40f))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -597,6 +598,8 @@ namespace RageCoop.Client
|
|||||||
MainPed.Task.StandStill(2000);
|
MainPed.Task.StandStill(2000);
|
||||||
LastMoving = false;
|
LastMoving = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (MainPed.IsTaskActive(TaskType.CTaskDiveToGround)) MainPed.Task.ClearAll();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
SmoothTransition();
|
SmoothTransition();
|
||||||
|
@ -43,7 +43,7 @@ namespace RageCoop.Client
|
|||||||
#endregion
|
#endregion
|
||||||
public static void Cleanup(bool keepPlayer = true, bool keepMine = true)
|
public static void Cleanup(bool keepPlayer = true, bool keepMine = true)
|
||||||
{
|
{
|
||||||
foreach (var ped in PedsByID.Values)
|
foreach (var ped in PedsByID.Values.ToArray())
|
||||||
{
|
{
|
||||||
if ((keepPlayer && (ped.ID == Main.LocalPlayerID)) || (keepMine && (ped.OwnerID == Main.LocalPlayerID))) { continue; }
|
if ((keepPlayer && (ped.ID == Main.LocalPlayerID)) || (keepMine && (ped.OwnerID == Main.LocalPlayerID))) { continue; }
|
||||||
RemovePed(ped.ID);
|
RemovePed(ped.ID);
|
||||||
@ -277,8 +277,8 @@ namespace RageCoop.Client
|
|||||||
{
|
{
|
||||||
ProjectilesByHandle.Remove(p.Handle);
|
ProjectilesByHandle.Remove(p.Handle);
|
||||||
}
|
}
|
||||||
Main.Logger.Debug($"Removing projectile {sp.ID}. Reason:{reason}");
|
//Main.Logger.Debug($"Removing projectile {sp.ID}. Reason:{reason}");
|
||||||
p.Explode();
|
if (sp.Exploded) p.Explode();
|
||||||
}
|
}
|
||||||
ProjectilesByID.Remove(id);
|
ProjectilesByID.Remove(id);
|
||||||
}
|
}
|
||||||
@ -363,7 +363,8 @@ namespace RageCoop.Client
|
|||||||
foreach (Ped p in allPeds)
|
foreach (Ped p in allPeds)
|
||||||
{
|
{
|
||||||
SyncedPed c = GetPedByHandle(p.Handle);
|
SyncedPed c = GetPedByHandle(p.Handle);
|
||||||
if (c == null && (p != Game.Player.Character))
|
List<PedHash> mainCharacters = new List<PedHash> { PedHash.Michael, PedHash.Franklin, PedHash.Franklin02, PedHash.Trevor };
|
||||||
|
if (c == null && p != Game.Player.Character && !mainCharacters.Contains((PedHash)p.Model.Hash))
|
||||||
{
|
{
|
||||||
if (allPeds.Length > Main.Settings.WorldPedSoftLimit && p.PopulationType == EntityPopulationType.RandomAmbient && !p.IsInVehicle())
|
if (allPeds.Length > Main.Settings.WorldPedSoftLimit && p.PopulationType == EntityPopulationType.RandomAmbient && !p.IsInVehicle())
|
||||||
{
|
{
|
||||||
|
@ -126,7 +126,7 @@ namespace RageCoop.Client
|
|||||||
}
|
}
|
||||||
|
|
||||||
var p = EntityPool.GetPedByID(ownerID)?.MainPed;
|
var p = EntityPool.GetPedByID(ownerID)?.MainPed;
|
||||||
if (p == null) { p = Game.Player.Character; Main.Logger.Warning("Failed to find owner for bullet"); }
|
if (p == null) { return; /* p = Game.Player.Character; Main.Logger.Warning("Failed to find owner for bullet"); */ }
|
||||||
if (!CorePFXAsset.IsLoaded) { CorePFXAsset.Request(); }
|
if (!CorePFXAsset.IsLoaded) { CorePFXAsset.Request(); }
|
||||||
if (_lastWeaponHash != weaponHash)
|
if (_lastWeaponHash != weaponHash)
|
||||||
{
|
{
|
||||||
|
@ -15,7 +15,7 @@ using System.Resources;
|
|||||||
[assembly: AssemblyCulture("")]
|
[assembly: AssemblyCulture("")]
|
||||||
|
|
||||||
// Version information
|
// Version information
|
||||||
[assembly: AssemblyVersion("1.5.4.3")]
|
[assembly: AssemblyVersion("1.5.4.5")]
|
||||||
[assembly: AssemblyFileVersion("1.5.4.3")]
|
[assembly: AssemblyFileVersion("1.5.4.5")]
|
||||||
[assembly: NeutralResourcesLanguageAttribute( "en-US" )]
|
[assembly: NeutralResourcesLanguageAttribute( "en-US" )]
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ namespace RageCoop.Server.Scripting
|
|||||||
});
|
});
|
||||||
API.RegisterCustomEventHandler(CustomEvents.OnPlayerDied, (e) =>
|
API.RegisterCustomEventHandler(CustomEvents.OnPlayerDied, (e) =>
|
||||||
{
|
{
|
||||||
API.SendCustomEventQueued(API.GetAllClients().Values.Where(x => x != e.Client).ToList(), CustomEvents.OnPlayerDied, e.Client.Username);
|
API.SendCustomEventQueued(API.GetAllClients().Values.Where(x => x != e.Client).ToList(), CustomEvents.OnPlayerDied, e.Args);
|
||||||
});
|
});
|
||||||
API.Events.OnChatMessage += (s, e) =>
|
API.Events.OnChatMessage += (s, e) =>
|
||||||
Server.Logger?.Info((e.Client?.Username ?? e.ClaimedSender ?? "Unknown") + ": " + e.Message);
|
Server.Logger?.Info((e.Client?.Username ?? e.ClaimedSender ?? "Unknown") + ": " + e.Message);
|
||||||
|
Binary file not shown.
Reference in New Issue
Block a user