mirror of
https://github.com/ClassiCube/MCGalaxy.git
synced 2025-09-23 12:42:22 -04:00
fix mistake with negative ping, better function names for PingList class.
This commit is contained in:
parent
2472887c6b
commit
b8dea9a093
@ -52,6 +52,7 @@ namespace MCGalaxy.Network {
|
|||||||
ushort SetTwoWayPing(int i, ushort prev) {
|
ushort SetTwoWayPing(int i, ushort prev) {
|
||||||
Entries[i].Data = (ushort)(prev + 1);
|
Entries[i].Data = (ushort)(prev + 1);
|
||||||
Entries[i].TimeSent = DateTime.UtcNow;
|
Entries[i].TimeSent = DateTime.UtcNow;
|
||||||
|
Entries[i].TimeReceived = default(DateTime);
|
||||||
return (ushort)(prev + 1);
|
return (ushort)(prev + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,42 +65,42 @@ namespace MCGalaxy.Network {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/// <summary> Gets best ping in milliseconds, or 0 if no ping measures. </summary>
|
/// <summary> Gets lowest (best) ping in milliseconds, or 0 if no ping measures. </summary>
|
||||||
public double BestPingMilliseconds() {
|
public int LowestPingMilliseconds() {
|
||||||
double totalMs = 100000000;
|
double totalMs = 100000000;
|
||||||
foreach (PingEntry ping in Entries) {
|
foreach (PingEntry ping in Entries) {
|
||||||
if (ping.TimeSent.Ticks == 0 || ping.TimeReceived.Ticks == 0) continue;
|
if (ping.TimeSent.Ticks == 0 || ping.TimeReceived.Ticks == 0) continue;
|
||||||
totalMs = Math.Min(totalMs, ping.Latency);
|
totalMs = Math.Min(totalMs, ping.Latency);
|
||||||
}
|
}
|
||||||
return totalMs;
|
return (int)totalMs;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> Gets average ping in milliseconds, or 0 if no ping measures. </summary>
|
/// <summary> Gets average ping in milliseconds, or 0 if no ping measures. </summary>
|
||||||
public double AveragePingMilliseconds() {
|
public int AveragePingMilliseconds() {
|
||||||
double totalMs = 0;
|
double totalMs = 0;
|
||||||
int measures = 0;
|
int measures = 0;
|
||||||
foreach (PingEntry ping in Entries) {
|
foreach (PingEntry ping in Entries) {
|
||||||
if (ping.TimeSent.Ticks == 0 || ping.TimeReceived.Ticks == 0) continue;
|
if (ping.TimeSent.Ticks == 0 || ping.TimeReceived.Ticks == 0) continue;
|
||||||
totalMs += ping.Latency; measures++;
|
totalMs += ping.Latency; measures++;
|
||||||
}
|
}
|
||||||
return measures == 0 ? 0 : (totalMs / measures);
|
return measures == 0 ? 0 : (int)(totalMs / measures);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary> Gets worst ping in milliseconds, or 0 if no ping measures. </summary>
|
/// <summary> Gets worst ping in milliseconds, or 0 if no ping measures. </summary>
|
||||||
public double WorstPingMilliseconds() {
|
public double HighestPingMilliseconds() {
|
||||||
double totalMs = 0;
|
double totalMs = 0;
|
||||||
foreach (PingEntry ping in Entries) {
|
foreach (PingEntry ping in Entries) {
|
||||||
if (ping.TimeSent.Ticks == 0 || ping.TimeReceived.Ticks == 0) continue;
|
if (ping.TimeSent.Ticks == 0 || ping.TimeReceived.Ticks == 0) continue;
|
||||||
totalMs = Math.Max(totalMs, ping.Latency);
|
totalMs = Math.Max(totalMs, ping.Latency);
|
||||||
}
|
}
|
||||||
return totalMs;
|
return (int)totalMs;
|
||||||
}
|
}
|
||||||
|
|
||||||
public string Format() {
|
public string Format() {
|
||||||
return String.Format("Lowest ping {0}ms, average {1}ms, highest {2}ms",
|
return String.Format("Lowest ping {0}ms, average {1}ms, highest {2}ms",
|
||||||
(int)BestPingMilliseconds(),
|
LowestPingMilliseconds(),
|
||||||
(int)AveragePingMilliseconds(),
|
AveragePingMilliseconds(),
|
||||||
(int)WorstPingMilliseconds());
|
HighestPingMilliseconds());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user