global using Yw.EPAnet;
using DevExpress.Mvvm.Native;
using DevExpress.Office.Utils;
using DevExpress.Utils.Extensions;
using DevExpress.Xpo.Helpers;
using DevExpress.XtraBars.Ribbon;
using DevExpress.XtraRichEdit.Layout;
using DevExpress.XtraSpreadsheet.Commands;
using HStation.WinFrmUI.PhartRelation;
using System.Diagnostics;
using System.Windows.Media;
using System.Windows.Media.Media3D;
using Yw.Hydro;
using Yw.Pump;
using Yw.Vmo;
using Yw.WinFrmUI.Bimface;
using Yw.WinFrmUI.Hydro;
namespace HStation.WinFrmUI
{
public partial class XhsProjectSimulationCorePage : DocumentPage
{
public XhsProjectSimulationCorePage()
{
InitializeComponent();
this.PageTitle.Caption = "水力模拟";
this.PageTitle.HeaderSvgImage = this.svgImg32[0];
this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Hidden;
RegistBulkSetEvents();
}
private HStation.Vmo.XhsProjectVmo _project = null;//项目
private HStation.Vmo.XhsProjectSiteVmo _projectSite = null;//项目站
private Yw.Model.HydroModelInfo _hydroInfo = null;//水力信息
///
/// 绑定数据
///
public async Task SetBindingData
(
HStation.Vmo.XhsProjectVmo project,
HStation.Vmo.XhsProjectSiteVmo projectSite,
Yw.Model.HydroModelInfo hydroInfo
)
{
if (project == null)
{
return;
}
_project = project;
_projectSite = projectSite;
_hydroInfo = hydroInfo;
if (_projectSite == null)
{
_projectSite = await BLLFactory.Instance.GetDefaultByProjectID(_project.ID);
}
if (_hydroInfo == null)
{
var hydroRelation = await BLLFactory.Instance
.GetDefaultByObjectTypeAndObjectIDOfPurpose(HStation.Xhs.DataType.XhsProjectSite, _projectSite.ID, HStation.Xhs.Purpose.Simulation);
_hydroInfo = await BLLFactory.Instance.GetByID(hydroRelation.ModelID);
}
}
///
/// 初始化数据
///
public override void InitialDataSource()
{
base.InitialDataSource();
if (_project == null)
{
return;
}
this.PageTitle.Caption = $"{_project.Name}\r\n水力模拟";
ShowBimfaceCtrl();
ShowQ3dCtrl();
ShowPropertyCtrl();
}
#region Bimface
//bimface控件
private XhsProjectSimulationBimfaceCtrl _bimfaceCtrl = null;
//获取 bimface 控件
private async Task GetBimfaceCtrl()
{
if (_bimfaceCtrl == null)
{
_bimfaceCtrl = new XhsProjectSimulationBimfaceCtrl();
_bimfaceCtrl.Dock = DockStyle.Fill;
await _bimfaceCtrl.InitialData(_project, _projectSite, () => _hydroInfo);
_bimfaceCtrl.LoadCompletedEvent += () =>
{//view加载完成事件
if (_hydroInfo == null)
{
return;
}
ApplyGrading();
};
_bimfaceCtrl.HydroMouseLeftClickEvent += (obj) =>
{//鼠标左键点击事件
if (_hydroInfo == null)
{
return;
}
_selectedVisual = obj;
ShowSelectedProperty();
};
}
return _bimfaceCtrl;
}
//显示 bimface 控件
private async void ShowBimfaceCtrl()
{
var bimfaceCtrl = await GetBimfaceCtrl();
this.tabPageBimface.Controls.Clear();
this.tabPageBimface.Controls.Add(bimfaceCtrl);
}
private void SelectBimfaceParter()
{
}
#endregion
#region Q3d
//Q3d 控件
private XhsProjectSimulationQ3dCtrl _q3dCtrl = null;
//获取 Q3d 控件
private XhsProjectSimulationQ3dCtrl GetQ3dCtrl()
{
if (_q3dCtrl == null)
{
_q3dCtrl = new XhsProjectSimulationQ3dCtrl();
_q3dCtrl.Dock = DockStyle.Fill;
_q3dCtrl.InitialData(() => _hydroInfo);
_q3dCtrl.SelectedPartersChangedEvent += (obj) =>
{
if (_hydroInfo == null)
{
return;
}
var allParterList = _hydroInfo.GetAllVisuals();
_selectedVisual = allParterList?.Find(x => x.Code == obj?.FirstOrDefault());
ShowSelectedProperty();
};
}
return _q3dCtrl;
}
//显示 Q3d 控件
private void ShowQ3dCtrl()
{
var q3dCtrl = GetQ3dCtrl();
this.tabPageQ3d.Controls.Clear();
this.tabPageQ3d.Controls.Add(q3dCtrl);
}
#endregion
#region 属性控件
//属性控件
private XhsProjectSimulationPropertyCtrl _propertyCtrl = null;
//获取属性控件
private XhsProjectSimulationPropertyCtrl GetPropertyCtrl()
{
if (_propertyCtrl == null)
{
_propertyCtrl = new XhsProjectSimulationPropertyCtrl();
_propertyCtrl.Dock = DockStyle.Fill;
_propertyCtrl.InitialData(() => _hydroInfo, () => GetCalcuResultList());
_propertyCtrl.BlinkLinkParterEvent += async (code, linkCode) =>
{ //强调连接组件
if (string.IsNullOrEmpty(code))
{
return;
}
if (string.IsNullOrEmpty(linkCode))
{
return;
}
if (_hydroInfo == null)
{
return;
}
var allVisualList = _hydroInfo.GetAllVisuals();
if (allVisualList == null || allVisualList.Count < 1)
{
return;
}
var linkParter = allVisualList.Find(x => x.Code == linkCode);
if (linkParter == null)
{
return;
}
var blinkCodes = new List();
if (linkParter.GetType() == typeof(Yw.Model.HydroJunctionInfo))
{
var allLinkList = _hydroInfo.GetAllLinks();
if (allLinkList == null || allLinkList.Count < 1)
{
return;
}
var linkList = allLinkList.Where(x => (x.StartCode == linkParter.Code || x.EndCode == linkParter.Code) && x.Code != code).ToList();
if (linkList == null || linkList.Count < 1)
{
return;
}
blinkCodes.AddRange(linkList.Select(x => x.Code));
}
else
{
blinkCodes.Add(linkCode);
}
await _bimfaceCtrl?.SetBlinkComponents(blinkCodes);
await Task.Delay(5000);
await _bimfaceCtrl?.ClearBlinkComponents();
};
_propertyCtrl.ViewParterEvent += (parter) =>
{
if (parter == null)
{
return;
}
_bimfaceCtrl?.ZoomToComponent(parter.Code);
};
_propertyCtrl.PropertyValueChangedEvent += (parter) =>
{
if (parter == null)
{
return;
}
UpdateVisualListCtrl();
AutoApplyGrading();
};
_propertyCtrl.MarkPropertyValueChangedEvent += (parter) =>
{
//标注属性发生改变
//判断当前是否有标注展示,若有则更新标注,最好是更新单个标注
};
_propertyCtrl.GradingPropertyValueChangedEvent += (parter) =>
{
//分级属性发生改变
//判断当前是否有分级展示,若有则更新分级,最好是更新单个分级
};
_propertyCtrl.FlowDirectionPropertyValueChangedEvent += (visual) =>
{
//流向属性发生改变
//判断流向是否加载,如果加载则更新流向,最好是更新单个流向
UpdateFlowEffect(visual);
};
}
return _propertyCtrl;
}
//属性控件是否可见
private bool IsPropertyCtrlVisible
{
get
{
if (this.docPnlRight.Visibility == DevExpress.XtraBars.Docking.DockVisibility.Visible)
{
if (this.controlContainerRight.Controls.Count > 0)
{
if (this.controlContainerRight.Controls[0] is XhsProjectSimulationPropertyCtrl)
{
return true;
}
}
}
return false;
}
}
//显示属性控件
private void ShowPropertyCtrl()
{
if (IsPropertyCtrlVisible)
{
return;
}
var propertyCtrl = GetPropertyCtrl();
this.controlContainerRight.Controls.Clear();
this.controlContainerRight.Controls.Add(propertyCtrl);
this.docPnlRight.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible;
this.docPnlRight.Text = "属性";
this.docPnlRight.Width = 300;
}
//显示选择属性
private void ShowSelectedProperty()
{
ShowSelectedProperty(_selectedVisual);
}
//显示选择属性
private void ShowSelectedProperty(Yw.Model.HydroVisualInfo visual)
{
if (_hydroInfo == null)
{
return;
}
ShowPropertyCtrl();
_selectedVisual = visual;
if (_selectedVisual == null)
{
_propertyCtrl.SelectedObject = null;
return;
}
_propertyCtrl.SelectedObject = GetVisualViewModel(_selectedVisual);
}
//更新选择属性
private void UpdateSelectedProperty()
{
if (!IsPropertyCtrlVisible)
{
return;
}
if (_selectedVisual == null)
{
return;
}
_propertyCtrl?.UpdateRows();
}
#endregion
#region 自动匹配
//获取匹配列表控件
private XhsProjectSimulationMatchingListCtrl GetMatchingListCtrl()
{
if (_matchingListCtrl == null)
{
_matchingListCtrl = new XhsProjectSimulationMatchingListCtrl();
_matchingListCtrl.Dock = DockStyle.Fill;
_matchingListCtrl.HydroClickEvent += async (code) =>
{
if (_hydroInfo == null)
{
return;
}
var allParterList = _hydroInfo.GetAllVisuals();
_selectedVisual = allParterList?.Find(x => x.Code == code);
var elementIds = new List();
if (_selectedVisual != null)
{
elementIds.Add(_selectedVisual.Code);
}
await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds);
ShowSelectedProperty();
};
_matchingListCtrl.ApplyMatchingEvent += (output) =>
{
if (_hydroInfo == null)
{
return false;
}
return AssetsMatchingParasHelper.Apply(_hydroInfo, output);
};
}
return _matchingListCtrl;
}
//匹配列表控件
private XhsProjectSimulationMatchingListCtrl _matchingListCtrl = null;
//自动匹配
private void barBtnMatchingList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
if (_hydroInfo == null)
{
return;
}
this.controlContainerBottom.Controls.Clear();
var matchingListCtrl = GetMatchingListCtrl();
var input = AssetsMatchingParasHelper.Create(_hydroInfo, GetCalcuResultList());
matchingListCtrl.SetBindingData(input);
this.controlContainerBottom.Controls.Add(matchingListCtrl);
this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible;
this.docPnlBottom.Text = "匹配列表";
this.docPnlBottom.Height = 350;
}
#endregion
#region 未匹配列表
//获取未匹配列表控件
private XhsProjectSimulationUnMatchingListCtrl GetUnMatchingListCtrl()
{
if (_unMatchingListCtrl == null)
{
_unMatchingListCtrl = new XhsProjectSimulationUnMatchingListCtrl();
_unMatchingListCtrl.Dock = DockStyle.Fill;
_unMatchingListCtrl.HydroClickEvent += async (parter) =>//行点击
{
if (parter == null)
{
return;
}
if (_hydroInfo == null)
{
return;
}
var allParterList = _hydroInfo.GetAllVisuals();
_selectedVisual = allParterList?.Find(x => x.Code == parter.Code);
var elementIds = new List() { parter.Code };
await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds);
ShowSelectedProperty();
};
_unMatchingListCtrl.ViewModelEvent += async (parters) =>//查看模型
{
var codes = parters?.Select(x => x.Code).Distinct().ToList();
await _bimfaceCtrl?.ZoomAndSelectComponents(codes);
_selectedVisual = null;
ShowSelectedProperty();
};
}
return _unMatchingListCtrl;
}
private XhsProjectSimulationUnMatchingListCtrl _unMatchingListCtrl = null;//未匹配列表
//未匹配列表
private void barBtnUnMatchingList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
if (_hydroInfo == null)
{
return;
}
this.controlContainerBottom.Controls.Clear();
var unMatchingListCtrl = GetUnMatchingListCtrl();
unMatchingListCtrl.SetBindingData(_hydroInfo);
this.controlContainerBottom.Controls.Add(unMatchingListCtrl);
this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible;
this.docPnlBottom.Text = "未匹配列表";
this.docPnlBottom.Height = 350;
}
#endregion
#region 一键显隐
//显隐编码列表
private List _fastShowHiddenCodeList = null;
//一键显隐
private async void FastShowHidden()
{
if (_hydroInfo == null)
{
return;
}
if (_hydroInfo.Decorators == null || _hydroInfo.Decorators.Count < 1)
{
return;
}
if (_fastShowHiddenCodeList == null)
{
_fastShowHiddenCodeList = _hydroInfo.Decorators.Select(x => x.Code).ToList();
await _bimfaceCtrl?.HideComponents(_fastShowHiddenCodeList);
}
else
{
await _bimfaceCtrl?.ShowComponents(_fastShowHiddenCodeList);
_fastShowHiddenCodeList = null;
}
}
//触发一键显隐
private void barBtnFastShowHidden_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
FastShowHidden();
}
#endregion
#region 保存信息
//保存
private async void barBtnSave_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
if (_hydroInfo == null)
{
return;
}
Stopwatch sw = new Stopwatch();
sw.Start();
var id = await BLLFactory.Instance.Save(_hydroInfo);
//耗时巨大的代码
sw.Stop();
TimeSpan ts2 = sw.Elapsed;
Console.WriteLine("Stopwatch总共花费{0}ms.", ts2.TotalMilliseconds);
if (id < 1)
{
TipFormHelper.ShowError("保存失败!");
return;
}
_hydroInfo = await BLLFactory.Instance.GetByID(id);
TipFormHelper.ShowSucceed("保存成功!");
}
#endregion
#region 批量配置
//注册批量配置事件
private void RegistBulkSetEvents()
{
//水库
this.barBtnSetReservoirList.ItemClick += delegate
{
//var dlg = new HydroReservoirBulkSetListDlg();
//dlg.ShowDialog();
};
//水池
this.barBtnSetTankList.ItemClick += delegate
{
//var dlg = new HydroTankBulkSetListDlg();
//dlg.ShowDialog();
};
//水箱
this.barBtnSetWaterboxList.ItemClick += delegate
{
//if (_hydroInfo == null)
//{
// return;
//}
//var dlg = new SetHydroWaterboxListDlg();
//dlg.SetBindingData(_hydroInfo);
//dlg.HydroClickEvent += async (obj) =>
//{
// if (obj == null)
// {
// return;
// }
// _selectedParter = obj;
// await _bimfaceCtrl?.ZoomAndSelectComponent(obj.Code);
// ShowProperty();
//};
//dlg.HydroChangedEvent += (obj) =>
//{
//};
//dlg.ShowDialog();
};
//连接节点
this.barBtnSetJunctionList.ItemClick += delegate
{
//var dlg = new HydroJunctionBulkSetListDlg();
//dlg.ShowDialog();
};
//闷头
this.barBtnSetBluntheadList.ItemClick += delegate
{
//if (_hydroInfo == null)
//{
// return;
//}
//var dlg = new SetHydroBluntheadListDlg();
//dlg.SetBindingData(_hydroInfo);
//dlg.HydroClickEvent += async (obj) =>
//{
// if (obj == null)
// {
// return;
// }
// _selectedParter = obj;
// await _bimfaceCtrl?.ZoomAndSelectComponent(obj.Code);
// ShowProperty();
//};
//dlg.HydroChangedEvent += (obj) =>
//{
//};
//dlg.ShowDialog();
};
//弯头
this.barBtnSetElbowsList.ItemClick += delegate
{
//if (_hydroInfo == null)
//{
// return;
//}
//var dlg = new SetHydroElbowListDlg();
//dlg.SetBindingData(_hydroInfo);
//dlg.HydroClickEvent += async (obj) =>
//{
// if (obj == null)
// {
// return;
// }
// _selectedParter = obj;
// await _bimfaceCtrl?.ZoomAndSelectComponent(obj.Code);
// ShowProperty();
//};
//dlg.HydroChangedEvent += (obj) =>
//{
//};
//dlg.ShowDialog();
};
//三通
this.barBtnSetThreelinkList.ItemClick += delegate
{
if (_hydroInfo == null)
{
return;
}
var dlg = new SetHydroThreelinkListDlg();
dlg.SetBindingData(_hydroInfo);
dlg.ShowDialog();
};
//四通
this.barBtnSetFourlinkList.ItemClick += delegate
{
if (_hydroInfo == null)
{
return;
}
var dlg = new SetHydroFourlinkListDlg();
dlg.SetBindingData(_hydroInfo);
dlg.ShowDialog();
};
//水表
this.barBtnSetMeterList.ItemClick += delegate
{
if (_hydroInfo == null)
{
return;
}
var dlg = new SetHydroMeterListDlg();
dlg.SetBindingData(_hydroInfo);
dlg.ShowDialog();
};
//流量计
this.barBtnSetFlowmeterList.ItemClick += delegate
{
if (_hydroInfo == null)
{
return;
}
var dlg = new SetHydroFlowmeterListDlg();
dlg.SetBindingData(_hydroInfo);
dlg.ShowDialog();
};
//压力表
this.barBtnSetPressmeterList.ItemClick += delegate
{
if (_hydroInfo == null)
{
return;
}
var dlg = new SetHydroPressmeterListDlg();
dlg.SetBindingData(_hydroInfo);
dlg.ShowDialog();
};
//管道
this.barBtnSetPipeList.ItemClick += delegate
{
if (_hydroInfo == null)
{
return;
}
var dlg = new SetHydroPipeListDlg();
dlg.SetBindingData(_hydroInfo);
dlg.ShowDialog();
};
//水泵
this.barBtnSetPumpList.ItemClick += delegate
{
if (_hydroInfo == null)
{
return;
}
var dlg = new SetHydroPumpListDlg();
dlg.SetBindingData(_hydroInfo);
dlg.ShowDialog();
};
//阀门
this.barBtnSetValveList.ItemClick += delegate
{
if (_hydroInfo == null)
{
return;
}
var dlg = new SetHydroValveListDlg();
dlg.SetBindingData(_hydroInfo);
dlg.ShowDialog();
};
}
//显示RadialMenu
private void barBtnSetList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
this.rmSet.ShowPopup(MousePosition, true);
}
//弹出前
private void rmSet_BeforePopup(object sender, CancelEventArgs e)
{
if (_hydroInfo == null)
{
e.Cancel = true;
return;
}
//水库
if (_hydroInfo.Reservoirs == null || _hydroInfo.Reservoirs.Count < 1)
{
this.barBtnSetReservoirList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetReservoirList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//水池
if (_hydroInfo.Tanks == null || _hydroInfo.Tanks.Count < 1)
{
this.barBtnSetTankList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetTankList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//水箱
if (_hydroInfo.Waterboxs == null || _hydroInfo.Waterboxs.Count < 1)
{
this.barBtnSetWaterboxList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetWaterboxList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//连接节点
if (_hydroInfo.Junctions == null || _hydroInfo.Junctions.Count < 1)
{
this.barBtnSetJunctionList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetJunctionList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//喷嘴
if (_hydroInfo.Nozzles == null || _hydroInfo.Nozzles.Count < 1)
{
this.barBtnSetNozzleList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetNozzleList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//消火栓
if (_hydroInfo.Hydrants == null || _hydroInfo.Hydrants.Count < 1)
{
this.barBtnSetHydrantList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetHydrantList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//闷头
if (_hydroInfo.Bluntheads == null || _hydroInfo.Bluntheads.Count < 1)
{
this.barBtnSetBluntheadList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetBluntheadList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//弯头
if (_hydroInfo.Elbows == null || _hydroInfo.Elbows.Count < 1)
{
this.barBtnSetElbowsList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetElbowsList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//三通
if (_hydroInfo.Threelinks == null || _hydroInfo.Threelinks.Count < 1)
{
this.barBtnSetThreelinkList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetThreelinkList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//四通
if (_hydroInfo.Fourlinks == null || _hydroInfo.Fourlinks.Count < 1)
{
this.barBtnSetFourlinkList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetFourlinkList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//水表
if (_hydroInfo.Meters == null || _hydroInfo.Meters.Count < 1)
{
this.barBtnSetMeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetMeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//流量计
if (_hydroInfo.Flowmeters == null || _hydroInfo.Flowmeters.Count < 1)
{
this.barBtnSetFlowmeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetFlowmeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//压力表
if (_hydroInfo.Pressmeters == null || _hydroInfo.Pressmeters.Count < 1)
{
this.barBtnSetPressmeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetPressmeterList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//管道
if (_hydroInfo.Pipes == null || _hydroInfo.Pipes.Count < 1)
{
this.barBtnSetPipeList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetPipeList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//过渡件
if (_hydroInfo.Translations == null || _hydroInfo.Translations.Count < 1)
{
this.barBtnSetTranslationList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetTranslationList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//换热器
if (_hydroInfo.Exchangers == null || _hydroInfo.Exchangers.Count < 1)
{
this.barBtnSetExchangerList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetExchangerList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//空压机
if (_hydroInfo.Compressors == null || _hydroInfo.Compressors.Count < 1)
{
this.barBtnSetCompressorList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetCompressorList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//水泵
if (_hydroInfo.Pumps == null || _hydroInfo.Pumps.Count < 1)
{
this.barBtnSetPumpList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetPumpList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
//阀门
if (_hydroInfo.Valves == null || _hydroInfo.Valves.Count < 1)
{
this.barBtnSetValveList.Visibility = DevExpress.XtraBars.BarItemVisibility.Never;
}
else
{
this.barBtnSetValveList.Visibility = DevExpress.XtraBars.BarItemVisibility.Always;
}
}
#endregion
#region 并联分析
//并联分析
private void barBtnAnaly_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
if (_hydroInfo == null)
{
return;
}
if (_hydroInfo.Pumps == null || _hydroInfo.Pumps.Count < 1)
{
return;
}
var allCalcuResultList = GetCalcuResultList();
var vmList = new List();
foreach (var pump in _hydroInfo.Pumps)
{
if (!pump.RatedN.HasValue)
{
continue;
}
var qh = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQH)?.CurveData;
var qe = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQE)?.CurveData;
var qp = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQP)?.CurveData;
if (qh == null)
{
continue;
}
var qhPtList = qh.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList();
var qePtList = qe?.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList();
var qpPtList = qp?.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList();
var vm = new XhsSinglePumpViewModel();
vmList.Add(vm);
vm.ID = pump.ID;
vm.Name = pump.Name;
vm.Code = pump.Code;
vm.IsBp = true;
vm.RunStatus = pump.LinkStatus == Yw.Hydro.LinkStatus.Open;
vm.RatedHz = pump.RatedHz;
vm.CurrentHz = Math.Round(pump.RatedHz * pump.SpeedRatio, 1);
vm.RatedSpeed = pump.RatedN.Value;
vm.CurrentSpeed = Math.Round(pump.RatedN.Value * pump.SpeedRatio);
vm.CurveQH = qhPtList;
vm.CurveQE = qePtList;
vm.CurveQP = qpPtList;
if (allCalcuResultList != null && allCalcuResultList.Count > 0)
{
var calcuResult = allCalcuResultList.Find(x => x.Code == pump.Code) as HydroCalcuLinkResult;
if (calcuResult != null)
{
if (calcuResult.CalcuFlow.HasValue)
{
vm.CalcuQ = Math.Abs(calcuResult.CalcuFlow.Value);
}
var calcuResultStart = allCalcuResultList.Find(x => x.Code == pump.StartCode) as HydroCalcuNodeResult;
var calcuResultEnd = allCalcuResultList.Find(x => x.Code == pump.EndCode) as HydroCalcuNodeResult;
if (calcuResultStart != null && calcuResultEnd != null)
{
if (calcuResultStart.CalcuHead.HasValue && calcuResultEnd.CalcuHead.HasValue)
{
vm.CalcuH = Math.Round(Math.Abs(calcuResultStart.CalcuHead.Value - calcuResultEnd.CalcuHead.Value), 4);
}
}
}
}
}
var dlg = new PumpParallelAnalyDlg();
dlg.SetBindingData(vmList);
dlg.ReloadDataEvent += (list) =>
{
list?.ForEach(x =>
{
var pump = _hydroInfo.Pumps?.Find(t => t.Code == x.Code);
if (pump != null)
{
pump.LinkStatus = x.RunStatus ? Yw.Hydro.PumpStatus.Open : Yw.Hydro.PumpStatus.Closed;
pump.SpeedRatio = Math.Round(x.CurrentHz / pump.RatedHz, 1);
}
});
ShowSelectedProperty();
return true;
};
dlg.ShowDialog();
}
#endregion
#region 构件查询
//查询组件
private HydroVisualSearchListCtrl _searchCtrl = null;
//获取查询组件
private HydroVisualSearchListCtrl GetSearchCtrl()
{
if (_searchCtrl == null)
{
_searchCtrl = new HydroVisualSearchListCtrl();
_searchCtrl.Dock = DockStyle.Fill;
var allVisualViewModelList = GetVisualViewModelList();
_searchCtrl.InitialData(allVisualViewModelList);
_searchCtrl.HydroClickInfoEvent += async (visual) =>
{
ShowSelectedProperty(visual);
await _bimfaceCtrl?.ZoomAndSelectComponent(visual?.Code);
};
_searchCtrl.HydroSearchInfoEvent += async (list) =>
{
var elementIds = new List();
if (list != null && list.Count > 0)
{
_selectedVisual = list.First();
list.ForEach(x => elementIds.Add(x.Code));
}
else
{
_selectedVisual = null;
}
ShowSelectedProperty();
await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds);
};
}
return _searchCtrl;
}
//查询控件是否可见
private bool IsSearchCtrlVisible
{
get
{
if (this.docPnlBottom.Visibility == DevExpress.XtraBars.Docking.DockVisibility.Visible)
{
if (this.controlContainerBottom.Controls.Count > 0)
{
if (this.controlContainerBottom.Controls[0] is HydroVisualSearchListCtrl)
{
return true;
}
}
}
return false;
}
}
//显示查询控件
private void ShowSearchCtrl(string content)
{
if (IsSearchCtrlVisible)
{
return;
}
var searchCtrl = GetSearchCtrl();
searchCtrl.SetBindingData(content);
this.controlContainerBottom.Controls.Clear();
this.controlContainerBottom.Controls.Add(searchCtrl);
this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible;
this.docPnlBottom.Text = "构件查询";
this.docPnlBottom.Height = 350;
}
//显示查询窗体
private void ShowSearchDlg()
{
if (IsSearchCtrlVisible)
{
return;
}
var dlg = new InputHydroVisualSearchListDlg();
dlg.SearchEvent += (content) =>
{
if (string.IsNullOrEmpty(content))
{
return;
}
ShowSearchCtrl(content);
};
dlg.SetBindingData();
dlg.ShowDialog();
}
//查询
private void barBtnSearch_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
ShowSearchDlg();
}
#endregion
#region 模型标注
#region 标注设置
//所有标注设置列表
private List _allMarkSetList = null;
//获取标注设置列表
private List GetMarkSetList()
{
if (_hydroInfo == null)
{
return default;
}
if (_allMarkSetList == null)
{
_allMarkSetList = HydroMarkHelper.GetSetList(_hydroInfo);
}
return _allMarkSetList;
}
#endregion
#region 标注结果
//所有标注结果列表
private List _allMarkResultList = null;
//获取标注结果列表
private List GetMarkResultList()
{
if (_hydroInfo == null)
{
return default;
}
var allSetList = GetMarkSetList();
_allMarkResultList = HydroMarkHelper.GetResultList(_hydroInfo, allSetList);
return _allMarkResultList;
}
#endregion
#region 标注显示
//标注是否显示
private bool _isMarkVisible = false;
//应用标注列表
private async void ApplyMarkList()
{
if (_isMarkVisible)
{
var allResultList = GetMarkResultList();
var leadLabels = allResultList?.Select(x => new LogicMarkLeadLabel(x.Code, x.Text, 100000)).ToList();
await _bimfaceCtrl?.SetLogicMarkLeadLabels(leadLabels);
}
else
{
await _bimfaceCtrl?.ClearLogicMarkLeadLabels();
}
}
//显示标注设置窗体
private void ShowSetMarkDlg()
{
if (_hydroInfo == null)
{
return;
}
var allMarkSetList = GetMarkSetList();
var dlg = new SetHydroMarkDlg();
dlg.SetBindingData(allMarkSetList);
dlg.ReloadDataEvent += (list) =>
{
_allMarkSetList = list;
ApplyMarkList();
};
dlg.ShowDialog();
}
//设置标注
private void barBtnSetMark_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
ShowSetMarkDlg();
}
//是否显示
private void barCkMark_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
_isMarkVisible = this.barCkMark.Checked;
ApplyMarkList();
}
#endregion
#endregion
#region 颜色分级
#region 颜色配置
//所有分级列表
private List _allGradingList = null;
//获取分级列表
private async Task> GetGradingList()
{
if (_hydroInfo == null)
{
return default;
}
if (_allGradingList == null)
{
_allGradingList = await BLLFactory.Instance.GetByModelID(_hydroInfo.ID);
if (_allGradingList == null || _allGradingList.Count < 1)
{
var config = Yw.Settings.HydroParasHelper.Hydro.Grading;
if (config != null && config.Items != null && config.Items.Count > 0)
{
_allGradingList = new List();
config.Items.ForEach(x =>
{
var vmo = new HydroGradingVmo()
{
ModelID = _hydroInfo.ID,
Catalog = x.Catalog,
PropName = x.PropName,
SetValue = x.SetValue,
MinValue = x.MinValue,
MaxValue = x.MaxValue,
Color = x.Color,
SortCode = config.Items.IndexOf(x)
};
_allGradingList.Add(vmo);
});
}
}
}
return _allGradingList;
}
//显示配置颜色分级窗体
private async void ShowSetGradingDlg()
{
if (_hydroInfo == null)
{
return;
}
var allGradingList = await GetGradingList();
var dlg = new SetHydroGradingTreeDlg();
dlg.SetBindingData(_hydroInfo, allGradingList);
dlg.ReloadDataEvent += (list) =>
{
_allGradingList = list;
};
dlg.ApplyDataEvent += (catalog, propName) =>
{
ApplyGrading(catalog, propName);
};
dlg.ShowDialog();
}
//配置颜色分级
private void barBtnGradingSet_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
ShowSetGradingDlg();
}
#endregion
#region 应用分级
//颜色分级应用列表
private List _allGradingApplyList = null;
//获取颜色分级应用列表
private List GetGradingApplyList()
{
if (_allGradingApplyList == null)
{
_allGradingApplyList = new List();
if (_hydroInfo.Pumps != null && _hydroInfo.Pumps.Count > 0)
{
_allGradingApplyList.Add(new HydroGradingApplyViewModel()
{
Code = Yw.Hydro.ParterCatalog.Pump,
Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetName(Yw.Hydro.ParterCatalog.Pump),
PropName = Yw.Hydro.ParterProp.LinkStatus
});
}
if (_hydroInfo.Valves != null && _hydroInfo.Valves.Count > 0)
{
_allGradingApplyList.Add(new HydroGradingApplyViewModel()
{
Code = Yw.Hydro.ParterCatalog.Valve,
Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetName(Yw.Hydro.ParterCatalog.Valve),
PropName = Yw.Hydro.ParterProp.LinkStatus
});
}
if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0)
{
_allGradingApplyList.Add(new HydroGradingApplyViewModel()
{
Code = Yw.Hydro.ParterCatalog.Pipe,
Name = Yw.WinFrmUI.HydroParterCatalogHelper.GetName(Yw.Hydro.ParterCatalog.Pipe),
PropName = HydroVisualCalcuProp.CalcuFlow
});
}
}
return _allGradingApplyList;
}
//获取颜色分级应用结果列表
private async Task> GetGradingApplyResultList()
{
if (_hydroInfo == null)
{
return default;
}
//所有分级列表
var allGradingList = await GetGradingList();
if (allGradingList == null || allGradingList.Count < 1)
{
return default;
}
//所有分级应用列表
var allGradingApplyList = GetGradingApplyList();
if (allGradingApplyList == null || allGradingApplyList.Count < 1)
{
return default;
}
//所有计算结果列表
var allCalcuResultList = GetCalcuResultList();
//所有应用结果列表
var allGradingApplyResultList = new List();
allGradingApplyList.ForEach(x =>
{
var allCatalogGradingList = allGradingList.Where(t => t.Catalog == x.Code).ToList();
if (allCatalogGradingList != null || allCatalogGradingList.Count > 0)
{
switch (x.Code)
{
case Yw.Hydro.ParterCatalog.Pump:
{
if (_hydroInfo.Pumps != null && _hydroInfo.Pumps.Count > 0)
{
foreach (var pump in _hydroInfo.Pumps)
{
switch (x.PropName)
{
case Yw.Hydro.ParterProp.LinkStatus:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.LinkStatus).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var grading = gradingList.Meet(pump.LinkStatus);
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pump.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
break;
case HydroVisualCalcuProp.CalcuFlow:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuFlow.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pump.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuVelocity:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuVelocity.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pump.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuHeadLoss:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuHeadLoss.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pump.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
}
}
break;
default: break;
}
}
}
}
break;
case Yw.Hydro.ParterCatalog.Valve:
{
if (_hydroInfo.Valves != null && _hydroInfo.Valves.Count > 0)
{
foreach (var valve in _hydroInfo.Valves)
{
switch (x.PropName)
{
case Yw.Hydro.ParterProp.LinkStatus:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.LinkStatus).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var grading = gradingList.Meet(valve.LinkStatus);
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = valve.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
break;
case HydroVisualCalcuProp.CalcuFlow:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuFlow.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = valve.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuVelocity:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuVelocity.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = valve.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuHeadLoss:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuHeadLoss.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = valve.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
}
}
break;
default: break;
}
}
}
}
break;
case Yw.Hydro.ParterCatalog.Pipe:
{
if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0)
{
foreach (var pipe in _hydroInfo.Pipes)
{
switch (x.PropName)
{
case HydroVisualCalcuProp.CalcuFlow:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuFlow.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pipe.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuVelocity:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuVelocity.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pipe.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuHeadLoss:
{
var gradingList = allCatalogGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuHeadLoss.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pipe.Code,
Color = grading.Color
};
allGradingApplyResultList.Add(result);
}
}
}
}
}
break;
default: break;
}
}
}
}
break;
default: break;
}
}
});
return allGradingApplyResultList;
}
//获取颜色分级应用结果列表
private async Task> GetGradingApplyResultList(string catalog, string propName)
{
if (_hydroInfo == null)
{
return default;
}
//所有分级列表
var allGradingList = await GetGradingList();
if (allGradingList == null || allGradingList.Count < 1)
{
return default;
}
var currentGradingList = allGradingList.Where(x => x.Catalog == catalog).ToList();
if (currentGradingList.Count < 1)
{
return default;
}
//所有分级应用列表
var allGradingApplyList = GetGradingApplyList();
if (allGradingApplyList == null || allGradingApplyList.Count < 1)
{
return default;
}
//当前分级应用
var gradingApply = allGradingApplyList.Find(x => x.Code == catalog);
if (gradingApply == null)
{
return default;
}
gradingApply.PropName = propName;
//所有计算结果
var allCalcuResultList = GetCalcuResultList();
//应用结果列表
var gradingApplyResultList = new List();
switch (catalog)
{
case Yw.Hydro.ParterCatalog.Pump:
{
if (_hydroInfo.Pumps != null && _hydroInfo.Pumps.Count > 0)
{
foreach (var pump in _hydroInfo.Pumps)
{
switch (propName)
{
case Yw.Hydro.ParterProp.LinkStatus:
{
var gradingList = currentGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.LinkStatus).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var grading = gradingList.Meet(pump.LinkStatus);
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pump.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
break;
case HydroVisualCalcuProp.CalcuFlow:
{
var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuFlow.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pump.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuVelocity:
{
var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuVelocity.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pump.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuHeadLoss:
{
var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pump.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuHeadLoss.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pump.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
}
}
break;
default: break;
}
}
}
}
break;
case Yw.Hydro.ParterCatalog.Valve:
{
if (_hydroInfo.Valves != null && _hydroInfo.Valves.Count > 0)
{
foreach (var valve in _hydroInfo.Valves)
{
switch (propName)
{
case Yw.Hydro.ParterProp.LinkStatus:
{
var gradingList = currentGradingList.Where(x => x.PropName == Yw.Hydro.ParterProp.LinkStatus).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var grading = gradingList.Meet(valve.LinkStatus);
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = valve.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
break;
case HydroVisualCalcuProp.CalcuFlow:
{
var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuFlow.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = valve.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuVelocity:
{
var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuVelocity.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = valve.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuHeadLoss:
{
var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == valve.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuHeadLoss.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = valve.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
}
}
break;
default: break;
}
}
}
}
break;
case Yw.Hydro.ParterCatalog.Pipe:
{
if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0)
{
foreach (var pipe in _hydroInfo.Pipes)
{
switch (propName)
{
case HydroVisualCalcuProp.CalcuFlow:
{
var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuFlow).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuFlow.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuFlow.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pipe.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuVelocity:
{
var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuVelocity).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuVelocity.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuVelocity.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pipe.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
}
}
break;
case HydroVisualCalcuProp.CalcuHeadLoss:
{
var gradingList = currentGradingList.Where(x => x.PropName == HydroVisualCalcuProp.CalcuHeadLoss).OrderBy(t => t.SortCode).ToList();
if (gradingList != null && gradingList.Count > 0)
{
var calcuResult = allCalcuResultList?.Find(t => t.Code == pipe.Code);
if (calcuResult is HydroCalcuLinkResult calcuLinkResult)
{
if (calcuLinkResult.CalcuHeadLoss.HasValue)
{
var grading = gradingList.Meet(Math.Abs(calcuLinkResult.CalcuHeadLoss.Value));
if (grading != null)
{
var result = new HydroGradingApplyResultViewModel()
{
Code = pipe.Code,
Color = grading.Color
};
gradingApplyResultList.Add(result);
}
}
}
}
}
break;
default: break;
}
}
}
}
break;
default: break;
}
return gradingApplyResultList;
}
//颜色分级是否应用了
private bool _isGradingApply = false;
//颜色分级应用编码列表
private List _allGradingApplyCodeList = null;
//应用颜色分级
private async void ApplyGrading()
{
if (_hydroInfo == null)
{
return;
}
_isGradingApply = true;
var allGradingApplyResultList = await GetGradingApplyResultList();
if (allGradingApplyResultList == null || allGradingApplyResultList.Count < 1)
{
CancelApplyGrading();
return;
}
var objGroupList = allGradingApplyResultList.GroupBy(x => x.Color).ToList();
objGroupList.ForEach(async x =>
{
await _bimfaceCtrl?.OverrideComponentsColor(x.Select(t => t.Code).Distinct().ToList(), x.Key, 1);
});
_allGradingApplyCodeList = allGradingApplyResultList.Select(x => x.Code).Distinct().ToList();
}
//应用颜色分级
private async void ApplyGrading(string catalog, string propName)
{
if (_hydroInfo == null)
{
return;
}
_isGradingApply = true;
var allGradingApplyResultList = await GetGradingApplyResultList(catalog, propName);
if (allGradingApplyResultList == null || allGradingApplyResultList.Count < 1)
{
return;
}
var objGroupList = allGradingApplyResultList.GroupBy(x => x.Color).ToList();
objGroupList.ForEach(async x =>
{
await _bimfaceCtrl?.OverrideComponentsColor(x.Select(t => t.Code).Distinct().ToList(), x.Key, 1);
});
var codeList = allGradingApplyResultList.Select(x => x.Code);
if (_allGradingApplyCodeList == null)
{
_allGradingApplyCodeList = new List();
}
_allGradingApplyCodeList.AddRange(codeList);
_allGradingApplyCodeList = _allGradingApplyCodeList.Distinct().ToList();
}
//自动应用颜色分级
private void AutoApplyGrading()
{
if (!_isGradingApply)
{
return;
}
ApplyGrading();
}
//取消应用颜色分级
private async void CancelApplyGrading()
{
if (_hydroInfo == null)
{
return;
}
_isGradingApply = false;
if (_allGradingApplyCodeList != null && _allGradingApplyCodeList.Count > 0)
{
await _bimfaceCtrl?.RestoreComponentsColor(_allGradingApplyCodeList);
}
}
//显示应用颜色分级窗体
private void ShowApplyGradingDlg()
{
if (_hydroInfo == null)
{
return;
}
var allGradingApplyList = GetGradingApplyList();
if (allGradingApplyList == null || allGradingApplyList.Count < 1)
{
return;
}
var dlg = new ApplyHydroGradingDlg();
dlg.SetBindingData(allGradingApplyList);
dlg.ReloadDataEvent += (obj) =>
{
_allGradingApplyList = obj;
ApplyGrading();
};
dlg.ShowDialog();
}
//应用颜色分级
private void barBtnGradingApply_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
ShowApplyGradingDlg();
}
//取消应用分级
private void batBtnCancelGradingApply_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
CancelApplyGrading();
}
#endregion
#endregion
#region 人工刷新
//刷新
private async void barBtnRefresh_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
if (XtraMessageBox.Show("刷新后将丢失当前水力信息更改,是否继续刷新?", "询问", MessageBoxButtons.YesNo) == DialogResult.Yes)
{
if (_project == null)
{
return;
}
if (_projectSite == null)
{
return;
}
var hydroRelation = await BLLFactory.Instance
.GetDefaultByObjectTypeAndObjectIDOfPurpose(HStation.Xhs.DataType.XhsProjectSite, _projectSite.ID, HStation.Xhs.Purpose.Simulation);
Stopwatch sw = new Stopwatch();
sw.Start();
_hydroInfo = await BLLFactory.Instance.GetByID(hydroRelation.ModelID);
sw.Stop();
TimeSpan ts2 = sw.Elapsed;
Console.WriteLine("Stopwatch总共花费{0}ms.", ts2.TotalMilliseconds);
_selectedVisual = null;
await _bimfaceCtrl?.ZoomAndSelectComponents(null);
ShowSelectedProperty();
TipFormHelper.ShowSucceed("数据已刷新");
}
}
#endregion
#region 水流动画
//水流动画是否可见
private bool _isFlowEffectVisible = false;
//所有水流动画列表
private List _allFlowEffectList = null;
//获取流向列表
private List GetFlowEffectList()
{
if (_hydroInfo == null)
{
return default;
}
if (_allFlowEffectList == null)
{
_allFlowEffectList = new List();
var allCalcuResultList = GetCalcuResultList();
if (_hydroInfo.Pipes != null && _hydroInfo.Pipes.Count > 0)
{
foreach (var parter in _hydroInfo.Pipes)
{
var flowEffect = new LogicFlowEffect();
_allFlowEffectList.Add(flowEffect);
flowEffect.Id = parter.Code;
flowEffect.Rotation = 90;
flowEffect.SpeedX = 0.1;
if (parter.FlowDirectionX == Yw.Hydro.FlowDirection.None)
{
flowEffect.SpeedX = 0;
}
else if (parter.FlowDirectionX == Yw.Hydro.FlowDirection.Positive)
{
flowEffect.SpeedX = 0.1;
}
else
{
flowEffect.SpeedX = -0.1;
}
if (parter.FlowDirectionY == Yw.Hydro.FlowDirection.None)
{
flowEffect.SpeedY = 0;
}
else if (parter.FlowDirectionY == Yw.Hydro.FlowDirection.Positive)
{
flowEffect.SpeedY = 0.1;
}
else
{
flowEffect.SpeedY = -0.1;
}
var calcuResult = allCalcuResultList?.Find(x => x.Code == parter.Code) as HydroCalcuLinkResult;
if (calcuResult != null)
{
if (calcuResult.CalcuVelocity < 0)
{
flowEffect.SpeedX = -flowEffect.SpeedX;
}
}
}
}
}
return _allFlowEffectList;
}
//加载水流动画
private async void LoadFlowEffect()
{
if (_hydroInfo == null)
{
return;
}
var allFlowEffectList = GetFlowEffectList();
await _bimfaceCtrl?.LoadFlowEffect(allFlowEffectList);
}
//卸载水流动画
private async void UnloadFlowEffect()
{
if (_hydroInfo == null)
{
return;
}
await _bimfaceCtrl?.UnloadFlowEffect();
}
//设置水力动画
private void SetFlowEffect()
{
if (_isFlowEffectVisible)
{
LoadFlowEffect();
}
else
{
UnloadFlowEffect();
}
}
//更新水流动画
private async void UpdateFlowEffect(Yw.Model.HydroVisualInfo visual)
{
if (_hydroInfo == null)
{
return;
}
var allFlowEffectList = GetFlowEffectList();
var flowEffect = _allFlowEffectList?.Find(x => x.Id == visual.Code);
if (flowEffect == null)
{
return;
}
if (visual.FlowDirectionX == Yw.Hydro.FlowDirection.None)
{
flowEffect.SpeedX = 0;
}
else if (visual.FlowDirectionX == Yw.Hydro.FlowDirection.Positive)
{
flowEffect.SpeedX = 0.1;
}
else
{
flowEffect.SpeedX = -0.1;
}
if (visual.FlowDirectionY == Yw.Hydro.FlowDirection.None)
{
flowEffect.SpeedY = 0;
}
else if (visual.FlowDirectionY == Yw.Hydro.FlowDirection.Positive)
{
flowEffect.SpeedY = 0.1;
}
else
{
flowEffect.SpeedY = -0.1;
}
var allCalcuResultList = GetCalcuResultList();
var calcuResult = allCalcuResultList?.Find(x => x.Code == visual.Code) as HydroCalcuLinkResult;
if (calcuResult != null)
{
if (calcuResult.CalcuVelocity < 0)
{
flowEffect.SpeedX = -flowEffect.SpeedX;
}
}
if (_isFlowEffectVisible)
{
await _bimfaceCtrl?.UpdateFlowEffect(flowEffect);
}
}
//水流动画是否可见
private void barCkFlowEffect_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
_isFlowEffectVisible = this.barCkFlowEffect.Checked;
SetFlowEffect();
}
#endregion
#region 选择构件
//选择构件
private Yw.Model.HydroVisualInfo _selectedVisual = null;
//选择构件
private Yw.Model.HydroVisualInfo SelectedVisual
{
get { return _selectedVisual; }
set
{
_selectedVisual = value;
if (_selectedVisual == null)
{
this.barBtnSetMonitor.Enabled = false;
}
else
{
this.barBtnSetMonitor.Enabled = true;
}
}
}
#endregion
#region 构件明细
#region 构件列表
//所有构件视图列表
private List _allVisualViewModelList = null;
//获取构件视图列表
private List GetVisualViewModelList()
{
if (_hydroInfo == null)
{
return default;
}
if (_allVisualViewModelList == null)
{
_allVisualViewModelList = new List();
var allVisualList = _hydroInfo.GetAllVisuals();
if (allVisualList != null && allVisualList.Count > 0)
{
var allCalcuResultList = GetCalcuResultList();
allVisualList.ForEach(x =>
{
var vm = HydroVisualViewModelBuilder.CreateVisualViewModel(x, _hydroInfo);
var calcuResult = allCalcuResultList?.Find(x => x.Code == x.Code);
if (calcuResult != null)
{
vm.UpdateCalcuProperty(calcuResult);
}
_allVisualViewModelList.Add(vm);
});
}
}
return _allVisualViewModelList;
}
//更新可见视图属性
private void UpdateVisualViewModelProperty()
{
var allVisualViewModelList = GetVisualViewModelList();
if (allVisualViewModelList != null && allVisualViewModelList.Count > 0)
{
allVisualViewModelList.ForEach(x =>
{
x.UpdateProperty();
});
}
}
//更新可见视图属性
private void UpdateVisualViewModelProperty(List codes)
{
if (codes == null || codes.Count < 1)
{
return;
}
var allVisualViewModelList = GetVisualViewModelList();
if (allVisualViewModelList != null && allVisualViewModelList.Count > 0)
{
allVisualViewModelList.ForEach(x =>
{
if (codes.Contains(x.Code))
{
x.UpdateProperty();
}
});
}
}
//更新可见视图属性
private void UpdateVisualViewModelProperty(List visualList)
{
if (visualList == null || visualList.Count < 1)
{
return;
}
var allVisualViewModelList = GetVisualViewModelList();
if (allVisualViewModelList != null && allVisualViewModelList.Count > 0)
{
allVisualViewModelList.ForEach(x =>
{
if (visualList.Exists(t => t.Code == x.Code))
{
x.UpdateProperty();
}
});
}
}
//更新可见视图计算属性
private void UpdateVisualViewModelCalcuProperty()
{
var allVisualViewModelList = GetVisualViewModelList();
if (allVisualViewModelList != null && allVisualViewModelList.Count > 0)
{
var allCalcuResultList = GetCalcuResultList();
if (allCalcuResultList != null && allCalcuResultList.Count > 0)
{
allVisualViewModelList.ForEach(x =>
{
var calcuResult = allCalcuResultList.Find(t => t.Code == x.Code);
if (calcuResult != null)
{
x.UpdateCalcuProperty(calcuResult);
}
});
}
}
}
//获取构件视图
private HydroVisualViewModel GetVisualViewModel(string code)
{
if (string.IsNullOrEmpty(code))
{
return default;
}
var allVisualViewModelList = GetVisualViewModelList();
return allVisualViewModelList?.Find(x => x.Code == code);
}
//获取可见视图
private HydroVisualViewModel GetVisualViewModel(Yw.Model.HydroVisualInfo visual)
{
if (visual == null)
{
return default;
}
var allVisualViewModelList = GetVisualViewModelList();
return allVisualViewModelList?.Find(x => x.Code == visual.Code);
}
#endregion
#region 构件明细控件
//构件明细控件
private Yw.WinFrmUI.HydroVisualListCtrl _visualListCtrl = null;
//获取构件明细控件
private Yw.WinFrmUI.HydroVisualListCtrl GetVisualListCtrl()
{
if (_visualListCtrl == null)
{
_visualListCtrl = new HydroVisualListCtrl();
_visualListCtrl.Dock = DockStyle.Fill;
_visualListCtrl.HydroClickInfoEvent += async (visual) =>
{
ShowSelectedProperty(visual);
await _bimfaceCtrl?.ZoomAndSelectComponent(_selectedVisual?.Code);
};
_visualListCtrl.HydroChangedInfoEvent += (visualList) =>
{
UpdateSelectedProperty();
AutoApplyGrading();
};
}
return _visualListCtrl;
}
//构件明细控件是否可见
private bool IsVisualListCtrlVisible
{
get
{
if (this.docPnlBottom.Visibility == DevExpress.XtraBars.Docking.DockVisibility.Visible)
{
if (this.controlContainerBottom.Controls.Count > 0)
{
if (this.controlContainerBottom.Controls[0] is HydroVisualListCtrl)
{
return true;
}
}
}
return false;
}
}
//显示构件明细控件
private void ShowVisualListCtrl()
{
if (_hydroInfo == null)
{
return;
}
if (IsVisualListCtrlVisible)
{
return;
}
var visualListCtrl = GetVisualListCtrl();
var allVisualViewModelList = GetVisualViewModelList();
visualListCtrl.SetBindingData(allVisualViewModelList);
var allCalcuResultList = GetCalcuResultList();
if (allCalcuResultList == null || allCalcuResultList.Count < 1)
{
visualListCtrl.SetNormalView();
}
else
{
visualListCtrl.SetCalcuView();
}
this.controlContainerBottom.Controls.Clear();
this.controlContainerBottom.Controls.Add(visualListCtrl);
this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible;
this.docPnlBottom.Text = "构件明细";
this.docPnlBottom.Height = 350;
}
//更新构件明细控件
private void UpdateVisualListCtrl()
{
if (!IsVisualListCtrlVisible)
{
return;
}
_visualListCtrl?.UpdateBindingData();
}
//构件明细
private void barBtnHydroVisualList_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
ShowVisualListCtrl();
}
#endregion
#endregion
#region 监测列表
#region 测点列表
//所有监测点列表
private List _allMonitorList = null;
//获取监测点列表
private async Task> GetMonitorList()
{
if (_hydroInfo == null)
{
return default;
}
if (_allMonitorList == null)
{
_allMonitorList = await BLLFactory.Instance.GetByModelID(_hydroInfo.ID);
if (_allMonitorList == null)
{
_allMonitorList = new List();
}
}
return _allMonitorList;
}
//更新监测点列表
private async void UpdateMonitorList(string code)
{
if (_hydroInfo == null)
{
return;
}
if (string.IsNullOrEmpty(code))
{
return;
}
var allMonitorList = await GetMonitorList();
allMonitorList.RemoveAll(x => x.Relation == code);
var monitorList = await BLLFactory.Instance.GetByRelation(_hydroInfo.ID, code);
if (monitorList != null && monitorList.Count > 0)
{
allMonitorList.AddRange(monitorList);
}
UpdateMonitorValueList(code, monitorList);
SetLogicMonitorList();
}
//设置选择构件监测点列表
private async void SetSelectVisualMonitorList()
{
if (_hydroInfo == null)
{
return;
}
if (_selectedVisual == null)
{
return;
}
var allMonitorList = await GetMonitorList();
var dlg = new SetHydroVisualMonitorDlg();
dlg.SetBindingData(_hydroInfo, _selectedVisual, allMonitorList);
dlg.ReloadDataEvent += async (hydroInfo, visual, list) =>
{
if (hydroInfo == null)
{
return;
}
if (visual == null)
{
return;
}
var bol = await BLLFactory.Instance.Save(hydroInfo.ID, visual.Code, list);
if (!bol)
{
TipFormHelper.ShowError("设置失败");
return;
}
TipFormHelper.ShowSucceed("设置成功");
UpdateMonitorList(visual.Code);
};
dlg.ShowDialog();
}
//设置监测点
private void barBtnSetMonitor_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
SetSelectVisualMonitorList();
}
#endregion
#region 监测值列表
//所有监测值列表
private List _allMonitorValueList = null;
//获取监测值列表
private async Task> GetMonitorValueList()
{
if (_allMonitorValueList == null)
{
_allMonitorValueList = new List();
var allMonitorList = await GetMonitorList();
var allVisualViewModelList = GetVisualViewModelList();
allMonitorList.ForEach(x =>
{
var visual = allVisualViewModelList.Find(t => t.Code == x.Relation);
if (visual != null)
{
var vm = new HydroVisualMonitorValueViewModel(visual.Vmo, x);
_allMonitorValueList.Add(vm);
}
});
}
return _allMonitorValueList;
}
//更新监测值列表
private async void UpdateMonitorValueList(string code, List monitorList)
{
if (string.IsNullOrEmpty(code))
{
return;
}
var visual = GetVisualViewModel(code)?.Vmo;
if (visual == null)
{
return;
}
var allMonitorValueList = await GetMonitorValueList();
var monitorValueList = allMonitorValueList.Where(x => x.Vmo.Relation == code).ToList();
monitorValueList?.ForEach(x =>
{
var result = monitorList?.Exists(t => t.Relation == x.Vmo.Relation && t.PropName == x.Vmo.PropName);
if (!(result.HasValue && result.Value))
{
allMonitorValueList.Remove(x);
}
});
monitorList?.ForEach(x =>
{
var result = monitorValueList?.Exists(t => t.Vmo.Relation == x.Relation && t.Vmo.PropName == x.PropName);
if (!(result.HasValue && result.Value))
{
var vm = new HydroVisualMonitorValueViewModel(visual, x);
allMonitorValueList.Add(vm);
}
});
}
#endregion
#region 监测值列表控件
//监测值列表控件
private HydroVisualMonitorValueListCtrl _monitorValueListCtrl = null;
//获取监测值列表控件
private HydroVisualMonitorValueListCtrl GetMonitorValueListCtrl()
{
if (_monitorValueListCtrl == null)
{
_monitorValueListCtrl = new HydroVisualMonitorValueListCtrl();
_monitorValueListCtrl.Dock = DockStyle.Fill;
_monitorValueListCtrl.HydroViewEvent += (code) =>
{
_bimfaceCtrl?.ZoomToComponent(code);
};
}
return _monitorValueListCtrl;
}
//显示监测值列表控件
private async void ShowMonitorValueListCtrl()
{
var monitorValueListCtrl = GetMonitorValueListCtrl();
var allMonitorValueList = await GetMonitorValueList();
monitorValueListCtrl.SetBindingData(allMonitorValueList);
this.controlContainerBottom.Controls.Clear();
this.controlContainerBottom.Controls.Add(monitorValueListCtrl);
this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible;
this.docPnlBottom.Text = "监测值";
this.docPnlBottom.Height = 350;
}
//设置监测值
private void barBtnSetMonitorValue_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
ShowMonitorValueListCtrl();
}
#endregion
#region 监测列表显示
//监测是否显示
private bool _isMonitorVisible = false;
//获取业务监测列表
private async Task> GetLogicMonitorList()
{
var allMonitorList = await GetMonitorList();
var allLogicMonitorList = allMonitorList.Select(x =>
{
var logicMonitor = new LogicMonitor();
logicMonitor.Id = x.Relation;
logicMonitor.PropName = x.PropName;
logicMonitor.Description = x.Description;
return logicMonitor;
}).ToList();
return allLogicMonitorList;
}
//设置业务监测列表
private async void SetLogicMonitorList()
{
if (_isMonitorVisible)
{
var allLogicMonitorList = await GetLogicMonitorList();
await _bimfaceCtrl?.SetLogicMonitors(allLogicMonitorList);
}
else
{
await _bimfaceCtrl?.ClearLogicMonitors();
}
}
//显示状态改变
private void barCkMonitor_CheckedChanged(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
_isMonitorVisible = this.barCkMonitor.Checked;
SetLogicMonitorList();
}
#endregion
#endregion
#region 水力检查
#region 检查结果
//检查结果缓存
private HydroCheckResult _checkResult = null;
//获取检查结果
//needCheckAgain 用于确定是否需要重新检查
private HydroCheckResult GetCheckResult(bool needCheckAgain = false)
{
if (_hydroInfo == null)
{
return default;
}
if (needCheckAgain)
{
_checkResult = _hydroInfo.Check();
}
if (_checkResult == null)
{
_checkResult = _hydroInfo.Check();
}
return _checkResult;
}
#endregion
#region 检查控件
//检查控件
private HydroCheckResultCtrl _checkCtrl = null;
//获取检查控件
private HydroCheckResultCtrl GetCheckCtrl()
{
if (_checkCtrl == null)
{
_checkCtrl = new HydroCheckResultCtrl();
_checkCtrl.Dock = DockStyle.Fill;
_checkCtrl.HydroClickEvent += async (code) =>
{
if (_hydroInfo == null)
{
return;
}
var elementIds = new List();
if (string.IsNullOrEmpty(code))
{
this.SelectedVisual = null;
}
else
{
var allVisualViewModelList = GetVisualViewModelList();
this.SelectedVisual = allVisualViewModelList?.Find(x => x.Code == code)?.Vmo;
if (this.SelectedVisual != null)
{
elementIds.Add(this.SelectedVisual.Code);
}
}
await _bimfaceCtrl?.ZoomAndSelectComponents(elementIds);
ShowSelectedProperty();
};
}
return _checkCtrl;
}
//显示检查控件
//needCheckAgain 用于确定是否需要重新检查
private void ShowCheckCtrl(bool needCheckAgain = false)
{
var checkResult = GetCheckResult(needCheckAgain);
if (checkResult == null)
{
return;
}
var checkCtrl = GetCheckCtrl();
checkCtrl.SetBindingData(checkResult);
this.controlContainerBottom.Controls.Clear();
this.controlContainerBottom.Controls.Add(checkCtrl);
this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible;
this.docPnlBottom.Text = "检查结果";
this.docPnlBottom.Height = 350;
}
#endregion
//检查
private void barBtnCheck_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
ShowCheckCtrl(true);
}
#endregion
#region EPA计算结果
//EPA计算结果
private Yw.EPAnet.CalcuResult _epaCalcuResult = null;
//获取EPA计算结果
//CalcuMode 在 Yw.EPANet.Calcu.Core 中定义
//NeedCalcuAgain 是否需要重新计算
private Yw.EPAnet.CalcuResult GetEpaCalcuResult(string calcuMode, bool needCalcuAgain = false)
{
if (_hydroInfo == null)
{
return default;
}
if (needCalcuAgain)
{
var network = _hydroInfo.ToNetwork();
_epaCalcuResult = network.Calcu(calcuMode);
}
if (_epaCalcuResult == null)
{
var network = _hydroInfo.ToNetwork();
_epaCalcuResult = network.Calcu(calcuMode);
}
return _epaCalcuResult;
}
#endregion
#region 计算失败
//计算失败控件
private HydroCalcuFailedCtrl _calcuFailedCtrl = null;
//获取计算失败控件
private HydroCalcuFailedCtrl GetCalcuFailedCtrl()
{
if (_calcuFailedCtrl == null)
{
_calcuFailedCtrl = new HydroCalcuFailedCtrl();
_calcuFailedCtrl.Dock = DockStyle.Fill;
}
return _calcuFailedCtrl;
}
//显示计算失败控件
private void ShowCalcuFailedCtrl(Yw.EPAnet.CalcuResult calcuResult)
{
if (_hydroInfo == null)
{
return;
}
if (calcuResult == null)
{
return;
}
if (calcuResult.Succeed)
{
return;
}
var calcuFailedCtrl = GetCalcuFailedCtrl();
calcuFailedCtrl.SetBindingData(calcuResult.FailedList);
this.controlContainerBottom.Controls.Clear();
this.controlContainerBottom.Controls.Add(calcuFailedCtrl);
this.docPnlBottom.Visibility = DevExpress.XtraBars.Docking.DockVisibility.Visible;
this.docPnlBottom.Text = "计算失败原因";
this.docPnlBottom.Height = 350;
}
//显示计算失败控件
private void ShowCalcuFailedCtrl()
{
ShowCalcuFailedCtrl(_epaCalcuResult);
}
#endregion
#region 管网修复
//修复管网
private void Repair()
{
if (_hydroInfo == null)
{
return;
}
var checkResult = GetCheckResult(true);
if (checkResult == null)
{
return;
}
if (!checkResult.Succeed)
{
ShowCheckCtrl(false);
TipFormHelper.ShowWarn("检查失败导致无法进行试算,停止修复!");
return;
}
var calcuResult = GetEpaCalcuResult(Yw.EPAnet.CalcuMode.Simple, true);
if (calcuResult == null || !calcuResult.Succeed)
{
ShowCalcuFailedCtrl(calcuResult);
TipFormHelper.ShowWarn("试算失败,停止修复!");
return;
}
var allLinks = _hydroInfo.GetAllLinks();
if (allLinks != null && allLinks.Count < 1)
{
TipFormHelper.ShowError("模型中未包含管段信息,停止修复!");
return;
}
int count = 0;
foreach (var link in allLinks)
{
var calcuLink = calcuResult.LinkList?.Find(x => x.Id == link.Code);
if (calcuLink == null)
{
continue;
}
if (calcuLink.Flow < 0)
{
var tempCode = link.StartCode;
link.StartCode = link.EndCode;
link.EndCode = tempCode;
count++;
}
}
UpdateVisualViewModelProperty();
UpdateVisualListCtrl();
UpdateSelectedProperty();
TipFormHelper.ShowSucceed($"修复完成,共修复管段({count})个!");
}
//管网修复
private void barBtnRepair_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
Repair();
}
#endregion
#region 导出INP文件
//导出INP文件
private void barBtnExportInp_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
if (_hydroInfo == null)
{
return;
}
var fileName = FileDialogHelper.SaveInp("导出Inp文件");
if (string.IsNullOrEmpty(fileName))
{
return;
}
var netWork = Yw.Hydro.ParseHelper.ToNetwork(_hydroInfo);
var result = netWork.ToInpString();
File.WriteAllText(fileName, result);
TipFormHelper.ShowSucceed("导出成功");
}
#endregion
#region 并联分析
//并联分析
private void ParallelAnalysis()
{
if (_hydroInfo == null)
{
return;
}
var pumps = _hydroInfo.Pumps;
if (pumps == null || pumps.Count < 1)
{
XtraMessageBox.Show("无水泵信息");
return;
}
var vmList = new List();
foreach (var pump in pumps)
{
if (!pump.RatedN.HasValue)
{
continue;
}
var qh = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQH)?.CurveData;
var qe = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQE)?.CurveData;
var qp = _hydroInfo.Curves?.Find(t => t.Code == pump.CurveQP)?.CurveData;
if (qh == null)
{
continue;
}
var qhPtList = qh.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList();
var qePtList = qe?.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList();
var qpPtList = qp?.Select(x => new XhsSplinePointViewModel(x.X, x.Y)).ToList();
var vm = new XhsSinglePumpViewModel();
vmList.Add(vm);
vm.ID = pump.ID;
vm.Name = pump.Name;
vm.Code = pump.Code;
vm.IsBp = true;
vm.RunStatus = pump.LinkStatus == Yw.Hydro.LinkStatus.Open;
vm.RatedHz = pump.RatedHz;
vm.CurrentHz = Math.Round(pump.RatedHz * pump.SpeedRatio, 1);
vm.RatedSpeed = pump.RatedN.Value;
vm.CurrentSpeed = Math.Round(pump.RatedN.Value * pump.SpeedRatio, 1);
vm.CurveQH = qhPtList;
vm.CurveQE = qePtList;
vm.CurveQP = qpPtList;
}
var dlg = new PumpParallelAnalyDlg();
dlg.SetBindingData(vmList);
dlg.ReloadDataEvent += (list) =>
{
list?.ForEach(x =>
{
var pump = pumps.Find(t => t.Code == x.Code);
if (pump != null)
{
pump.LinkStatus = x.RunStatus ? Yw.Hydro.PumpStatus.Open : Yw.Hydro.PumpStatus.Closed;
pump.SpeedRatio = x.CurrentHz / pump.RatedHz;
}
});
var codes = list?.Select(x => x.Code).ToList();
UpdateVisualViewModelProperty(codes);
ShowSelectedProperty();
UpdateVisualListCtrl();
return true;
};
dlg.ShowDialog();
}
//并联分析
private void barBtnParallel_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
ParallelAnalysis();
}
#endregion
#region 工况计算
//所有工况元组列表
private Tuple _allWorkingTupleList = null;
#region 工况
//显示工况计算窗体
private void ShowWorkingCalcuDlg()
{
var dlg = new SetHydroWorkingDlg();
dlg.HydroViewEvent += async (parter) =>
{
_selectedVisual = parter as Yw.Model.HydroVisualInfo;
if (_selectedVisual != null)
{
await _bimfaceCtrl?.ZoomAndSelectComponents(new List() { _selectedVisual.Code });
}
ShowSelectedProperty();
};
dlg.HydroCalcuEvent += async (hydroInfo, workingInfo) =>
{
if (_hydroInfo == null)
{
return;
}
_hydroInfo.UpdateWorkingInfo(workingInfo);
//校验
_checkResult = _hydroInfo.Check();
if (!_checkResult.Succeed)
{
ShowCheckCtrl();
TipFormHelper.ShowWarn("校验失败,请检查后重试");
return;
}
WaitFormHelper.ShowWaitForm(this, "正在计算分析中,请稍候...");
//await Task.Delay(5000);
var netWork = Yw.Hydro.ParseHelper.ToNetwork(_hydroInfo);
_epaCalcuResult = netWork.CalcuMinorLoss();
WaitFormHelper.HideWaitForm();
if (_epaCalcuResult.Succeed)
{
GetCalcuResultList(false);
UpdateVisualViewModelProperty();
UpdateVisualViewModelCalcuProperty();
UpdateVisualListCtrl();
UpdateSelectedProperty();
await _bimfaceCtrl?.SetLogicCalcuCustomLabels(_epaCalcuResult);
TipFormHelper.ShowSucceed("计算成功!");
var codes = _hydroInfo.Pumps.Select(x => x.Code).ToList();
await _bimfaceCtrl?.ZoomAndSelectComponents(codes);
}
else
{
ShowCalcuFailedCtrl();
TipFormHelper.ShowError("计算失败!");
}
AutoApplyGrading();
UpdateVisualListCtrl();
ShowSelectedProperty();
};
dlg.SetBindingData(_hydroInfo);
dlg.ShowDialog();
}
#endregion
#region 计算结果
//所有计算结果列表
private List _allCalcuResultList = null;
//获取计算结果
//true 使用缓存,false 不使用缓存
private List GetCalcuResultList(bool isCache = true)
{
if (_hydroInfo == null)
{
return default;
}
if (_epaCalcuResult == null)
{
return default;
}
if (!_epaCalcuResult.Succeed)
{
return default;
}
if (isCache)
{
return _allCalcuResultList;
}
_allCalcuResultList = new List();
//节点
var allNodeList = _hydroInfo.GetAllNodes();
if (allNodeList != null && allNodeList.Count > 0)
{
foreach (var node in allNodeList)
{
var calcuNode = _epaCalcuResult.NodeList?.Find(x => x.Id == node.Code);
if (calcuNode != null)
{
var calcuResult = new HydroCalcuNodeResult()
{
Code = node.Code,
CalcuPress = calcuNode.Press,
CalcuHead = calcuNode.Head,
CalcuDemand = calcuNode.Demand
};
_allCalcuResultList.Add(calcuResult);
}
}
}
//管段
var allLinkList = _hydroInfo.GetAllLinks();
if (allLinkList != null && allLinkList.Count > 0)
{
foreach (var link in allLinkList)
{
var calcuLink = _epaCalcuResult.LinkList?.Find(x => x.Id == link.Code);
if (calcuLink != null)
{
var calcuResult = new HydroCalcuLinkResult()
{
Code = link.Code,
CalcuFlow = calcuLink.Flow,
CalcuVelocity = calcuLink.Velocity,
CalcuHeadLoss = calcuLink.Headloss
};
_allCalcuResultList.Add(calcuResult);
}
}
}
//流量计
var allFlowmeterList = _hydroInfo.Flowmeters;
if (allFlowmeterList != null && allFlowmeterList.Count > 0)
{
foreach (var flowmeter in allFlowmeterList)
{
var calcuFlowmeterResult = _allCalcuResultList.Find(x => x.Code == flowmeter.Code) as HydroCalcuNodeResult;
if (calcuFlowmeterResult != null)
{
var calcuFlowmeterNewResult = new HydroCalcuFlowmeterResult(calcuFlowmeterResult);
var calcuFlowmeterLinkResultList = new List();
var flowmeterLinkList = allLinkList?.Where(x => x.StartCode == flowmeter.Code || x.EndCode == flowmeter.Code).ToList();
if (flowmeterLinkList != null && flowmeterLinkList.Count > 0)
{
foreach (var flowmeterLink in flowmeterLinkList)
{
var calcuFlowmeterLinkResult = _allCalcuResultList.Find(x => x.Code == flowmeterLink.Code) as HydroCalcuLinkResult;
if (calcuFlowmeterLinkResult != null)
{
calcuFlowmeterLinkResultList.Add(calcuFlowmeterLinkResult);
}
}
}
if (calcuFlowmeterLinkResultList.Exists(x => x.CalcuFlow.HasValue))
{
calcuFlowmeterNewResult.CalcuQ = calcuFlowmeterLinkResultList.Where(x => x.CalcuFlow.HasValue).Average(x => x.CalcuFlow.Value);
}
_allCalcuResultList.Remove(calcuFlowmeterResult);
_allCalcuResultList.Add(calcuFlowmeterNewResult);
}
}
}
//压力表
var allPressmeterList = _hydroInfo.Pressmeters;
if (allPressmeterList != null && allPressmeterList.Count > 0)
{
foreach (var pressmeter in allPressmeterList)
{
var calcuPressmeterResult = _allCalcuResultList.Find(x => x.Code == pressmeter.Code) as HydroCalcuNodeResult;
if (calcuPressmeterResult != null)
{
var calcuPressmeterNewResult = new HydroCalcuPressmeterResult(calcuPressmeterResult);
calcuPressmeterNewResult.CalcuPr = calcuPressmeterResult.CalcuPress;
_allCalcuResultList.Remove(calcuPressmeterResult);
_allCalcuResultList.Add(calcuPressmeterNewResult);
}
}
}
//水泵
var allPumpList = _hydroInfo.Pumps;
if (allPumpList != null && allPumpList.Count > 0)
{
foreach (var pump in allPumpList)
{
var calcuPumpResult = _allCalcuResultList.Find(x => x.Code == pump.Code) as HydroCalcuLinkResult;
if (calcuPumpResult != null)
{
var calcuPumpNewResult = new HydroCalcuPumpResult(calcuPumpResult);
calcuPumpNewResult.CalcuQ = calcuPumpResult.CalcuFlow;
if (calcuPumpNewResult.CalcuQ.HasValue)
{
var calcuNodeStartResult = _allCalcuResultList.Find(x => x.Code == pump.StartCode) as HydroCalcuNodeResult;
var calcuNodeEndResult = _allCalcuResultList.Find(x => x.Code == pump.EndCode) as HydroCalcuNodeResult;
if (calcuNodeStartResult != null && calcuNodeEndResult != null)
{
if (calcuNodeStartResult.CalcuPress.HasValue && calcuNodeEndResult.CalcuPress.HasValue)
{
calcuPumpNewResult.CalcuH = Math.Abs(calcuNodeStartResult.CalcuPress.Value - calcuNodeEndResult.CalcuPress.Value);
}
if (pump.LinkStatus == Yw.Hydro.PumpStatus.Open && pump.RatedN.HasValue)
{
var curveqp = _hydroInfo.Curves?.Find(x => x.Code == pump.CurveQP);
if (curveqp != null)
{
if (curveqp.CurveData != null && curveqp.CurveData.Count > 3)
{
var point2dList = curveqp.CurveData.Select(x => new Yw.Geometry.Point2d(x.X, x.Y)).ToList();
var point2dSimularList = point2dList.GetQPPointListByN(pump.RatedN.Value, pump.RatedN.Value * pump.SpeedRatio);
var pumpCurveQp = new Yw.Pump.CurveQP(eFeatType.Cubic, point2dSimularList);
calcuPumpNewResult.CalcuP = pumpCurveQp.FeatCurve.GetPointY(calcuPumpNewResult.CalcuQ.Value);
}
}
}
if (calcuPumpNewResult.CalcuH.HasValue && calcuPumpNewResult.CalcuP.HasValue)
{
calcuPumpNewResult.CalcuE = Yw.Pump.CalculationHelper.CalcuE(calcuPumpNewResult.CalcuQ.Value, calcuPumpNewResult.CalcuH.Value, calcuPumpNewResult.CalcuP.Value);
}
}
}
_allCalcuResultList.Remove(calcuPumpResult);
_allCalcuResultList.Add(calcuPumpNewResult);
}
}
}
return _allCalcuResultList;
}
#endregion
//水力计算
private void barBtnHydroCalcu_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
ShowWorkingCalcuDlg();
}
#endregion
}
}