Files
XCharts/Runtime/Internal/Utilities/DataHelper.cs
2026-05-20 22:13:04 +08:00

210 lines
8.4 KiB
C#

using System.Collections.Generic;
using UnityEngine;
namespace XCharts.Runtime
{
public static class DataHelper
{
private static List<double> s_SampleSumPrefix = new List<double>();
public static bool IsAnyDataChanged(ref List<SerieData> showData, int minCount, int maxCount)
{
for (int i = minCount; i < maxCount; i++)
{
if (showData[i].IsDataChanged())
return true;
}
return false;
}
public static List<double> BuildSampleSumPrefix(ref List<SerieData> showData, int maxCount, bool inverse)
{
if (maxCount < 0) maxCount = 0;
var targetCount = maxCount + 1;
if (s_SampleSumPrefix.Count != targetCount)
{
s_SampleSumPrefix.Clear();
for (int i = 0; i < targetCount; i++)
s_SampleSumPrefix.Add(0);
}
s_SampleSumPrefix[0] = 0;
for (int i = 0; i < maxCount; i++)
{
s_SampleSumPrefix[i + 1] = s_SampleSumPrefix[i] + showData[i].GetData(1, inverse);
}
return s_SampleSumPrefix;
}
public static double DataAverage(ref List<SerieData> showData, SampleType sampleType,
int minCount, int maxCount, int rate)
{
double totalAverage = 0;
if (rate > 1 && sampleType == SampleType.Peak)
{
double total = 0;
for (int i = minCount; i < maxCount; i++)
{
total += showData[i].data[1];
}
totalAverage = total / (maxCount - minCount);
}
return totalAverage;
}
public static double SampleValue(ref List<SerieData> showData, SampleType sampleType, int rate,
int minCount, int maxCount, double totalAverage, int index, float dataAddDuration, float dataChangeDuration,
ref bool dataChanging, Axis axis, bool unscaledTime, bool useCurrentData = true,
bool checkDataChanging = true, List<double> sampleSumPrefix = null)
{
var inverse = axis.inverse;
var minValue = 0;
var maxValue = 0;
if (!useCurrentData)
{
if (rate <= 1 || index == minCount)
return showData[index].GetData(1, inverse);
switch (sampleType)
{
case SampleType.Sum:
case SampleType.Average:
if (sampleSumPrefix != null)
{
var totalByPrefix = sampleSumPrefix[index + 1] - sampleSumPrefix[index - rate + 1];
if (sampleType == SampleType.Average)
return totalByPrefix / rate;
else
return totalByPrefix;
}
double total = 0;
for (int i = index; i > index - rate; i--)
{
total += showData[i].GetData(1, inverse);
}
if (sampleType == SampleType.Average)
return total / rate;
else
return total;
case SampleType.Max:
double max = double.MinValue;
for (int i = index; i > index - rate; i--)
{
var value = showData[i].GetData(1, inverse);
if (value > max)
max = value;
}
return max;
case SampleType.Min:
double min = double.MaxValue;
for (int i = index; i > index - rate; i--)
{
var value = showData[i].GetData(1, inverse);
if (value < min)
min = value;
}
return min;
case SampleType.Peak:
max = double.MinValue;
min = double.MaxValue;
total = 0;
for (int i = index; i > index - rate; i--)
{
var value = showData[i].GetData(1, inverse);
total += value;
if (value < min)
min = value;
if (value > max)
max = value;
}
var average = total / rate;
if (average >= totalAverage)
return max;
else
return min;
}
return showData[index].GetData(1, inverse);
}
if (rate <= 1 || index == minCount)
{
if (checkDataChanging && showData[index].IsDataChanged())
dataChanging = true;
return showData[index].GetCurrData(1, dataAddDuration, dataChangeDuration, inverse, minValue, maxValue, unscaledTime);
}
switch (sampleType)
{
case SampleType.Sum:
case SampleType.Average:
double total = 0;
var count = 0;
for (int i = index; i > index - rate; i--)
{
count++;
total += showData[i].GetCurrData(1, dataAddDuration, dataChangeDuration, inverse, minValue, maxValue, unscaledTime);
if (checkDataChanging && showData[i].IsDataChanged())
dataChanging = true;
}
if (sampleType == SampleType.Average)
return total / rate;
else
return total;
case SampleType.Max:
double max = double.MinValue;
for (int i = index; i > index - rate; i--)
{
var value = showData[i].GetCurrData(1, dataAddDuration, dataChangeDuration, inverse, minValue, maxValue, unscaledTime);
if (value > max)
max = value;
if (checkDataChanging && showData[i].IsDataChanged())
dataChanging = true;
}
return max;
case SampleType.Min:
double min = double.MaxValue;
for (int i = index; i > index - rate; i--)
{
var value = showData[i].GetCurrData(1, dataAddDuration, dataChangeDuration, inverse, minValue, maxValue, unscaledTime);
if (value < min)
min = value;
if (checkDataChanging && showData[i].IsDataChanged())
dataChanging = true;
}
return min;
case SampleType.Peak:
max = double.MinValue;
min = double.MaxValue;
total = 0;
for (int i = index; i > index - rate; i--)
{
var value = showData[i].GetCurrData(1, dataAddDuration, dataChangeDuration, inverse, minValue, maxValue, unscaledTime);
total += value;
if (value < min)
min = value;
if (value > max)
max = value;
if (checkDataChanging && showData[i].IsDataChanged())
dataChanging = true;
}
var average = total / rate;
if (average >= totalAverage)
return max;
else
return min;
}
if (checkDataChanging && showData[index].IsDataChanged())
dataChanging = true;
return showData[index].GetCurrData(1, dataAddDuration, dataChangeDuration, inverse, minValue, maxValue, unscaledTime);
}
}
}