EChart_Trianglediagram.cs 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678
  1. using CefSharp;
  2. using CefSharp.WinForms;
  3. using Newtonsoft.Json;
  4. using OTSCommon.Model;
  5. using OTSIncAReportApp.DataOperation.DataAccess;
  6. using OTSIncAReportApp.OTSDataMgrFunction;
  7. using OTSIncAReportApp.OTSSampleReportInfo;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Data;
  11. using System.IO;
  12. using System.Runtime.Serialization;
  13. using System.Windows.Forms;
  14. namespace OTSIncAReportApp.Control_ECharts
  15. {
  16. /// <summary>
  17. /// 三元相图EChart版
  18. /// </summary>
  19. public partial class EChart_Trianglediagram : UserControl
  20. {
  21. #region 变量定义
  22. public List<string> m_list_string_sizelevel; //图例中:颗粒粒级字符列表
  23. public List<string> m_old_list_string_sizelevel;//图例中,颗粒粒级字符列表,未处理格式的,从底层拿出来的原始格式
  24. public List<string> m_list_string_samplename;//图例中:样品名字符列表
  25. public string Template { get; set; }
  26. public int condition = -1;
  27. /// <summary>
  28. /// 全局函数,与json数据对应的类结构
  29. /// </summary>
  30. List<TriangleJsonClass> m_list_trianglejsonclass = null;
  31. string url = "Resources/HTML/charts.html";
  32. frmReportApp m_ReportApp;
  33. frmReportConditionChoose m_condition;
  34. ResultDataMgr m_DataMgr;
  35. private bool ReportExporting = false;
  36. public bool Report { set; get; }
  37. /// <summary>
  38. /// 判断颗粒范围(true全部颗粒,false选择颗粒)
  39. /// </summary>
  40. public bool ParticleRange { set; get; }
  41. #endregion
  42. #region 构造函数及窗体加载
  43. /// <summary>
  44. /// 三角图,构造函数
  45. /// </summary>
  46. /// <param name="in_sec">传入,委托类对象</param>
  47. /// <param name="in_Cotsreportprojfilemgrclr">传入,项目管理类对象</param>
  48. public EChart_Trianglediagram(frmReportApp ReportApp)
  49. {
  50. m_list_trianglejsonclass = new List<TriangleJsonClass>();
  51. m_list_string_sizelevel = new List<string>();
  52. m_list_string_samplename = new List<string>();
  53. m_old_list_string_sizelevel = new List<string>();
  54. m_ReportApp = ReportApp;
  55. m_condition = ReportApp.m_conditionChoose;
  56. m_DataMgr = ReportApp.m_rstDataMgr;
  57. InitializeComponent();
  58. }
  59. /// <summary>
  60. /// 三角图,构造函数
  61. /// </summary>
  62. /// <param name="in_sec">传入,委托类对象</param>
  63. /// <param name="in_Cotsreportprojfilemgrclr">传入,项目管理类对象</param>
  64. public EChart_Trianglediagram(frmReportApp ReportApp, string Templates)
  65. {
  66. m_list_trianglejsonclass = new List<TriangleJsonClass>();
  67. m_list_string_sizelevel = new List<string>();
  68. m_list_string_samplename = new List<string>();
  69. m_old_list_string_sizelevel = new List<string>();
  70. Template = Templates;
  71. m_ReportApp = ReportApp;
  72. m_condition = ReportApp.m_conditionChoose;
  73. m_DataMgr = ReportApp.m_rstDataMgr;
  74. ReportExporting = true;
  75. InitializeComponent();
  76. }
  77. private void EChart_Trianglediagram_Load(object sender, EventArgs e)
  78. {
  79. string template = Template;
  80. if (template == "")
  81. { //三元相图模板
  82. template = m_condition.m_SourceGridData.GetPropItemDisplayValueByPropItemName(OTS_REPORT_PROP_GRID_ITEMS.TRIO_CHART_TYPE).ToString();
  83. }
  84. //获取粒级表
  85. string pathtpf = Application.StartupPath + "\\Config\\ProData\\DefaultTriTemplateFile.tpf";
  86. List<string> nameList = new List<string>();
  87. DataSet ds = XMLoperate.GetXmlData(pathtpf, "XMLData");
  88. DataTable dt = ds.Tables["Member"];
  89. string TemplateName = "";
  90. //遍历第一层节点
  91. foreach (DataRow element in dt.Rows)
  92. {
  93. TemplateName = element["TemplateName"].ToString();
  94. if (TemplateName == template)
  95. {
  96. string Element = element["Element"].ToString();
  97. nameList.Add(Element.Split('.')[0]);
  98. nameList.Add(Element.Split('.')[1]);
  99. nameList.Add(Element.Split('.')[2]);
  100. break;
  101. }
  102. }
  103. //将所有的测量结果名添加到list中
  104. m_list_string_samplename.Clear();
  105. string sou = "";
  106. int sel = 0;
  107. if (Report)
  108. {
  109. sou = m_DataMgr.ResultFilesList[m_DataMgr.getSelectedIndex()].FileName.ToString();
  110. if(ParticleRange)
  111. {
  112. sel = 0;
  113. }
  114. else
  115. {
  116. sel = 1;
  117. }
  118. }
  119. else
  120. {
  121. sou = m_condition.m_CurrentConditions[OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE].itemDisplayVal.ToString();
  122. //判断颗粒范围(全部颗粒或者选择颗粒)
  123. sel = m_ReportApp.m_conditionChoose.m_SourceGridData.GetComboDownListIndexByItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE_TYPE);
  124. }
  125. Report = false;
  126. if (sou.Contains("+"))
  127. {
  128. if (m_ReportApp.more)
  129. {
  130. m_ReportApp.trans = false;
  131. }
  132. else
  133. {
  134. m_ReportApp.trans = true;
  135. }
  136. for (int i = 0; i < sou.Split('+').Length; i++)
  137. {
  138. ResultFile resultFile = m_DataMgr.ResultFilesList.Find(s => s.FileName == sou.Split('+')[i]);
  139. if (resultFile == null)
  140. {
  141. continue;
  142. }
  143. TriangleJsonClass cl = GettriangleJsonClass(resultFile.FilePath, resultFile.FileName, nameList, TemplateName,sel);
  144. m_list_trianglejsonclass.Add(cl);
  145. }
  146. }
  147. else
  148. {
  149. if (!m_ReportApp.more)
  150. {
  151. m_ReportApp.trans = false;
  152. }
  153. else
  154. {
  155. m_ReportApp.trans = true;
  156. }
  157. m_ReportApp.more = false;
  158. ResultFile resultFile;
  159. int index = (int)m_condition.m_CurrentConditions[OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE].itemVal;
  160. if (ReportExporting)
  161. {
  162. resultFile = m_DataMgr.ResultFilesList[m_DataMgr.getSelectedIndex()];
  163. }
  164. else
  165. {
  166. //resultFile = m_DataMgr.ResultFilesList[m_DataMgr.GetWorkingResult()];
  167. resultFile = m_DataMgr.ResultFilesList[index];
  168. }
  169. ReportExporting = false;
  170. TriangleJsonClass cl = GettriangleJsonClass(resultFile.FilePath, resultFile.FileName, nameList, TemplateName,sel);
  171. m_list_trianglejsonclass.Add(cl);
  172. }
  173. //使用EChart进行显示
  174. if (m_list_trianglejsonclass.Count > 1)
  175. {
  176. List<Chartdate> list = new List<Chartdate>();
  177. for (int i = 0; i < m_list_trianglejsonclass.Count; i++)
  178. {
  179. //拼写Json数据
  180. Chartdate list_json_str = SpellTriangleJson(m_list_trianglejsonclass[i]);
  181. list.Add(list_json_str);
  182. }
  183. url = "Resources/HTML/chartsMore.html";
  184. m_ReportApp.data = JsonConvert.SerializeObject(list);
  185. }
  186. else
  187. {
  188. //拼写Json数据
  189. Chartdate list_json_str = SpellTriangleJson(m_list_trianglejsonclass[0]);
  190. url = "Resources/HTML/charts.html";
  191. m_ReportApp.data = JsonConvert.SerializeObject(list_json_str);
  192. }
  193. InitBrowser();
  194. }
  195. private TriangleJsonClass GettriangleJsonClass(string path, string name, List<string> nameList, string templatename,int sel)
  196. {
  197. TriangleJsonClass triangleJsonClass = new TriangleJsonClass();
  198. m_list_string_samplename.Add(name);
  199. List<string> list_string_sort = new List<string>();
  200. List<double[]> list_point_sort = new List<double[]>();
  201. DataTable particles = GetParticles(path, nameList,sel);
  202. foreach (DataRow item in particles.Rows)
  203. {
  204. if (item["particleLocation"].ToString() == "0,0,0")
  205. {
  206. continue;
  207. }
  208. list_string_sort.Add(item["sizeLevel"].ToString());
  209. double top = Convert.ToDouble(item["top"]);
  210. double left = Convert.ToDouble(item["left"]);
  211. double right = Convert.ToDouble(item["right"]);
  212. //x=right+top/2,y=(√3/2)*top
  213. double Y = 0.866 * top * 100;
  214. double X = (right + top / 2) * 100;
  215. double[] point = { Math.Round(X, 2), Math.Round(Y) };
  216. list_point_sort.Add(point);
  217. }
  218. triangleJsonClass = new TriangleJsonClass()
  219. {
  220. Samplename = name,
  221. TopName = templatename.Split('.')[0],
  222. LeftName = templatename.Split('.')[1],
  223. RightName = templatename.Split('.')[2],
  224. ListPartSize = list_string_sort,
  225. ListPointF = list_point_sort
  226. };
  227. return triangleJsonClass;
  228. }
  229. //获取颗粒信息
  230. private DataTable GetParticles(string filepath, List<string> nameList,int sel)
  231. {
  232. ParticleData particledata = new ParticleData(filepath);
  233. //设置标签名称
  234. List<string> listName = new List<string>();
  235. //获取粒级表
  236. string pathe = m_DataMgr.m_RptConfigFile.PartSizeFileFolder + m_DataMgr.m_RptConfigFile.PartSizeFile;
  237. DataSet ds = XMLoperate.GetXml(pathe);
  238. string sizestr = ds.Tables[0].Rows[0]["Sizes"].ToString();
  239. for (int i = 0; i < sizestr.Split(',').Length - 1; i++)
  240. {
  241. if (sizestr.Split(',')[i].Length > 0)
  242. {
  243. double d1 = Convert.ToDouble(sizestr.Split(',')[i]);
  244. double d2 = Convert.ToDouble(sizestr.Split(',')[i + 1]);
  245. listName.Add(d1.ToString() + "~" + d2.ToString());
  246. }
  247. }
  248. double d = Convert.ToDouble(sizestr.Split(',')[sizestr.Split(',').Length - 1]);
  249. listName.Add(d.ToString() + "~MAX");
  250. //int sel = m_ReportApp.m_conditionChoose.m_SourceGridData.GetComboDownListIndexByItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE_TYPE);
  251. //int sel = m_condition.SourceGridData.ConditionItemList[m_ReportApp.m_DataMgrFun.GetPropIndexByPropItemName(m_ReportApp.SourceGridData.ConditionItemList, OTSSampleReportInfo.OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE_TYPE)].comboDownList.IndexOf(m_ReportApp.SourceGridData.ConditionItemList[1].itemVal.ToString());
  252. //int sel = m_condition.m_SourceGridData.GetPropIndexByPropItemName(OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE_TYPE);
  253. string filedAndParticl = "";
  254. if (sel == 1)
  255. {
  256. List<Particle> selectParticles = m_ReportApp.GetSelectedParticles();
  257. foreach (var item in selectParticles)
  258. {
  259. filedAndParticl = filedAndParticl + "," + (item.FieldId.ToString() + "-" + item.ParticleId.ToString());
  260. }
  261. if (filedAndParticl != "")
  262. {
  263. filedAndParticl = filedAndParticl + ",";
  264. }
  265. }
  266. string po = "";
  267. string con = "";
  268. int row = m_condition.m_SourceGridData.ConditionItemList.Count;
  269. if (condition != -1)
  270. {
  271. List<string> li = new List<string>() { "DMAX", "DMIN", "Area", "FERET" };
  272. con = li[condition];
  273. }
  274. else
  275. {
  276. if (row < 4)
  277. {
  278. con = "DMAX";
  279. }
  280. else
  281. {
  282. con = m_condition.m_SourceGridData.GetPropItemDisplayValueByPropItemName( OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE).ToString();
  283. }
  284. }
  285. switch (con)
  286. {
  287. case "DMAX":
  288. po = "DMAX";
  289. break;
  290. case "DMIN":
  291. po = "DMIN";
  292. break;
  293. case "CIRCLE":
  294. po = "Area";
  295. break;
  296. case "FERET":
  297. po = "DFERET";
  298. break;
  299. }
  300. DataTable dtp = particledata.GetParticleHaveXray(filedAndParticl);
  301. //创建一个临时表
  302. DataTable ret_dt = new DataTable();
  303. //然后额外存放三列,用于存放拆分后三个顶点的值
  304. ret_dt.Columns.Add("sizeLevel");
  305. ret_dt.Columns.Add("particleLocation");
  306. ret_dt.Columns.Add("top");
  307. ret_dt.Columns.Add("left");
  308. ret_dt.Columns.Add("right");
  309. for (int k = 0; k < listName.Count; k++)
  310. {
  311. string str = listName[k];
  312. string d1 = str.Split('~')[0];
  313. string d2 = str.Split('~')[1];
  314. if (d2 == "MAX")
  315. {
  316. d2 = "999";
  317. }
  318. DataRow[] datas = dtp.Select(getWhere(d2, d1, po));
  319. foreach (var item in datas)
  320. {
  321. DataRow dr = ret_dt.NewRow();
  322. dr["sizeLevel"] = str;
  323. string element = item["Element"].ToString();
  324. string strRet = getStrRet(nameList, element);
  325. dr["particleLocation"] = strRet;
  326. dr["top"] = strRet.Split(',')[0];
  327. dr["left"] = strRet.Split(',')[1];
  328. dr["right"] = strRet.Split(',')[2];
  329. ret_dt.Rows.Add(dr);
  330. }
  331. }
  332. return ret_dt;
  333. }
  334. private string getWhere(string max, string min, string col)
  335. {
  336. return col + ">=" + min + " and " + col + "<=" + max;
  337. }
  338. private string getStrRet(List<string> template, string element)
  339. {
  340. List<string> name = new List<string>()
  341. { "h","he",
  342. "li","be","b","c","n","o","f","ne",
  343. "na","mg","al","si","p","s","cl","ar",
  344. "k","ca","sc","ti","v","cr","mn","fe","co","ni","cu","zn","ga","ge","as","se","br","kr",
  345. "rb","sr","y","zr","nb","mo","tc","ru","rh","pd","ag","cd","in","sn","sb","te","i","xe",
  346. "cs","ba","la",
  347. "ce","pr","nd","pm","sm","eu","gd","tb","dy","ho","er","tm","yb","lu",
  348. "hf","ta","w","re","os","ir","pt","au","hg","tl","pb","bi","po","at","rn",
  349. "fr","ra","ac",
  350. "th","pa","u","np","pu","am","cm","bk","cf","es","fm","md","no","lr"
  351. };
  352. List<double> value = new List<double>()
  353. { 1.008,4.003,
  354. 6.941,9.012,10.811,12.011,14.007,15.999,18.998,20.180,
  355. 22.990,24.305,26.982,28.086,30.974,32.066,35.453,39.948,
  356. 39.098,40.08,44.956,47.88,50.942,51.996,54.938,55.847,58.933,58.70,63.546,65.39,69.72,72.61,74.922,78.96,79.904,83.80,
  357. 85.468,87.62,88.906,91.22,92.906,95.94,98.00,101.07,102.906,106.42,107.868,112.41,114.82,118.71,121.76,127.60,126.905,131.29,
  358. 132.905,137.33,138.906,
  359. 140.12,140.908,144.24,145.0,150.36,151.97,157.25,158.925,162.50,64.93,167.26,168.934,173.04,174.967,
  360. 178.49,180.948,183.85,186.207,190.20,192.22,195.08,196.967,200.59,204.38,207.2,208.980,209.00,210.00,222.00,
  361. 223.00,226.025,227.028,
  362. 232.038,231.036,238.029,237.048,244.00,243.00,247.00,247.00,251.00,252.00,257.00,258.00,259.00,260.00
  363. };
  364. double d_ASum = 0;
  365. double d_BSum = 0;
  366. double d_CSum = 0;
  367. string aElements = template[0];
  368. string bElements = template[1];
  369. string cElements = template[2];
  370. foreach (var item in element.Split(';'))
  371. {
  372. if (item.Contains(aElements + "-"))
  373. {
  374. if (aElements != "")
  375. {
  376. d_ASum = Convert.ToDouble(item.Split('-')[1]) / value[name.IndexOf(aElements.ToLower())];
  377. }
  378. }
  379. for (int i = 0; i < bElements.Split(',').Length; i++)
  380. {
  381. string e = bElements.Split(',')[i];
  382. if (item.Contains(e + "-"))
  383. {
  384. d_BSum = d_BSum + Convert.ToDouble(item.Split('-')[1]) / value[name.IndexOf(e.ToLower())];
  385. }
  386. }
  387. if (item.Contains(cElements + "-"))
  388. {
  389. if (cElements != "")
  390. d_CSum = Convert.ToDouble(item.Split('-')[1]) / value[name.IndexOf(cElements.ToLower())];
  391. }
  392. }
  393. double allNums = d_ASum + d_BSum + d_CSum;
  394. string strRet = "";
  395. if ((allNums) == 0)
  396. {
  397. strRet = "0,0,0";
  398. }
  399. else
  400. {
  401. double aPercent = 0, bPercent = 0, cPercent = 0;
  402. if (d_ASum != 0)
  403. {
  404. aPercent = d_ASum / allNums;
  405. }
  406. if (d_BSum != 0)
  407. {
  408. bPercent = d_BSum / allNums;
  409. }
  410. if (d_CSum != 0)
  411. {
  412. cPercent = d_CSum / allNums;
  413. }
  414. strRet = aPercent.ToString() + "," + bPercent.ToString() + "," + cPercent.ToString();
  415. }
  416. return strRet;
  417. }
  418. class Chartdate
  419. {
  420. public string Samplename { get; set; }
  421. public string LeftName { get; set; }
  422. public string RightName { get; set; }
  423. public string TopName { get; set; }
  424. public List<string> ListPartSize { get; set; }
  425. public List<List<double[]>> ListPoint { get; set; }
  426. }
  427. #endregion
  428. #region echarts
  429. //定义图片
  430. //JsEvent js;
  431. //定义图片base64
  432. public string pic { get; set; }
  433. //定义图形类型
  434. public string type { get; set; }
  435. //获取图片
  436. private void button1_Click(object sender, EventArgs e)
  437. {
  438. //string str = GetPic();
  439. //pic = str;
  440. }
  441. /// <summary>
  442. /// 加载浏览器
  443. /// </summary>
  444. public void InitBrowser()
  445. {//加载网页
  446. if (m_ReportApp.browser_trio == null || m_ReportApp.trans)
  447. {
  448. // 获取生成路径下网页文件的绝对路径
  449. string fileName = Path.Combine(Directory.GetCurrentDirectory(), url);
  450. //加载网页
  451. m_ReportApp.browser_trio = new ChromiumWebBrowser(fileName);
  452. //禁止网页
  453. m_ReportApp.browser_trio.MenuHandler = new MenuHandler();
  454. m_ReportApp.browser_trio.Dock = DockStyle.Fill;
  455. //添加网页到当前自定义控件
  456. this.Controls.Add(m_ReportApp.browser_trio);
  457. m_ReportApp.js.MessageText = "";
  458. //供页面调用以传递数据
  459. m_ReportApp.browser_trio.RegisterJsObject("jsObj", m_ReportApp.js, false);
  460. //升级cef版本后新方法
  461. //CefSharpSettings.LegacyJavascriptBindingEnabled = true;
  462. //CefSharpSettings.WcfEnabled = true;
  463. //m_ReportApp.browser_trio.JavascriptObjectRepository.Register("jsObj", m_ReportApp.js, isAsync: false, options: BindingOptions.DefaultBinder);
  464. //网页加载结束后调用事件
  465. m_ReportApp.browser_trio.FrameLoadEnd += WebBrowser_FrameLoadEnd;
  466. }
  467. else
  468. {
  469. m_ReportApp.browser_trio.ResetText();
  470. m_ReportApp.browser_trio.Reload();
  471. m_ReportApp.browser_trio.Refresh();
  472. //供页面调用以传递数据
  473. this.Controls.Add(m_ReportApp.browser_trio);
  474. }
  475. if (m_ReportApp.timerKG)
  476. {
  477. timer1.Enabled = true;
  478. }
  479. }
  480. /// <summary>
  481. /// 页面加载结束后事件
  482. /// </summary>
  483. /// <param name="sender"></param>
  484. /// <param name="e"></param>
  485. private void WebBrowser_FrameLoadEnd(object sender, FrameLoadEndEventArgs e)
  486. {
  487. if (e.Frame.IsMain)
  488. {
  489. //为页面图形提供数据参数
  490. string str = m_ReportApp.data;
  491. //执行网页脚本事件
  492. m_ReportApp.browser_trio.ExecuteScriptAsync("showchart('" + str + "','','triangle')");
  493. }
  494. }
  495. //public string GetPic()
  496. //{
  497. // return js.MessageText;
  498. //}
  499. //禁止网页操作,右键点击等
  500. class MenuHandler : CefSharp.IContextMenuHandler
  501. {
  502. void CefSharp.IContextMenuHandler.OnBeforeContextMenu(CefSharp.IWebBrowser browserControl, CefSharp.IBrowser browser, CefSharp.IFrame frame, CefSharp.IContextMenuParams parameters, CefSharp.IMenuModel model)
  503. {
  504. model.Clear();
  505. }
  506. bool CefSharp.IContextMenuHandler.OnContextMenuCommand(CefSharp.IWebBrowser browserControl, CefSharp.IBrowser browser, CefSharp.IFrame frame, CefSharp.IContextMenuParams parameters, CefSharp.CefMenuCommand commandId, CefSharp.CefEventFlags eventFlags)
  507. {
  508. //throw new NotImplementedException();
  509. return false;
  510. }
  511. void CefSharp.IContextMenuHandler.OnContextMenuDismissed(CefSharp.IWebBrowser browserControl, CefSharp.IBrowser browser, CefSharp.IFrame frame)
  512. {
  513. //throw new NotImplementedException();
  514. }
  515. bool CefSharp.IContextMenuHandler.RunContextMenu(CefSharp.IWebBrowser browserControl, CefSharp.IBrowser browser, CefSharp.IFrame frame, CefSharp.IContextMenuParams parameters, CefSharp.IMenuModel model, CefSharp.IRunContextMenuCallback callback)
  516. {
  517. return false;
  518. }
  519. }
  520. class JsEvent
  521. {
  522. public string MessageText { set; get; }
  523. public void ShowTest()
  524. {
  525. MessageBox.Show(MessageText);
  526. }
  527. }
  528. #endregion
  529. #region 自定义方法
  530. /// <summary>
  531. /// 拼写json数据
  532. /// </summary>
  533. /// <returns></returns>
  534. private Chartdate SpellTriangleJson(TriangleJsonClass in_trianglejsonclass)
  535. {
  536. Chartdate chart = new Chartdate();
  537. chart.LeftName = in_trianglejsonclass.LeftName;
  538. chart.RightName = in_trianglejsonclass.RightName;
  539. chart.TopName = in_trianglejsonclass.TopName;
  540. chart.Samplename = in_trianglejsonclass.Samplename;
  541. List<string> str_listpartsize = new List<string>();
  542. List<List<double[]>> str_listpoint = new List<List<double[]>>();
  543. for (int i = 0; i < in_trianglejsonclass.ListPartSize.Count; i++)
  544. {
  545. //如果未包含该粒级
  546. if (!str_listpartsize.Contains(in_trianglejsonclass.ListPartSize[i]))
  547. {
  548. //第一步先添加该粒级
  549. str_listpartsize.Add(in_trianglejsonclass.ListPartSize[i]);
  550. }
  551. }
  552. //第二步再添加所有该粒级对应的坐标,到一个分组中
  553. for (int i = 0; i < str_listpartsize.Count; i++)
  554. {
  555. List<double[]> point = new List<double[]>();
  556. for (int k = 0; k < in_trianglejsonclass.ListPointF.Count; k++)
  557. {
  558. if (str_listpartsize[i] == in_trianglejsonclass.ListPartSize[k])
  559. {
  560. point.Add(in_trianglejsonclass.ListPointF[k]);
  561. }
  562. }
  563. str_listpoint.Add(point);
  564. }
  565. chart.ListPartSize = str_listpartsize;
  566. chart.ListPoint = str_listpoint;
  567. return chart;
  568. }
  569. #endregion
  570. #region EChart导出图像委托调用部份
  571. public delegate void MyDelgate(string va);
  572. public event MyDelgate butclic;
  573. private void timer1_Tick(object sender, EventArgs e)
  574. {
  575. if (butclic == null)
  576. return;
  577. if (m_ReportApp.js == null)
  578. return;
  579. if (m_ReportApp.js.MessageText == null)
  580. return;
  581. if (m_ReportApp.js.MessageText != "")
  582. {
  583. butclic(m_ReportApp.js.MessageText);
  584. timer1.Enabled = false;
  585. m_ReportApp.timerKG = false;
  586. m_ReportApp.js.MessageText = "";
  587. }
  588. }
  589. [DataContract]
  590. public class TriangleJsonClass
  591. {
  592. [DataMember]
  593. public string Samplename { set; get; }
  594. [DataMember]
  595. public string TopName { set; get; }
  596. [DataMember]
  597. public string LeftName { set; get; }
  598. [DataMember]
  599. public string RightName { set; get; }
  600. [DataMember]
  601. public List<string> ListPartSize { set; get; }
  602. [DataMember]
  603. public List<double[]> ListPointF { set; get; }
  604. }
  605. #endregion
  606. }
  607. }