Main.cs 72 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222
  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. //WriteCheck配置读取
  704. WriteCheck1.DIDCheckcheck = jObject["WriteCheck"]["DID"].Value<bool>();
  705. WriteCheck1.MacCheckcheck = jObject["WriteCheck"]["MAC"].Value<bool>();
  706. WriteCheck1.HDCPCheckcheck = jObject["WriteCheck"]["HDCP"].Value<bool>();
  707. WriteCheck1.HDCP22Checkcheck = jObject["WriteCheck"]["HDCP22"].Value<bool>();
  708. WriteCheck1.WiDiCheckcheck = jObject["WriteCheck"]["WIDI"].Value<bool>();
  709. WriteCheck1.WidevineCheckcheck = jObject["WriteCheck"]["WIDEVINE"].Value<bool>();
  710. WriteCheck1.ESNCheckcheck = jObject["WriteCheck"]["ESN"].Value<bool>();
  711. WriteCheck1.CI_plusCheckcheck = jObject["WriteCheck"]["CI"].Value<bool>();
  712. WriteCheck1.AttestationCheckcheck = jObject["WriteCheck"]["Attestation"].Value<bool>();
  713. WriteCheck1.MGKCheckcheck = jObject["WriteCheck"]["MGK"].Value<bool>();
  714. WriteCheck1.FairplayCheckcheck = jObject["WriteCheck"]["Fairplay"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "Fairplay") : jObject["WriteCheck"]["Fairplay"].Value<bool>();
  715. WriteCheck1.ECPCheckcheck = jObject["WriteCheck"]["ECP"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "ECP") : jObject["WriteCheck"]["ECP"].Value<bool>();
  716. WriteCheck1.WifiMacCheckcheck = jObject["WriteCheck"]["WifiMac"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "WifiMac") : jObject["WriteCheck"]["WifiMac"].Value<bool>();
  717. WriteCheck1.BTMacCheckcheck = jObject["WriteCheck"]["BTMac"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "BTMac") : jObject["WriteCheck"]["BTMac"].Value<bool>();
  718. WriteCheck1.LEKCheckcheck = jObject["WriteCheck"]["LEK"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "LEK") : jObject["WriteCheck"]["LEK"].Value<bool>();
  719. WriteCheck1.PEKCheckcheck = jObject["WriteCheck"]["PEK"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "PEK") : jObject["WriteCheck"]["PEK"].Value<bool>();
  720. WriteCheck1.PlayreadyCheckcheck = jObject["WriteCheck"]["Playready"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "Playready") : jObject["WriteCheck"]["Playready"].Value<bool>();
  721. WriteCheck1.HashCheckcheck = jObject["WriteCheck"]["Hash"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "Hash") : jObject["WriteCheck"]["Hash"].Value<bool>();
  722. WriteCheck1.DSNCheckcheck = jObject["WriteCheck"]["DSN"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "DSN") : jObject["WriteCheck"]["DSN"].Value<bool>();
  723. WriteCheck1.YouTubeCheckcheck = jObject["WriteCheck"]["YouTube"] == null ? CommonMethod.InsertJsonConfig("WriteCheck", "YouTube") : jObject["WriteCheck"]["YouTube"].Value<bool>();
  724. //WriteDone配置读取
  725. WriteDone1.PIDWrite_YesNo = jObject["WriteDone"]["PID"].Value<bool>();
  726. WriteDone1.PIDWriteDelay = jObject["WriteDone"]["PIDWirteDelay"].Value<int>();
  727. WriteDone1.ClientTypeCheck_YesNo = jObject["WriteDone"]["ClientType"].Value<bool>();
  728. WriteDone1.SoftwareVersionCheck_YesNo = jObject["WriteDone"]["SoftwareVersion"].Value<bool>();
  729. WriteDone1.DIDWrite_YesNo = jObject["WriteDone"]["DID"].Value<bool>();
  730. WriteDone1.MacWrite_YesNo = jObject["WriteDone"]["MAC"].Value<bool>();
  731. WriteDone1.HDCPWrite_YesNo = jObject["WriteDone"]["HDCP"].Value<bool>();
  732. WriteDone1.HDCP22Write_YesNo = jObject["WriteDone"]["HDCP22"].Value<bool>();
  733. WriteDone1.WiDiWrite_YesNo = jObject["WriteDone"]["WIDI"].Value<bool>();
  734. WriteDone1.WidevineWrite_YesNo = jObject["WriteDone"]["WIDEVINE"].Value<bool>();
  735. WriteDone1.ESNWrite_YesNo = jObject["WriteDone"]["ESN"].Value<bool>();
  736. WriteDone1.CI_plusWrite_YesNo = jObject["WriteDone"]["CI"].Value<bool>();
  737. WriteDone1.AttestationWrite_YesNo = jObject["WriteDone"]["Attestation"].Value<bool>();
  738. WriteDone1.MGKWrite_YesNo = jObject["WriteDone"]["MGK"].Value<bool>();
  739. WriteDone1.FairplayWrite_YesNo = jObject["WriteDone"]["Fairplay"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "Fairplay") : jObject["WriteDone"]["Fairplay"].Value<bool>();
  740. WriteDone1.ECPWrite_YesNo = jObject["WriteDone"]["ECP"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "ECP") : jObject["WriteDone"]["ECP"].Value<bool>();
  741. WriteDone1.WifiMacWrite_YesNo = jObject["WriteDone"]["WifiMac"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "WifiMac") : jObject["WriteDone"]["WifiMac"].Value<bool>();
  742. WriteDone1.BTMacWrite_YesNo = jObject["WriteDone"]["BTMac"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "BTMac") : jObject["WriteDone"]["BTMac"].Value<bool>();
  743. WriteDone1.LEKWrite_YesNo = jObject["WriteDone"]["LEK"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "LEK") : jObject["WriteDone"]["LEK"].Value<bool>();
  744. WriteDone1.PEKWrite_YesNo = jObject["WriteDone"]["PEK"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "PEK") : jObject["WriteDone"]["PEK"].Value<bool>();
  745. WriteDone1.PlayreadyWrite_YesNo = jObject["WriteDone"]["Playready"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "Playready") : jObject["WriteDone"]["Playready"].Value<bool>();
  746. WriteDone1.HashWrite_YesNo = jObject["WriteDone"]["Hash"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "Hash") : jObject["WriteDone"]["Hash"].Value<bool>();
  747. WriteDone1.DSNWrite_YesNo = jObject["WriteDone"]["DSN"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "DSN") : jObject["WriteDone"]["DSN"].Value<bool>();
  748. WriteDone1.AutoWhiteBalance= jObject["WriteDone"]["AutoWhiteBalance"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "AutoWhiteBalance") : jObject["WriteDone"]["AutoWhiteBalance"].Value<bool>();
  749. WriteDone1.YouTubeWrite_YesNo = jObject["WriteDone"]["YouTube"] == null ? CommonMethod.InsertJsonConfig("WriteDone", "YouTube") : jObject["WriteDone"]["YouTube"].Value<bool>();
  750. file.Close();
  751. if (Custom_ProjectID != null)
  752. if (Custom_ProjectID.Trim().Length > 0)
  753. PID_Num.Value = Convert.ToDecimal(Custom_ProjectID);
  754. if (TVCOM.Items.Contains(COM))
  755. TVCOM.SelectedItem = COM;
  756. if (TVBaud.Items.Contains(Baudrate))
  757. TVBaud.SelectedItem = Baudrate;
  758. if (ChannelList.Items.Contains(ChannelSelect))
  759. {
  760. ChannelList.SelectedItem = ChannelSelect;
  761. functionSetting1.ChannelCode = SerialInit.HexToByte(ChannelMapList[ChannelSelect]);
  762. }
  763. if (OSDList.Items.Contains(OSDLanguageSelect))
  764. {
  765. OSDList.SelectedItem = OSDLanguageSelect;
  766. functionSetting1.OSDLCode = SerialInit.HexToByte(LanguageMapList[OSDLanguageSelect]);
  767. }
  768. if (SHOPList.Items.Contains(SHOPLanguageSelect))
  769. {
  770. SHOPList.SelectedItem = SHOPLanguageSelect;
  771. functionSetting1.ShopLCode = SerialInit.HexToByte(LanguageMapList[SHOPLanguageSelect]);
  772. }
  773. BarcodeLimit.Checked = functionSetting1.BarcodeLimit;
  774. BarcodeWrite.Checked = functionSetting1.BarcodeWrite;
  775. BarCodeKeyCodeText.Text = functionSetting1.BarcodeKeyword;
  776. BarCodeLengthText.Value = functionSetting1.BarcodeLength;
  777. Preload.Checked = Preloadmode == "True";
  778. WriteChannel.Checked = WriteChannelConfig == "True";
  779. WriteOSD.Checked = WriteOSDLanguageConfig == "True";
  780. WriteSHOP.Checked = WriteSHOPLanguageConfig == "True";
  781. WBInit.Checked = WhiteBalanceInitConfig == "True";
  782. UsinglocalIDCheck.Checked = UsingLocalPID == "True";
  783. OrderText.Text = LastOrder;
  784. if(File.Exists(WhiteBalancePath))
  785. {
  786. if (!LoadWBConfig(WhiteBalancePath))
  787. {
  788. MessageBox.Show(LResource.ReadWBError);
  789. WriteWB.Checked = false;
  790. }
  791. else
  792. {
  793. WBPath.Text = WhiteBalancePath;
  794. WriteWB.Checked = WriteWhiteBalanceConfig == "True";
  795. }
  796. }
  797. else
  798. WriteWB.Checked = false;
  799. }
  800. }
  801. /// <summary>
  802. /// 加载本地白平衡配置
  803. /// </summary>
  804. /// <param name="filepath"></param>
  805. /// <returns></returns>
  806. public bool LoadWBConfig(string filepath)
  807. {
  808. try
  809. {
  810. functionSetting1.NormalRGB = new byte[3];
  811. functionSetting1.CoolRGB = new byte[3];
  812. functionSetting1.WarmRGB = new byte[3];
  813. functionSetting1.NormalRGB[0] = (byte)Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "HDMI white R:", null, filepath));
  814. functionSetting1.NormalRGB[1] = (byte)Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "HDMI white G:", null, filepath));
  815. functionSetting1.NormalRGB[2] = (byte)Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "HDMI white B:", null, filepath));
  816. functionSetting1.CoolRGB[0] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Cool white R:", null, filepath)) + 256);
  817. functionSetting1.CoolRGB[1] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Cool white G:", null, filepath)) + 256);
  818. functionSetting1.CoolRGB[2] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Cool white B:", null, filepath)) + 256);
  819. functionSetting1.WarmRGB[0] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Warm white R:", null, filepath)) + 256);
  820. functionSetting1.WarmRGB[1] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Warm white G:", null, filepath)) + 256);
  821. functionSetting1.WarmRGB[2] = (byte)(Convert.ToDouble(Iniconfig.OperateIniFile.ReadIniData("WBA value:", "Warm white B:", null, filepath)) + 256);
  822. return true;
  823. }
  824. catch(Exception ex)
  825. {
  826. MessageBox.Show(ex.Message);
  827. return false;
  828. }
  829. }
  830. private void ChannelList_SelectedIndexChanged(object sender, EventArgs e)
  831. {
  832. string ChannelSelect = ChannelList.SelectedItem.ToString();
  833. string channelcode = ChannelMapList[ChannelSelect];
  834. functionSetting1.ChannelCode = SerialInit.HexToByte(channelcode);
  835. SaveJsonConfig("ChannelSelect", ChannelSelect);
  836. Log.WriteInfoLog("\r\nSet channel setting to " + ChannelSelect + "\r\nchannel code is "+ channelcode);
  837. }
  838. private void OSDList_SelectedIndexChanged(object sender, EventArgs e)
  839. {
  840. string OSDLanguageSelect = OSDList.SelectedItem.ToString();
  841. string OSDLcode = LanguageMapList[OSDLanguageSelect];
  842. functionSetting1.OSDLCode = SerialInit.HexToByte(OSDLcode);
  843. SaveJsonConfig("OSDLanguageSelect", OSDLanguageSelect);
  844. Log.WriteInfoLog("\r\nSet channel setting to " + OSDLanguageSelect + "\r\nchannel code is " + OSDLcode);
  845. }
  846. private void SHOPList_SelectedIndexChanged(object sender, EventArgs e)
  847. {
  848. string SHOPLanguageSelect = SHOPList.SelectedItem.ToString();
  849. string SHOPLcode = LanguageMapList[SHOPLanguageSelect];
  850. functionSetting1.ShopLCode = SerialInit.HexToByte(SHOPLcode);
  851. SaveJsonConfig("SHOPLanguageSelect", SHOPLanguageSelect);
  852. Log.WriteInfoLog("\r\nSet channel setting to " + SHOPLanguageSelect + "\r\nchannel code is " + SHOPLcode);
  853. }
  854. private void skinButton1_Click(object sender, EventArgs e)
  855. {
  856. SaveJsonConfig("COM", "COM3");
  857. string strFileName = null;
  858. openFileDialog1.Filter = "WBConfig file|*.wba";
  859. openFileDialog1.FileName = "";
  860. openFileDialog1.Title = "Please select the WB config file";
  861. if (openFileDialog1.ShowDialog() == DialogResult.OK)
  862. {
  863. strFileName = System.IO.Path.GetFullPath(openFileDialog1.FileName);
  864. WBPath.Text = strFileName;
  865. if(LoadWBConfig(strFileName))
  866. {
  867. functionSetting1.WBFileName = Path.GetFileName(openFileDialog1.FileName);
  868. SaveJsonConfig("WhiteBalancePath", strFileName);
  869. MessageBox.Show(LResource.LoadWBsuccess);
  870. }
  871. }
  872. }
  873. private void WriteWB_CheckedChanged(object sender, EventArgs e)
  874. {
  875. if(WriteWB.Checked==true)
  876. {
  877. if (WBPath.Text.Trim().Length > 0)
  878. {
  879. LoadWBConfig(WBPath.Text.Trim());
  880. SaveJsonConfig("WriteWhiteBalance", true);
  881. }
  882. else
  883. {
  884. MessageBox.Show(LResource.SelectWBfirst);
  885. WriteWB.Checked = false;
  886. }
  887. }
  888. else
  889. {
  890. SaveJsonConfig("WriteWhiteBalance", false);
  891. }
  892. }
  893. public void SaveJsonConfig(string node,object value)
  894. {
  895. StreamReader file = File.OpenText(LocalPath.localpath + "\\Config.json");
  896. using (JsonTextReader reader = new JsonTextReader(file))
  897. {
  898. JObject jObject = (JObject)JToken.ReadFrom(reader);
  899. jObject[node] = value.ToString();
  900. file.Close();
  901. using (StreamWriter writer = new StreamWriter(LocalPath.localpath + "\\Config.json"))
  902. {
  903. writer.Write(jObject.ToString()); //将JToken.ReadFrom(reader)的数据写入文件,这样的数据有空行。
  904. }
  905. }
  906. }
  907. private void WBInit_CheckedChanged(object sender, EventArgs e)
  908. {
  909. if (WBInit.Checked)
  910. {
  911. SaveJsonConfig("WhiteBalanceInit", true);
  912. }
  913. else
  914. SaveJsonConfig("WhiteBalanceInit", false);
  915. }
  916. private void WriteChannel_CheckedChanged(object sender, EventArgs e)
  917. {
  918. if (WriteChannel.Checked)
  919. {
  920. SaveJsonConfig("WriteChannel", true);
  921. }
  922. else
  923. SaveJsonConfig("WriteChannel", false);
  924. }
  925. private void WriteOSD_CheckedChanged(object sender, EventArgs e)
  926. {
  927. if (WriteOSD.Checked)
  928. {
  929. SaveJsonConfig("WriteOSDLanguage", true);
  930. }
  931. else
  932. SaveJsonConfig("WriteOSDLanguage", false);
  933. }
  934. private void WriteSHOP_CheckedChanged(object sender, EventArgs e)
  935. {
  936. if (WriteSHOP.Checked)
  937. {
  938. SaveJsonConfig("WriteSHOPLanguage", true);
  939. }
  940. else
  941. SaveJsonConfig("WriteSHOPLanguage", false);
  942. }
  943. private void TVCOM_SelectedIndexChanged(object sender, EventArgs e)
  944. {
  945. SaveJsonConfig("COM", TVCOM.SelectedItem.ToString());
  946. }
  947. private void TVBaud_SelectedIndexChanged(object sender, EventArgs e)
  948. {
  949. SaveJsonConfig("Baudrate", TVBaud.SelectedItem.ToString());
  950. }
  951. private void Form1_FormClosed(object sender, FormClosedEventArgs e)
  952. {
  953. Environment.Exit(0);
  954. }
  955. public void LockSettingFunction(bool locksetting)
  956. {
  957. ChannelList.Enabled = locksetting;
  958. WriteOSD.Enabled = locksetting;
  959. WriteSHOP.Enabled = locksetting;
  960. WriteChannel.Enabled = locksetting;
  961. OSDList.Enabled = locksetting;
  962. SHOPList.Enabled = locksetting;
  963. skinButton1.Enabled = locksetting;
  964. WriteOSD.Enabled = locksetting;
  965. WBInit.Enabled = locksetting;
  966. WriteWB.Enabled = locksetting;
  967. OrderText.Enabled = locksetting;
  968. Preload.Enabled = locksetting;
  969. PID_Num.Enabled = locksetting;
  970. BarcodeLimit.Enabled = locksetting;
  971. BarCodeLengthText.Enabled = locksetting;
  972. BarCodeKeyCodeText.Enabled = locksetting;
  973. }
  974. private void TVCOM_MouseClick(object sender, MouseEventArgs e)
  975. {
  976. TVCOM.Items.Clear();
  977. TVCOM.Items.AddRange(SerialPort.GetPortNames());
  978. }
  979. private void CreateKeyManually_Click(object sender, EventArgs e)
  980. {
  981. CreateDBManually CreateDBManually1 = new CreateDBManually(TestMode.serverurl,ErrorDB);
  982. CreateDBManually1.ShowDialog();
  983. }
  984. private void Preload_CheckedChanged(object sender, EventArgs e)
  985. {
  986. SaveJsonConfig("Preload", Preload.Checked.ToString());
  987. }
  988. private void Form1_Move(object sender, EventArgs e)
  989. {
  990. if (this.MoveEvent != null)
  991. {
  992. Point XY = this.Location;
  993. XY.X = this.Right;
  994. XY.Y = this.Top;
  995. this.MoveEvent(XY, formlocationmsg,LocationNum);
  996. }
  997. }
  998. private void DeleteIntptr(IntPtr intPtr)
  999. {
  1000. foreach (Dictionary<IntPtr, Point> pairs in formlocationmsg)
  1001. {
  1002. if (pairs.ContainsKey(intPtr))
  1003. {
  1004. formlocationmsg.Remove(pairs);
  1005. if (this.MoveEvent != null)
  1006. {
  1007. Point XY = this.Location;
  1008. XY.X = this.Right;
  1009. XY.Y = this.Top;
  1010. this.MoveEvent(XY, formlocationmsg, LocationNum);
  1011. }
  1012. break;
  1013. }
  1014. }
  1015. }
  1016. private void AutoKeyRequire(IntPtr intPtr,string key,string keytype)
  1017. {
  1018. Task.Run(() =>
  1019. {
  1020. var a = ((Dictionary<IntPtr, Point>)formlocationmsg[0]).First();
  1021. if (a.Key == intPtr)
  1022. {
  1023. ;//start autokey require
  1024. if (CommonMethod.AutoGetKeyStatus(midList1.host, key, keytype, ErrorDB))
  1025. {
  1026. CommonMethod.AutoGetKey(midList1.host, OrderText.Text.Trim(), key, keytype, ErrorDB);
  1027. }
  1028. }
  1029. });
  1030. }
  1031. private void SNKeyDownEven(IntPtr intPtr)
  1032. {
  1033. this.KeyDownEvent(formlocationmsg, intPtr);
  1034. }
  1035. private void timer1_Tick(object sender, EventArgs e)
  1036. {
  1037. string count = SQLiteHelper.GetProductionNum(ErrorDB, OrderText.Text.Trim());
  1038. UpdateCountLabel(ProductionNum_Text, count);
  1039. }
  1040. /// <summary>
  1041. /// 刷新订单数量
  1042. /// </summary>
  1043. /// <param name="label"></param>
  1044. /// <param name="str"></param>
  1045. public void UpdateCountLabel(Label label, string str)
  1046. {
  1047. if (label.InvokeRequired)
  1048. {
  1049. BeginInvoke(new Action<string>(x => { label.Text = x.ToString(); }), str);
  1050. }
  1051. else
  1052. {
  1053. label.Text = str;
  1054. }
  1055. }
  1056. /// <summary>
  1057. /// 后台上报
  1058. /// </summary>
  1059. public void UploadBackGround()
  1060. {
  1061. while (true)
  1062. {
  1063. if(CommonMethod.HTTPChecker(StructList.CheckServerConnectionUrl))
  1064. {
  1065. try
  1066. {
  1067. string url;
  1068. string content;
  1069. string id;
  1070. if (SQLiteHelper.GetDelayReportData(ErrorDB, out url, out content, out id))
  1071. if (content.Contains("@"))
  1072. {
  1073. string[] data = content.Split('@');
  1074. if (CommonMethod.UploadPreloadCopyResult(url, data[1], data[0], LocalDB, ErrorDB, true, id, 30000))
  1075. {
  1076. SQLiteHelper.UpdateReportData(ErrorDB, "CopyDelayReport", "ID", id);
  1077. }
  1078. }
  1079. else
  1080. if (CommonMethod.UploadCopyResult(content, url, ErrorDB, OrderText.Text.Trim(), true, id, functionSetting1.ReportTimeOut))
  1081. {
  1082. SQLiteHelper.UpdateReportData(ErrorDB, "CopyDelayReport", "ID", id);
  1083. }
  1084. }
  1085. catch (Exception ex)
  1086. {
  1087. Log.WriteErrorLog(ex.Message);
  1088. }
  1089. try
  1090. {
  1091. string url;
  1092. string content;
  1093. string id;
  1094. if (SQLiteHelper.GetErrorReportData(ErrorDB, out url, out content, out id))
  1095. {
  1096. CommonMethod.ReportErrormsg2(url, content, out bool mark);
  1097. if (mark)
  1098. {
  1099. SQLiteHelper.UpdateReportData(ErrorDB, "ErrorReport", "ID", id);
  1100. }
  1101. }
  1102. }
  1103. catch (Exception ex)
  1104. {
  1105. Log.WriteErrorLog(ex.Message);
  1106. }
  1107. Thread.Sleep(5000);
  1108. }
  1109. else
  1110. Thread.Sleep(20000);
  1111. }
  1112. }
  1113. private void PID_Num_ValueChanged(object sender, EventArgs e)
  1114. {
  1115. Custom_ProjectID = PID_Num.Value.ToString();
  1116. SaveJsonConfig("Custom_ProjectID", Custom_ProjectID);
  1117. }
  1118. private void BarCodeLengthText_ValueChanged(object sender, EventArgs e)
  1119. {
  1120. functionSetting1.BarcodeLength = Convert.ToInt32(BarCodeLengthText.Value);
  1121. SaveJsonConfig("BarcodeLength", functionSetting1.BarcodeLength);
  1122. }
  1123. private void BarcodeLimit_CheckedChanged(object sender, EventArgs e)
  1124. {
  1125. functionSetting1.BarcodeLimit = BarcodeLimit.Checked;
  1126. SaveJsonConfig("BarcodeLimit", BarcodeLimit.Checked);
  1127. }
  1128. private void BarCodeKeyCodeText_TextChanged(object sender, EventArgs e)
  1129. {
  1130. functionSetting1.BarcodeKeyword = BarCodeKeyCodeText.Text;
  1131. SaveJsonConfig("BarcodeKeyword", BarCodeKeyCodeText.Text);
  1132. }
  1133. private void UsinglocalIDCheck_CheckedChanged(object sender, EventArgs e)
  1134. {
  1135. SaveJsonConfig("UsingLocalPID", UsinglocalIDCheck.Checked);
  1136. }
  1137. private void BarcodeWrite_CheckedChanged(object sender, EventArgs e)
  1138. {
  1139. functionSetting1.BarcodeWrite = BarcodeWrite.Checked;
  1140. SaveJsonConfig("BarcodeWrite", BarcodeWrite.Checked);
  1141. }
  1142. }
  1143. }