本文整理汇总了C#中TimingMethod类的典型用法代码示例。如果您正苦于以下问题:C# TimingMethod类的具体用法?C# TimingMethod怎么用?C# TimingMethod使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
TimingMethod类属于命名空间,在下文中一共展示了TimingMethod类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: RecentSplitsFile
public RecentSplitsFile(string path, TimingMethod method, string gameName = null, string categoryName = null)
{
GameName = gameName;
CategoryName = categoryName;
Path = path;
LastTimingMethod = method;
}
示例2: PopulatePredictions
private static void PopulatePredictions(IRun run, TimeSpan? currentTime, int segmentIndex, IList<TimeSpan?> predictions, bool simpleCalculation, bool useCurrentRun, TimingMethod method)
{
if (currentTime != null)
{
PopulatePrediction(predictions, currentTime + run[segmentIndex].BestSegmentTime[method], segmentIndex + 1);
if (!simpleCalculation)
{
foreach (var nullSegment in run[segmentIndex].SegmentHistory.Where(x => !x.Time[method].HasValue))
{
var segmentTime = segmentIndex > 0 ? run[segmentIndex - 1].SegmentHistory.FirstOrDefault(x => x.Index == nullSegment.Index) : null;
if (segmentTime == null || segmentTime.Time[method] != null)
{
var prediction = SumOfSegmentsHelper.TrackBranch(run, currentTime, segmentIndex + 1, nullSegment.Index, method);
PopulatePrediction(predictions, prediction.Time[method], prediction.Index);
}
}
}
if (useCurrentRun)
{
var currentRunPrediction = SumOfSegmentsHelper.TrackCurrentRun(run, currentTime, segmentIndex, method);
PopulatePrediction(predictions, currentRunPrediction.Time[method], currentRunPrediction.Index);
}
var personalBestRunPrediction = SumOfSegmentsHelper.TrackPersonalBestRun(run, currentTime, segmentIndex, method);
PopulatePrediction(predictions, personalBestRunPrediction.Time[method], personalBestRunPrediction.Index);
}
}
示例3: Generate
public void Generate(TimingMethod method)
{
var maxIndex = Run.AttemptHistory.Select(x => x.Index).DefaultIfEmpty(0).Max();
for (var y = Run.GetMinSegmentHistoryIndex(); y <= maxIndex; y++)
{
var time = TimeSpan.Zero;
foreach (var segment in Run)
{
Time segmentHistoryElement;
if (segment.SegmentHistory.TryGetValue(y, out segmentHistoryElement))
{
var segmentTime = segmentHistoryElement[method];
if (segmentTime != null)
{
time += segmentTime.Value;
if (segment.Comparisons[Name][method] == null || time < segment.Comparisons[Name][method])
{
var newTime = new Time(segment.Comparisons[Name]);
newTime[method] = time;
segment.Comparisons[Name] = newTime;
}
}
}
else break;
}
}
}
示例4: PopulatePredictions
private static void PopulatePredictions(IRun run, TimeSpan? currentTime, int segmentIndex, IList<TimeSpan?> predictions, bool useCurrentRun, TimingMethod method)
{
if (currentTime != null)
{
PopulatePrediction(predictions, currentTime + run[segmentIndex].BestSegmentTime[method], segmentIndex + 1);
foreach (var segment in run[segmentIndex].SegmentHistory)
{
Time segmentTime;
if (segmentIndex == 0
|| !run[segmentIndex - 1].SegmentHistory.TryGetValue(segment.Key, out segmentTime)
|| segmentTime[method] != null)
{
var prediction = SumOfSegmentsHelper.TrackBranch(run, currentTime, segmentIndex, segment.Key, method);
PopulatePrediction(predictions, prediction.Time[method], prediction.Index);
}
}
if (useCurrentRun)
{
var currentRunPrediction = SumOfSegmentsHelper.TrackCurrentRun(run, currentTime, segmentIndex, method);
PopulatePrediction(predictions, currentRunPrediction.Time[method], currentRunPrediction.Index);
}
var personalBestRunPrediction = SumOfSegmentsHelper.TrackPersonalBestRun(run, currentTime, segmentIndex, method);
PopulatePrediction(predictions, personalBestRunPrediction.Time[method], personalBestRunPrediction.Index);
}
}
示例5: SubmitRun
public virtual bool SubmitRun(
IRun run,
string username, string password,
Func<Image> screenShotFunction = null,
bool attachSplits = false,
TimingMethod method = TimingMethod.RealTime,
string gameId = "", string categoryId = "",
string version = "", string comment = "",
string video = "",
params string[] additionalParams)
{
try
{
if (attachSplits)
comment += " " + SplitsIO.Instance.Share(run, screenShotFunction);
if (gameId == string.Empty)
gameId = GetGameIdByName(run.GameName);
if (categoryId == string.Empty)
categoryId = GetCategoryIdByName(gameId, run.CategoryName);
var json = ASUP.SubmitRun(run, username, password, gameId, categoryId, version, comment, video, additionalParams);
return json.result == "success";
}
catch (Exception e)
{
Log.Error(e);
return false;
}
}
示例6: GetSegmentTimeOrSegmentDelta
private static TimeSpan? GetSegmentTimeOrSegmentDelta(LiveSplitState state, int splitNumber, bool useCurrentTime, bool segmentTime, string comparison, TimingMethod method)
{
TimeSpan? currentTime;
if (useCurrentTime)
currentTime = state.CurrentTime[method];
else
currentTime = state.Run[splitNumber].SplitTime[method];
if (currentTime == null)
return null;
for (int x = splitNumber - 1; x >= 0; x--)
{
var splitTime = state.Run[x].SplitTime[method];
if (splitTime != null)
{
if (segmentTime)
return currentTime - splitTime;
else if (state.Run[x].Comparisons[comparison][method] != null)
return (currentTime - state.Run[splitNumber].Comparisons[comparison][method]) - (splitTime - state.Run[x].Comparisons[comparison][method]);
}
}
if (segmentTime)
return currentTime;
else
return currentTime - state.Run[splitNumber].Comparisons[comparison][method];
}
示例7: Generate
public void Generate(TimingMethod method)
{
for (var y = Run.GetMinSegmentHistoryIndex() + 1; y <= Run.AttemptHistory.Count; y++)
{
var time = TimeSpan.Zero;
foreach (var segment in Run)
{
var segmentHistoryElement = segment.SegmentHistory.FirstOrDefault(x => x.Index == y);
if (segmentHistoryElement != null)
{
var segmentTime = segmentHistoryElement.Time[method];
if (segmentTime != null)
{
time += segmentTime.Value;
if (segment.Comparisons[Name][method] == null || time < segment.Comparisons[Name][method])
{
var newTime = new Time(segment.Comparisons[Name]);
newTime[method] = time;
segment.Comparisons[Name] = newTime;
}
}
}
else break;
}
}
}
示例8: PopulatePredictions
private static void PopulatePredictions(IRun run, TimeSpan? currentTime, int segmentIndex, IList<TimeSpan?> predictions, bool simpleCalculation, bool useCurrentRun, TimingMethod method)
{
if (currentTime != null)
{
PopulatePrediction(predictions, currentTime + run[segmentIndex].BestSegmentTime[method], segmentIndex + 1);
if (!simpleCalculation)
{
foreach (var nullSegment in run[segmentIndex].SegmentHistory.Where(x => !x.Value[method].HasValue))
{
Time segmentTime;
if (segmentIndex == 0
|| !run[segmentIndex - 1].SegmentHistory.TryGetValue(nullSegment.Key, out segmentTime)
|| segmentTime[method] != null)
{
var prediction = TrackBranch(run, currentTime, segmentIndex + 1, nullSegment.Key, method);
PopulatePrediction(predictions, prediction.Time[method], prediction.Index);
}
}
}
if (useCurrentRun)
{
var currentRunPrediction = TrackCurrentRun(run, currentTime, segmentIndex, method);
PopulatePrediction(predictions, currentRunPrediction.Time[method], currentRunPrediction.Index);
}
var personalBestRunPrediction = TrackPersonalBestRun(run, currentTime, segmentIndex, method);
PopulatePrediction(predictions, personalBestRunPrediction.Time[method], personalBestRunPrediction.Index);
}
}
示例9: TimedRun
public TimedRun(String paramValue,
TimingMethod timingMethod = TimingMethod.Stopwatch)
{
ParamValue = paramValue;
Method = timingMethod;
Start();
}
示例10: GetLastDelta
/// <summary>
/// Gets the last non-live delta in the run starting from splitNumber.
/// </summary>
/// <param name="state">The current state.</param>
/// <param name="splitNumber">The split number to start checking deltas from.</param>
/// <param name="comparison">The comparison that you are comparing with.</param>
/// <param name="method">The timing method that you are using.</param>
/// <returns>Returns the last non-live delta or null if there have been no deltas yet.</returns>
public static TimeSpan? GetLastDelta(LiveSplitState state, int splitNumber, string comparison, TimingMethod method)
{
for (var x = splitNumber; x >= 0; x--)
{
if (state.Run[x].Comparisons[comparison][method] != null && state.Run[x].SplitTime[method] != null)
return state.Run[x].SplitTime[method] - state.Run[x].Comparisons[comparison][method];
}
return null;
}
示例11: parseTime
private static Time parseTime(int? time, TimingMethod timingMethod)
{
var parsedTime = new Time();
if (time.HasValue)
parsedTime[timingMethod] = TimeSpan.FromMilliseconds(time.Value);
return parsedTime;
}
示例12:
public TimeSpan? this[TimingMethod method]
{
get { return method == TimingMethod.RealTime ? RealTime : GameTime; }
set
{
if (method == TimingMethod.RealTime)
RealTime = value;
else
GameTime = value;
}
}
示例13: CreateTimer
private static IDisposable CreateTimer(TimingMethod timingMethod)
{
switch (timingMethod)
{
case TimingMethod.WallClock:
return new MyWallTimer();
case TimingMethod.CPU:
return new MyCpuTimer();
default:
return new NullTimer();
}
}
示例14: CalculateSumOfBest
public static TimeSpan? CalculateSumOfBest(IRun run, int startIndex, int endIndex, IList<TimeSpan?> predictions, bool simpleCalculation = false, bool useCurrentRun = true, TimingMethod method = TimingMethod.RealTime)
{
int segmentIndex = 0;
TimeSpan? currentTime = TimeSpan.Zero;
predictions[startIndex] = TimeSpan.Zero;
foreach (var segment in run.Skip(startIndex).Take(endIndex - startIndex + 1))
{
currentTime = predictions[segmentIndex];
PopulatePredictions(run, currentTime, segmentIndex, predictions, simpleCalculation, useCurrentRun, method);
segmentIndex++;
}
return predictions[endIndex + 1];
}
示例15: Run
/// <summary>
/// Runs an action a given number of times.
/// </summary>
public static void Run(int numberOfIterations, Action action, Action betweenEachAction = null, TimingMethod timingMethod = TimingMethod.None)
{
using (var timer = CreateTimer(timingMethod))
{
for (int i = 1; i <= numberOfIterations; i++)
{
action();
if (i < numberOfIterations)
{
betweenEachAction?.Invoke();
}
}
}
}