我正在使用 GMAP.NET 编写车辆跟踪应用程序
我想根据日期/时间显示多个车辆标记的同时移动。
为此,我想使用一个 Trackbar,这样当用户滑动 trackbar 时,会显示多个标记的相应移动。
我在浏览器上做了同样的应用程序,效果很好。我将标记标记的日期时间属性转换为 UNIX 时间戳,然后将跟踪栏(NOUI 滑块)值设置为 UNIX 时间戳范围。
但是,现在我发现使用 Windows 桌面 C# Trackbar 根本无法做到这一点。
问题是:
轨迹栏无法获取非常大的时间戳值。例如。5年数据。
即使减少了非常大的数字,trackbar 仍然无法获取如此高的值,并且一直滞后或崩溃。
例如。我需要显示 5 年的数据。在这种情况下,我的轨迹栏将具有最小值 - 1262304000(即 01-01-2010)到 1425203100(即 01-03-2015 | 09:45)。
但是这么大的值不适用于我的轨迹栏。
我什至采取了减少,例如。将 1262304000 设置为 1,然后 162899100(即 1425203100 - 1262304000)成为我的最大值。
但即便如此,这也是非常密集的,并且轨迹栏不起作用。
请建议是否有一个时间轨迹栏可以显示非常大的日期时间范围,或者我如何使用具有非常大值的常规轨迹栏。
代码如下——
A. 将日期时间转换为 UNIX 时间戳的函数
public Int32 UnixTimeStampUTC(DateTime datetime)
{
Int32 unixTimeStamp;
DateTime zuluTime = datetime.ToUniversalTime();
DateTime unixEpoch = new DateTime(1970, 1, 1).ToUniversalTime();
unixTimeStamp = (Int32)(zuluTime.Subtract(unixEpoch)).TotalSeconds;
return unixTimeStamp;
}
B. 通过连接日期和时间列并添加第三列来保存日期时间列的 Unix 时间戳,从数据表中获取日期时间
for (int z = 0; z < dt.Rows.Count; z++)
{
if (reviseddt.Rows[z]["date"].ToString() != "")
{
dte = DateTime.Parse(reviseddt.Rows[z]["date"].ToString());
dteticks = UnixTimeStampUTC(dte);
}
else
{
dteticks = 0;
}
if (reviseddt.Rows[z]["time"].ToString() != "")
{
tm = DateTime.Parse(reviseddt.Rows[z]["time"].ToString());
tmticks = UnixTimeStampUTC(tm);
}
else
{
tmticks = 0;
}
Int32 fullDt = dteticks + tmticks;
reviseddt.Rows[z]["datetime"] = fullDt.ToString();
reviseddt.Rows[z]["datetimestring"] = reviseddt.Rows[z]["date"].ToString() + reviseddt.Rows[z]["time"].ToString();
C. 通过从数据表中的日期时间列中获取最小值和最大值,然后将范围作为最小值和最大值之间的差值来初始化 Trackbar。因此,Trackbar range = 1 to (Max-Min)
string strminlevel = toplotDataTable.Compute("min(datetime)", String.Empty).ToString();
string strmaxLevel = toplotDataTable.Compute("max(datetime)", String.Empty).ToString();
Int32 minLevel = Convert.ToInt32(strminlevel);
Int32 maxLevel = Convert.ToInt32(strmaxLevel);
Int32 rangeint = maxLevel - minLevel;
trackBarMoveTarget.Maximum = rangeint;
trackBarMoveTarget.Minimum = 1;
trackBarMoveTarget.LargeChange = 100;
trackBarMoveTarget.SmallChange = 1;