diff --git a/ModbusTester/ModbusTester.sln b/ModbusTester/ModbusTester.sln new file mode 100644 index 0000000..fd5f9f5 --- /dev/null +++ b/ModbusTester/ModbusTester.sln @@ -0,0 +1,25 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 17 +VisualStudioVersion = 17.8.34511.84 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "ModbusTester", "ModbusTester\ModbusTester.csproj", "{D99D07AC-3477-4DEB-9B02-A2EA30996ED3}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Any CPU = Debug|Any CPU + Release|Any CPU = Release|Any CPU + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {D99D07AC-3477-4DEB-9B02-A2EA30996ED3}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {D99D07AC-3477-4DEB-9B02-A2EA30996ED3}.Debug|Any CPU.Build.0 = Debug|Any CPU + {D99D07AC-3477-4DEB-9B02-A2EA30996ED3}.Release|Any CPU.ActiveCfg = Release|Any CPU + {D99D07AC-3477-4DEB-9B02-A2EA30996ED3}.Release|Any CPU.Build.0 = Release|Any CPU + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {115AF6A3-8669-4F9F-AB65-52AC409AB907} + EndGlobalSection +EndGlobal diff --git a/ModbusTester/ModbusTester/App.config b/ModbusTester/ModbusTester/App.config new file mode 100644 index 0000000..193aecc --- /dev/null +++ b/ModbusTester/ModbusTester/App.config @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/ModbusTester/ModbusTester/App.xaml b/ModbusTester/ModbusTester/App.xaml new file mode 100644 index 0000000..fbeef22 --- /dev/null +++ b/ModbusTester/ModbusTester/App.xaml @@ -0,0 +1,22 @@ + + + #d4eaf7 + #b6ccd8 + #3b3c3d + #71c4ef + #00668c + #1d1c1c + #313d44 + #fffefb + #f5f4f1 + #cccbc8 + + orangeRed + #ffdf80 + #a5d46a + + diff --git a/ModbusTester/ModbusTester/App.xaml.cs b/ModbusTester/ModbusTester/App.xaml.cs new file mode 100644 index 0000000..e8ac76a --- /dev/null +++ b/ModbusTester/ModbusTester/App.xaml.cs @@ -0,0 +1,17 @@ +using System; +using System.Collections.Generic; +using System.Configuration; +using System.Data; +using System.Linq; +using System.Threading.Tasks; +using System.Windows; + +namespace ModbusTester +{ + /// + /// App.xaml에 대한 상호 작용 논리 + /// + public partial class App : Application + { + } +} diff --git a/ModbusTester/ModbusTester/MainWindow.xaml b/ModbusTester/ModbusTester/MainWindow.xaml new file mode 100644 index 0000000..7be4372 --- /dev/null +++ b/ModbusTester/ModbusTester/MainWindow.xaml @@ -0,0 +1,98 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/ModbusTester/ModbusTester/MainWindow.xaml.cs b/ModbusTester/ModbusTester/MainWindow.xaml.cs new file mode 100644 index 0000000..de3d5d9 --- /dev/null +++ b/ModbusTester/ModbusTester/MainWindow.xaml.cs @@ -0,0 +1,126 @@ +using ModbusTester.Model; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Windows; +using System.Windows.Controls; +using System.Windows.Data; +using System.Windows.Documents; +using System.Windows.Input; +using System.Windows.Media; +using System.Windows.Media.Imaging; +using System.Windows.Navigation; +using System.Windows.Shapes; + +namespace ModbusTester +{ + /// + /// MainWindow.xaml에 대한 상호 작용 논리 + /// + public partial class MainWindow : Window + { + private ModbusModel _pmsModbus; + private DataModel _pmsData; + public MainWindow() + { + InitializeComponent(); + InitInstance(); + } + + private void InitInstance() + { + _pmsModbus = new ModbusModel(); + _pmsModbus.OnConnectionChanged += _pmsModbus_OnConnectionChanged; + _pmsModbus.OnSendDataChanged += _pmsModbus_OnSendDataChanged; + _pmsModbus.OnReceiveDataChanged += _pmsModbus_OnReceiveDataChanged; + _pmsModbus.OnDataRead += _pmsModbus_OnDataRead; + _pmsModbus.Port = 502; + + _pmsData = DataContext as DataModel; + } + + private void _pmsModbus_OnDataRead(object sender, DataModel e) + { + Application.Current.Dispatcher.Invoke(() => + { + DataContext = e; + _pmsData = DataContext as DataModel; + }); + } + + private string GetDataString(float[] data) + { + string result = ""; + foreach (float item in data) + { + result += $"{item.ToString("N2")}, "; + } + + return result; + } + + private void _pmsModbus_OnReceiveDataChanged(object sender, byte[] e) + { + + } + + private void _pmsModbus_OnSendDataChanged(object sender, byte[] e) + { + + } + + private void _pmsModbus_OnConnectionChanged(object sender, bool e) + { + Application.Current.Dispatcher.Invoke(() => + { + if (_pmsModbus.IsConnected == true) + { + lblStatus.Background = (SolidColorBrush)Application.Current.FindResource("traffic_green"); + tbtConnect.IsChecked = true; + } + else + { + lblStatus.Background = (SolidColorBrush)Application.Current.FindResource("traffic_red"); + tbtConnect.IsChecked= false; + } + }); + } + + private void SetModbus() + { + _pmsModbus.IP = _pmsData.IP; + _pmsModbus.Interval = _pmsData.Interval; + } + + private void tbtConnect_Checked(object sender, RoutedEventArgs e) + { + + try + { + SetModbus(); + _pmsModbus.Connect(); + + } + catch (Exception ex) + { + tbtConnect.IsChecked = false; + MessageBox.Show($"Error: {ex.Message}"); + } + } + + private void tbtConnect_Unchecked(object sender, RoutedEventArgs e) + { + try + { + _pmsModbus.Disconnect(); + } + catch (Exception ex) + { + tbtConnect.IsChecked = true; + MessageBox.Show($"Error: {ex.Message}"); + } + } + } +} diff --git a/ModbusTester/ModbusTester/ModbusTester.csproj b/ModbusTester/ModbusTester/ModbusTester.csproj new file mode 100644 index 0000000..1049934 --- /dev/null +++ b/ModbusTester/ModbusTester/ModbusTester.csproj @@ -0,0 +1,111 @@ + + + + + Debug + AnyCPU + {D99D07AC-3477-4DEB-9B02-A2EA30996ED3} + WinExe + PMSModbusTester + PMSModbusTester + v4.8 + 512 + {60dc8134-eba5-43b8-bcc9-bb4bc16c2548};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC} + 4 + true + true + + + AnyCPU + true + full + false + bin\Debug\ + DEBUG;TRACE + prompt + 4 + + + AnyCPU + pdbonly + true + bin\Release\ + TRACE + prompt + 4 + + + + ..\packages\EasyModbusTCP.5.6.0\lib\net40\EasyModbus.dll + + + + + + + + + + + + 4.0 + + + + + + + + MSBuild:Compile + Designer + + + MSBuild:Compile + Designer + + + App.xaml + Code + + + MainWindow.xaml + Code + + + + + + + Code + + + True + True + Resources.resx + + + True + Settings.settings + True + + + ResXFileCodeGenerator + Resources.Designer.cs + + + + SettingsSingleFileGenerator + Settings.Designer.cs + + + + + + + + Always + + + + + \ No newline at end of file diff --git a/ModbusTester/ModbusTester/Model/DataModel.cs b/ModbusTester/ModbusTester/Model/DataModel.cs new file mode 100644 index 0000000..009f24c --- /dev/null +++ b/ModbusTester/ModbusTester/Model/DataModel.cs @@ -0,0 +1,53 @@ +using System; +using System.Collections.Generic; +using System.Collections.ObjectModel; +using System.ComponentModel; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace ModbusTester.Model +{ + public class DataModel : INotifyPropertyChanged + { + public event PropertyChangedEventHandler PropertyChanged; + + public string IP { get; set; } + public int Interval { get; set; } + + public float ConfigFlowrate { get; set; } + public float ActualFlowrate { get; set; } + public int NumberOfChannel { get; set; } + + private ObservableCollection _data; + public ObservableCollection Data + { + get { return _data; } + set + { + _data = value; + OnPropertyChanged(nameof(Data)); + } + } + + public DataModel() + { + IP = "200.200.200.200"; + Interval = 60; + + _data = new ObservableCollection(); + } + + private void OnPropertyChanged(string propertyName = null) + { + PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName)); + } + } + + public class PMSChannelData + { + public string Name { get; set; } + public DateTime TimeStamp { get; set; } + public int CummulativeRaw { get; set; } + } +} diff --git a/ModbusTester/ModbusTester/Model/ModbusModel.cs b/ModbusTester/ModbusTester/Model/ModbusModel.cs new file mode 100644 index 0000000..fde1bd6 --- /dev/null +++ b/ModbusTester/ModbusTester/Model/ModbusModel.cs @@ -0,0 +1,250 @@ +using System; +using System.Collections.Generic; +using System.Collections.ObjectModel; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Timers; +using EasyModbus; + +namespace ModbusTester.Model +{ + public class ModbusModel + { + private readonly int COIL_ADDR_DATA_SAMPLING = 1 - 1; + private readonly int COIL_ADDR_DATA_AVAILABLE = 2 - 1; + private readonly int COIL_ADDR_DATA_CLEAR = 3 - 1; + + private readonly int HOLDING_RESISTER_SAMPLING_INTERVAL = 3 - 1; + private readonly int HOLDING_RESISTER_TARE_TIME = 4 - 1; + private readonly int HOLDING_RESISTER_REPEAT_COUNT = 5 - 1; + + private readonly int INPUT_RESISTER_CONFIG_FLOW_RATE = 13 - 1; // length: 2 + private readonly int INPUT_RESISTER_FLOW_RATE = 222 - 1; // length: 2 + private readonly int INPUT_RESISTER_ADDR_NUM_OF_CHANNEL = 227 - 1; // length: 1 + private readonly int INPUT_RESISTER_CHANNEL_SIZE_START = 17 - 1; // length: 2 for each + private readonly int INPUT_RESISTER_CHANNEL_START = 229 - 1; // length: 2 for each + + private ModbusClient _master; + + private Timer _timer; + + public string IP { get; set; } + public int Port { get; set; } + + public int Interval { get; set; } + + public bool? IsConnected { get { return _master?.Connected; } } + + public event EventHandler OnConnectionChanged; + public event EventHandler OnSendDataChanged; + public event EventHandler OnReceiveDataChanged; + public event EventHandler OnDataRead; + + public ModbusModel() + { + Port = 502; + + _master = new ModbusClient(); + _master.ReceiveDataChanged += _master_ReceiveDataChanged; + _master.SendDataChanged += _master_SendDataChanged; + _master.ConnectedChanged += _master_ConnectedChanged; + + _timer = new Timer(); + _timer.Interval = 1000; + _timer.Elapsed += _timer_Elapsed; + _timer.Stop(); + } + + private void _timer_Elapsed(object sender, ElapsedEventArgs e) + { + if (_master == null || !_master.Connected) + return; + + // data available check + bool available = _master.ReadCoils(COIL_ADDR_DATA_AVAILABLE, 1)[0]; + if (!available) + return; + + // get data + ReadData(); + + // pop queued data + _master.WriteSingleCoil(COIL_ADDR_DATA_AVAILABLE, false); + } + + private void _master_ConnectedChanged(object sender) + { + if (OnConnectionChanged != null) + OnConnectionChanged(this, _master.Connected); + + if (_master.Connected) + _timer.Start(); + else + _timer.Stop(); + } + + private void _master_SendDataChanged(object sender) + { + if (OnSendDataChanged != null) + OnSendDataChanged(this, _master.sendData); + } + + private void _master_ReceiveDataChanged(object sender) + { + if (OnReceiveDataChanged != null) + OnReceiveDataChanged(this, _master.receiveData); + } + + public void Connect() + { + Disconnect(); + + _master.IPAddress = IP; + _master.Port = Port; + _master.UnitIdentifier = 1; + _master.Connect(); + + // clear queue + _master.WriteSingleCoil(COIL_ADDR_DATA_CLEAR, true); + + // write interval + _master.WriteSingleRegister(HOLDING_RESISTER_SAMPLING_INTERVAL, Interval); + + // write tare + _master.WriteSingleRegister(HOLDING_RESISTER_TARE_TIME, 0); + + // set repeat count + _master.WriteSingleRegister(HOLDING_RESISTER_REPEAT_COUNT, 0); + + // read basic information + ReadData(); + + // Sampling Start + StartSampling(); + } + + public void Disconnect() + { + if (!_master.Connected) + return; + + StopSampling(); + + _master.Disconnect(); + } + + public void StartSampling() + { + if (_master == null || !_master.Connected) + return; + + // coil check + bool samping = _master.ReadCoils(COIL_ADDR_DATA_SAMPLING, 1)[0]; + if (!samping) + _master.WriteSingleCoil(COIL_ADDR_DATA_SAMPLING, true); + } + + public void StopSampling() + { + if (_master == null || !_master.Connected) + return; + + // coil check + bool samping = _master.ReadCoils(COIL_ADDR_DATA_SAMPLING, 1)[0]; + if (samping) + _master.WriteSingleCoil(COIL_ADDR_DATA_SAMPLING, false); + } + + public DataModel ReadData() + { + if (_master == null || !_master.Connected) + return null; + + // interval + int interval = _master.ReadHoldingRegisters(HOLDING_RESISTER_SAMPLING_INTERVAL, 1)[0]; + + // config flowrate + int[] configFlowratePacket = _master.ReadInputRegisters(INPUT_RESISTER_CONFIG_FLOW_RATE, 2); + float configFlowrate = ConvertHighLowToFloat(configFlowratePacket)[0]; + + // actual flowrate + int[] acturalFlowratePacket = _master.ReadInputRegisters(INPUT_RESISTER_FLOW_RATE, 2); + float acturalFlowrate = ConvertHighLowToFloat(acturalFlowratePacket)[0]; + + // channel data + DateTime now = DateTime.Now; + int channelLength = _master.ReadInputRegisters(INPUT_RESISTER_ADDR_NUM_OF_CHANNEL, 1)[0]; + int[] channetSizePacket = _master.ReadInputRegisters(INPUT_RESISTER_CHANNEL_SIZE_START, channelLength * 2); + int[] channelDataPacket = _master.ReadInputRegisters(INPUT_RESISTER_CHANNEL_START, channelLength * 2); + + // channel data converting + int[] channelSizeData = ConvertHighLowToInt(channetSizePacket); + int[] channelData = ConvertHighLowToInt(channelDataPacket); + PMSChannelData[] data = new PMSChannelData[channelData.Length]; + for (int i = 0; i < channelData.Length; i++) + { + data[i] = new PMSChannelData() + { + Name = $"Ch{i + 1} ({channelSizeData[i]})", + TimeStamp = now, + CummulativeRaw = channelData[i] + }; + } + + DataModel read = new DataModel() + { + IP = IP, + Interval = interval, + ConfigFlowrate = configFlowrate, + ActualFlowrate = acturalFlowrate, + NumberOfChannel = channelLength, + Data = new ObservableCollection(data) + }; + + + if (OnDataRead != null) + OnDataRead(this, read); + + return read; + } + + private float[] ConvertHighLowToFloat(int[] input) + { + if (input.Length % 2 != 0) + throw new ArgumentException("Input array is not even."); + + float[] output = new float[input.Length / 2]; + for (int i = 0; i < input.Length; i += 2) + { + ushort high = (ushort)input[i]; + ushort low = (ushort)input[i + 1]; + // big-endian to little-endian + byte[] bytes = BitConverter.GetBytes(low).Concat(BitConverter.GetBytes(high)).ToArray(); + float convertedValue = BitConverter.ToSingle(bytes, 0); + output[i / 2] = convertedValue; + } + + return output; + } + + private int[] ConvertHighLowToInt(int[] input) + { + if (input.Length % 2 != 0) + throw new ArgumentException("Input array is not even."); + + int[] output = new int[input.Length / 2]; + for (int i = 0; i < input.Length; i += 2) + { + ushort high = (ushort)input[i]; + ushort low = (ushort)input[i + 1]; + // big-endian to little-endian + byte[] bytes = BitConverter.GetBytes(low).Concat(BitConverter.GetBytes(high)).ToArray(); + int convertedValue = BitConverter.ToInt32(bytes, 0); + output[i / 2] = convertedValue; + } + + return output; + } + } +} diff --git a/ModbusTester/ModbusTester/Properties/AssemblyInfo.cs b/ModbusTester/ModbusTester/Properties/AssemblyInfo.cs new file mode 100644 index 0000000..8674ebd --- /dev/null +++ b/ModbusTester/ModbusTester/Properties/AssemblyInfo.cs @@ -0,0 +1,55 @@ +using System.Reflection; +using System.Resources; +using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; +using System.Windows; + +// 어셈블리에 대한 일반 정보는 다음 특성 집합을 통해 +// 제어됩니다. 어셈블리와 관련된 정보를 수정하려면 +// 이러한 특성 값을 변경하세요. +[assembly: AssemblyTitle("PMSModbusTester")] +[assembly: AssemblyDescription("")] +[assembly: AssemblyConfiguration("")] +[assembly: AssemblyCompany("")] +[assembly: AssemblyProduct("PMSModbusTester")] +[assembly: AssemblyCopyright("Copyright © 2024")] +[assembly: AssemblyTrademark("")] +[assembly: AssemblyCulture("")] + +// ComVisible을 false로 설정하면 이 어셈블리의 형식이 COM 구성 요소에 +// 표시되지 않습니다. COM에서 이 어셈블리의 형식에 액세스하려면 +// 해당 형식에 대해 ComVisible 특성을 true로 설정하세요. +[assembly: ComVisible(false)] + +//지역화 가능 애플리케이션 빌드를 시작하려면 다음을 설정하세요. +//.csproj 파일의 CultureYouAreCodingWith +// 내부. 예를 들어 미국 영어를 사용하는 경우 +//사용하는 경우 를 en-US로 설정합니다. 그런 다음 아래 +//NeutralResourceLanguage 특성의 주석 처리를 제거합니다. 아래 줄의 "en-US"를 업데이트하여 +//프로젝트 파일의 UICulture 설정과 일치시킵니다. + +//[assembly: NeutralResourcesLanguage("en-US", UltimateResourceFallbackLocation.Satellite)] + + +[assembly: ThemeInfo( + ResourceDictionaryLocation.None, //테마별 리소스 사전의 위치 + //(페이지 또는 응용 프로그램 리소스 사진에 + // 리소스가 없는 경우에 사용됨) + ResourceDictionaryLocation.SourceAssembly //제네릭 리소스 사전의 위치 + //(페이지 또는 응용 프로그램 리소스 사진에 + // 리소스가 없는 경우에 사용됨) +)] + + +// 어셈블리의 버전 정보는 다음 네 가지 값으로 구성됩니다. +// +// 주 버전 +// 부 버전 +// 빌드 번호 +// 수정 버전 +// +// 모든 값을 지정하거나 아래와 같이 '*'를 사용하여 빌드 번호 및 수정 번호를 +// 기본값으로 할 수 있습니다. +// [assembly: AssemblyVersion("1.0.*")] +[assembly: AssemblyVersion("1.0.0.0")] +[assembly: AssemblyFileVersion("1.0.0.0")] diff --git a/ModbusTester/ModbusTester/Properties/Resources.Designer.cs b/ModbusTester/ModbusTester/Properties/Resources.Designer.cs new file mode 100644 index 0000000..db313b0 --- /dev/null +++ b/ModbusTester/ModbusTester/Properties/Resources.Designer.cs @@ -0,0 +1,71 @@ +//------------------------------------------------------------------------------ +// +// 이 코드는 도구를 사용하여 생성되었습니다. +// 런타임 버전:4.0.30319.42000 +// +// 파일 내용을 변경하면 잘못된 동작이 발생할 수 있으며, 코드를 다시 생성하면 +// 이러한 변경 내용이 손실됩니다. +// +//------------------------------------------------------------------------------ + +namespace ModbusTester.Properties +{ + + + /// + /// 지역화된 문자열 등을 찾기 위한 강력한 형식의 리소스 클래스입니다. + /// + // 이 클래스는 ResGen 또는 Visual Studio와 같은 도구를 통해 StronglyTypedResourceBuilder + // 클래스에서 자동으로 생성되었습니다. + // 멤버를 추가하거나 제거하려면 .ResX 파일을 편집한 다음 /str 옵션을 사용하여 + // ResGen을 다시 실행하거나 VS 프로젝트를 다시 빌드하십시오. + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("System.Resources.Tools.StronglyTypedResourceBuilder", "4.0.0.0")] + [global::System.Diagnostics.DebuggerNonUserCodeAttribute()] + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + internal class Resources + { + + private static global::System.Resources.ResourceManager resourceMan; + + private static global::System.Globalization.CultureInfo resourceCulture; + + [global::System.Diagnostics.CodeAnalysis.SuppressMessageAttribute("Microsoft.Performance", "CA1811:AvoidUncalledPrivateCode")] + internal Resources() + { + } + + /// + /// 이 클래스에서 사용하는 캐시된 ResourceManager 인스턴스를 반환합니다. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Resources.ResourceManager ResourceManager + { + get + { + if ((resourceMan == null)) + { + global::System.Resources.ResourceManager temp = new global::System.Resources.ResourceManager("PMSModbusTester.Properties.Resources", typeof(Resources).Assembly); + resourceMan = temp; + } + return resourceMan; + } + } + + /// + /// 이 강력한 형식의 리소스 클래스를 사용하여 모든 리소스 조회에 대해 현재 스레드의 CurrentUICulture 속성을 + /// 재정의합니다. + /// + [global::System.ComponentModel.EditorBrowsableAttribute(global::System.ComponentModel.EditorBrowsableState.Advanced)] + internal static global::System.Globalization.CultureInfo Culture + { + get + { + return resourceCulture; + } + set + { + resourceCulture = value; + } + } + } +} diff --git a/ModbusTester/ModbusTester/Properties/Resources.resx b/ModbusTester/ModbusTester/Properties/Resources.resx new file mode 100644 index 0000000..af7dbeb --- /dev/null +++ b/ModbusTester/ModbusTester/Properties/Resources.resx @@ -0,0 +1,117 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + text/microsoft-resx + + + 2.0 + + + System.Resources.ResXResourceReader, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + + System.Resources.ResXResourceWriter, System.Windows.Forms, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089 + + \ No newline at end of file diff --git a/ModbusTester/ModbusTester/Properties/Settings.Designer.cs b/ModbusTester/ModbusTester/Properties/Settings.Designer.cs new file mode 100644 index 0000000..d64df03 --- /dev/null +++ b/ModbusTester/ModbusTester/Properties/Settings.Designer.cs @@ -0,0 +1,30 @@ +//------------------------------------------------------------------------------ +// +// This code was generated by a tool. +// Runtime Version:4.0.30319.42000 +// +// Changes to this file may cause incorrect behavior and will be lost if +// the code is regenerated. +// +//------------------------------------------------------------------------------ + +namespace ModbusTester.Properties +{ + + + [global::System.Runtime.CompilerServices.CompilerGeneratedAttribute()] + [global::System.CodeDom.Compiler.GeneratedCodeAttribute("Microsoft.VisualStudio.Editors.SettingsDesigner.SettingsSingleFileGenerator", "11.0.0.0")] + internal sealed partial class Settings : global::System.Configuration.ApplicationSettingsBase + { + + private static Settings defaultInstance = ((Settings)(global::System.Configuration.ApplicationSettingsBase.Synchronized(new Settings()))); + + public static Settings Default + { + get + { + return defaultInstance; + } + } + } +} diff --git a/ModbusTester/ModbusTester/Properties/Settings.settings b/ModbusTester/ModbusTester/Properties/Settings.settings new file mode 100644 index 0000000..033d7a5 --- /dev/null +++ b/ModbusTester/ModbusTester/Properties/Settings.settings @@ -0,0 +1,7 @@ + + + + + + + \ No newline at end of file diff --git a/ModbusTester/ModbusTester/Resources/Logo.png b/ModbusTester/ModbusTester/Resources/Logo.png new file mode 100644 index 0000000..1be1326 Binary files /dev/null and b/ModbusTester/ModbusTester/Resources/Logo.png differ diff --git a/ModbusTester/ModbusTester/packages.config b/ModbusTester/ModbusTester/packages.config new file mode 100644 index 0000000..574c664 --- /dev/null +++ b/ModbusTester/ModbusTester/packages.config @@ -0,0 +1,4 @@ + + + + \ No newline at end of file