DataMgrFun.cs 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071
  1. using OTSIncAReportApp.OTSSampleReportInfo;
  2. using OTSIncAReportApp.SysMgrTools;
  3. using System;
  4. using System.Collections;
  5. using System.Collections.Generic;
  6. using System.Data;
  7. using System.IO;
  8. using System.Linq;
  9. namespace OTSIncAReportApp.OTSDataMgrFunction
  10. {
  11. /// <summary>
  12. /// 框架与底层进行交互的操作类
  13. /// </summary>
  14. public class DataMgrFun
  15. {
  16. #region 变量定义
  17. /// <summary>
  18. /// 报告主进程框架对象
  19. /// </summary>
  20. private frmReportApp m_ReportApp = null;
  21. #endregion
  22. #region 构造函数
  23. /// <summary>
  24. /// 构造函数
  25. /// </summary>
  26. /// <param name="ReportApp"></param>
  27. public DataMgrFun(frmReportApp ReportApp)
  28. {
  29. m_ReportApp = ReportApp;
  30. Language lan = new Language();
  31. table = lan.GetNameTable("DataMgrFun");
  32. }
  33. //国际化存储信息
  34. Hashtable table;
  35. #endregion
  36. #region 获取组合项相关方法
  37. /// <summary>
  38. /// 根据系统设置的默认粒级表路径,获取所有的粒级表文件List
  39. /// </summary>
  40. /// <returns></returns>
  41. public List<string> GetPartSizeFileList()
  42. {
  43. List<string> ret_list = new List<string>();
  44. //遍历粒级文件夹
  45. DirectoryInfo theFolder = new DirectoryInfo(m_ReportApp.m_RptConfigFile.FileFolderSize);
  46. if (!theFolder.Exists)
  47. return ret_list;
  48. //读取遍历粒级文件信息
  49. foreach (FileInfo nextifile in theFolder.GetFiles())
  50. {
  51. //找出粒级文件
  52. if (nextifile.Name.Contains(".psf") == true || nextifile.Name.Contains(".PSF") == true)
  53. {
  54. ret_list.Add(nextifile.Name);
  55. }
  56. }
  57. return ret_list;
  58. }
  59. /// <summary>
  60. /// 根据系统设置默认的粒级表的路径,获取粒级表List
  61. /// </summary>
  62. /// <param name="path"></param>
  63. /// <returns></returns>
  64. public List<string> GetPartSizeList()
  65. {
  66. DataSet ds = DataOperation.DataAccess.XMLoperate.GetXml(m_ReportApp.m_RptConfigFile.FileFolderSize + m_ReportApp.m_RptConfigFile.PartSizeFile);
  67. string sizestr = ds.Tables[0].Rows[0]["Sizes"].ToString();
  68. List<string> sizeList = new List<string>();
  69. for (int i = 0; i < sizestr.Split(',').Length - 1; i++)
  70. {
  71. if (sizestr.Split(',')[i].Length > 0)
  72. {
  73. double d1 = Convert.ToDouble(sizestr.Split(',')[i]);
  74. double d2 = Convert.ToDouble(sizestr.Split(',')[i + 1]);
  75. sizeList.Add(d1.ToString() + "~" + d2.ToString());
  76. }
  77. }
  78. double d = Convert.ToDouble(sizestr.Split(',')[sizestr.Split(',').Length - 1]);
  79. sizeList.Add(d.ToString() + "~MAX");
  80. return sizeList;
  81. }
  82. /// <summary>
  83. /// 根据传入的粒级表目录,获取粒级表List
  84. /// </summary>
  85. /// <returns></returns>
  86. public List<string> GetPartSizeList(string path)
  87. {
  88. DataSet ds = DataOperation.DataAccess.XMLoperate.GetXml(path);
  89. string sizestr = ds.Tables[0].Rows[0]["Sizes"].ToString();
  90. List<string> sizeList = new List<string>();
  91. for (int i = 0; i < sizestr.Split(',').Length - 1; i++)
  92. {
  93. if (sizestr.Split(',')[i].Length > 0)
  94. {
  95. double d1 = Convert.ToDouble(sizestr.Split(',')[i]);
  96. double d2 = Convert.ToDouble(sizestr.Split(',')[i + 1]);
  97. sizeList.Add(d1.ToString() + "~" + d2.ToString());
  98. }
  99. }
  100. double d = Convert.ToDouble(sizestr.Split(',')[sizestr.Split(',').Length - 1]);
  101. sizeList.Add(d.ToString() + "~MAX");
  102. return sizeList;
  103. }
  104. /// <summary>
  105. /// 获取三元相图模板名称列表
  106. /// </summary>
  107. /// <returns></returns>
  108. public List<string> GetTriTemplateNameList()
  109. {
  110. string pathtpf = m_ReportApp.m_RptConfigFile.FileFolderTrigTemp + m_ReportApp.m_RptConfigFile.TriTempFile;
  111. List<string> ret_list = new List<string>();
  112. DataSet ds = DataOperation.DataAccess.XMLoperate.GetXmlData(pathtpf, "XMLData");
  113. DataTable dt = ds.Tables["Member"];
  114. foreach (DataRow item in dt.Rows)
  115. {
  116. if (item["TemplateName"].ToString() != "")
  117. {
  118. ret_list.Add(item["TemplateName"].ToString());
  119. }
  120. }
  121. return ret_list;
  122. }
  123. /// <summary>
  124. /// 获取测量结果名称列表
  125. /// </summary>
  126. /// <returns></returns>
  127. public List<string> GetSampleListName()
  128. {
  129. List<string> ret_list = new List<string>();
  130. var resultfileList = m_ReportApp.resultFilesList;
  131. foreach (var item in resultfileList)
  132. {
  133. ret_list.Add(item.FileName);
  134. }
  135. if (m_ReportApp.MoreSource != "")
  136. {
  137. ret_list.Add(m_ReportApp.MoreSource);
  138. }
  139. return ret_list;
  140. }
  141. /// <summary>
  142. /// 获取计算方法列表
  143. /// </summary>
  144. /// <returns></returns>
  145. public List<string> GetSizeCalMethodTypeList()
  146. {
  147. List<string> ret_list = new List<string>() { "DMAX", "DMIN", "Area", "FERET" };
  148. return ret_list;
  149. }
  150. /// <summary>
  151. /// 数据类型,全部颗粒,分析颗粒
  152. /// </summary>
  153. /// <returns></returns>
  154. public List<string> GetDataSourceTypeList()
  155. {
  156. string sscaptionname23 = table["sscaptionname23"].ToString();
  157. string sscaptionname24 = table["sscaptionname24"].ToString();
  158. List<string> ret_list = new List<string>() { sscaptionname23, sscaptionname24 };
  159. return ret_list;
  160. }
  161. #endregion
  162. #region [属性选项Grid窗体]相关封装方法
  163. /// <summary>
  164. /// 初始化加载sourceGrid各项
  165. /// </summary>
  166. /// <param name="tbindex"></param>
  167. /// <returns></returns>SampleData1
  168. private List<SampleData> GetSourceGridData(int tbindex)
  169. {
  170. List<SampleData> list = new List<SampleData>();
  171. if (tbindex == 0)//分布图页
  172. {
  173. //测量结果数据
  174. List<string> list_source_str = GetSampleListName();
  175. string sSCaptionName1 = table["sscaptionname1"].ToString();
  176. SampleData sampleData = new SampleData();
  177. sampleData.iItemId = 0;
  178. sampleData.sSCaptionName = sSCaptionName1;
  179. sampleData.iItemValType = OTS_ITEM_TYPES.COMBO;
  180. sampleData.bReadOnly = false;
  181. sampleData.sDescriptionInfo = "Select Measurement Result";
  182. sampleData.itemVal = list_source_str[m_ReportApp.WorkingResult];
  183. sampleData.comboDownList = list_source_str;
  184. list.Add(sampleData);
  185. string sSCaptionName2 = table["sscaptionname2"].ToString();
  186. string sSCaptionName13 = table["sscaptionname13"].ToString();
  187. SampleData sampleData1 = new SampleData();
  188. sampleData1.iItemId = OTS_REPORT_PROP_GRID_ITEMS.IMAGE_TYPE;
  189. sampleData1.sSCaptionName = sSCaptionName2;//测量图类型
  190. sampleData1.iItemValType = OTS_ITEM_TYPES.COMBO;
  191. sampleData1.bReadOnly = false;
  192. sampleData1.sDescriptionInfo = "Survey Chart Type";
  193. sampleData1.itemVal = "BSE";
  194. sampleData1.comboDownList = new List<string>() { "BSE", sSCaptionName13, "Original", "原图颗粒分布" };//bse,颗粒分类图
  195. list.Add(sampleData1);
  196. //测量图类型
  197. List<string> list_datasourcetypelist = GetDataSourceTypeList();
  198. string sSCaptionName3 = table["sscaptionname3"].ToString();
  199. string sscaptionname14 = table["sscaptionname14"].ToString();
  200. string sscaptionname15 = table["sscaptionname15"].ToString();
  201. List<string> list1 = new List<string>() { sscaptionname14, sscaptionname15 };
  202. SampleData sampleData2 = new SampleData();
  203. sampleData2.iItemId = OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE;
  204. sampleData2.sSCaptionName = sSCaptionName3;
  205. sampleData2.iItemValType = OTS_ITEM_TYPES.COMBO;
  206. sampleData2.bReadOnly = false;
  207. sampleData2.sDescriptionInfo = "chart display mode";
  208. sampleData2.itemVal = list1[0];
  209. sampleData2.comboDownList = list1;
  210. list.Add(sampleData2);
  211. //测量图显示方式
  212. string sSCaptionName4 = table["sscaptionname4"].ToString();
  213. string sscaptionname16 = table["sscaptionname16"].ToString();
  214. string sscaptionname17 = table["sscaptionname17"].ToString();
  215. List<string> list2 = new List<string>() { sscaptionname16, sscaptionname17 };
  216. SampleData sampleData3 = new SampleData();
  217. sampleData3.iItemId = OTS_REPORT_PROP_GRID_ITEMS.PARTICLE_TYPE;
  218. sampleData3.sSCaptionName = sSCaptionName4;
  219. sampleData3.iItemValType = OTS_ITEM_TYPES.COMBO;
  220. sampleData3.bReadOnly = false;
  221. sampleData3.sDescriptionInfo = "Particle Type";
  222. sampleData3.itemVal = list2[0];
  223. sampleData3.comboDownList = list2;
  224. list.Add(sampleData3);
  225. //粒级表
  226. string sSCaptionName_partsizefile = "粒级表";
  227. List<string> list_partsizelist = GetPartSizeFileList();//从系统默认的路径中查找出所有的粒级表文件
  228. SampleData sampleData_partsizefile = new SampleData();
  229. sampleData_partsizefile.iItemId = OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE;
  230. sampleData_partsizefile.sSCaptionName = sSCaptionName_partsizefile;
  231. sampleData_partsizefile.iItemValType = OTS_ITEM_TYPES.COMBO;
  232. sampleData_partsizefile.bReadOnly = false;
  233. sampleData_partsizefile.sDescriptionInfo = "Particle Table";
  234. sampleData_partsizefile.itemVal = list_partsizelist[0];
  235. sampleData_partsizefile.comboDownList = list_partsizelist;
  236. list.Add(sampleData_partsizefile);
  237. //粒级
  238. string sscaptionname18 = table["sscaptionname18"].ToString();
  239. SampleData sampleData4 = new SampleData();
  240. List<string> sizeList = new List<string>();
  241. sizeList = GetPartSizeList();//获取粒级后额外增加全部,自定义,选项
  242. sizeList.Insert(0, sscaptionname16);//全部
  243. sizeList.Insert(1, sscaptionname18);//自定义
  244. string sSCaptionName5 = table["sscaptionname5"].ToString();
  245. sampleData4.iItemId = OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS;
  246. sampleData4.sSCaptionName = sSCaptionName5;
  247. sampleData4.iItemValType = OTS_ITEM_TYPES.COMBO;
  248. sampleData4.bReadOnly = false;
  249. sampleData4.sDescriptionInfo = "Grain Size";
  250. sampleData4.itemVal = sscaptionname16;
  251. sampleData4.comboDownList = sizeList;
  252. list.Add(sampleData4);
  253. //自定义最小
  254. string sSCaptionName6 = table["sscaptionname6"].ToString();
  255. SampleData sampleData41 = new SampleData();
  256. sampleData41.iItemId = OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN;
  257. sampleData41.sSCaptionName = sSCaptionName6;
  258. sampleData41.iItemValType = OTS_ITEM_TYPES.DOUBLE;
  259. sampleData41.bReadOnly = false;
  260. sampleData41.sDescriptionInfo = "Smallest Particle";
  261. sampleData41.itemVal = "0";
  262. list.Add(sampleData41);
  263. //自定义最大
  264. string sSCaptionName7 = table["sscaptionname7"].ToString();
  265. SampleData sampleData42 = new SampleData();
  266. sampleData42.iItemId = OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MAX;
  267. sampleData42.sSCaptionName = sSCaptionName7;
  268. sampleData42.iItemValType = OTS_ITEM_TYPES.DOUBLE;
  269. sampleData42.bReadOnly = false;
  270. sampleData42.sDescriptionInfo = "Maximum Particle";
  271. sampleData42.itemVal = "0";
  272. list.Add(sampleData42);
  273. //测量数据
  274. string sSCaptionName22 = table["sscaptionname22"].ToString();
  275. string sSCaptionName19 = table["sscaptionname19"].ToString();
  276. string sSCaptionName20 = table["sscaptionname20"].ToString();
  277. string sSCaptionName21 = table["sscaptionname21"].ToString();
  278. List<string> list3 = new List<string>() { sSCaptionName19, sSCaptionName20, sSCaptionName21 };
  279. SampleData sampleData6 = new SampleData();
  280. sampleData6.iItemId = OTS_REPORT_PROP_GRID_ITEMS.MEASURE_DATA_TYPE;
  281. sampleData6.sSCaptionName = sSCaptionName22;
  282. sampleData6.iItemValType = OTS_ITEM_TYPES.COMBO;
  283. sampleData6.bReadOnly = false;
  284. sampleData6.sDescriptionInfo = "Measured Data";
  285. sampleData6.itemVal = list3[0];
  286. sampleData6.comboDownList = list3;
  287. list.Add(sampleData6);
  288. //计算方式
  289. string sSCaptionName8 = table["sscaptionname8"].ToString();
  290. SampleData sampleData5 = new SampleData();
  291. sampleData5.iItemId = OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE;
  292. sampleData5.sSCaptionName = sSCaptionName8;
  293. sampleData5.iItemValType = OTS_ITEM_TYPES.COMBO;
  294. sampleData5.bReadOnly = false;
  295. sampleData5.sDescriptionInfo = "Dimension calculation method";
  296. sampleData5.itemVal = "DMAX";
  297. sampleData5.comboDownList = GetSizeCalMethodTypeList();
  298. list.Add(sampleData5);
  299. }
  300. else if (tbindex == 1)//Grid表格页
  301. {
  302. //测量结果数据
  303. List<string> list_source_str = GetSampleListName();
  304. string sSCaptionName1 = table["sscaptionname1"].ToString();
  305. SampleData sampleData = new SampleData();
  306. sampleData.iItemId = 0;
  307. sampleData.sSCaptionName = sSCaptionName1;
  308. sampleData.iItemValType = OTS_ITEM_TYPES.COMBO;
  309. sampleData.bReadOnly = false;
  310. sampleData.sDescriptionInfo = "Select Measurement Result";
  311. sampleData.itemVal = list_source_str[m_ReportApp.WorkingResult];
  312. sampleData.comboDownList = list_source_str;
  313. list.Add(sampleData);
  314. //数据类型
  315. List<string> list_datasourcetypelist = GetDataSourceTypeList();
  316. string sSCaptionName9 = table["sscaptionname9"].ToString();
  317. SampleData sampleData1 = new SampleData();
  318. sampleData1.iItemId = OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE_TYPE;
  319. sampleData1.sSCaptionName = sSCaptionName9;
  320. sampleData1.iItemValType = OTS_ITEM_TYPES.COMBO;
  321. sampleData1.bReadOnly = false;
  322. sampleData1.sDescriptionInfo = "Data Type";
  323. sampleData1.itemVal = list_datasourcetypelist[0];
  324. sampleData1.comboDownList = list_datasourcetypelist;
  325. list.Add(sampleData1);
  326. //数据表类型
  327. string sSCaptionName10 = table["sscaptionname10"].ToString();
  328. List<string> list2 = new List<string>() { table["sscaptionname25"].ToString(), table["sscaptionname26"].ToString(), table["sscaptionname27"].ToString(), table["sscaptionname28"].ToString(), table["sscaptionname29"].ToString(), table["sscaptionname30"].ToString()};
  329. string[] aa = m_ReportApp.Text.Split('-');
  330. if(aa[aa.Count()-1]== " Inclusion Analysis System")
  331. {
  332. List<string> listStd = new List<string>() {"国标一", "国标二", "美标", "德标" };
  333. list2.AddRange(listStd);
  334. }
  335. SampleData sampleData3 = new SampleData();
  336. sampleData3.iItemId = OTS_REPORT_PROP_GRID_ITEMS.CALCULATE_TABLE_TYPE;
  337. sampleData3.sSCaptionName = sSCaptionName10;
  338. sampleData3.iItemValType = OTS_ITEM_TYPES.COMBO;
  339. sampleData3.bReadOnly = false;
  340. sampleData3.sDescriptionInfo = "Data table type";
  341. sampleData3.itemVal = list2[0];
  342. sampleData3.comboDownList = list2;
  343. list.Add(sampleData3);
  344. //粒级表
  345. string sSCaptionName_partsizefile = "粒级表";
  346. List<string> list_partsizelist = GetPartSizeFileList();//从系统默认的路径中查找出所有的粒级表文件
  347. SampleData sampleData_partsizefile = new SampleData();
  348. sampleData_partsizefile.iItemId = OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE;
  349. sampleData_partsizefile.sSCaptionName = sSCaptionName_partsizefile;
  350. sampleData_partsizefile.iItemValType = OTS_ITEM_TYPES.COMBO;
  351. sampleData_partsizefile.bReadOnly = false;
  352. sampleData_partsizefile.sDescriptionInfo = "Particle Table";
  353. sampleData_partsizefile.itemVal = list_partsizelist[0];
  354. sampleData_partsizefile.comboDownList = list_partsizelist;
  355. list.Add(sampleData_partsizefile);
  356. //尺寸计算方法
  357. string sSCaptionName8 = table["sscaptionname8"].ToString();
  358. SampleData sampleData13 = new SampleData();
  359. sampleData13.iItemId = OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE;
  360. sampleData13.sSCaptionName = sSCaptionName8;
  361. sampleData13.iItemValType = OTS_ITEM_TYPES.COMBO;
  362. sampleData13.bReadOnly = false;
  363. sampleData13.sDescriptionInfo = "Dimension Calculation Method";
  364. sampleData13.itemVal = "DMAX";
  365. sampleData13.comboDownList = GetSizeCalMethodTypeList();
  366. list.Add(sampleData13);
  367. }
  368. else if (tbindex == 2)//Chart图页
  369. {
  370. //测量结果数据
  371. List<string> list_source_str = GetSampleListName();
  372. string sSCaptionName1 = table["sscaptionname1"].ToString();
  373. SampleData sampleData = new SampleData();
  374. sampleData.iItemId = 0;
  375. sampleData.sSCaptionName = sSCaptionName1;
  376. sampleData.iItemValType = OTS_ITEM_TYPES.COMBO;
  377. sampleData.bReadOnly = false;
  378. sampleData.sDescriptionInfo = "Select Measurement Result";
  379. sampleData.itemVal = list_source_str[m_ReportApp.WorkingResult];
  380. sampleData.comboDownList = list_source_str;
  381. list.Add(sampleData);
  382. //数据类型
  383. List<string> list_datasourcetypelist = GetDataSourceTypeList();
  384. string sSCaptionName9 = table["sscaptionname9"].ToString();
  385. SampleData sampleData1 = new SampleData();
  386. sampleData1.iItemId = OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE_TYPE;
  387. sampleData1.sSCaptionName = sSCaptionName9;
  388. sampleData1.iItemValType = OTS_ITEM_TYPES.COMBO;
  389. sampleData1.bReadOnly = false;
  390. sampleData1.sDescriptionInfo = "Data Type";
  391. sampleData1.itemVal = list_datasourcetypelist[0];
  392. sampleData1.comboDownList = list_datasourcetypelist;
  393. list.Add(sampleData1);
  394. //数据图类型
  395. string sSCaptionName10 = table["sscaptionname10"].ToString();
  396. List<string> list2 = new List<string>() { "常用夹杂物分类", table["sscaptionname27"].ToString(), table["sscaptionname28"].ToString(), table["sscaptionname29"].ToString(), table["sscaptionname12"].ToString() };
  397. SampleData sampleData3 = new SampleData();
  398. sampleData3.iItemId = OTS_REPORT_PROP_GRID_ITEMS.CALCULATE_CHART_TYPE;
  399. sampleData3.sSCaptionName = sSCaptionName10;
  400. sampleData3.iItemValType = OTS_ITEM_TYPES.COMBO;
  401. sampleData3.bReadOnly = false;
  402. sampleData3.sDescriptionInfo = "Data graph type";
  403. sampleData3.itemVal = list2[0];
  404. sampleData3.comboDownList = list2;
  405. list.Add(sampleData3);
  406. //三元相图模板
  407. string sSCaptionName12 = table["sscaptionname12"].ToString();
  408. SampleData sampleData15 = new SampleData();
  409. List<string> trio_listname = GetTriTemplateNameList();
  410. sampleData15.iItemId = OTS_REPORT_PROP_GRID_ITEMS.TRIO_CHART_TYPE;
  411. sampleData15.sSCaptionName = sSCaptionName12;
  412. sampleData15.iItemValType = OTS_ITEM_TYPES.COMBO;
  413. sampleData15.bReadOnly = false;
  414. sampleData15.sDescriptionInfo = "Ternary phase diagram";
  415. sampleData15.itemVal = trio_listname.First();
  416. sampleData15.comboDownList = trio_listname;
  417. list.Add(sampleData15);
  418. //粒级表
  419. string sSCaptionName_partsizefile = "粒级表";
  420. List<string> list_partsizelist = GetPartSizeFileList();
  421. SampleData sampleData_partsizefile = new SampleData();
  422. sampleData_partsizefile.iItemId = OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE;
  423. sampleData_partsizefile.sSCaptionName = sSCaptionName_partsizefile;
  424. sampleData_partsizefile.iItemValType = OTS_ITEM_TYPES.COMBO;
  425. sampleData_partsizefile.bReadOnly = false;
  426. sampleData_partsizefile.sDescriptionInfo = "Particle Table";
  427. sampleData_partsizefile.itemVal = list_partsizelist[0];
  428. sampleData_partsizefile.comboDownList = list_partsizelist;
  429. list.Add(sampleData_partsizefile);
  430. //尺寸计算法
  431. string sSCaptionName8 = table["sscaptionname8"].ToString();
  432. SampleData sampleData13 = new SampleData();
  433. sampleData13.iItemId = OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE;
  434. sampleData13.sSCaptionName = sSCaptionName8;
  435. sampleData13.iItemValType = OTS_ITEM_TYPES.COMBO;
  436. sampleData13.bReadOnly = false;
  437. sampleData13.sDescriptionInfo = "Dimension Calculation Method";
  438. sampleData13.itemVal = "DMAX";
  439. sampleData13.comboDownList = GetSizeCalMethodTypeList();
  440. list.Add(sampleData13);
  441. }
  442. return list;
  443. }
  444. /// <summary>
  445. /// 分发SourceGrid,各选项值改变事件
  446. /// </summary>
  447. /// <param name="tbindex"></param>
  448. /// <param name="typ"></param>
  449. /// <param name="val"></param>
  450. /// <param name="sel"></param>
  451. /// <returns></returns>
  452. public OTSSampleMeaInfo ChangeSouceGrid(int tbindex, OTS_REPORT_PROP_GRID_ITEMS typ, string val, int sel)
  453. {
  454. OTSSampleMeaInfo ret = new OTSSampleMeaInfo();
  455. ret = m_ReportApp.SourceGridDataList[tbindex];
  456. switch (tbindex)
  457. {
  458. case 0:
  459. ret = ChangeSouceGrid_Image(typ, val, sel);
  460. break;
  461. case 1:
  462. ret = ChangeSouceGrid_Grid(typ, val, sel);
  463. break;
  464. case 2:
  465. ret = ChangeSouceGrid_Chart(typ, val, sel);
  466. break;
  467. }
  468. return ret;
  469. }
  470. /// <summary>
  471. /// SourceGrid,分析图页面组合各项方法
  472. /// </summary>
  473. /// <param name="typ"></param>
  474. /// <param name="val"></param>
  475. /// <param name="sel"></param>
  476. /// <returns></returns>
  477. public OTSSampleMeaInfo ChangeSouceGrid_Image(OTS_REPORT_PROP_GRID_ITEMS typ, string val, int sel)
  478. {
  479. OTSSampleMeaInfo ret = new OTSSampleMeaInfo();
  480. ret = m_ReportApp.SourceGridDataList[0];
  481. //string strlist = ret.TSampleParam.sSampleTitleName;
  482. List<OTS_REPORT_PROP_GRID_ITEMS> list_showgrid_item = ret.TSampleParam.List_ShowGrid_Items;
  483. //测量结果数据
  484. if (typ == OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE)
  485. {
  486. if (val.Contains("+"))
  487. {
  488. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE)].itemVal = val;
  489. }
  490. else
  491. {
  492. DataOperation.Model.ResultFile resultFile = m_ReportApp.resultFilesList.Find(s => s.FileName == val);
  493. int index = m_ReportApp.resultFilesList.IndexOf(resultFile);
  494. m_ReportApp.WorkingResult = index;
  495. }
  496. }
  497. //测量图类型
  498. if (typ == OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE)
  499. {
  500. }
  501. ////---------------------------------------------------------------
  502. //测量图显示方式
  503. if (typ == OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE)
  504. {
  505. if (sel == 0)//选择分布图
  506. {
  507. //strlist = ",0,2,3,7,10,13,";
  508. list_showgrid_item = new List<OTS_REPORT_PROP_GRID_ITEMS>(){OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE,//0
  509. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_TYPE,//2
  510. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE,//3
  511. OTS_REPORT_PROP_GRID_ITEMS.PARTICLE_TYPE,//7
  512. OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS,//10
  513. OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE };//13
  514. if (ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE)].comboDownList.IndexOf(ret.SampleDataList[4].itemVal.ToString()) != 0)
  515. {
  516. //strlist = ",0,2,3,7,10,11,12,13,";
  517. list_showgrid_item = new List<OTS_REPORT_PROP_GRID_ITEMS>(){OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE,//0
  518. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_TYPE,//2
  519. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE,//3
  520. OTS_REPORT_PROP_GRID_ITEMS.PARTICLE_TYPE,//7
  521. OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS,//10
  522. OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN,//11
  523. OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MAX,//12
  524. OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE };//13
  525. }
  526. }
  527. else if (sel == 1)//选择排序图时
  528. {
  529. //strlist = ",0,2,3,4,13,";
  530. list_showgrid_item = new List<OTS_REPORT_PROP_GRID_ITEMS>(){OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE,//0
  531. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_TYPE,//2
  532. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE,//3
  533. OTS_REPORT_PROP_GRID_ITEMS.MEASURE_DATA_TYPE,//4
  534. OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE };//13
  535. }
  536. }
  537. //颗粒类型
  538. if (typ == OTS_REPORT_PROP_GRID_ITEMS.PARTICLE_TYPE)
  539. {
  540. }
  541. //测量数据
  542. if (typ == OTS_REPORT_PROP_GRID_ITEMS.MEASURE_DATA_TYPE)
  543. {
  544. if (sel == 0)//全部颗粒类型
  545. {
  546. //strlist = ",0,2,3,4,13,";
  547. list_showgrid_item = new List<OTS_REPORT_PROP_GRID_ITEMS>(){OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE,//0
  548. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_TYPE,//2
  549. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE,//3
  550. OTS_REPORT_PROP_GRID_ITEMS.MEASURE_DATA_TYPE,//4
  551. OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE };//13
  552. }
  553. else if (sel == 1)//分析颗粒类型
  554. {
  555. list_showgrid_item = new List<OTS_REPORT_PROP_GRID_ITEMS>(){OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE,//0
  556. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_TYPE,//2
  557. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE,//3
  558. OTS_REPORT_PROP_GRID_ITEMS.MEASURE_DATA_TYPE,//4
  559. OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE };//13
  560. }
  561. else if (sel == 2)//颗粒尺寸类型
  562. {
  563. list_showgrid_item = new List<OTS_REPORT_PROP_GRID_ITEMS>(){OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE,//0
  564. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_TYPE,//2
  565. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE,//3
  566. OTS_REPORT_PROP_GRID_ITEMS.MEASURE_DATA_TYPE,//4
  567. OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE,//9
  568. OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS,//10
  569. OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE };//13
  570. }
  571. }
  572. //颗粒粒级表
  573. if (typ == OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE)
  574. {
  575. //点击下拉框,级联联动事件
  576. int idx = m_ReportApp.m_DataMgrFun.GetSampleIndexByPropItemName(m_ReportApp.SourceGridData.SampleDataList, OTSIncAReportApp.OTSSampleReportInfo.OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE);
  577. List<string> list_partsize = GetPartSizeList(m_ReportApp.m_RptConfigFile.FileFolderSize + ret.SampleDataList[idx].itemVal.ToString());
  578. string sscaptionname16 = table["sscaptionname16"].ToString();
  579. string sscaptionname18 = table["sscaptionname18"].ToString();
  580. list_partsize.Insert(0, sscaptionname16);//全部
  581. list_partsize.Insert(1, sscaptionname18);//自定义
  582. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE)].itemVal = list_partsize[0];
  583. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE)].comboDownList = list_partsize;
  584. m_ReportApp.m_RptConfigFile.PartSizeFile = ret.SampleDataList[idx].itemVal.ToString();
  585. }
  586. //粒级
  587. if (typ == OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS)
  588. {
  589. switch (sel)
  590. {
  591. case 0:
  592. list_showgrid_item.Remove(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN);//11
  593. list_showgrid_item.Remove(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MAX);//12
  594. break;
  595. case 1:
  596. if (!list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN))
  597. {
  598. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN);//11
  599. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MAX);//12
  600. }
  601. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN)].bReadOnly = false;
  602. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN)].itemVal = "0";
  603. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MAX)].bReadOnly = false;
  604. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MAX)].itemVal = "0";
  605. break;
  606. default:
  607. if (!list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN))
  608. {
  609. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN);//11
  610. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MAX);//12
  611. }
  612. string[] v = ret.SampleDataList[5].itemVal.ToString().Split('~');
  613. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN)].bReadOnly = true;
  614. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MIN)].itemVal = v[0];
  615. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MAX)].bReadOnly = true;
  616. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_MAX)].itemVal = v[1];
  617. break;
  618. }
  619. }
  620. //尺寸计算法
  621. if (typ == OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE)
  622. {
  623. }
  624. //ret.TSampleParam.sSampleTitleName = strlist;
  625. ret.TSampleParam.List_ShowGrid_Items = list_showgrid_item;
  626. ret = FilterData(ret);
  627. return ret;
  628. }
  629. /// <summary>
  630. ///
  631. /// </summary>
  632. /// <param name="in_list_sampledata"></param>
  633. /// <param name="in_orpgi"></param>
  634. /// <returns></returns>
  635. public int GetSampleIndexByPropItemName(List<SampleData> in_list_sampledata, OTS_REPORT_PROP_GRID_ITEMS in_orpgi)
  636. {
  637. for (int i = 0; i < in_list_sampledata.Count; i++)
  638. {
  639. if (in_list_sampledata[i].iItemId == in_orpgi)
  640. {
  641. return i;
  642. }
  643. }
  644. return -1;
  645. }
  646. /// <summary>
  647. /// SourceGrid,Grid表格部份组合各项方法
  648. /// </summary>
  649. /// <param name="typ"></param>
  650. /// <param name="val"></param>
  651. /// <param name="sel"></param>
  652. /// <returns></returns>
  653. public OTSSampleMeaInfo ChangeSouceGrid_Grid(OTS_REPORT_PROP_GRID_ITEMS typ, string val, int sel)
  654. {
  655. OTSSampleMeaInfo ret = new OTSSampleMeaInfo();
  656. ret = m_ReportApp.SourceGridDataList[1];
  657. //string strlist = ret.TSampleParam.sSampleTitleName;
  658. List<OTS_REPORT_PROP_GRID_ITEMS> list_showgrid_item = ret.TSampleParam.List_ShowGrid_Items;
  659. //测量结果数据
  660. if (typ == OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE)
  661. {
  662. if (val.Contains("+"))
  663. {
  664. ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE)].itemVal = val;
  665. }
  666. else
  667. {
  668. DataOperation.Model.ResultFile resultFile = m_ReportApp.resultFilesList.Find(s => s.FileName == val);
  669. int index = m_ReportApp.resultFilesList.IndexOf(resultFile);
  670. m_ReportApp.WorkingResult = index;
  671. }
  672. }
  673. //数据类型
  674. if (typ == OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE_TYPE)
  675. {
  676. }
  677. //数据表类型
  678. if (typ == OTS_REPORT_PROP_GRID_ITEMS.CALCULATE_TABLE_TYPE)
  679. {
  680. switch (sel)
  681. {
  682. case 2://颗粒成份
  683. if (!list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE))//13
  684. {
  685. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE);
  686. }
  687. list_showgrid_item.Remove(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE);//9
  688. break;
  689. case 4://颗粒尺寸分布
  690. if (!list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE))//9
  691. {
  692. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE);
  693. }
  694. if (!list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE))//13
  695. {
  696. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE);
  697. }
  698. break;
  699. default://其它Grid模块不需要,粒级表和尺寸计算法
  700. list_showgrid_item.Remove(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE);//9
  701. //list_showgrid_item.Remove(OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE);//13
  702. break;
  703. }
  704. }
  705. //颗粒粒级表
  706. if (typ == OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE)
  707. {
  708. m_ReportApp.m_RptConfigFile.PartSizeFile = ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE)].itemVal.ToString();
  709. }
  710. //尺寸计算方法
  711. if (typ == OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE)
  712. {
  713. }
  714. //ret.TSampleParam.sSampleTitleName = strlist;
  715. ret.TSampleParam.List_ShowGrid_Items = list_showgrid_item;
  716. ret = FilterData(ret);
  717. return ret;
  718. }
  719. /// <summary>
  720. /// SourceGrid,Chart图表部份组合各项方法
  721. /// </summary>
  722. /// <param name="typ"></param>
  723. /// <param name="val"></param>
  724. /// <param name="sel"></param>
  725. /// <returns></returns>
  726. public OTSSampleMeaInfo ChangeSouceGrid_Chart(OTS_REPORT_PROP_GRID_ITEMS typ, string val, int sel)
  727. {
  728. OTSSampleMeaInfo ret = new OTSSampleMeaInfo();
  729. ret = m_ReportApp.SourceGridDataList[2];
  730. //string strlist = ret.TSampleParam.sSampleTitleName;
  731. List<OTS_REPORT_PROP_GRID_ITEMS> list_showgrid_item = ret.TSampleParam.List_ShowGrid_Items;
  732. //测量结果数据
  733. if (typ == OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE)
  734. {
  735. if (val.Contains("+"))
  736. {
  737. //ret.SampleDataList[1].bReadOnly = true;
  738. //ret.SampleDataList[1].itemVal = ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE)].comboDownList[0];
  739. ret.SampleDataList[0].itemVal = val;
  740. }
  741. else
  742. {
  743. //ret.SampleDataList[1].bReadOnly = false;
  744. DataOperation.Model.ResultFile resultFile = m_ReportApp.resultFilesList.Find(s => s.FileName == val);
  745. int index = m_ReportApp.resultFilesList.IndexOf(resultFile);
  746. m_ReportApp.WorkingResult = index;
  747. }
  748. }
  749. //数据类型
  750. if (typ == OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE_TYPE)
  751. {
  752. }
  753. //数据图类型
  754. if (typ == OTS_REPORT_PROP_GRID_ITEMS.CALCULATE_CHART_TYPE)
  755. {
  756. switch (sel)
  757. {
  758. case 4://三元相图
  759. if (!list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE) && !list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.TRIO_CHART_TYPE) && !list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE))
  760. {
  761. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE);
  762. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE);
  763. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.TRIO_CHART_TYPE);//15
  764. }
  765. else if (!list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.TRIO_CHART_TYPE))
  766. {
  767. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.TRIO_CHART_TYPE);//15
  768. }
  769. break;
  770. case 3://颗粒尺寸分布图
  771. if (!list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE))//9
  772. {
  773. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE);
  774. }
  775. if (!list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE))//13
  776. {
  777. list_showgrid_item.Add(OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE);
  778. }
  779. if (list_showgrid_item.Contains(OTS_REPORT_PROP_GRID_ITEMS.TRIO_CHART_TYPE))//15
  780. {
  781. list_showgrid_item.Remove(OTS_REPORT_PROP_GRID_ITEMS.TRIO_CHART_TYPE);
  782. }
  783. break;
  784. default:
  785. list_showgrid_item.Remove(OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE);
  786. list_showgrid_item.Remove(OTS_REPORT_PROP_GRID_ITEMS.TRIO_CHART_TYPE);//15
  787. break;
  788. }
  789. }
  790. //三元相图模板
  791. if (typ == OTS_REPORT_PROP_GRID_ITEMS.TRIO_CHART_TYPE)
  792. {
  793. }
  794. //颗粒种类
  795. if (typ == OTS_REPORT_PROP_GRID_ITEMS.PARTICLE_TYPE)
  796. {
  797. }
  798. //颗粒粒级表
  799. if (typ == OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE)
  800. {
  801. m_ReportApp.m_RptConfigFile.PartSizeFile = ret.SampleDataList[GetSampleIndexByPropItemName(ret.SampleDataList, OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE)].itemVal.ToString();
  802. }
  803. //尺寸计算方法
  804. if (typ == OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE)
  805. {
  806. }
  807. //ret.TSampleParam.sSampleTitleName = strlist;
  808. ret.TSampleParam.List_ShowGrid_Items = list_showgrid_item;
  809. ret = FilterData(ret);
  810. return ret;
  811. }
  812. /// <summary>
  813. /// 按照枚举字符串,过滤Source掉不显示的项
  814. /// </summary>
  815. /// <param name="source"></param>
  816. /// <returns></returns>
  817. private OTSSampleMeaInfo FilterData(OTSSampleMeaInfo source)
  818. {
  819. OTSSampleMeaInfo ret = new OTSSampleMeaInfo();
  820. ret.TabIndex = source.TabIndex;
  821. //new
  822. List<OTS_REPORT_PROP_GRID_ITEMS> list_shogrid_items = source.TSampleParam.List_ShowGrid_Items;
  823. for (int i = 0; i < source.SampleDataList.Count; i++)
  824. {
  825. if (list_shogrid_items.Contains(source.SampleDataList[i].iItemId))
  826. {
  827. ret.SampleDataList.Add(source.SampleDataList[i]);
  828. }
  829. }
  830. return ret;
  831. }
  832. /// <summary>
  833. /// 获取sourceGrid数据
  834. /// </summary>
  835. /// <param name="SMeasureInfo"></param>
  836. /// <returns></returns>
  837. public bool GetWorkSamplePropertyVal(ref OTSSampleMeaInfo SMeasureInfo)
  838. {
  839. int tabindex = (int)m_ReportApp.m_PropWindow.tabIndex;
  840. if (m_ReportApp.WorkingResult == -1)
  841. {
  842. return false;
  843. }
  844. if (m_ReportApp.SourceGridData.SampleDataList.Count > 0)
  845. {
  846. OTSSampleMeaInfo a = m_ReportApp.SourceGridData;
  847. //if (a.TSampleParam.sSampleTitleName == null)
  848. //{
  849. // a.TSampleParam.sSampleTitleName = m_ReportApp.SourceGridDataListLog[a.TabIndex].TSampleParam.sSampleTitleName;
  850. //}
  851. //new
  852. if (a.TSampleParam.List_ShowGrid_Items == null)
  853. {
  854. a.TSampleParam.List_ShowGrid_Items = m_ReportApp.SourceGridDataListLog[a.TabIndex].TSampleParam.List_ShowGrid_Items;
  855. }
  856. m_ReportApp.SourceGridDataListLog[a.TabIndex] = a;
  857. OTSSampleMeaInfo b = m_ReportApp.SourceGridDataListLog[tabindex];
  858. SMeasureInfo = FilterData(b);
  859. m_ReportApp.SourceGridData = SMeasureInfo;
  860. }
  861. else
  862. {
  863. OTSSampleMeaInfo data = new OTSSampleMeaInfo();
  864. data.TabIndex = 0;
  865. //data.TSampleParam.sSampleTitleName = ",0,2,3,7,9,10,13,";
  866. data.TSampleParam.List_ShowGrid_Items = new List<OTS_REPORT_PROP_GRID_ITEMS> { OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE,//0
  867. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_TYPE,//2
  868. OTS_REPORT_PROP_GRID_ITEMS.IMAGE_DISPLAY_TYPE,//3
  869. OTS_REPORT_PROP_GRID_ITEMS.PARTICLE_TYPE,//7
  870. OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS_TABLE,//9
  871. OTS_REPORT_PROP_GRID_ITEMS.GRAIN_SIZE_CLASS,//10
  872. OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE};//13
  873. data.SampleDataList = GetSourceGridData(0);
  874. m_ReportApp.SourceGridDataList.Add(data);
  875. m_ReportApp.SourceGridDataListLog.Add(data);
  876. OTSSampleMeaInfo data1 = new OTSSampleMeaInfo();
  877. data1.TabIndex = 1;
  878. //data1.TSampleParam.sSampleTitleName = ",0,1,5,";
  879. data1.TSampleParam.List_ShowGrid_Items = new List<OTS_REPORT_PROP_GRID_ITEMS> { OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE,//0
  880. OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE_TYPE,//1
  881. OTS_REPORT_PROP_GRID_ITEMS.CALCULATE_TABLE_TYPE};//5
  882. data1.SampleDataList = GetSourceGridData(1);
  883. m_ReportApp.SourceGridDataList.Add(data1);
  884. m_ReportApp.SourceGridDataListLog.Add(data1);
  885. OTSSampleMeaInfo data2 = new OTSSampleMeaInfo();
  886. data2.TabIndex = 2;
  887. //data2.TSampleParam.sSampleTitleName = ",0,1,6,";
  888. data2.TSampleParam.List_ShowGrid_Items = new List<OTS_REPORT_PROP_GRID_ITEMS> { OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE,//0
  889. OTS_REPORT_PROP_GRID_ITEMS.DATA_SOURCE_TYPE,//1
  890. OTS_REPORT_PROP_GRID_ITEMS.CALCULATE_CHART_TYPE };
  891. //,//6
  892. //OTS_REPORT_PROP_GRID_ITEMS.SIZE_CAL_METHOD_TYPE};//13
  893. data2.SampleDataList = GetSourceGridData(2);
  894. m_ReportApp.SourceGridDataList.Add(data2);
  895. m_ReportApp.SourceGridDataListLog.Add(data2);
  896. switch (tabindex)
  897. {
  898. case 0:
  899. SMeasureInfo = FilterData(data);
  900. break;
  901. case 1:
  902. SMeasureInfo = FilterData(data1);
  903. break;
  904. case 2:
  905. SMeasureInfo = FilterData(data2);
  906. break;
  907. }
  908. m_ReportApp.SourceGridData = SMeasureInfo;
  909. }
  910. return true;
  911. }
  912. #endregion
  913. #region [测量结果treeview]相关封装方法
  914. /// <summary>
  915. /// 获取测量结果treeview树测量结果名
  916. /// </summary>
  917. /// <returns></returns>
  918. public string GetSampleName()
  919. {
  920. //获取样品名
  921. String sWorkSampleName = m_ReportApp.resultFilesList[m_ReportApp.WorkingResult].FileName;
  922. if (null == sWorkSampleName)
  923. {
  924. return "";
  925. }
  926. return sWorkSampleName;
  927. }
  928. #endregion
  929. #region 自定义方法相关
  930. /// <summary>
  931. /// 显示默认图表
  932. /// </summary>
  933. public void ShowsTheDefaultPic()
  934. {
  935. try
  936. {
  937. if (m_ReportApp.resultFilesList.Count > 0)
  938. {
  939. m_ReportApp.m_PropWindow.m_SampleGrid.ShowDataDiagram((int)m_ReportApp.m_PropWindow.tabIndex);
  940. }
  941. }
  942. catch (Exception ex)
  943. {
  944. //日记记录
  945. string str = ex.ToString();
  946. }
  947. }
  948. #endregion
  949. }
  950. }