123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 |
- using DevExpress.XtraEditors;
- using System;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Data;
- using System.Data.Entity;
- using System.Drawing;
- using System.Linq;
- using System.Net.Sockets;
- using System.Net;
- using System.Text;
- using System.Threading.Tasks;
- using System.Windows.Documents;
- using System.Windows.Forms;
- using XdCxRhDW.Repostory;
- using System.IO;
- using System.Data.Entity.Migrations;
- using ExtensionsDev;
- using DevExpress.Utils;
- using DevExpress.XtraMap;
- using XdCxRhDW.WebApi;
- using DevExpress.XtraPrinting;
- using XdCxRhDW.Entity;
- using DevExpress.XtraEditors.Controls;
- using System.Security.Policy;
- namespace XdCxRhDW.App.UserControl
- {
- public partial class CtrlSysSettings : DevExpress.XtraEditors.XtraUserControl
- {
- public CtrlSysSettings()
- {
- InitializeComponent();
- //this.layoutControl1.UseDefault();
- }
- private async void CtrlSysSettings_Load(object sender, EventArgs e)
- {
- try
- {
- txtWmtsSource.Properties.Items.AddEnum<EnumWmtsSource>();
- txtLayer.Properties.Items.AddEnum<EnumMapLayerType>();
- txtWmtsSource.SelectedIndex = 0;
- txtLayer.SelectedIndex = 0;
- using (RHDWContext db = new RHDWContext())
- {
- var res = await db.SysSetings.FirstOrDefaultAsync();
- if (res != null)
- {
- this.txtHttpPort.Text = res.HttpPort.ToString();
- if (!string.IsNullOrEmpty(res.XLDirectory))
- this.txtXLDirectory.Text = res.XLDirectory.ToString();
- this.txtWmtsSource.EditValue = res.WmtsSource;
- this.txtLayer.EditValue = res.MapLayerType;
- if (res.YDPZThreshold > 0)
- this.txtYDPZThreshold.Text = res.YDPZThreshold.ToString();
- if (this.txtMapType.SelectedIndex == res.MapType)
- {
- txtMapType_SelectedIndexChanged(null, null);
- }
- else
- this.txtMapType.SelectedIndex = res.MapType;
- }
- }
- }
- catch (Exception ex)
- {
- Serilog.Log.Error(ex, "加载配置信息异常");
- DxHelper.MsgBoxHelper.ShowError("加载配置信息异常");
- }
- layoutControl1.BestFit();
- }
- private async void btnSave_Click(object sender, EventArgs e)
- {
- bool needStartHttpSvr = false;
- try
- {
- if (!int.TryParse(txtHttpPort.Text, out int port))
- {
- DxHelper.MsgBoxHelper.ShowError("Http端口错误!");
- return;
- }
- if (txtMapType.SelectedIndex != 0 && txtWmtsSource.EditValue == null)
- {
- DxHelper.MsgBoxHelper.ShowError("请选择行政图类型!");
- return;
- }
- if (txtMapType.SelectedIndex != 0 && string.IsNullOrEmpty(txtLayer.Text))
- {
- DxHelper.MsgBoxHelper.ShowError("请填写地图图层名称!");
- return;
- }
- using (RHDWContext db = new RHDWContext())
- {
- var res = await db.SysSetings.FirstOrDefaultAsync();
- if (res == null) res = new SysSetings();
- res.HttpPort = port;
- res.XLDirectory = txtXLDirectory.Text;
- res.YDPZThreshold = string.IsNullOrWhiteSpace(txtYDPZThreshold.Text) ? 0 : Convert.ToInt32(txtYDPZThreshold.Text);
- res.MapType = txtMapType.SelectedIndex;
- if (txtMapType.SelectedIndex != 0)
- {
- res.WmtsSource = (EnumWmtsSource)txtWmtsSource.EditValue;
- res.MapLayerType = (EnumMapLayerType)txtLayer.EditValue;
-
- }
- db.SysSetings.AddOrUpdate(res);
- needStartHttpSvr = true;
- await db.SaveChangesAsync();
- DxHelper.MsgBoxHelper.ShowInfo("配置信息保存成功!");
- Messenger.Defalut.Pub("系统配置改变", await db.SysSetings.FirstOrDefaultAsync());
- }
- }
- catch (Exception ex)
- {
- Serilog.Log.Error(ex, "配置信息保存异常");
- DxHelper.MsgBoxHelper.ShowError("配置信息保存异常");
- }
- if (needStartHttpSvr)
- {
- try
- {
- using (RHDWContext db = new RHDWContext())
- {
- var settings = await db.SysSetings.FirstOrDefaultAsync();
- Startup.Start(settings.HttpPort, "多模式融合定位平台.Xml", "XdCxRhDW.Dto.xml");
- }
- }
- catch (System.Reflection.TargetInvocationException ex)
- {
- Serilog.Log.Error(ex, $"启动Http服务失败!");
- if (ex.InnerException is HttpListenerException)
- {
- DxHelper.MsgBoxHelper.ShowWarning($"{ex.InnerException.Message}");
- }
- else
- {
- DxHelper.MsgBoxHelper.ShowWarning($"启动Http服务失败!");
- }
- }
- catch (Exception ex)
- {
- Serilog.Log.Error(ex, $"启动Http服务失败!");
- DxHelper.MsgBoxHelper.ShowWarning($"启动Http服务失败!");
- }
- }
- }
- private void txtMapType_SelectedIndexChanged(object sender, EventArgs e)
- {
- if (txtMapType.SelectedIndex == 0)
- {
- itemWmtsSource.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
- itemMapLayer.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
- }
- else
- {
- itemWmtsSource.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
- itemMapLayer.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
- }
- layoutControl1.BestFit();
- }
-
- }
- }
|