mirror of
https://github.com/PepperDash/Essentials.git
synced 2026-02-15 12:44:58 +00:00
add Math.Floor calls to ignore milliseconds
Change formatting for timeRemaining Add logic to prevent initial timeRemaining value from being massive negative value
This commit is contained in:
@@ -32,7 +32,7 @@ namespace PepperDash.Essentials.Core
|
|||||||
public DateTime StartTime { get; private set; }
|
public DateTime StartTime { get; private set; }
|
||||||
public DateTime FinishTime { get; private set; }
|
public DateTime FinishTime { get; private set; }
|
||||||
|
|
||||||
CTimer SecondTimer;
|
private CTimer _secondTimer;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor
|
/// Constructor
|
||||||
@@ -49,28 +49,26 @@ namespace PepperDash.Essentials.Core
|
|||||||
|
|
||||||
var timeSpan = FinishTime - DateTime.Now;
|
var timeSpan = FinishTime - DateTime.Now;
|
||||||
|
|
||||||
if (timeSpan.TotalSeconds < 60)
|
Debug.Console(2, this,
|
||||||
|
"timeSpan.Minutes == {0}, timeSpan.Seconds == {1}, timeSpan.TotalSeconds == {2}",
|
||||||
|
timeSpan.Minutes, timeSpan.Seconds, timeSpan.TotalSeconds);
|
||||||
|
|
||||||
|
if (Math.Floor(timeSpan.TotalSeconds) < 60 && Math.Floor(timeSpan.TotalSeconds) >= 0) //ignore milliseconds
|
||||||
{
|
{
|
||||||
return Math.Round(timeSpan.TotalSeconds).ToString();
|
return String.Format("{0:00}", timeSpan.Seconds);
|
||||||
}
|
|
||||||
else if (timeSpan.TotalSeconds < 0)
|
|
||||||
{
|
|
||||||
return "0";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Debug.Console(2, this, "timeSpan.Minutes == {0}, timeSpan.Seconds == {1}", timeSpan.Minutes, timeSpan.Seconds);
|
|
||||||
return String.Format("{0:c}", timeSpan);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return Math.Floor(timeSpan.TotalSeconds) < 0
|
||||||
|
? "00"
|
||||||
|
: String.Format("{0:00}:{1:00}", timeSpan.Minutes, timeSpan.Seconds);
|
||||||
});
|
});
|
||||||
|
|
||||||
PercentFeedback = new IntFeedback(() =>
|
PercentFeedback =
|
||||||
{
|
new IntFeedback(
|
||||||
var percent = (FinishTime - DateTime.Now).TotalSeconds
|
() =>
|
||||||
/ (FinishTime - StartTime).TotalSeconds
|
(int)
|
||||||
* 100;
|
(Math.Floor((FinishTime - DateTime.Now).TotalSeconds)/
|
||||||
return (int)percent;
|
Math.Floor((FinishTime - StartTime).TotalSeconds)*100));
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -83,9 +81,9 @@ namespace PepperDash.Essentials.Core
|
|||||||
StartTime = DateTime.Now;
|
StartTime = DateTime.Now;
|
||||||
FinishTime = StartTime + TimeSpan.FromSeconds(SecondsToCount);
|
FinishTime = StartTime + TimeSpan.FromSeconds(SecondsToCount);
|
||||||
|
|
||||||
if (SecondTimer != null)
|
if (_secondTimer != null)
|
||||||
SecondTimer.Stop();
|
_secondTimer.Stop();
|
||||||
SecondTimer = new CTimer(SecondElapsedTimerCallback, null, 0, 1000);
|
_secondTimer = new CTimer(SecondElapsedTimerCallback, null, 0, 1000);
|
||||||
_isRunning = true;
|
_isRunning = true;
|
||||||
IsRunningFeedback.FireUpdate();
|
IsRunningFeedback.FireUpdate();
|
||||||
|
|
||||||
@@ -129,19 +127,22 @@ namespace PepperDash.Essentials.Core
|
|||||||
|
|
||||||
void StopHelper()
|
void StopHelper()
|
||||||
{
|
{
|
||||||
if (SecondTimer != null)
|
if (_secondTimer != null)
|
||||||
SecondTimer.Stop();
|
_secondTimer.Stop();
|
||||||
_isRunning = false;
|
_isRunning = false;
|
||||||
IsRunningFeedback.FireUpdate();
|
IsRunningFeedback.FireUpdate();
|
||||||
}
|
}
|
||||||
|
|
||||||
void SecondElapsedTimerCallback(object o)
|
void SecondElapsedTimerCallback(object o)
|
||||||
{
|
{
|
||||||
|
if (DateTime.Now >= FinishTime)
|
||||||
|
{
|
||||||
|
Finish();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
PercentFeedback.FireUpdate();
|
PercentFeedback.FireUpdate();
|
||||||
TimeRemainingFeedback.FireUpdate();
|
TimeRemainingFeedback.FireUpdate();
|
||||||
|
|
||||||
if (DateTime.Now >= FinishTime)
|
|
||||||
Finish();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user