Don't display epoch on map overlay

This commit is contained in:
Dan Paulat 2022-03-06 16:52:00 -06:00
parent 7c44bafeb5
commit 78a16b6a99
3 changed files with 16 additions and 10 deletions

View file

@ -103,7 +103,8 @@ void OverlayLayer::Render(const QMapbox::CustomLayerRenderParameters& params)
{
p->sweepTimeString_ =
scwx::util::TimeString(context()->radarProductView_->sweep_time(),
std::chrono::current_zone());
std::chrono::current_zone(),
false);
p->sweepTimeNeedsUpdate_ = false;
}

View file

@ -11,7 +11,8 @@ std::chrono::system_clock::time_point TimePoint(uint16_t modifiedJulianDate,
uint32_t milliseconds);
std::string TimeString(std::chrono::system_clock::time_point time,
const std::chrono::time_zone* timeZone = nullptr);
const std::chrono::time_zone* timeZone = nullptr,
bool epochValid = true);
} // namespace util
} // namespace scwx

View file

@ -22,12 +22,15 @@ std::chrono::system_clock::time_point TimePoint(uint16_t modifiedJulianDate,
}
std::string TimeString(std::chrono::system_clock::time_point time,
const std::chrono::time_zone* timeZone)
const std::chrono::time_zone* timeZone,
bool epochValid)
{
using namespace std::chrono;
auto timeInSeconds = time_point_cast<seconds>(time);
std::ostringstream os;
if (epochValid || time.time_since_epoch().count() != 0)
{
if (timeZone != nullptr)
{
zoned_time zt = {current_zone(), timeInSeconds};
@ -37,6 +40,7 @@ std::string TimeString(std::chrono::system_clock::time_point time,
{
os << timeInSeconds;
}
}
return os.str();
}