20240801_FJEQ_upperpc/FujianEarthquake_seabed/FujianEarthquake/ViewModels/JunctionBoxEnvironDataViewModel.cs
XuMin 2f88b96460 1 完成接驳盒环境数据展示页面的编写;
2 完成接驳盒状态数据展示页面的编写;
2024-08-27 17:39:30 +08:00

549 lines
21 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

using FujianEarthquake.Common;
using FujianEarthquake.DataAccess;
using FujianEarthquake.Views.UserControls;
using FujianEarthquake.Models;
using MySql.Data.MySqlClient;
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Media;
using System.Windows.Threading;
namespace FujianEarthquake.ViewModels
{
public class JunctionBoxEnvironDataViewModel : NotifyBase
{
#region Search Data
private DateTime _startDateTime;
public DateTime StartDateTime
{
get { return _startDateTime; }
set { Set(ref _startDateTime, value); }
}
private DateTime _endDateTime;
public DateTime EndDateTime
{
get { return _endDateTime; }
set { Set(ref _endDateTime, value); }
}
int PageIndex = 0;
private int recordCount;
public int RecordCount
{
get { return recordCount; }
set { recordCount = value; this.DoNotify(); }
}
private int totalPage;
public int TotalPage
{
get { return totalPage; }
set { totalPage = value; this.DoNotify(); }
}
private string junctionBoxEnvironMsg;
public string JunctionBoxEnvironMsg
{
get { return junctionBoxEnvironMsg; }
set { junctionBoxEnvironMsg = value; this.DoNotify(); }
}
private ObservableCollection<JunctionBoxEnvironModel> junctionBoxEnvironDataList = new ObservableCollection<JunctionBoxEnvironModel>();
public ObservableCollection<JunctionBoxEnvironModel> JunctionBoxEnvironDataList
{
get { return junctionBoxEnvironDataList; }
set { junctionBoxEnvironDataList = value; this.DoNotify(); }
}
private ObservableCollection<JunctionBoxEnvironModel> totalJunctionBoxEnvironDataList = new ObservableCollection<JunctionBoxEnvironModel>();
public ObservableCollection<JunctionBoxEnvironModel> TotalJunctionBoxEnvironDataList
{
get { return totalJunctionBoxEnvironDataList; }
set { totalJunctionBoxEnvironDataList = value; this.DoNotify(); }
}
#endregion
#region Command Define
public CommandBase ForwordJunctionBoxEnvironCommand { get; set; }
public CommandBase NextJunctionBoxEnvironCommand { get; set; }
//public CommandBase AskDataBtnCommand { get; set; }
public CommandBase RefreshDataCommand { get; set; }
public CommandBase DownloadDataCommand { get; set; }
public CommandBase FTPSettingCommand { get; set; }
public CommandBase RefreshFileCommand { get; set; }
#endregion
int station_id = 1;
public DispatcherTimer timerDownloadDataMsgHidden = new DispatcherTimer();
//public FTPSettingView fTPSettingView1 = new FTPSettingView(1);
//public FTPSettingView fTPSettingView2 = new FTPSettingView(2);
//public FTPLIST ftpList { get; set; } = new FTPLIST();
//public FTPConnectModel ftpcon { get; set; } = new FTPConnectModel();
#region Data Filtering
string timeSearch = "";
public static DialogViewModel vm;
private bool _isChecked;
public bool IsChecked
{
get { return _isChecked; }
set
{
_isChecked = value;
this.DoNotify();
if (IsChecked)
{
if (string.IsNullOrEmpty(EndDateTime.ToString()) || string.IsNullOrEmpty(StartDateTime.ToString()))
{
IsChecked = false;
return;
}
if (EndDateTime < StartDateTime)
{
HandyControl.Controls.Dialog.Show(new TextDialog("起始时间大于结束时间,\n请重新输入"));
IsChecked = false;
return;
}
timeSearch = " and DataTime BETWEEN '" + StartDateTime + "' and '" + EndDateTime + "' ";
}
else
{
timeSearch = "";
}
//设置当前页为1
PageIndex = 1;
TotalJunctionBoxEnvironDataList.Clear();
JunctionBoxEnvironDataList.Clear();
string sql = String.Format("select * from underjuncbox_env where StationID = {0} {1} ORDER by id desc limit 100", station_id, timeSearch);
MySqlDataReader dataReader = DBHelper.ExecuteReader(sql, 1);
string sqlSub = String.Format("select * from underjuncbox_cavity_state where StationID = {0} {1} ORDER by id desc limit 100", station_id, timeSearch);
MySqlDataReader dataReaderSub = DBHelper.ExecuteReader(sqlSub, 1);
int index = 1;
while (dataReader.Read())
{
JunctionBoxEnvironModel JunctionBoxEnvironModel = new JunctionBoxEnvironModel();
JunctionBoxEnvironModel.Index = index++;
JunctionBoxEnvironModel.DataTime = Convert.ToDateTime(dataReader["DataTime"]);
JunctionBoxEnvironModel.RecordTime = Convert.ToDateTime(dataReader["RecordTime"]);
JunctionBoxEnvironModel.Temperature = Convert.ToSingle(string.IsNullOrEmpty(dataReader["Temperature"].ToString()) ? "0" : dataReader["Temperature"]);
JunctionBoxEnvironModel.Humidity = Convert.ToSingle(string.IsNullOrEmpty(dataReader["Humidity"].ToString()) ? "0" : dataReader["Humidity"]);
JunctionBoxEnvironModel.AttitudeX = Convert.ToSingle(string.IsNullOrEmpty(dataReader["AttitudeX"].ToString()) ? "0" : dataReader["AttitudeX"]);
JunctionBoxEnvironModel.AttitudeY = Convert.ToSingle(string.IsNullOrEmpty(dataReader["AttitudeY"].ToString()) ? "0" : dataReader["AttitudeY"]);
JunctionBoxEnvironModel.AttitudeZ = Convert.ToSingle(string.IsNullOrEmpty(dataReader["AttitudeZ"].ToString()) ? "0" : dataReader["AttitudeZ"]);
if (dataReaderSub.Read())
{
int leakState = Convert.ToInt32(string.IsNullOrEmpty(dataReaderSub["Leakage"].ToString()) ? "2" : dataReaderSub["Leakage"]);
if (leakState == 1)
{
JunctionBoxEnvironModel.Leakage = (ImageSource)Application.Current.FindResource("CycleRed");
}
else if (leakState == 0)
{
JunctionBoxEnvironModel.Leakage = (ImageSource)Application.Current.FindResource("CycleGreen");
}
else
{
JunctionBoxEnvironModel.Leakage = (ImageSource)Application.Current.FindResource("CycleGray");
}
}
else
{
JunctionBoxEnvironModel.Leakage = (ImageSource)Application.Current.FindResource("CycleGray");
}
TotalJunctionBoxEnvironDataList.Add(JunctionBoxEnvironModel);
}
dataReader.Dispose();
dataReaderSub.Dispose();
RecordCount = index - 1;
if (RecordCount <= 10)
{
TotalPage = 1;
JunctionBoxEnvironDataList = TotalJunctionBoxEnvironDataList;
}
else
{
TotalPage = (int)Math.Ceiling((double)RecordCount / 10);
for (int i = 0; i < 10; i++)
{
JunctionBoxEnvironDataList.Add(TotalJunctionBoxEnvironDataList[i]);
}
}
JunctionBoxEnvironMsg = string.Format("共计{0}页,当前第{1}页", TotalPage, PageIndex);
string record = "查询接驳盒环境数据历史数据,查询时间范围为:" + StartDateTime + "至" + EndDateTime + ",共查询到" + RecordCount + "条历史数据";
sql = $"insert into underjuncbox_log_record(StationID,RecordTime,Device_Name,Operation_Type,Record) values('{station_id}','{DateTime.Now}','海底地震监测基站-接驳盒','数据查询','{record}');";
DBHelper.ExecuteNonQuery(sql, 1);
}
}
#endregion
public JunctionBoxEnvironDataViewModel(int id)
{
// 默认查询1天内的日志
this.EndDateTime = DateTime.Now;
this.StartDateTime = DateTime.Now.AddDays(-1);
PageIndex = 1;
station_id = id;
vm = new DialogViewModel
{
Content = ""
};
#region Command Set
this.ForwordJunctionBoxEnvironCommand = new CommandBase();
this.ForwordJunctionBoxEnvironCommand.DoExcute = new Action<object>(ForwordJunctionBoxEnviron);
this.ForwordJunctionBoxEnvironCommand.DoCanExcute = new Func<object, bool>((o) => true);
this.NextJunctionBoxEnvironCommand = new CommandBase();
this.NextJunctionBoxEnvironCommand.DoExcute = new Action<object>(NextJunctionBoxEnviron);
this.NextJunctionBoxEnvironCommand.DoCanExcute = new Func<object, bool>((o) => true);
//this.AskDataBtnCommand = new CommandBase();
//this.AskDataBtnCommand.DoExcute = new Action<object>(AskData);
//this.AskDataBtnCommand.DoCanExcute = new Func<object, bool>((o) => true);
this.RefreshDataCommand = new CommandBase();
this.RefreshDataCommand.DoExcute = new Action<object>(RefreshData);
this.RefreshDataCommand.DoCanExcute = new Func<object, bool>((o) => true);
this.DownloadDataCommand = new CommandBase();
this.DownloadDataCommand.DoExcute = new Action<object>(DownloadData);
this.DownloadDataCommand.DoCanExcute = new Func<object, bool>((o) => true);
this.FTPSettingCommand = new CommandBase();
this.FTPSettingCommand.DoExcute = new Action<object>(FTPSetting);
this.FTPSettingCommand.DoCanExcute = new Func<object, bool>((o) => true);
this.RefreshFileCommand = new CommandBase();
this.RefreshFileCommand.DoExcute = new Action<object>(RefreshFile);
this.RefreshFileCommand.DoCanExcute = new Func<object, bool>((o) => true);
#endregion
#region DispatcherTimer Set
timerDownloadDataMsgHidden.Interval = TimeSpan.FromSeconds(2);
timerDownloadDataMsgHidden.Tick += TimerDownloadDataMsgHidden_Tick;
#endregion
//if (station_id == 1)
//{
// ftpcon.IP = Tools.GetAppSetting("FTPIP1");
// ftpcon.Port = int.Parse(Tools.GetAppSetting("FTPPort1"));
// ftpcon.UserName = Tools.GetAppSetting("FTPUserName1");
// ftpcon.PassWord = Tools.GetAppSetting("FTPPassword1");
//}
//else
//{
// ftpcon.IP = Tools.GetAppSetting("FTPIP2");
// ftpcon.Port = int.Parse(Tools.GetAppSetting("FTPPort2"));
// ftpcon.UserName = Tools.GetAppSetting("FTPUserName2");
// ftpcon.PassWord = Tools.GetAppSetting("FTPPassword2");
//}
}
/// <summary>
/// 更新FTP文件目录
/// </summary>
/// <param name="FTPPath"></param>
public void RefreshFTPList(string FTPPath)
{
// try
// {
// string ftpURL = ftpcon.getFtpHelper(ftpcon.IP, ftpcon.Port, FTPPath, ftpcon.UserName, ftpcon.PassWord, "");
// List<FTPModel> list = ftpcon.ListDirectories(); //该目录下的文件夹
// List<FTPModel> File_list = ftpcon.ListFiles(); //该目录下的文件
// if (File_list != null)
// {
// for (int i = 0; i < File_list.Count; i++)
// {
// list.Add(File_list[i]);
// }
// }
// ftpList.FTPList = list;
// }
// catch (Exception ex)
// {
// }
}
public void RefreshFile(object o)
{
// if (Tools.PingIp(ftpcon.IP))
// RefreshFTPList("FTP_Test");
}
#region Page Switching
public void ForwordJunctionBoxEnviron(object o)
{
if (PageIndex == 1)
return;
try
{
PageIndex -= 1;
JunctionBoxEnvironDataList.Clear();
for (int i = 0; i < 10; i++)
{
JunctionBoxEnvironDataList.Add(TotalJunctionBoxEnvironDataList[i + (PageIndex - 1) * 10]);
}
JunctionBoxEnvironMsg = string.Format("共计{0}页,当前第{1}页", TotalPage, PageIndex);
}
catch
{
TotalJunctionBoxEnvironDataList.Clear();
JunctionBoxEnvironDataList.Clear();
}
}
public void NextJunctionBoxEnviron(object o)
{
if (PageIndex == TotalPage)
return;
try
{
PageIndex += 1;
JunctionBoxEnvironDataList.Clear();
for (int i = 0; i < (PageIndex == TotalPage ? (RecordCount - (PageIndex - 1) * 10) : 10); i++)
{
JunctionBoxEnvironDataList.Add(TotalJunctionBoxEnvironDataList[i + (PageIndex - 1) * 10]);
}
JunctionBoxEnvironMsg = string.Format("共计{0}页,当前第{1}页", TotalPage, PageIndex);
}
catch
{
TotalJunctionBoxEnvironDataList.Clear();
JunctionBoxEnvironDataList.Clear();
}
}
#endregion
#region RefreshData
public void RefreshData(object o)
{
if (IsChecked)
{
timeSearch = " and DataTime BETWEEN '" + StartDateTime + "' and '" + EndDateTime + "' ";
}
else
{
timeSearch = "";
}
//设置当前页为1
PageIndex = 1;
TotalJunctionBoxEnvironDataList.Clear();
JunctionBoxEnvironDataList.Clear();
string sql = String.Format("select * from underjuncbox_env where StationID = {0} {1} ORDER by id desc limit 100", station_id, timeSearch);
MySqlDataReader dataReader = DBHelper.ExecuteReader(sql, 1);
string sqlSub = String.Format("select * from underjuncbox_cavity_state where StationID = {0} {1} ORDER by id desc limit 100", station_id, timeSearch);
MySqlDataReader dataReaderSub = DBHelper.ExecuteReader(sqlSub, 1);
int index = 1;
while (dataReader.Read())
{
JunctionBoxEnvironModel junctionBoxEnvironModel = new JunctionBoxEnvironModel();
junctionBoxEnvironModel.Index = index++;
junctionBoxEnvironModel.DataTime = Convert.ToDateTime(dataReader["DataTime"]);
junctionBoxEnvironModel.RecordTime = Convert.ToDateTime(dataReader["RecordTime"]);
junctionBoxEnvironModel.Temperature = Convert.ToSingle(string.IsNullOrEmpty(dataReader["Temperature"].ToString()) ? "0" : dataReader["Temperature"]);
junctionBoxEnvironModel.Humidity = Convert.ToSingle(string.IsNullOrEmpty(dataReader["Humidity"].ToString()) ? "0" : dataReader["Humidity"]);
junctionBoxEnvironModel.AttitudeX = Convert.ToSingle(string.IsNullOrEmpty(dataReader["AttitudeX"].ToString()) ? "0" : dataReader["AttitudeX"]);
junctionBoxEnvironModel.AttitudeY = Convert.ToSingle(string.IsNullOrEmpty(dataReader["AttitudeY"].ToString()) ? "0" : dataReader["AttitudeY"]);
junctionBoxEnvironModel.AttitudeZ = Convert.ToSingle(string.IsNullOrEmpty(dataReader["AttitudeZ"].ToString()) ? "0" : dataReader["AttitudeZ"]);
if (dataReaderSub.Read())
{
int leakState = Convert.ToInt32(string.IsNullOrEmpty(dataReaderSub["Leakage"].ToString()) ? "2" : dataReaderSub["Leakage"]);
if (leakState == 1)
{
junctionBoxEnvironModel.Leakage = (ImageSource)Application.Current.FindResource("CycleRed");
}
else if (leakState == 0)
{
junctionBoxEnvironModel.Leakage = (ImageSource)Application.Current.FindResource("CycleGreen");
}
else
{
junctionBoxEnvironModel.Leakage = (ImageSource)Application.Current.FindResource("CycleGray");
}
}
else
{
junctionBoxEnvironModel.Leakage = (ImageSource)Application.Current.FindResource("CycleGray");
}
TotalJunctionBoxEnvironDataList.Add(junctionBoxEnvironModel);
}
dataReader.Dispose();
dataReaderSub.Dispose();
RecordCount = index - 1;
if (RecordCount <= 10)
{
TotalPage = 1;
JunctionBoxEnvironDataList = TotalJunctionBoxEnvironDataList;
}
else
{
TotalPage = (int)Math.Ceiling((double)RecordCount / 10);
for (int i = 0; i < 10; i++)
{
JunctionBoxEnvironDataList.Add(TotalJunctionBoxEnvironDataList[i]);
}
}
JunctionBoxEnvironMsg = string.Format("共计{0}页,当前第{1}页", TotalPage, PageIndex);
sql = $"insert into underjuncbox_log_record(StationID,RecordTime,Device_Name,Operation_Type,Record) values('{station_id}','{DateTime.Now}','海底地震监测基站-接驳盒','数据刷新','刷新接驳盒环境数据');";
DBHelper.ExecuteNonQuery(sql, 1);
}
#endregion
#region DownloadData
private void TimerDownloadDataMsgHidden_Tick(object sender, EventArgs e)
{
DownloadDataMsgVisibility = Visibility.Hidden;
// 停止定时器
(sender as DispatcherTimer).Stop();
}
private string downloadDataMsg;
public string DownloadDataMsg
{
get { return downloadDataMsg; }
set { downloadDataMsg = value; this.DoNotify(); }
}
private Brush downloadDataMsgForeground;
public Brush DownloadDataMsgForeground
{
get { return downloadDataMsgForeground; }
set { downloadDataMsgForeground = value; this.DoNotify(); }
}
private bool downloadDataBtnIsEnabled = true;
public bool DownloadDataBtnIsEnabled
{
get { return downloadDataBtnIsEnabled; }
set { downloadDataBtnIsEnabled = value; this.DoNotify(); }
}
private Visibility downloadDataMsgVisibility = Visibility.Visible;
public Visibility DownloadDataMsgVisibility
{
get { return downloadDataMsgVisibility; }
set { downloadDataMsgVisibility = value; this.DoNotify(); }
}
public void DownloadData(object o)
{
DownloadDataBtnIsEnabled = false;
string baseStationFolder = Tools.GetAppSetting("BaseStationFolder");
string savePath = CSVDownload.CreateFile(baseStationFolder, "JunctionBoxEnvironData_" + DateTime.Now.ToString("yyyyMMddhhMMss"), "csv");
bool result = CSVDownload.SaveJunctionBoxEnvironDataToCSVFile(TotalJunctionBoxEnvironDataList, savePath);
if (result)
{
DownloadDataMsg = "下载数据成功!";
DownloadDataMsgVisibility = Visibility.Visible;
DownloadDataMsgForeground = new SolidColorBrush(Colors.Green);
}
else
{
DownloadDataMsg = "下载数据失败!";
DownloadDataMsgVisibility = Visibility.Visible;
DownloadDataMsgForeground = new SolidColorBrush(Colors.Red);
}
timerDownloadDataMsgHidden.Start();
DownloadDataBtnIsEnabled = true;
string record = "下载接驳盒环境数据," + DownloadDataMsg;
string sql = $"insert into underjuncbox_log_record(StationID,RecordTime,Device_Name,Operation_Type,Record) values('{station_id}','{DateTime.Now}','海底地震监测基站-地震仪','数据下载','{record}');";
DBHelper.ExecuteNonQuery(sql, 1);
}
#endregion
#region FTPSetting
public void FTPSetting(object o)
{
//if (station_id == 1)
// HandyControl.Controls.Dialog.Show(fTPSettingView1);
//else
// HandyControl.Controls.Dialog.Show(fTPSettingView2);
}
#endregion
}
}