Main.cs 73 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226
  1. using CCWin;
  2. using Newtonsoft.Json;
  3. using Newtonsoft.Json.Linq;
  4. using SufeiUtil;
  5. using SXLibrary;
  6. using System;
  7. using System.Collections;
  8. using System.Collections.Generic;
  9. using System.Data.SQLite;
  10. using System.Drawing;
  11. using System.IO;
  12. using System.IO.Ports;
  13. using System.Linq;
  14. using System.Net;
  15. using System.Threading;
  16. using System.Threading.Tasks;
  17. using System.Windows.Forms;
  18. namespace MOKA_Factory_Tools
  19. {
  20. public delegate void MoveHandler(Point XY, ArrayList formlocationmsg, int num);
  21. public delegate void KeyDownHandler(ArrayList formlocationmsg, IntPtr intPtr);
  22. public partial class Main : Skin_Color
  23. {
  24. MidList midList1 = new MidList();
  25. UpgradeMsgList UpgradeMsgList1 = new UpgradeMsgList();
  26. MidAddress midAddress1 = new MidAddress();
  27. ReadCheck ReadCheck1 = new ReadCheck();
  28. WriteCheck WriteCheck1 = new WriteCheck();
  29. WriteDone WriteDone1 = new WriteDone();
  30. FunctionSetting functionSetting1 = new FunctionSetting();
  31. SQLiteConnection LocalDB = null;
  32. SQLiteConnection ErrorDB = null;
  33. Dictionary<string, string> ChannelMapList = new Dictionary<string, string>();
  34. Dictionary<string, string> LanguageMapList = new Dictionary<string, string>();
  35. string Custom_ProjectID = "";
  36. ArrayList formlocationmsg = new ArrayList();
  37. string ErrorDBPath = AppDomain.CurrentDomain.BaseDirectory + "\\Error.db";
  38. Thread uploadbackground;
  39. bool LocalWrite = false;//离线抄写开关
  40. bool LocationMark = true;//操作窗体换行点
  41. int LocationNum = 0;//一行操作窗体数
  42. public event KeyDownHandler KeyDownEvent;
  43. public event MoveHandler MoveEvent;
  44. public Main(int enable)
  45. {
  46. InitializeComponent();
  47. LockSettingFunction(enable == 0 || enable == 3);
  48. CreateKeyManually.Visible = enable == 1;
  49. LocalWrite = enable == 3;
  50. }
  51. private void Form1_Load(object sender, EventArgs e)
  52. {
  53. uploadbackground = new Thread(UploadBackGround);
  54. uploadbackground.IsBackground = true;
  55. TVCOM.Items.AddRange(SerialPort.GetPortNames());
  56. LoadJsonConfig();
  57. this.StartPosition = FormStartPosition.Manual;
  58. this.Location = new Point(0, 0);
  59. this.Text = CommonMethod.FactoryName + " " + System.Reflection.Assembly.GetExecutingAssembly().GetName().Version.ToString();
  60. if (!File.Exists(ErrorDBPath))
  61. {
  62. if (SQLiteHelper.NewDbFile(ErrorDBPath))
  63. {
  64. SQLiteHelper.NewTable(ErrorDBPath, "ErrorReport", "(ID INTEGER PRIMARY KEY AUTOINCREMENT,url varchar,content varvhar,gener_date DATETIME DEFAULT (datetime(CURRENT_TIMESTAMP,'localtime')),report_date DATETIME)");
  65. SQLiteHelper.NewTable(ErrorDBPath, "CopyDelayReport", "(ID INTEGER PRIMARY KEY AUTOINCREMENT,bid varchar,url varchar,content varvhar,copy_date DATETIME DEFAULT (datetime(CURRENT_TIMESTAMP,'localtime')),report_date DATETIME)");
  66. SQLiteHelper.NewTable(ErrorDBPath, "ProductionCount", "(bid varchar,count varchar)");
  67. }
  68. }
  69. if (ErrorDB == null)
  70. {
  71. ErrorDB = new SQLiteConnection("data source=" + ErrorDBPath);
  72. ErrorDB.Open();
  73. }
  74. }
  75. private void SetDSNLimit()
  76. {
  77. // 如果抄写PSN,不自动赋值条码限制;
  78. if (BarcodeWrite.Checked)
  79. return;
  80. // 设置条码限制默认打上勾;
  81. if (midList1.keytype != null && midList1.keytype.ContainsKey("DSN"))
  82. {
  83. BarcodeLimit.Checked = true;
  84. BarCodeKeyCodeText.Text = OrderText.Text;
  85. }
  86. }
  87. private void OrderSubmit_Click(object sender, EventArgs e)
  88. {
  89. SQLiteHelper.DeleteOldData(ErrorDB);//删除30天以前已经上报的数据
  90. if (TestMode.serverurl == Serverurl.Testurl)
  91. {
  92. MessageBoxButtons messButton = MessageBoxButtons.YesNo;
  93. DialogResult dr = MessageBox.Show(LResource.TestServerUsingError, LResource.Error, messButton);
  94. if (dr == DialogResult.Yes)
  95. {
  96. //
  97. }
  98. else
  99. {
  100. return;
  101. }
  102. }
  103. if (TVCOM.SelectedItem == null)
  104. {
  105. MessageBox.Show(LResource.TVCOMNullError, LResource.Error);
  106. return;
  107. }
  108. if (OrderText.Text.Trim().Length == 0)
  109. {
  110. MessageBox.Show(LResource.OrderNullError, LResource.Error);
  111. return;
  112. }
  113. if (!SQLiteHelper.CheckProductionNum(ErrorDB, OrderText.Text.Trim()))
  114. {
  115. MessageBox.Show(LResource.CheckProductionNumError, LResource.Error);
  116. return;
  117. }
  118. if (timer1.Enabled == false)
  119. timer1.Start();
  120. OrderSubmit.Text = LResource.Waiting;
  121. SaveJsonConfig("LastOrder", OrderText.Text.ToString());
  122. functionSetting1.TVCOM = TVCOM.SelectedItem.ToString();
  123. functionSetting1.TVBaud = TVBaud.SelectedItem.ToString();
  124. functionSetting1.ChannelList = ChannelList.SelectedItem.ToString();
  125. functionSetting1.WriteChannel = WriteChannel.Checked;
  126. functionSetting1.WriteOSD = WriteOSD.Checked;
  127. functionSetting1.OSDList = OSDList.SelectedItem.ToString();
  128. functionSetting1.WriteSHOP = WriteSHOP.Checked;
  129. functionSetting1.SHOPList = SHOPList.SelectedItem.ToString();
  130. functionSetting1.WriteWB = WriteWB.Checked;
  131. functionSetting1.WBInit = WBInit.Checked;
  132. functionSetting1.WBPath = WBPath.Text;
  133. if (!LocalWrite)
  134. {
  135. if (Preload.Checked)
  136. {
  137. string dbPath = AppDomain.CurrentDomain.BaseDirectory + "\\Keys\\" + OrderText.Text.Trim() + ".db";
  138. if (File.Exists(dbPath))
  139. {
  140. if (LocalDB == null)
  141. {
  142. LocalDB = new SQLiteConnection("data source=" + dbPath);
  143. LocalDB.Open();
  144. }
  145. if (SQLiteHelper.WholeCheckDownloadStatus(LocalDB, OrderText.Text.Trim()))
  146. {
  147. try
  148. {
  149. if (SQLiteHelper.GetDBMidInfo(LocalDB, OrderText.Text.Trim(), out midAddress1))
  150. {
  151. if (UsinglocalIDCheck.Checked)
  152. {
  153. midAddress1.pid = Custom_ProjectID;
  154. MessageBox.Show(LResource.WilluseLocalPID, "", MessageBoxButtons.OK, MessageBoxIcon.Warning);
  155. }
  156. else if (midAddress1.pid != Custom_ProjectID && Custom_ProjectID.Trim().Length > 0)
  157. {
  158. if (midAddress1.pid != null)
  159. if (midAddress1.pid.Trim().Length > 0)
  160. PID_Num.Value = Convert.ToDecimal(midAddress1.pid);
  161. MessageBox.Show(LResource.WilluseOnlinePID, "", MessageBoxButtons.OK, MessageBoxIcon.Information);
  162. }
  163. if (SQLiteHelper.GetrokuCustomer(LocalDB, OrderText.Text, out RokuCustomer rokuCustomer_1))
  164. {
  165. midList1.rokuCustomer = rokuCustomer_1;
  166. };
  167. if (SQLiteHelper.Getdsn(LocalDB, OrderText.Text, out string firetvdsn))
  168. {
  169. midList1.keytype = new Dictionary<string, string>();
  170. midList1.keytype.Add("DSN", firetvdsn);
  171. };
  172. if (SQLiteHelper.Getwhitebalance(LocalDB, OrderText.Text, out WhiteBalanceInfo whiteBalanceInfo_1))
  173. {
  174. functionSetting1.WBPath = dbPath;
  175. functionSetting1.WriteWB = true;
  176. functionSetting1.NormalRGB = new byte[3];
  177. functionSetting1.CoolRGB = new byte[3];
  178. functionSetting1.WarmRGB = new byte[3];
  179. functionSetting1.NormalRGB[0] = (byte)Convert.ToDouble(whiteBalanceInfo_1.hdmirgain);
  180. functionSetting1.NormalRGB[1] = (byte)Convert.ToDouble(whiteBalanceInfo_1.hdmiggain);
  181. functionSetting1.NormalRGB[2] = (byte)Convert.ToDouble(whiteBalanceInfo_1.hdmibgain);
  182. functionSetting1.CoolRGB[0] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.lrgain) + 256);
  183. functionSetting1.CoolRGB[1] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.lggain) + 256);
  184. functionSetting1.CoolRGB[2] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.lbgain) + 256);
  185. functionSetting1.WarmRGB[0] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.nrgain) + 256);
  186. functionSetting1.WarmRGB[1] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.nggain) + 256);
  187. functionSetting1.WarmRGB[2] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.nbgain) + 256);
  188. };
  189. OperationPanel operationPanel1 = new OperationPanel(this, LocalDB, ErrorDB, midAddress1, functionSetting1, WriteCheck1, ReadCheck1, WriteDone1, Preload.Checked, midList1, OrderText.Text.Trim());
  190. operationPanel1.StartPosition = FormStartPosition.Manual;
  191. if ((this.Right + operationPanel1.Size.Width * formlocationmsg.Count) > Screen.PrimaryScreen.Bounds.Width && LocationMark)
  192. {
  193. LocationMark = false;
  194. LocationNum = formlocationmsg.Count;
  195. }
  196. if (formlocationmsg.Count == 0)
  197. operationPanel1.Location = (Point)new Size(this.Right, this.Top);
  198. else if ((this.Right + operationPanel1.Size.Width * formlocationmsg.Count) > Screen.PrimaryScreen.Bounds.Width)
  199. {
  200. Point point = ((Dictionary<IntPtr, Point>)formlocationmsg[formlocationmsg.Count - 1]).Last().Value;
  201. operationPanel1.Location = (Point)new Size(this.Right + operationPanel1.Size.Width * (formlocationmsg.Count - LocationNum), this.Top + operationPanel1.Size.Height);
  202. }
  203. else
  204. {
  205. Point point = ((Dictionary<IntPtr, Point>)formlocationmsg[formlocationmsg.Count - 1]).Last().Value;
  206. operationPanel1.Location = (Point)new Size(this.Right + operationPanel1.Size.Width * formlocationmsg.Count, this.Top);
  207. }
  208. operationPanel1.DeleteIntptr += new OperationPanel.DisplayUpdateDelegate(DeleteIntptr);
  209. operationPanel1.SNKeyDownEven += new OperationPanel.SNKeyDown(SNKeyDownEven);
  210. operationPanel1.AutoKeyRequire += new OperationPanel.AutoKeyRequireDelegate(AutoKeyRequire);
  211. IntPtr intPtr = operationPanel1.Handle;
  212. Dictionary<IntPtr, Point> part1 = new Dictionary<IntPtr, Point>();
  213. part1.Add(intPtr, (Point)new Size(operationPanel1.Right, operationPanel1.Top));
  214. formlocationmsg.Add(part1);
  215. operationPanel1.Show();
  216. }
  217. else
  218. {
  219. MessageBox.Show("Read LocalDB error,please delete old db file and download a new one");
  220. }
  221. }
  222. catch (Exception ex)
  223. {
  224. Log.WriteErrorLog(ex.Message);
  225. }
  226. // 是否有dsn要抄写;
  227. SetDSNLimit();
  228. }
  229. }
  230. else
  231. {
  232. if (CommonMethod.GetMidInfo(TestMode.serverurl, OrderText.Text.Trim(), TestMode.MAC, "", "", ErrorDB, out midList1))
  233. {
  234. if (CommonMethod.GetMidAddress2(midList1, OrderText.Text.Trim(), ErrorDB, out List<MidAddress> midAddress2))
  235. {
  236. WhiteBalanceList WhiteBalanceListNow;
  237. switch (midList1.whiteType)//订单白平衡预置状态
  238. {
  239. case "0"://旧订单,默认值
  240. {
  241. CommonMethod.GetWhiteBalanceInfo(TestMode.getWhiteBalanceInfoUrl, OrderText.Text.Trim(), TestMode.MAC, ErrorDB, out WhiteBalanceListNow);
  242. break;
  243. }
  244. case "1"://未预置或预置LR数据
  245. {
  246. CommonMethod.GetWhiteBalanceInfo(TestMode.getWhiteBalanceInfoUrl, OrderText.Text.Trim(), TestMode.MAC, ErrorDB, out WhiteBalanceListNow);
  247. if (WhiteBalanceListNow.whiteBalanceInfo == null)
  248. {
  249. MessageBox.Show("White balance info error, please contact factory engineer!");
  250. return;
  251. }
  252. break;
  253. }
  254. case "2"://已预置PR数据
  255. {
  256. CommonMethod.GetWhiteBalanceInfo(TestMode.getWhiteBalanceInfoUrl, OrderText.Text.Trim(), TestMode.MAC, ErrorDB, out WhiteBalanceListNow);
  257. break;
  258. }
  259. default:
  260. {
  261. WhiteBalanceListNow = null;
  262. break;
  263. }
  264. }
  265. foreach (var midAddress1 in midAddress2)
  266. {
  267. string KeyPath = AppDomain.CurrentDomain.BaseDirectory + "\\download\\" + midAddress1.order + ".json";
  268. if (System.IO.File.Exists(KeyPath))
  269. {
  270. if (GetMD5.GetMD5HashFromFile(KeyPath) == midAddress1.pmd5)
  271. {
  272. if (SQLiteHelper.NewDbFile(dbPath))
  273. {
  274. SQLiteHelper.NewTable(dbPath, "keys", "(sn varchar,keys varvhar,copy_date DATETIME,report_date DATETIME)");
  275. SQLiteHelper.NewTable(dbPath, "mid", "(bid varchar,number varchar, pid varchar,ctype varvhar,version varvhar,host varchar,purl varvhar,psize varvhar,pmd5 varvhar,status varvhar,start_date DATETIME DEFAULT (datetime(CURRENT_TIMESTAMP,'localtime')),finish_date DATETIME,desc varvhar)");
  276. SQLiteHelper.NewTable(dbPath, "report", "(url varchar,content varchar,gener_date DATETIME,report_date DATETIME)");
  277. SQLiteHelper.NewTable(dbPath, "rokuCustomer", "(ordernum varchar,region varchar,brand varchar,oemmodel varchar,supporturl varchar,supportphone varchar,productiondate varchar,remotetype varchar)");
  278. SQLiteHelper.NewTable(dbPath, "whitebalance", "(ordernum varchar,hdmirgain varchar,hdmiggain varchar,hdmibgain varchar,nrgain varchar,nggain varchar,nbgain varchar,lrgain varchar,lggain varchar,lbgain varchar,updatetime DATETIME DEFAULT (datetime(CURRENT_TIMESTAMP,'localtime')))");
  279. SQLiteHelper.NewTable(dbPath, "dsn", "(ordernum varchar,dsn varchar,updatetime DATETIME DEFAULT (datetime(CURRENT_TIMESTAMP,'localtime')))");
  280. SQLiteHelper.AddOneLine(dbPath, new object[] { midAddress1.order, midAddress1.number, midAddress1.pid, midAddress1.ctype, midAddress1.version, midList1.host, midAddress1.purl, midAddress1.psize, midAddress1.pmd5, "1" });
  281. if (midList1.rokuCustomer != null)
  282. SQLiteHelper.AddRokuOneLine(dbPath, new object[] { midList1.rokuCustomer.ordernum, midList1.rokuCustomer.region, midList1.rokuCustomer.brand, midList1.rokuCustomer.oemmodel, midList1.rokuCustomer.supporturl, midList1.rokuCustomer.supportphone, midList1.rokuCustomer.productiondate, midList1.rokuCustomer.remotetype });
  283. if (WhiteBalanceListNow != null)
  284. if (WhiteBalanceListNow.whiteBalanceInfo != null)
  285. SQLiteHelper.AddwbOneLine(dbPath, new object[] { WhiteBalanceListNow.whiteBalanceInfo.ordernum,
  286. WhiteBalanceListNow.whiteBalanceInfo.hdmirgain, WhiteBalanceListNow.whiteBalanceInfo.hdmiggain, WhiteBalanceListNow.whiteBalanceInfo.hdmibgain,
  287. WhiteBalanceListNow.whiteBalanceInfo.nrgain, WhiteBalanceListNow.whiteBalanceInfo.nggain, WhiteBalanceListNow.whiteBalanceInfo.nbgain,
  288. WhiteBalanceListNow.whiteBalanceInfo.lrgain, WhiteBalanceListNow.whiteBalanceInfo.lggain, WhiteBalanceListNow.whiteBalanceInfo.lbgain });
  289. if (midList1.keytype.ContainsKey("DSN"))
  290. {
  291. SQLiteHelper.AdddsnOneLine(dbPath, new object[] { midAddress1.order, midList1.keytype["DSN"] });
  292. }
  293. SQLiteHelper.UpdateTime(dbPath, midAddress1.order);
  294. }
  295. if (File.Exists(dbPath))
  296. {
  297. List<object[]> keyDatas = new List<object[]>();
  298. using (System.IO.StreamReader file = System.IO.File.OpenText(KeyPath))
  299. {
  300. using (JsonTextReader reader = new JsonTextReader(file))
  301. {
  302. JArray o = (JArray)JToken.ReadFrom(reader);
  303. foreach (var ss in o) //查找某个字段与值
  304. {
  305. var sn = ((JObject)ss)["sn"];
  306. var data = ((JObject)ss)["key"];
  307. keyDatas.Add(new object[] { sn, data });
  308. }
  309. }
  310. }
  311. SQLiteHelper.InsertKeys(dbPath, keyDatas);
  312. }
  313. try
  314. {
  315. if (LocalDB == null)
  316. {
  317. LocalDB = new SQLiteConnection("data source=" + dbPath);
  318. LocalDB.Open();
  319. }
  320. OperationPanel operationPanel1 = new OperationPanel(this, LocalDB, ErrorDB, midAddress1, functionSetting1, WriteCheck1, ReadCheck1, WriteDone1, Preload.Checked, midList1, OrderText.Text.Trim());
  321. operationPanel1.StartPosition = FormStartPosition.Manual;
  322. if ((this.Right + operationPanel1.Size.Width * formlocationmsg.Count) > Screen.PrimaryScreen.Bounds.Width && LocationMark)
  323. {
  324. LocationMark = false;
  325. LocationNum = formlocationmsg.Count;
  326. }
  327. if (formlocationmsg.Count == 0)
  328. operationPanel1.Location = (Point)new Size(this.Right, this.Top);
  329. else if ((this.Right + operationPanel1.Size.Width * formlocationmsg.Count) > Screen.PrimaryScreen.Bounds.Width)
  330. {
  331. Point point = ((Dictionary<IntPtr, Point>)formlocationmsg[formlocationmsg.Count - 1]).Last().Value;
  332. operationPanel1.Location = (Point)new Size(this.Right + operationPanel1.Size.Width * (formlocationmsg.Count - LocationNum), this.Top + operationPanel1.Size.Height);
  333. }
  334. else
  335. {
  336. Point point = ((Dictionary<IntPtr, Point>)formlocationmsg[formlocationmsg.Count - 1]).Last().Value;
  337. operationPanel1.Location = (Point)new Size(this.Right + operationPanel1.Size.Width * formlocationmsg.Count, this.Top);
  338. }
  339. operationPanel1.DeleteIntptr += new OperationPanel.DisplayUpdateDelegate(DeleteIntptr);
  340. operationPanel1.SNKeyDownEven += new OperationPanel.SNKeyDown(SNKeyDownEven);
  341. operationPanel1.AutoKeyRequire += new OperationPanel.AutoKeyRequireDelegate(AutoKeyRequire);
  342. IntPtr intPtr = operationPanel1.Handle;
  343. Dictionary<IntPtr, Point> part1 = new Dictionary<IntPtr, Point>();
  344. part1.Add(intPtr, (Point)new Size(operationPanel1.Right, operationPanel1.Top));
  345. formlocationmsg.Add(part1);
  346. operationPanel1.Show();
  347. }
  348. catch (Exception ex)
  349. {
  350. Log.WriteErrorLog(ex.Message);
  351. }
  352. }
  353. else
  354. {
  355. Download DownloadPage = new Download(ErrorDB, midAddress1, -1, midList1, WhiteBalanceListNow);
  356. DownloadPage.ShowDialog();
  357. int gid = GC.GetGeneration(DownloadPage);
  358. DownloadPage = null;
  359. GC.Collect(gid);
  360. }
  361. }
  362. else
  363. {
  364. Download DownloadPage = new Download(ErrorDB, midAddress1, -1, midList1, WhiteBalanceListNow);
  365. DownloadPage.ShowDialog();
  366. int gid = GC.GetGeneration(DownloadPage);
  367. DownloadPage = null;
  368. GC.Collect(gid);
  369. }
  370. }
  371. if (File.Exists(dbPath))
  372. {
  373. if (LocalDB == null)
  374. {
  375. LocalDB = new SQLiteConnection("data source=" + dbPath);
  376. LocalDB.Open();
  377. }
  378. if (SQLiteHelper.WholeCheckDownloadStatus(LocalDB, OrderText.Text.Trim()))
  379. {
  380. if (CommonMethod.ReportDownloadStatus(midList1.host, OrderText.Text.Trim(), ErrorDB))
  381. MessageBox.Show(LResource.DownloadSuccess);
  382. else
  383. MessageBox.Show(LResource.DownloadReportFail);
  384. }
  385. }
  386. }
  387. else
  388. {
  389. MessageBox.Show(LResource.GetMidAdresserror);
  390. }
  391. }
  392. else
  393. {
  394. MessageBox.Show(LResource.GetMidInfoerror);
  395. }
  396. // 是否有dsn要抄写;
  397. SetDSNLimit();
  398. }
  399. }
  400. else
  401. {
  402. if (CommonMethod.GetMidInfo(TestMode.serverurl, OrderText.Text.Trim(), TestMode.MAC, "", "", ErrorDB, out midList1))
  403. {
  404. //CommonMethod.UpgradeCheck(UpgradeUrl.Officialurl, midList1.factoryNum, ErrorDB, out UpgradeMsgList1);
  405. if (UsinglocalIDCheck.Checked)
  406. {
  407. midList1.projectid = Custom_ProjectID;
  408. MessageBox.Show(LResource.WilluseLocalPID, "", MessageBoxButtons.OK, MessageBoxIcon.Warning);
  409. }
  410. else if (midList1.projectid != Custom_ProjectID && Custom_ProjectID.Trim().Length > 0)
  411. {
  412. if (midList1.projectid != null)
  413. if (midList1.projectid.Trim().Length > 0)
  414. PID_Num.Value = Convert.ToDecimal(midList1.projectid);
  415. MessageBox.Show(LResource.WilluseOnlinePID, "", MessageBoxButtons.OK, MessageBoxIcon.Information);
  416. }
  417. try
  418. {
  419. OperationPanel operationPanel1 = new OperationPanel(this, LocalDB, ErrorDB, midAddress1, functionSetting1, WriteCheck1, ReadCheck1, WriteDone1, Preload.Checked, midList1, OrderText.Text.Trim());
  420. operationPanel1.StartPosition = FormStartPosition.Manual;
  421. if ((this.Right + operationPanel1.Size.Width * formlocationmsg.Count) > Screen.PrimaryScreen.Bounds.Width && LocationMark)
  422. {
  423. LocationMark = false;
  424. LocationNum = formlocationmsg.Count;
  425. }
  426. if (formlocationmsg.Count == 0)
  427. operationPanel1.Location = (Point)new Size(this.Right, this.Top);
  428. else if ((this.Right + operationPanel1.Size.Width * formlocationmsg.Count) > Screen.PrimaryScreen.Bounds.Width)
  429. {
  430. Point point = ((Dictionary<IntPtr, Point>)formlocationmsg[formlocationmsg.Count - 1]).Last().Value;
  431. operationPanel1.Location = (Point)new Size(this.Right + operationPanel1.Size.Width * (formlocationmsg.Count - LocationNum), this.Top + operationPanel1.Size.Height);
  432. }
  433. else
  434. {
  435. Point point = ((Dictionary<IntPtr, Point>)formlocationmsg[formlocationmsg.Count - 1]).Last().Value;
  436. operationPanel1.Location = (Point)new Size(this.Right + operationPanel1.Size.Width * formlocationmsg.Count, this.Top);
  437. }
  438. operationPanel1.DeleteIntptr += new OperationPanel.DisplayUpdateDelegate(DeleteIntptr);
  439. operationPanel1.SNKeyDownEven += new OperationPanel.SNKeyDown(SNKeyDownEven);
  440. operationPanel1.AutoKeyRequire += new OperationPanel.AutoKeyRequireDelegate(AutoKeyRequire);
  441. IntPtr intPtr = operationPanel1.Handle;
  442. Dictionary<IntPtr, Point> part1 = new Dictionary<IntPtr, Point>();
  443. part1.Add(intPtr, (Point)new Size(operationPanel1.Right, operationPanel1.Top));
  444. formlocationmsg.Add(part1);
  445. operationPanel1.Show();
  446. }
  447. catch (Exception ex)
  448. {
  449. Log.WriteErrorLog(ex.Message);
  450. }
  451. // 是否有dsn要抄写;
  452. SetDSNLimit();
  453. }
  454. else
  455. {
  456. MessageBox.Show(LResource.GetMidInfoerror);
  457. }
  458. }
  459. }
  460. else
  461. {
  462. MessageBox.Show(LResource.LocalKeyMode);
  463. try
  464. {
  465. if (Preload.Checked)
  466. {
  467. string dbPath = AppDomain.CurrentDomain.BaseDirectory + "\\Keys\\" + OrderText.Text.Trim() + ".db";
  468. if (File.Exists(dbPath))
  469. {
  470. if (LocalDB == null)
  471. {
  472. LocalDB = new SQLiteConnection("data source=" + dbPath);
  473. LocalDB.Open();
  474. }
  475. if (SQLiteHelper.WholeCheckDownloadStatus(LocalDB, OrderText.Text.Trim()))
  476. {
  477. if (SQLiteHelper.GetDBMidInfo(LocalDB, OrderText.Text.Trim(), out midAddress1))
  478. {
  479. if (UsinglocalIDCheck.Checked)
  480. {
  481. midAddress1.pid = Custom_ProjectID;
  482. MessageBox.Show(LResource.WilluseLocalPID, "", MessageBoxButtons.OK, MessageBoxIcon.Warning);
  483. }
  484. else if (midAddress1.pid != Custom_ProjectID && Custom_ProjectID.Trim().Length > 0)
  485. {
  486. if (midAddress1.pid != null)
  487. if (midAddress1.pid.Trim().Length > 0)
  488. PID_Num.Value = Convert.ToDecimal(midAddress1.pid);
  489. MessageBox.Show(LResource.WilluseOnlinePID, "", MessageBoxButtons.OK, MessageBoxIcon.Information);
  490. }
  491. midList1 = new MidList()
  492. {
  493. keytype = new Dictionary<string, string>(),
  494. clienttype = midAddress1.ctype,
  495. version = midAddress1.version,
  496. projectid = midAddress1.pid,
  497. host = "LocalPC"
  498. };
  499. if (SQLiteHelper.GetrokuCustomer(LocalDB, OrderText.Text, out RokuCustomer rokuCustomer_1))
  500. {
  501. midList1.rokuCustomer = rokuCustomer_1;
  502. };
  503. if (SQLiteHelper.Getdsn(LocalDB, OrderText.Text, out string firetvdsn))
  504. {
  505. midList1.keytype = new Dictionary<string, string>();
  506. midList1.keytype.Add("DSN", firetvdsn);
  507. };
  508. if (SQLiteHelper.Getwhitebalance(LocalDB, OrderText.Text, out WhiteBalanceInfo whiteBalanceInfo_1))
  509. {
  510. functionSetting1.WBPath = dbPath;
  511. functionSetting1.WriteWB = true;
  512. functionSetting1.NormalRGB = new byte[3];
  513. functionSetting1.CoolRGB = new byte[3];
  514. functionSetting1.WarmRGB = new byte[3];
  515. functionSetting1.NormalRGB[0] = (byte)Convert.ToDouble(whiteBalanceInfo_1.hdmirgain);
  516. functionSetting1.NormalRGB[1] = (byte)Convert.ToDouble(whiteBalanceInfo_1.hdmiggain);
  517. functionSetting1.NormalRGB[2] = (byte)Convert.ToDouble(whiteBalanceInfo_1.hdmibgain);
  518. functionSetting1.CoolRGB[0] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.lrgain) + 256);
  519. functionSetting1.CoolRGB[1] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.lggain) + 256);
  520. functionSetting1.CoolRGB[2] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.lbgain) + 256);
  521. functionSetting1.WarmRGB[0] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.nrgain) + 256);
  522. functionSetting1.WarmRGB[1] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.nggain) + 256);
  523. functionSetting1.WarmRGB[2] = (byte)(Convert.ToDouble(whiteBalanceInfo_1.nbgain) + 256);
  524. };
  525. }
  526. else
  527. {
  528. MessageBox.Show(LResource.FailtoReadLocalDB);
  529. return;
  530. }
  531. }
  532. else
  533. {
  534. MessageBox.Show(LResource.LocalDBIncomplete);
  535. return;
  536. }
  537. }
  538. else
  539. {
  540. MessageBox.Show(LResource.NofoundLocalDB);
  541. return;
  542. }
  543. }
  544. else
  545. {
  546. midList1 = new MidList()
  547. {
  548. keytype = new Dictionary<string, string>(),
  549. projectid = Custom_ProjectID,
  550. host = "LocalPC"
  551. };
  552. }
  553. OperationPanel operationPanel1 = new OperationPanel(this, LocalDB, ErrorDB, null, functionSetting1, WriteCheck1, ReadCheck1, WriteDone1, Preload.Checked, midList1, OrderText.Text.Trim());
  554. operationPanel1.StartPosition = FormStartPosition.Manual;
  555. if ((this.Right + operationPanel1.Size.Width * formlocationmsg.Count) > Screen.PrimaryScreen.Bounds.Width && LocationMark)
  556. {
  557. LocationMark = false;
  558. LocationNum = formlocationmsg.Count;
  559. }
  560. if (formlocationmsg.Count == 0)
  561. operationPanel1.Location = (Point)new Size(this.Right, this.Top);
  562. else if ((this.Right + operationPanel1.Size.Width * formlocationmsg.Count) > Screen.PrimaryScreen.Bounds.Width)
  563. {
  564. Point point = ((Dictionary<IntPtr, Point>)formlocationmsg[formlocationmsg.Count - 1]).Last().Value;
  565. operationPanel1.Location = (Point)new Size(this.Right + operationPanel1.Size.Width * (formlocationmsg.Count - LocationNum), this.Top + operationPanel1.Size.Height);
  566. }
  567. else
  568. {
  569. Point point = ((Dictionary<IntPtr, Point>)formlocationmsg[formlocationmsg.Count - 1]).Last().Value;
  570. operationPanel1.Location = (Point)new Size(this.Right + operationPanel1.Size.Width * formlocationmsg.Count, this.Top);
  571. }
  572. operationPanel1.DeleteIntptr += new OperationPanel.DisplayUpdateDelegate(DeleteIntptr);
  573. operationPanel1.SNKeyDownEven += new OperationPanel.SNKeyDown(SNKeyDownEven);
  574. operationPanel1.AutoKeyRequire += new OperationPanel.AutoKeyRequireDelegate(AutoKeyRequire);
  575. IntPtr intPtr = operationPanel1.Handle;
  576. Dictionary<IntPtr, Point> part1 = new Dictionary<IntPtr, Point>();
  577. part1.Add(intPtr, (Point)new Size(operationPanel1.Right, operationPanel1.Top));
  578. formlocationmsg.Add(part1);
  579. operationPanel1.Show();
  580. }
  581. catch
  582. {
  583. //
  584. }
  585. }
  586. OrderSubmit.Text = LResource.submitbutton;
  587. #if DEBUG
  588. #else
  589. LockSettingFunction(false);
  590. #endif
  591. if (!LocalWrite)
  592. {
  593. if (!uploadbackground.IsAlive)
  594. if (!Preload.Checked || LocalDB != null)
  595. uploadbackground.Start();
  596. }
  597. }
  598. /// <summary>
  599. /// 加载配置
  600. /// </summary>
  601. public void LoadJsonConfig()
  602. {
  603. StreamReader file = File.OpenText(LocalPath.localpath + "\\Config.json");
  604. using (JsonTextReader reader = new JsonTextReader(file))
  605. {
  606. JObject jObject = (JObject)JToken.ReadFrom(reader);
  607. reader.Close();
  608. var COM = jObject["COM"].Value<string>();
  609. var Baudrate = jObject["Baudrate"].Value<string>();
  610. var WriteChannelConfig = jObject["WriteChannel"].Value<string>();
  611. var ChannelSelect = jObject["ChannelSelect"].Value<string>();
  612. var WriteOSDLanguageConfig = jObject["WriteOSDLanguage"].Value<string>();
  613. var OSDLanguageSelect = jObject["OSDLanguageSelect"].Value<string>();
  614. var WriteSHOPLanguageConfig = jObject["WriteSHOPLanguage"].Value<string>();
  615. var SHOPLanguageSelect = jObject["SHOPLanguageSelect"].Value<string>();
  616. var WriteWhiteBalanceConfig = jObject["WriteWhiteBalance"].Value<string>();
  617. var WhiteBalanceInitConfig = jObject["WhiteBalanceInit"].Value<string>();
  618. var WhiteBalancePath = jObject["WhiteBalancePath"].Value<string>();
  619. var LastOrder = jObject["LastOrder"].Value<string>();
  620. var Preloadmode = jObject["Preload"].Value<string>();
  621. var UsingLocalPID = jObject["UsingLocalPID"].Value<string>();
  622. Custom_ProjectID = jObject["Custom_ProjectID"].Value<string>();
  623. functionSetting1.Wait_after_completion = jObject["Wait_after_completion"].Value<int>();
  624. functionSetting1.EnterFactoryRetry = jObject["EnterFactoryRetry"].Value<int>();
  625. functionSetting1.AllowNoScanning = jObject["AllowNoScanning"].Value<bool>();
  626. functionSetting1.ReportTimeOut = jObject["ReportTimeOut"].Value<int>();
  627. //本地离线抄写时key长度设置获取
  628. functionSetting1.LocalDidSize = jObject["LocalSize"]["DID"].Value<int>();
  629. functionSetting1.LocalMacSize = jObject["LocalSize"]["MAC"].Value<int>();
  630. functionSetting1.LocalHdcpSize = jObject["LocalSize"]["HDCP"].Value<int>();
  631. functionSetting1.LocalWidiSize = jObject["LocalSize"]["WIDI"].Value<int>();
  632. functionSetting1.LocalHdcp22Size = jObject["LocalSize"]["HDCP22"].Value<int>();
  633. functionSetting1.LocalEsnSize = jObject["LocalSize"]["ESN"].Value<int>();
  634. functionSetting1.LocalWidevineSize = jObject["LocalSize"]["WIDEVINE"].Value<int>();
  635. functionSetting1.LocalCiSize = jObject["LocalSize"]["CI"].Value<int>();
  636. functionSetting1.LocalMGKSize = jObject["LocalSize"]["MGK"].Value<int>();
  637. functionSetting1.LocalFairplaySize = jObject["LocalSize"]["Fairplay"] == null ? (CommonMethod.InsertJsonConfig("LocalSize", "Fairplay") ? -1 : 0) : jObject["LocalSize"]["Fairplay"].Value<int>();
  638. functionSetting1.LocalECPSize = jObject["LocalSize"]["ECP"] == null ? (CommonMethod.InsertJsonConfig("LocalSize", "ECP") ? -1 : 0) : jObject["LocalSize"]["ECP"].Value<int>();
  639. functionSetting1.LocalWifiMacSize = jObject["LocalSize"]["WifiMac"] == null ? (CommonMethod.InsertJsonConfig("LocalSize", "WifiMac") ? -1 : 0) : jObject["LocalSize"]["WifiMac"].Value<int>();
  640. functionSetting1.LocalBTMacSize = jObject["LocalSize"]["BTMac"] == null ? (CommonMethod.InsertJsonConfig("LocalSize", "BTMac") ? -1 : 0) : jObject["LocalSize"]["BTMac"].Value<int>();
  641. //本地DB离线抄写时是否不允许重复抄写
  642. functionSetting1.NoDoublewrite = jObject["NodoubleWrite"].Value<bool>();
  643. //条码限制
  644. functionSetting1.BarcodeLimit = jObject["BarcodeLimit"].Value<bool>();
  645. functionSetting1.BarcodeWrite = jObject["BarcodeWrite"] == null ? CommonMethod.AddJsonConfig("BarcodeWrite", false) : jObject["BarcodeWrite"].Value<bool>();
  646. functionSetting1.BarcodeLength = jObject["BarcodeLength"].Value<int>();
  647. functionSetting1.BarcodeKeyword = jObject["BarcodeKeyword"].Value<string>();
  648. //串口延迟
  649. functionSetting1.SerailDelay = jObject["SerailDelay"].Value<int>();
  650. SerialCMD.SerialTimeout = jObject["SerialTimeout"].Value<int>();
  651. // G客户防呆措施;
  652. functionSetting1.UsingGFoolProofing = jObject["UsingGFoolProofing"] == null ? false : jObject["UsingGFoolProofing"].Value<bool>();
  653. functionSetting1.GFoolProofingCount = jObject["GFoolProofingCount"] == null ? 2 : jObject["GFoolProofingCount"].Value<int>();
  654. // 导出日规acas与sn;
  655. functionSetting1.ExportSNACASID = jObject["ExportSNACASID"] == null ? false : jObject["ExportSNACASID"].Value<bool>();
  656. foreach (var ss in jObject["Channel"]) //遍历Channel
  657. {
  658. Dictionary<string, string> ChannelValues = JsonConvert.DeserializeObject<Dictionary<string, string>>(ss.ToString());
  659. foreach (string key in ChannelValues.Keys)
  660. {
  661. ChannelMapList.Add(key, ChannelValues[key]);
  662. ChannelList.Items.Add(key);
  663. }
  664. }
  665. foreach (var ss in jObject["Language"]) //遍历Language
  666. {
  667. Dictionary<string, string> LanguageValues = JsonConvert.DeserializeObject<Dictionary<string, string>>(ss.ToString());
  668. foreach (string key in LanguageValues.Keys)
  669. {
  670. OSDList.Items.Add(key);
  671. SHOPList.Items.Add(key);
  672. LanguageMapList.Add(key, LanguageValues[key]);
  673. }
  674. }
  675. foreach (var ss in jObject["CustomCMD"]) //遍历自定义命令表
  676. {
  677. functionSetting1.CustomCMD = JsonConvert.DeserializeObject<Dictionary<string, string>>(ss.ToString());
  678. }
  679. //ReadCheck配置读取
  680. ReadCheck1.PIDReadcheck = jObject["ReadCheck"]["PID"].Value<bool>();
  681. ReadCheck1.OSDReadcheck = jObject["ReadCheck"]["OSD"].Value<bool>();
  682. ReadCheck1.SHOPReadcheck = jObject["ReadCheck"]["SHOP"].Value<bool>();
  683. ReadCheck1.DIDReadcheck = jObject["ReadCheck"]["DID"].Value<bool>();
  684. ReadCheck1.MacReadcheck = jObject["ReadCheck"]["MAC"].Value<bool>();
  685. ReadCheck1.HDCPReadcheck = jObject["ReadCheck"]["HDCP"].Value<bool>();
  686. ReadCheck1.HDCP22Readcheck = jObject["ReadCheck"]["HDCP22"].Value<bool>();
  687. ReadCheck1.WiDiReadcheck = jObject["ReadCheck"]["WIDI"].Value<bool>();
  688. ReadCheck1.WidevineReadcheck = jObject["ReadCheck"]["WIDEVINE"].Value<bool>();
  689. ReadCheck1.ESNReadcheck = jObject["ReadCheck"]["ESN"].Value<bool>();
  690. ReadCheck1.CI_plusReadcheck = jObject["ReadCheck"]["CI"].Value<bool>();
  691. ReadCheck1.AttestationReadcheck = jObject["ReadCheck"]["Attestation"].Value<bool>();
  692. ReadCheck1.MGKReadcheck = jObject["ReadCheck"]["MGK"].Value<bool>();
  693. ReadCheck1.FairplayReadcheck = jObject["ReadCheck"]["Fairplay"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "Fairplay") : jObject["ReadCheck"]["Fairplay"].Value<bool>();
  694. ReadCheck1.ECPReadcheck = jObject["ReadCheck"]["ECP"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "ECP") : jObject["ReadCheck"]["ECP"].Value<bool>();
  695. ReadCheck1.WifiMacReadcheck = jObject["ReadCheck"]["WifiMac"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "WifiMac") : jObject["ReadCheck"]["WifiMac"].Value<bool>();
  696. ReadCheck1.BTMacReadcheck = jObject["ReadCheck"]["BTMac"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "BTMac") : jObject["ReadCheck"]["BTMac"].Value<bool>();
  697. ReadCheck1.LEKReadcheck = jObject["ReadCheck"]["LEK"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "LEK") : jObject["ReadCheck"]["LEK"].Value<bool>();
  698. ReadCheck1.PEKReadcheck = jObject["ReadCheck"]["PEK"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "PEK") : jObject["ReadCheck"]["PEK"].Value<bool>();
  699. ReadCheck1.PlayreadyReadcheck = jObject["ReadCheck"]["Playready"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "Playready") : jObject["ReadCheck"]["Playready"].Value<bool>();
  700. ReadCheck1.HashReadcheck = jObject["ReadCheck"]["Hash"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "Hash") : jObject["ReadCheck"]["Hash"].Value<bool>();
  701. ReadCheck1.DSNReadcheck = jObject["ReadCheck"]["DSN"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "DSN") : jObject["ReadCheck"]["DSN"].Value<bool>();
  702. ReadCheck1.YouTubeReadcheck = jObject["ReadCheck"]["YouTube"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "YouTube") : jObject["ReadCheck"]["YouTube"].Value<bool>();
  703. ReadCheck1.EDIDPIDReadcheck = jObject["ReadCheck"]["EDIDPID"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "EDIDPID") : jObject["ReadCheck"]["EDIDPID"].Value<bool>();
  704. ReadCheck1.EDIDModeNameReadcheck = jObject["ReadCheck"]["EDIDModeName"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "EDIDModeName") : jObject["ReadCheck"]["EDIDModeName"].Value<bool>();
  705. ReadCheck1.ACASKeyReadcheck = jObject["ReadCheck"]["ACASKey"] == null ? CommonMethod.InsertJsonConfig("ReadCheck", "ACASKey") : jObject["ReadCheck"]["ACASKey"].Value<bool>();
  706. //WriteCheck配置读取
  707. WriteCheck1.DIDCheckcheck = jObject["WriteCheck"]["DID"].Value<bool>();
  708. WriteCheck1.MacCheckcheck = jObject["WriteCheck"]["MAC"].Value<bool>();
  709. WriteCheck1.HDCPCheckcheck = jObject["WriteCheck"]["HDCP"].Value<bool>();
  710. WriteCheck1.HDCP22Checkcheck = jObject["WriteCheck"]["HDCP22"].Value<bool>();
  711. WriteCheck1.WiDiCheckcheck = jObject["WriteCheck"]["WIDI"].Value<bool>();
  712. WriteCheck1.WidevineCheckcheck = jObject["WriteCheck"]["WIDEVINE"].Value<bool>();
  713. WriteCheck1.ESNCheckcheck = jObject["WriteCheck"]["ESN"].Value<bool>();
  714. WriteCheck1.CI_plusCheckcheck = jObject["WriteCheck"]["CI"].Value<bool>();
  715. WriteCheck1.AttestationCheckcheck = jObject["WriteCheck"]["Attestation"].Value<bool>();
  716. WriteCheck1.MGKCheckcheck = jObject["WriteCheck"]["MGK"].Value<bool>();
  717. WriteCheck1.FairplayCheckcheck = jObject["WriteCheck"]["Fairplay"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "Fairplay") : jObject["WriteCheck"]["Fairplay"].Value<bool>();
  718. WriteCheck1.ECPCheckcheck = jObject["WriteCheck"]["ECP"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "ECP") : jObject["WriteCheck"]["ECP"].Value<bool>();
  719. WriteCheck1.WifiMacCheckcheck = jObject["WriteCheck"]["WifiMac"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "WifiMac") : jObject["WriteCheck"]["WifiMac"].Value<bool>();
  720. WriteCheck1.BTMacCheckcheck = jObject["WriteCheck"]["BTMac"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "BTMac") : jObject["WriteCheck"]["BTMac"].Value<bool>();
  721. WriteCheck1.LEKCheckcheck = jObject["WriteCheck"]["LEK"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "LEK") : jObject["WriteCheck"]["LEK"].Value<bool>();
  722. WriteCheck1.PEKCheckcheck = jObject["WriteCheck"]["PEK"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "PEK") : jObject["WriteCheck"]["PEK"].Value<bool>();
  723. WriteCheck1.PlayreadyCheckcheck = jObject["WriteCheck"]["Playready"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "Playready") : jObject["WriteCheck"]["Playready"].Value<bool>();
  724. WriteCheck1.HashCheckcheck = jObject["WriteCheck"]["Hash"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "Hash") : jObject["WriteCheck"]["Hash"].Value<bool>();
  725. WriteCheck1.DSNCheckcheck = jObject["WriteCheck"]["DSN"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "DSN") : jObject["WriteCheck"]["DSN"].Value<bool>();
  726. WriteCheck1.YouTubeCheckcheck = jObject["WriteCheck"]["YouTube"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "YouTube") : jObject["WriteCheck"]["YouTube"].Value<bool>();
  727. WriteCheck1.ACASKeyCheckcheck = jObject["WriteCheck"]["ACASKey"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "ACASKey") : jObject["WriteCheck"]["ACASKey"].Value<bool>();
  728. //WriteDone配置读取
  729. WriteDone1.PIDWrite_YesNo = jObject["WriteDone"]["PID"].Value<bool>();
  730. WriteDone1.PIDWriteDelay = jObject["WriteDone"]["PIDWirteDelay"].Value<int>();
  731. WriteDone1.ClientTypeCheck_YesNo = jObject["WriteDone"]["ClientType"].Value<bool>();
  732. WriteDone1.SoftwareVersionCheck_YesNo = jObject["WriteDone"]["SoftwareVersion"].Value<bool>();
  733. WriteDone1.DIDWrite_YesNo = jObject["WriteDone"]["DID"].Value<bool>();
  734. WriteDone1.MacWrite_YesNo = jObject["WriteDone"]["MAC"].Value<bool>();
  735. WriteDone1.HDCPWrite_YesNo = jObject["WriteDone"]["HDCP"].Value<bool>();
  736. WriteDone1.HDCP22Write_YesNo = jObject["WriteDone"]["HDCP22"].Value<bool>();
  737. WriteDone1.WiDiWrite_YesNo = jObject["WriteDone"]["WIDI"].Value<bool>();
  738. WriteDone1.WidevineWrite_YesNo = jObject["WriteDone"]["WIDEVINE"].Value<bool>();
  739. WriteDone1.ESNWrite_YesNo = jObject["WriteDone"]["ESN"].Value<bool>();
  740. WriteDone1.CI_plusWrite_YesNo = jObject["WriteDone"]["CI"].Value<bool>();
  741. WriteDone1.AttestationWrite_YesNo = jObject["WriteDone"]["Attestation"].Value<bool>();
  742. WriteDone1.MGKWrite_YesNo = jObject["WriteDone"]["MGK"].Value<bool>();
  743. WriteDone1.FairplayWrite_YesNo = jObject["WriteDone"]["Fairplay"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "Fairplay") : jObject["WriteDone"]["Fairplay"].Value<bool>();
  744. WriteDone1.ECPWrite_YesNo = jObject["WriteDone"]["ECP"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "ECP") : jObject["WriteDone"]["ECP"].Value<bool>();
  745. WriteDone1.WifiMacWrite_YesNo = jObject["WriteDone"]["WifiMac"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "WifiMac") : jObject["WriteDone"]["WifiMac"].Value<bool>();
  746. WriteDone1.BTMacWrite_YesNo = jObject["WriteDone"]["BTMac"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "BTMac") : jObject["WriteDone"]["BTMac"].Value<bool>();
  747. WriteDone1.LEKWrite_YesNo = jObject["WriteDone"]["LEK"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "LEK") : jObject["WriteDone"]["LEK"].Value<bool>();
  748. WriteDone1.PEKWrite_YesNo = jObject["WriteDone"]["PEK"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "PEK") : jObject["WriteDone"]["PEK"].Value<bool>();
  749. WriteDone1.PlayreadyWrite_YesNo = jObject["WriteDone"]["Playready"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "Playready") : jObject["WriteDone"]["Playready"].Value<bool>();
  750. WriteDone1.HashWrite_YesNo = jObject["WriteDone"]["Hash"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "Hash") : jObject["WriteDone"]["Hash"].Value<bool>();
  751. WriteDone1.DSNWrite_YesNo = jObject["WriteDone"]["DSN"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "DSN") : jObject["WriteDone"]["DSN"].Value<bool>();
  752. WriteDone1.AutoWhiteBalance = jObject["WriteDone"]["AutoWhiteBalance"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "AutoWhiteBalance") : jObject["WriteDone"]["AutoWhiteBalance"].Value<bool>();
  753. WriteDone1.YouTubeWrite_YesNo = jObject["WriteDone"]["YouTube"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "YouTube") : jObject["WriteDone"]["YouTube"].Value<bool>();
  754. WriteDone1.EDIDPIDWrite_YesNo = jObject["WriteDone"]["EDIDPID"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "EDIDPID") : jObject["WriteDone"]["EDIDPID"].Value<bool>();
  755. WriteDone1.EDIDModeNameWrite_YesNo = jObject["WriteDone"]["EDIDModeName"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "EDIDModeName") : jObject["WriteDone"]["EDIDModeName"].Value<bool>();
  756. WriteDone1.ACASKeyWrite_YesNo = jObject["WriteDone"]["ACASKey"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "ACASKey") : jObject["WriteDone"]["ACASKey"].Value<bool>();
  757. file.Close();
  758. if (Custom_ProjectID != null)
  759. if (Custom_ProjectID.Trim().Length > 0)
  760. PID_Num.Value = Convert.ToDecimal(Custom_ProjectID);
  761. if (TVCOM.Items.Contains(COM))
  762. TVCOM.SelectedItem = COM;
  763. if (TVBaud.Items.Contains(Baudrate))
  764. TVBaud.SelectedItem = Baudrate;
  765. if (ChannelList.Items.Contains(ChannelSelect))
  766. {
  767. ChannelList.SelectedItem = ChannelSelect;
  768. functionSetting1.ChannelCode = SerialInit.HexToByte(ChannelMapList[ChannelSelect]);
  769. }
  770. if (OSDList.Items.Contains(OSDLanguageSelect))
  771. {
  772. OSDList.SelectedItem = OSDLanguageSelect;
  773. functionSetting1.OSDLCode = SerialInit.HexToByte(LanguageMapList[OSDLanguageSelect]);
  774. }
  775. if (SHOPList.Items.Contains(SHOPLanguageSelect))
  776. {
  777. SHOPList.SelectedItem = SHOPLanguageSelect;
  778. functionSetting1.ShopLCode = SerialInit.HexToByte(LanguageMapList[SHOPLanguageSelect]);
  779. }
  780. BarcodeLimit.Checked = functionSetting1.BarcodeLimit;
  781. BarcodeWrite.Checked = functionSetting1.BarcodeWrite;
  782. BarCodeKeyCodeText.Text = functionSetting1.BarcodeKeyword;
  783. BarCodeLengthText.Value = functionSetting1.BarcodeLength;
  784. Preload.Checked = Preloadmode == "True";
  785. WriteChannel.Checked = WriteChannelConfig == "True";
  786. WriteOSD.Checked = WriteOSDLanguageConfig == "True";
  787. WriteSHOP.Checked = WriteSHOPLanguageConfig == "True";
  788. WBInit.Checked = WhiteBalanceInitConfig == "True";
  789. UsinglocalIDCheck.Checked = UsingLocalPID == "True";
  790. OrderText.Text = LastOrder;
  791. if (File.Exists(WhiteBalancePath))
  792. {
  793. if (!LoadWBConfig(WhiteBalancePath))
  794. {
  795. MessageBox.Show(LResource.ReadWBError);
  796. WriteWB.Checked = false;
  797. }
  798. else
  799. {
  800. WBPath.Text = WhiteBalancePath;
  801. WriteWB.Checked = WriteWhiteBalanceConfig == "True";
  802. }
  803. }
  804. else
  805. WriteWB.Checked = false;
  806. }
  807. }
  808. /// <summary>
  809. /// 加载本地白平衡配置
  810. /// </summary>
  811. /// <param name="filepath"></param>
  812. /// <returns></returns>
  813. public bool LoadWBConfig(string filepath)
  814. {
  815. try
  816. {
  817. functionSetting1.NormalRGB = new byte[3];
  818. functionSetting1.CoolRGB = new byte[3];
  819. functionSetting1.WarmRGB = new byte[3];
  820. functionSetting1.NormalRGB[0] = (byte)Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "HDMI white R:", null, filepath));
  821. functionSetting1.NormalRGB[1] = (byte)Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "HDMI white G:", null, filepath));
  822. functionSetting1.NormalRGB[2] = (byte)Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "HDMI white B:", null, filepath));
  823. functionSetting1.CoolRGB[0] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Cool white R:", null, filepath)) + 256);
  824. functionSetting1.CoolRGB[1] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Cool white G:", null, filepath)) + 256);
  825. functionSetting1.CoolRGB[2] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Cool white B:", null, filepath)) + 256);
  826. functionSetting1.WarmRGB[0] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Warm white R:", null, filepath)) + 256);
  827. functionSetting1.WarmRGB[1] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Warm white G:", null, filepath)) + 256);
  828. functionSetting1.WarmRGB[2] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Warm white B:", null, filepath)) + 256);
  829. return true;
  830. }
  831. catch (Exception ex)
  832. {
  833. MessageBox.Show(ex.Message);
  834. return false;
  835. }
  836. }
  837. private void ChannelList_SelectedIndexChanged(object sender, EventArgs e)
  838. {
  839. string ChannelSelect = ChannelList.SelectedItem.ToString();
  840. string channelcode = ChannelMapList[ChannelSelect];
  841. functionSetting1.ChannelCode = SerialInit.HexToByte(channelcode);
  842. SaveJsonConfig("ChannelSelect", ChannelSelect);
  843. Log.WriteInfoLog("\r\nSet channel setting to " + ChannelSelect + "\r\nchannel code is " + channelcode);
  844. }
  845. private void OSDList_SelectedIndexChanged(object sender, EventArgs e)
  846. {
  847. string OSDLanguageSelect = OSDList.SelectedItem.ToString();
  848. string OSDLcode = LanguageMapList[OSDLanguageSelect];
  849. functionSetting1.OSDLCode = SerialInit.HexToByte(OSDLcode);
  850. SaveJsonConfig("OSDLanguageSelect", OSDLanguageSelect);
  851. Log.WriteInfoLog("\r\nSet channel setting to " + OSDLanguageSelect + "\r\nchannel code is " + OSDLcode);
  852. }
  853. private void SHOPList_SelectedIndexChanged(object sender, EventArgs e)
  854. {
  855. string SHOPLanguageSelect = SHOPList.SelectedItem.ToString();
  856. string SHOPLcode = LanguageMapList[SHOPLanguageSelect];
  857. functionSetting1.ShopLCode = SerialInit.HexToByte(SHOPLcode);
  858. SaveJsonConfig("SHOPLanguageSelect", SHOPLanguageSelect);
  859. Log.WriteInfoLog("\r\nSet channel setting to " + SHOPLanguageSelect + "\r\nchannel code is " + SHOPLcode);
  860. }
  861. private void skinButton1_Click(object sender, EventArgs e)
  862. {
  863. SaveJsonConfig("COM", "COM3");
  864. string strFileName = null;
  865. openFileDialog1.Filter = "WBConfig file|*.wba";
  866. openFileDialog1.FileName = "";
  867. openFileDialog1.Title = "Please select the WB config file";
  868. if (openFileDialog1.ShowDialog() == DialogResult.OK)
  869. {
  870. strFileName = System.IO.Path.GetFullPath(openFileDialog1.FileName);
  871. WBPath.Text = strFileName;
  872. if (LoadWBConfig(strFileName))
  873. {
  874. functionSetting1.WBFileName = Path.GetFileName(openFileDialog1.FileName);
  875. SaveJsonConfig("WhiteBalancePath", strFileName);
  876. MessageBox.Show(LResource.LoadWBsuccess);
  877. }
  878. }
  879. }
  880. private void WriteWB_CheckedChanged(object sender, EventArgs e)
  881. {
  882. if (WriteWB.Checked == true)
  883. {
  884. if (WBPath.Text.Trim().Length > 0)
  885. {
  886. LoadWBConfig(WBPath.Text.Trim());
  887. SaveJsonConfig("WriteWhiteBalance", true);
  888. }
  889. else
  890. {
  891. MessageBox.Show(LResource.SelectWBfirst);
  892. WriteWB.Checked = false;
  893. }
  894. }
  895. else
  896. {
  897. SaveJsonConfig("WriteWhiteBalance", false);
  898. }
  899. }
  900. public void SaveJsonConfig(string node, object value)
  901. {
  902. StreamReader file = File.OpenText(LocalPath.localpath + "\\Config.json");
  903. using (JsonTextReader reader = new JsonTextReader(file))
  904. {
  905. JObject jObject = (JObject)JToken.ReadFrom(reader);
  906. jObject[node] = value.ToString();
  907. file.Close();
  908. using (StreamWriter writer = new StreamWriter(LocalPath.localpath + "\\Config.json"))
  909. {
  910. writer.Write(jObject.ToString()); //将JToken.ReadFrom(reader)的数据写入文件,这样的数据有空行。
  911. }
  912. }
  913. }
  914. private void WBInit_CheckedChanged(object sender, EventArgs e)
  915. {
  916. if (WBInit.Checked)
  917. {
  918. SaveJsonConfig("WhiteBalanceInit", true);
  919. }
  920. else
  921. SaveJsonConfig("WhiteBalanceInit", false);
  922. }
  923. private void WriteChannel_CheckedChanged(object sender, EventArgs e)
  924. {
  925. if (WriteChannel.Checked)
  926. {
  927. SaveJsonConfig("WriteChannel", true);
  928. }
  929. else
  930. SaveJsonConfig("WriteChannel", false);
  931. }
  932. private void WriteOSD_CheckedChanged(object sender, EventArgs e)
  933. {
  934. if (WriteOSD.Checked)
  935. {
  936. SaveJsonConfig("WriteOSDLanguage", true);
  937. }
  938. else
  939. SaveJsonConfig("WriteOSDLanguage", false);
  940. }
  941. private void WriteSHOP_CheckedChanged(object sender, EventArgs e)
  942. {
  943. if (WriteSHOP.Checked)
  944. {
  945. SaveJsonConfig("WriteSHOPLanguage", true);
  946. }
  947. else
  948. SaveJsonConfig("WriteSHOPLanguage", false);
  949. }
  950. private void TVCOM_SelectedIndexChanged(object sender, EventArgs e)
  951. {
  952. SaveJsonConfig("COM", TVCOM.SelectedItem.ToString());
  953. }
  954. private void TVBaud_SelectedIndexChanged(object sender, EventArgs e)
  955. {
  956. SaveJsonConfig("Baudrate", TVBaud.SelectedItem.ToString());
  957. }
  958. private void Form1_FormClosed(object sender, FormClosedEventArgs e)
  959. {
  960. Environment.Exit(0);
  961. }
  962. public void LockSettingFunction(bool locksetting)
  963. {
  964. ChannelList.Enabled = locksetting;
  965. WriteOSD.Enabled = locksetting;
  966. WriteSHOP.Enabled = locksetting;
  967. WriteChannel.Enabled = locksetting;
  968. OSDList.Enabled = locksetting;
  969. SHOPList.Enabled = locksetting;
  970. skinButton1.Enabled = locksetting;
  971. WriteOSD.Enabled = locksetting;
  972. WBInit.Enabled = locksetting;
  973. WriteWB.Enabled = locksetting;
  974. OrderText.Enabled = locksetting;
  975. Preload.Enabled = locksetting;
  976. PID_Num.Enabled = locksetting;
  977. BarcodeLimit.Enabled = locksetting;
  978. BarCodeLengthText.Enabled = locksetting;
  979. BarCodeKeyCodeText.Enabled = locksetting;
  980. }
  981. private void TVCOM_MouseClick(object sender, MouseEventArgs e)
  982. {
  983. TVCOM.Items.Clear();
  984. TVCOM.Items.AddRange(SerialPort.GetPortNames());
  985. }
  986. private void CreateKeyManually_Click(object sender, EventArgs e)
  987. {
  988. CreateDBManually CreateDBManually1 = new CreateDBManually(TestMode.serverurl, ErrorDB);
  989. CreateDBManually1.ShowDialog();
  990. }
  991. private void Preload_CheckedChanged(object sender, EventArgs e)
  992. {
  993. SaveJsonConfig("Preload", Preload.Checked.ToString());
  994. }
  995. private void Form1_Move(object sender, EventArgs e)
  996. {
  997. if (this.MoveEvent != null)
  998. {
  999. Point XY = this.Location;
  1000. XY.X = this.Right;
  1001. XY.Y = this.Top;
  1002. this.MoveEvent(XY, formlocationmsg, LocationNum);
  1003. }
  1004. }
  1005. private void DeleteIntptr(IntPtr intPtr)
  1006. {
  1007. foreach (Dictionary<IntPtr, Point> pairs in formlocationmsg)
  1008. {
  1009. if (pairs.ContainsKey(intPtr))
  1010. {
  1011. formlocationmsg.Remove(pairs);
  1012. if (this.MoveEvent != null)
  1013. {
  1014. Point XY = this.Location;
  1015. XY.X = this.Right;
  1016. XY.Y = this.Top;
  1017. this.MoveEvent(XY, formlocationmsg, LocationNum);
  1018. }
  1019. break;
  1020. }
  1021. }
  1022. }
  1023. private void AutoKeyRequire(IntPtr intPtr, string key, string keytype)
  1024. {
  1025. Task.Run(() =>
  1026. {
  1027. var a = ((Dictionary<IntPtr, Point>)formlocationmsg[0]).First();
  1028. if (a.Key == intPtr)
  1029. {
  1030. ;//start autokey require
  1031. if (CommonMethod.AutoGetKeyStatus(midList1.host, key, keytype, ErrorDB))
  1032. {
  1033. CommonMethod.AutoGetKey(midList1.host, OrderText.Text.Trim(), key, keytype, ErrorDB);
  1034. }
  1035. }
  1036. });
  1037. }
  1038. private void SNKeyDownEven(IntPtr intPtr)
  1039. {
  1040. this.KeyDownEvent(formlocationmsg, intPtr);
  1041. }
  1042. private void timer1_Tick(object sender, EventArgs e)
  1043. {
  1044. string count = SQLiteHelper.GetProductionNum(ErrorDB, OrderText.Text.Trim());
  1045. UpdateCountLabel(ProductionNum_Text, count);
  1046. }
  1047. /// <summary>
  1048. /// 刷新订单数量
  1049. /// </summary>
  1050. /// <param name="label"></param>
  1051. /// <param name="str"></param>
  1052. public void UpdateCountLabel(Label label, string str)
  1053. {
  1054. if (label.InvokeRequired)
  1055. {
  1056. BeginInvoke(new Action<string>(x => { label.Text = x.ToString(); }), str);
  1057. }
  1058. else
  1059. {
  1060. label.Text = str;
  1061. }
  1062. }
  1063. /// <summary>
  1064. /// 后台上报
  1065. /// </summary>
  1066. public void UploadBackGround()
  1067. {
  1068. while (true)
  1069. {
  1070. if (CommonMethod.HTTPChecker(StructList.CheckServerConnectionUrl))
  1071. {
  1072. try
  1073. {
  1074. string url;
  1075. string content;
  1076. string id;
  1077. if (SQLiteHelper.GetDelayReportData(ErrorDB, out url, out content, out id))
  1078. if (content.Contains("@"))
  1079. {
  1080. string[] data = content.Split('@');
  1081. if (CommonMethod.UploadPreloadCopyResult(url, data[1], data[0], LocalDB, ErrorDB, true, id, 30000))
  1082. {
  1083. SQLiteHelper.UpdateReportData(ErrorDB, "CopyDelayReport", "ID", id);
  1084. }
  1085. }
  1086. else
  1087. if (CommonMethod.UploadCopyResult(content, url, ErrorDB, OrderText.Text.Trim(), true, id, functionSetting1.ReportTimeOut))
  1088. {
  1089. SQLiteHelper.UpdateReportData(ErrorDB, "CopyDelayReport", "ID", id);
  1090. }
  1091. }
  1092. catch (Exception ex)
  1093. {
  1094. Log.WriteErrorLog(ex.Message);
  1095. }
  1096. try
  1097. {
  1098. string url;
  1099. string content;
  1100. string id;
  1101. if (SQLiteHelper.GetErrorReportData(ErrorDB, out url, out content, out id))
  1102. {
  1103. CommonMethod.ReportErrormsg2(url, content, out bool mark);
  1104. if (mark)
  1105. {
  1106. SQLiteHelper.UpdateReportData(ErrorDB, "ErrorReport", "ID", id);
  1107. }
  1108. }
  1109. }
  1110. catch (Exception ex)
  1111. {
  1112. Log.WriteErrorLog(ex.Message);
  1113. }
  1114. Thread.Sleep(5000);
  1115. }
  1116. else
  1117. Thread.Sleep(20000);
  1118. }
  1119. }
  1120. private void PID_Num_ValueChanged(object sender, EventArgs e)
  1121. {
  1122. Custom_ProjectID = PID_Num.Value.ToString();
  1123. SaveJsonConfig("Custom_ProjectID", Custom_ProjectID);
  1124. }
  1125. private void BarCodeLengthText_ValueChanged(object sender, EventArgs e)
  1126. {
  1127. functionSetting1.BarcodeLength = Convert.ToInt32(BarCodeLengthText.Value);
  1128. SaveJsonConfig("BarcodeLength", functionSetting1.BarcodeLength);
  1129. }
  1130. private void BarcodeLimit_CheckedChanged(object sender, EventArgs e)
  1131. {
  1132. functionSetting1.BarcodeLimit = BarcodeLimit.Checked;
  1133. SaveJsonConfig("BarcodeLimit", BarcodeLimit.Checked);
  1134. }
  1135. private void BarCodeKeyCodeText_TextChanged(object sender, EventArgs e)
  1136. {
  1137. functionSetting1.BarcodeKeyword = BarCodeKeyCodeText.Text;
  1138. SaveJsonConfig("BarcodeKeyword", BarCodeKeyCodeText.Text);
  1139. }
  1140. private void UsinglocalIDCheck_CheckedChanged(object sender, EventArgs e)
  1141. {
  1142. SaveJsonConfig("UsingLocalPID", UsinglocalIDCheck.Checked);
  1143. }
  1144. private void BarcodeWrite_CheckedChanged(object sender, EventArgs e)
  1145. {
  1146. functionSetting1.BarcodeWrite = BarcodeWrite.Checked;
  1147. SaveJsonConfig("BarcodeWrite", BarcodeWrite.Checked);
  1148. }
  1149. }
  1150. }