HamBook – Blame information for rev 13

Subversion Repositories:
Rev:
Rev Author Line No. Line
1 office 1 using Configuration;
10 office 2 using NAudio.CoreAudioApi;
3 using NAudio.Wave;
1 office 4 using System;
5 using System.Collections.Generic;
6 using System.ComponentModel;
7 using System.Data;
10 office 8 using System.Diagnostics;
1 office 9 using System.Drawing;
12 office 10 using System.IO;
1 office 11 using System.IO.Ports;
12 using System.Linq;
12 office 13 using System.Reflection;
1 office 14 using System.Text;
15 using System.Threading;
16 using System.Threading.Tasks;
17 using System.Windows.Forms;
18  
19 namespace HamBook
20 {
21 public partial class SettingsForm : Form
22 {
23 public bool SaveOnClose { get; private set; }
24  
25 private Configuration.Configuration _configuration;
26  
27 public SettingsForm()
28 {
29 InitializeComponent();
30 }
31 public SettingsForm(Configuration.Configuration configuration, CancellationToken cancellationToken) : this()
32 {
33 _configuration = configuration;
34 }
35  
36 private void SettingsForm_Load(object sender, EventArgs e)
37 {
38 var ports = SerialPort.GetPortNames();
39  
40 if (ports != null && ports.Length != 0)
41 {
42 foreach (var port in ports)
43 {
44 comboBox1.Items.Add(port);
45 }
46  
47 comboBox1.Text = ports[0];
48 }
49  
50 // Create data bindings.
8 office 51 checkBox1.DataBindings.Add(nameof(checkBox1.Checked), _configuration, nameof(_configuration.LaunchOnBoot), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
52  
5 office 53 comboBox1.DataBindings.Add(nameof(comboBox1.Text), _configuration, nameof(_configuration.Port), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
54 comboBox2.DataBindings.Add(nameof(comboBox2.Text), _configuration, nameof(_configuration.Speed), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
55 comboBox3.DataBindings.Add(nameof(comboBox3.Text), _configuration, nameof(_configuration.DataBits), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
56 comboBox4.DataBindings.Add(nameof(comboBox4.Text), _configuration, nameof(_configuration.Parity), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
57 comboBox5.DataBindings.Add(nameof(comboBox5.Text), _configuration, nameof(_configuration.StopBits), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
1 office 58  
5 office 59 comboBox7.DataBindings.Add(nameof(comboBox7.Text), _configuration, nameof(_configuration.Radio), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
7 office 60 comboBox8.DataBindings.Add(nameof(comboBox8.Text), _configuration, nameof(_configuration.Handshake), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
5 office 61  
62 var bandBindingSource = new BindingSource();
63 bandBindingSource.DataSource = _configuration.Definitions.Bands;
64 comboBox6.DataSource = bandBindingSource;
12 office 65 comboBox6.DisplayMember = "Meters";
5 office 66  
67 textBox1.DataBindings.Add(nameof(textBox1.Text), bandBindingSource, nameof(Band.Min), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
68 textBox2.DataBindings.Add(nameof(textBox1.Text), bandBindingSource, nameof(Band.Max), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
7 office 69  
70 textBox3.DataBindings.Add(nameof(textBox3.Text), _configuration.SerialPortTimeout, nameof(SerialPortTimeout.Read), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
71 textBox4.DataBindings.Add(nameof(textBox4.Text), _configuration.SerialPortTimeout, nameof(SerialPortTimeout.Write), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
9 office 72 textBox5.DataBindings.Add(nameof(textBox5.Text), _configuration, nameof(_configuration.ScanDetectPause), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
10 office 73  
74  
75 comboBox9.DataBindings.Add(nameof(comboBox9.Text), _configuration.Audio, nameof(_configuration.Audio.InputDeviceFriendlyName), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
76 comboBox10.DataBindings.Add(nameof(comboBox10.Text), _configuration.Audio, nameof(_configuration.Audio.OutputDeviceFriendlyName), true, DataSourceUpdateMode.OnPropertyChanged, string.Empty);
77  
78 foreach (var deviceNumber in Enumerable.Range(0, WaveIn.DeviceCount))
79 {
80 var capabilities = WaveIn.GetCapabilities(deviceNumber);
81  
82 comboBox9.Items.Add(capabilities.ProductName);
83 }
84  
85 foreach (var deviceNumber in Enumerable.Range(0, WaveOut.DeviceCount))
86 {
87 var capabilities = WaveOut.GetCapabilities(deviceNumber);
88 comboBox10.Items.Add(capabilities.ProductName);
89 }
12 office 90  
91 foreach(var notificationState in _configuration.Notifications.State)
92 {
13 office 93 switch(notificationState.Type)
94 {
95 case NotificationType.None:
96 continue;
97 }
98  
12 office 99 var index = dataGridView1.Rows.Add();
100  
13 office 101 var nameTextBox = (DataGridViewTextBoxCell)dataGridView1.Rows[index].Cells["DescriptionColumn"];
102 nameTextBox.Value = Utilities.Miscellaneous.GetDescriptionFromEnumValue(notificationState.Type);
12 office 103  
104 var enableCheckBox = (DataGridViewCheckBoxCell)dataGridView1.Rows[index].Cells["EnableColumn"];
105 enableCheckBox.Value= notificationState.Enabled;
106  
107 var lingerTextBox = (DataGridViewTextBoxCell)dataGridView1.Rows[index].Cells["LingerColumn"];
108 lingerTextBox.Value = notificationState.LingerTime;
109 }
1 office 110 }
111  
112 private void button1_Click(object sender, EventArgs e)
113 {
114 SaveOnClose = true;
115 Close();
116 }
117  
118 private void button2_Click(object sender, EventArgs e)
119 {
120 SaveOnClose = false;
121 Close();
122 }
5 office 123  
124 private void textBox1_TextChanged(object sender, EventArgs e)
125 {
126 var textBox = (TextBox)sender;
127 if(string.IsNullOrEmpty(textBox.Text) || !int.TryParse(textBox.Text, out var frequency))
128 {
129 return;
130 }
131  
132 var band = (Band)comboBox6.SelectedValue;
133 band.Min = frequency;
134 }
135  
136 private void textBox2_TextChanged(object sender, EventArgs e)
137 {
138 var textBox = (TextBox)sender;
139 if (string.IsNullOrEmpty(textBox.Text) || !int.TryParse(textBox.Text, out var frequency))
140 {
141 return;
142 }
143  
144 var band = (Band)comboBox6.SelectedValue;
145 band.Max = frequency;
146 }
12 office 147  
148 private void DataGridView1_CurrentCellDirtyStateChanged(object sender, EventArgs e)
149 {
150 var dataGridView = (DataGridView)sender;
151  
152 if (dataGridView.CurrentCell is DataGridViewCheckBoxCell)
153 {
154 dataGridView.CommitEdit(DataGridViewDataErrorContexts.Commit);
155 }
156 }
157  
158 private void DataGridView1_CellEndEdit(object sender, DataGridViewCellEventArgs e)
159 {
160 var dataGridView = (DataGridView)sender;
161  
162 dataGridView.CommitEdit(DataGridViewDataErrorContexts.Commit);
163 }
164  
165 private void DataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
166 {
167 var dataGridView = (DataGridView)sender;
168  
169 if (dataGridView.CurrentCell is DataGridViewCheckBoxCell)
170 {
171 if (dataGridView.CurrentCell.IsInEditMode)
172 {
173 if (dataGridView.IsCurrentCellDirty)
174 {
175 dataGridView.EndEdit();
176 }
177 }
178 }
179 }
180  
181 private void DataGridView1_CellValueChanged(object sender, DataGridViewCellEventArgs e)
182 {
183 var dataGridView = (DataGridView)sender;
184  
185 if (e.RowIndex == -1 || e.ColumnIndex == -1)
186 {
187 return;
188 }
189  
190 switch (dataGridView.Columns[e.ColumnIndex].Name)
191 {
192 case "EnableColumn":
193 ProcessEnable(dataGridView.Rows[e.RowIndex]);
194 break;
195 }
196 }
197  
198 private void ProcessEnable(DataGridViewRow dataGridViewRow)
199 {
200 var enableCheckBoxCell =
201 (DataGridViewCheckBoxCell)dataGridViewRow.Cells["EnableColumn"];
202  
203 foreach(var notificationState in _configuration.Notifications.State)
204 {
205 switch (notificationState.Type)
206 {
207 case NotificationType.SignalScanDetect:
208 notificationState.Enabled = (bool)enableCheckBoxCell.Value;
209 break;
210 }
211 }
212 }
213  
214 private void DataGridView1_CellMouseUp(object sender, DataGridViewCellMouseEventArgs e)
215 {
216 var dataGridView = (DataGridView)sender;
217  
218 if (e.RowIndex == -1 || e.ColumnIndex == -1 ||
219 !(dataGridView.Columns[e.ColumnIndex] is DataGridViewCheckBoxColumn))
220 {
221 return;
222 }
223  
224 dataGridView.EndEdit();
225 }
226  
227 private void DataGridView_CellDoubleClick(object sender, DataGridViewCellEventArgs e)
228 {
229 var dataGridView = (DataGridView)sender;
230  
231 if (e.RowIndex == -1 || e.ColumnIndex == -1 ||
232 !(dataGridView.Columns[e.ColumnIndex] is DataGridViewCheckBoxColumn))
233 {
234 return;
235 }
236  
237 dataGridView.EndEdit();
238 }
239  
240 private void DataGridView1_DataError(object sender, DataGridViewDataErrorEventArgs e)
241 {
242 // Do not allow errors.
243 }
244  
1 office 245 }
246 }