OTSIncAReportTemplate.cs 71 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658
  1. using OTSCommon;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Data;
  5. using System.IO;
  6. using System.Linq;
  7. using System.Windows.Forms;
  8. namespace OTSIncAReportTemplate
  9. {
  10. public partial class OTSIncAReportTemplate : Form
  11. {
  12. #region 全局变量
  13. List<DataTable> list_dt;
  14. MBSZClass m_mbszclass = null;
  15. public XmlConfigUtil xmlutil;
  16. public XmlConfigUtil xmlutil2;
  17. //全局变量,与报告项目同步,共传4个参数
  18. //参数1:是需要打开db数据库的路径
  19. //参数2:是打开报表模板xml文件的路径
  20. //参数3:是要执行查看报表的类型,输出主报表,还是输出颗粒列表
  21. //参数4:打开主报表时是是指定夹杂物的数量,打开颗粒列表时,是颗粒列表显示的范围如,0-50,50-100
  22. //参数5:是要执行查看报表的类型,输出主报表时,指定读取的标记帧图图像范围,如0-50,50-100,输出颗粒列表时无用
  23. //参数6:导出颗粒列表类型
  24. string m_arg1 = "";
  25. string m_arg2 = "";
  26. string m_arg3 = "";
  27. string m_arg4 = "";
  28. string m_arg5 = "";
  29. #endregion
  30. #region 构造函数及窗体加载
  31. public OTSIncAReportTemplate()
  32. {
  33. InitializeComponent();
  34. }
  35. public OTSIncAReportTemplate(string[] args)
  36. {
  37. InitializeComponent();
  38. //if (args.Length == 0)
  39. //{
  40. // MessageBox.Show("请使用报告程序打开模板程序!");
  41. // return;
  42. //}
  43. //if (args.Length != 5)
  44. //{
  45. // string str = "";
  46. // for (int i = 0; i < args.Length; i++)
  47. // {
  48. // str = str + "参数" + (i + 1).ToString() + ":" + args[i].ToString() + Environment.NewLine;
  49. // }
  50. // MessageBox.Show("传入的参数数量不正确,应为5个参数:" + Environment.NewLine + str);
  51. // return;
  52. //}
  53. //方便测试代码分岐
  54. bool bDebug = false;
  55. if (bDebug == false)
  56. {
  57. m_arg1 = args[0].Replace("^", " ");
  58. m_arg2 = args[1].Replace("^", " ");
  59. m_arg3 = args[2].Replace("^", " ");
  60. m_arg4 = args[3].Replace("^", " ");
  61. m_arg5 = args[4].Replace("^", " ");
  62. }
  63. else
  64. {
  65. ////测试
  66. m_arg1 = "C:\\Users\\admin\\Desktop\\马钢\\71-3\\71-3\\Sample71-3\\ReportTemplateDBParticleList.db";
  67. m_arg2 = "./Config/ProData/ReportTemplateConfig.xml";
  68. m_arg3 = "MainReport";
  69. m_arg4 = "100";
  70. m_arg5 = "0-100";
  71. }
  72. //MessageBox.Show(m_arg5);
  73. //初始化xml类
  74. xmlutil = new XmlConfigUtil(m_arg2);
  75. m_mbszclass = new MBSZClass();
  76. list_dt = new List<DataTable>();
  77. }
  78. protected override void SetVisibleCore(bool value)
  79. {
  80. base.SetVisibleCore(value);
  81. }
  82. private void Form1_Load(object sender, EventArgs e)
  83. {
  84. //隐藏窗体
  85. this.WindowState = FormWindowState.Minimized;
  86. //this.ShowInTaskbar = false;
  87. //SetVisibleCore(false);
  88. if (m_arg1 != "")
  89. {
  90. rmReport1 = new RMReportEngine.RMReport();
  91. rmReport1.ModifyPrepared = false;
  92. rmReport1.Init(this, RM.Interop.ReportMachine.TxRMReportType.rmrtReport);
  93. //1300购买的注册码
  94. rmReport1.SetUserInfo("15040732794", "UEsDBBQAAAAIAPZ9ulCdRMtANAAAADUAAAAFAAAAZmlsZTET4mZgYDA0NTAxMDc2Mrc0EVIA8dPMU5LMDBONLC0NzCyTzZJTDROTzc0TDZIskhINLFIBUEsBAhQAFAAAAAgA9n26UJ1Ey0A0AAAANQAAAAUAAAAAAAAAAAAAAAAAAAAAAGZpbGUxUEsFBgAAAAABAAEAMwAAAFcAAAAAAA == ");
  95. //读取xml
  96. //LoadControlsToXml();
  97. LoadMBSZClass();
  98. LoadRouteclass();
  99. //加载显示report
  100. if (m_arg3 == "MainReport")
  101. {
  102. //读取db
  103. LoadReportTemplateDBFile();
  104. ReportTemplatePrint_MainReport();
  105. }
  106. else if (m_arg3 == "ParticleListReport")
  107. {
  108. //读取db
  109. LoadReportTemplateDBFile_ParticleList();
  110. ReportTemplatePrint_PartilceListReport();
  111. }
  112. else if( m_arg3 == "GBReport")
  113. {
  114. LoadReportGBDBFile();
  115. ReportTemplatePrint_GBReport();
  116. }
  117. //File.Delete(m_arg1);
  118. }
  119. //关闭查看报告,则退出进程
  120. this.Close();
  121. Application.Exit();
  122. }
  123. #endregion
  124. #region 显示报表方法
  125. /// <summary>
  126. /// 调用预览查看报表,显示主报表
  127. /// </summary>
  128. private void ReportTemplatePrint_MainReport()
  129. {
  130. DataRelation myRela1;
  131. DataTable ls_resultgrid = list_dt.Where(aa => aa.TableName.Contains("ResultGrid")).ToList()[0];//插入测量结果Grid表格
  132. rmReport1.PreviewOptions.BtnDesignVisible = true;
  133. #region 选择报告模板
  134. if (m_mbszclass.M_KLLBXX.b_ck_kllb_xsmk == true && m_mbszclass.M_YSFXJG.b_ck_ysfx_xsmk == true && m_mbszclass.M_YSFXJG.b_ck_yscf_xsmk == true)
  135. {
  136. rmReport1.LoadFromFile("Resources\\ReportTemplate\\OTS_Report.rmf");
  137. }
  138. else
  139. if (m_mbszclass.M_YSFXJG.b_ck_ysfx_xsmk == false && m_mbszclass.M_YSFXJG.b_ck_yscf_xsmk == false && m_mbszclass.M_KLLBXX.b_ck_kllb_xsmk == true)
  140. {
  141. rmReport1.LoadFromFile("Resources\\ReportTemplate\\groupCancelElement.rmf");
  142. }
  143. else
  144. if (m_mbszclass.M_YSFXJG.b_ck_ysfx_xsmk == false && m_mbszclass.M_YSFXJG.b_ck_yscf_xsmk == false && m_mbszclass.M_KLLBXX.b_ck_kllb_xsmk == false)
  145. {
  146. rmReport1.LoadFromFile("Resources\\ReportTemplate\\groupCancelBlank.rmf");
  147. }
  148. else
  149. {
  150. rmReport1.LoadFromFile("Resources\\ReportTemplate\\groupCancelGrain.rmf");
  151. }
  152. #endregion
  153. rmReport1.AddVariable("ZBT", m_mbszclass.M_SY.str_tb_ZBT, true);
  154. rmReport1.AddVariable("FBT", m_mbszclass.M_SY.str_tb_FBT, true);
  155. rmReport1.AddVariable("YPBH", m_mbszclass.M_SY.str_tb_YPBH, true);
  156. rmReport1.AddVariable("KHH", m_mbszclass.M_YMYJ.str_tb_KHH, true);
  157. rmReport1.AddVariable("CKBZ", m_mbszclass.M_SY.str_tb_CKBZ, true);
  158. rmReport1.AddVariable("RM_YM", m_mbszclass.M_YMYJ.str_tb_ymwb, true);
  159. rmReport1.AddVariable("RM_YJ", m_mbszclass.M_YMYJ.str_tb_yjwb, true);
  160. rmReport1.AddVariable("BZ", m_mbszclass.M_SY.str_bz, true);
  161. #region 判断是否显示
  162. DataTable ls_dt_AreaRatio = list_dt.Where(aa => aa.TableName.Contains("AreaRatio")).ToList()[0];
  163. rmReport1.AddDataSet(ls_dt_AreaRatio, "AreaRatio");
  164. DataTable ls_dt_PicInclusionAreaRatio = list_dt.Where(aa => aa.TableName.Contains("PicInclusionAreaRatio")).ToList()[0];
  165. rmReport1.AddDataSet(ls_dt_PicInclusionAreaRatio, "PicInclusionAreaRatio");
  166. DataTable ls_dt_PicInclusionAreaClassRatio = list_dt.Where(aa => aa.TableName.Contains("Pic_InclusionareaClassRatio")).ToList()[0];
  167. rmReport1.AddDataSet(ls_dt_PicInclusionAreaClassRatio, "Pic_InclusionareaClassRatio");
  168. if (m_mbszclass.M_SYXT.b_ck_syxt_xsmk)//判断三元相图是否显示
  169. {
  170. rmReport1.FindObject("GroupHeader1").Prop["Visible"] = true;
  171. if (m_mbszclass.M_SYXT.str_cb_syxt_mhxssl == "2")
  172. {
  173. DataTable ls_dt_picSYXT = list_dt.Where(aa => aa.TableName.Contains("PicSYXT2T")).ToList()[0];//一排两个三元相图
  174. //rmReport1.FindObject("MasterData18").Prop["Visible"] = false;
  175. List<byte[]> list_by = new List<byte[]>();
  176. for (int i = 0; i < ls_dt_picSYXT.Rows.Count;i++)
  177. {
  178. list_by.Add((byte[])ls_dt_picSYXT.Rows[i][0]);
  179. }
  180. if (list_by.GroupBy(i => i).Where(g => g.Count() > 1).Count() >= 1)
  181. {
  182. MessageBox.Show("图片重复");
  183. }
  184. rmReport1.FindObject("MasterData10").Prop["Visible"] = true;
  185. rmReport1.AddDataSet(ls_dt_picSYXT, "PicSYXT");//三元相图
  186. ls_dt_picSYXT.Dispose();
  187. }
  188. else if (m_mbszclass.M_SYXT.str_cb_syxt_mhxssl == "3")
  189. {
  190. DataTable ls_dt_picSYXT3T = list_dt.Where(aa => aa.TableName.Contains("PicSYXT3T")).ToList()[0];//一排三个三元相图
  191. rmReport1.FindObject("MasterData10").Prop["Visible"] = false;
  192. rmReport1.FindObject("MasterData18").Prop["Visible"] = true;
  193. rmReport1.AddDataSet(ls_dt_picSYXT3T, "PicSYXT3T");
  194. ls_dt_picSYXT3T.Dispose();
  195. //ls_dt_picSYXT3T.Clear();
  196. }
  197. }
  198. if (m_mbszclass.M_SY.b_ck_ypsm)//判断样品说明是否显示
  199. {
  200. rmReport1.AddDataSet(ls_resultgrid, "ResultGrid");
  201. ls_resultgrid.Dispose();
  202. rmReport1.FindObject("MasterData1").Prop["Visible"] = true;
  203. }
  204. else
  205. {
  206. rmReport1.FindObject("MasterData1").Prop["Visible"] = false;
  207. }
  208. if (m_mbszclass.M_KLFXJG.b_ck_klcc_xsmk == false && m_mbszclass.M_KLFXJG.b_cb_jzwfl_xsmk == false)//如果颗粒尺寸分析结果和夹杂物分类图都不显示
  209. {
  210. DataTable dataTable = new DataTable();
  211. rmReport1.AddDataSet(dataTable, "PartSize");
  212. rmReport1.AddDataSet(dataTable, "Particel");
  213. //rmReport1.AddDataSet(dataTable, "PicKL");
  214. dataTable.Dispose();
  215. dataTable.Clear();
  216. rmReport1.FindObject("MasterData2").Prop["Visible"] = false;
  217. rmReport1.FindObject("MasterData126").Prop["Visible"] = false;
  218. //rmReport1.FindObject("MasterData95").Prop["Visible"] = false;
  219. rmReport1.DeletePage(1);
  220. }
  221. else
  222. {
  223. if (m_mbszclass.M_KLFXJG.b_ck_klcc_xsmk)//判断颗粒尺寸分析结果
  224. {
  225. DataTable ls_dt_PartSize = list_dt.Where(aa => aa.TableName.Contains("PartSize")).ToList()[0];//插入 颗粒尺寸表
  226. DataTable ls_dt_Particel = list_dt.Where(aa => aa.TableName.Contains("Particel")).ToList()[0];
  227. DataTable ls_dt_Particel_subdivision = list_dt.Where(aa => aa.TableName.Contains("Particel_subdivision")).ToList()[0];
  228. rmReport1.AddDataSet(ls_dt_PartSize, "PartSize");
  229. rmReport1.AddDataSet(ls_dt_Particel, "Particel");
  230. rmReport1.AddDataSet(ls_dt_Particel_subdivision, "Particel_subdivision");
  231. List<string> vs = new List<string>() { "DMAX", "DMIN", "Area", "FERET" };
  232. string str = vs[m_mbszclass.M_KLFXJG.index_cb_klcc_jsfs];
  233. rmReport1.AddVariable("klccfxjg_jsfx", str, true);
  234. ls_dt_PartSize.Dispose();
  235. //ls_dt_PartSize.Clear();
  236. ls_dt_Particel.Dispose();
  237. //ls_dt_Particel.Clear();
  238. rmReport1.FindObject("MasterData2").Prop["Visible"] = true;
  239. rmReport1.FindObject("MasterData126").Prop["Visible"] = true;
  240. }
  241. else
  242. {
  243. DataTable dataTable = new DataTable();
  244. rmReport1.AddDataSet(dataTable, "PartSize");
  245. rmReport1.AddDataSet(dataTable, "Particel");
  246. dataTable.Dispose();
  247. dataTable.Clear();
  248. rmReport1.FindObject("MasterData2").Prop["Visible"] = false;
  249. rmReport1.FindObject("MasterData126").Prop["Visible"] = false;
  250. }
  251. }
  252. if (m_mbszclass.M_YSFXJG.b_ck_ysfx_xsmk == false && m_mbszclass.M_YSFXJG.b_ck_yscf_xsmk == false)//如果元素分析表和显示元素成分图都不显示
  253. {
  254. }
  255. else
  256. {
  257. if (m_mbszclass.M_YSFXJG.b_ck_ysfx_xsmk)//判断元素分析表是否显示
  258. {
  259. DataTable ls_dt_elementname = list_dt.Where(aa => aa.TableName.Contains("ElementName")).ToList()[0];
  260. DataTable ls_dt_element = list_dt.Where(aa => aa.TableName == "ElementValue").ToList()[0];
  261. rmReport1.AddDataSet(ls_dt_elementname, "ElementName");
  262. rmReport1.AddDataSet(ls_dt_element, "ElementValue");
  263. DataTable ls_dt_ElementalSubstance_Name = list_dt.Where(aa => aa.TableName.Contains("ElementalSubstance_Name")).ToList()[0];
  264. DataTable ls_dt_ElementalSubstance_Value = list_dt.Where(aa => aa.TableName == "ElementalSubstance_Value").ToList()[0];
  265. rmReport1.AddDataSet(ls_dt_ElementalSubstance_Name, "ElementalSubstance_Name");
  266. rmReport1.AddDataSet(ls_dt_ElementalSubstance_Value, "ElementalSubstance_Value");
  267. DataTable ls_dt_ElementSubdivision_Name = list_dt.Where(aa => aa.TableName.Contains("ElementSubdivision_Name")).ToList()[0];
  268. DataTable ls_dt_ElementSubdivision_Value = list_dt.Where(aa => aa.TableName == "ElementSubdivision_Value").ToList()[0];
  269. rmReport1.AddDataSet(ls_dt_ElementSubdivision_Name, "ElementSubdivision_Name");
  270. rmReport1.AddDataSet(ls_dt_ElementSubdivision_Value, "ElementSubdivision_Value");
  271. ls_dt_elementname.Dispose();
  272. ls_dt_element.Dispose();
  273. }
  274. else
  275. {
  276. DataTable dataTable = new DataTable();
  277. rmReport1.AddDataSet(dataTable, "ElementName");
  278. rmReport1.AddDataSet(dataTable, "ElementValue");
  279. dataTable.Dispose();
  280. dataTable.Clear();
  281. rmReport1.FindObject("MasterData3").Prop["Visible"] = false;
  282. rmReport1.FindObject("MasterData42").Prop["Visible"] = false;
  283. }
  284. if (m_mbszclass.M_YSFXJG.b_ck_yscf_xsmk)//判断显示元素成分图
  285. {
  286. DataTable ls_dt_picYS = list_dt.Where(aa => aa.TableName.Contains("PicYS")).ToList()[0];//用于元素图chart
  287. rmReport1.AddDataSet(ls_dt_picYS, "PicYS");
  288. ls_dt_picYS.Dispose();
  289. }
  290. else
  291. {
  292. DataTable dataTable = new DataTable();
  293. rmReport1.AddDataSet(dataTable, "PicYS");
  294. dataTable.Dispose();
  295. dataTable.Clear();
  296. }
  297. }
  298. if (m_mbszclass.M_KLLBXX.b_ck_kllb_xsmk)//判断显示颗粒列表
  299. {
  300. DataTable ls_dt_largest = list_dt.Where(aa => aa.TableName.Contains("Largest20")).ToList()[0];
  301. rmReport1.AddDataSet(ls_dt_largest, "Largest20");
  302. ls_dt_largest.Dispose();
  303. DataTable ls_dt_largest2 = list_dt.Where(aa => aa.TableName.Contains("Largest2")).ToList()[0];
  304. rmReport1.AddDataSet(ls_dt_largest2, "Largest2");
  305. ls_dt_largest2.Dispose();
  306. #region 主副表
  307. DataTable ls_dt_frame = list_dt.Where(aa => aa.TableName.Contains("FrameGraphSubTable")).ToList()[0].Copy();//副表
  308. DataTable ls_dt_fielddt = list_dt.Where(aa => aa.TableName.Contains("field_dt")).ToList()[0].Copy();//帧图主表
  309. DataSet ds = new DataSet("fieldimgds");
  310. ds.Tables.Add(ls_dt_fielddt);
  311. ds.Tables.Add(ls_dt_frame);
  312. myRela1 = new DataRelation("Rela1", ls_dt_fielddt.Columns["FieldId"], ls_dt_frame.Columns["FieldId"],false);
  313. ds.Relations.Add(myRela1);
  314. rmReport1.AddDataSet(ls_dt_fielddt, "CustomersDS");
  315. rmReport1.AddDetailDataSet(ls_dt_frame, "OrdersDS", "CustomersDS", myRela1);
  316. ls_dt_frame.Dispose();
  317. ls_dt_fielddt.Dispose();
  318. #endregion
  319. rmReport1.FindObject("Memo66").Prop["Text"] = m_mbszclass.M_KLLBXX.str_cb_kllb_Sort_p1.ToString();
  320. rmReport1.FindObject("Memo101").Prop["Text"] = m_mbszclass.M_KLLBXX.str_cb_kllb_Sort_p2.ToString();
  321. rmReport1.FindObject("Memo52").Prop["Text"] = m_mbszclass.M_KLLBXX.str_cb_kllb_Sort_p3.ToString();
  322. rmReport1.FindObject("Memo155").Prop["Text"] = m_mbszclass.M_KLLBXX.str_cb_kllb_ChartSort_p1.ToString();
  323. rmReport1.FindObject("Memo154").Prop["Text"] = m_mbszclass.M_KLLBXX.str_cb_kllb_ChartSort_p2.ToString();
  324. rmReport1.FindObject("GroupHeader12").Prop["Visible"] = true;
  325. rmReport1.FindObject("MasterData49").Prop["Visible"] = true;
  326. if (m_mbszclass.M_KLLBXX.b_ck_kllb_ystx == true && m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx != true && m_mbszclass.M_KLLBXX.b_ck_kllb_npxx != true)//原图开,放大图关,能谱关
  327. {
  328. //rmReport1.FindObject("Memo44").Prop["Visible"] = true;
  329. rmReport1.FindObject("Picture46").Prop["Visible"] = true;
  330. rmReport1.FindObject("Picture69").Prop["Visible"] = false;
  331. rmReport1.FindObject("Picture70").Prop["Visible"] = false;
  332. //最原始的数据
  333. //rmReport1.FindObject("Memo44").Prop["Left"] = 0.2;//原图像框
  334. rmReport1.FindObject("Picture46").Prop["Left"] = 0.2;//原图像
  335. rmReport1.FindObject("Picture69").Prop["Left"] = 2.6;//放大图
  336. rmReport1.FindObject("Picture70").Prop["Left"] = 5;//能谱
  337. rmReport1.FindObject("Picture70").Prop["Width"] = 13.8;//能谱长度
  338. }
  339. else if (m_mbszclass.M_KLLBXX.b_ck_kllb_ystx == true && m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx == true && m_mbszclass.M_KLLBXX.b_ck_kllb_npxx != true)//原图开,放大图开,能谱关
  340. {
  341. //rmReport1.FindObject("Memo44").Prop["Visible"] = true;
  342. rmReport1.FindObject("Picture46").Prop["Visible"] = true;
  343. rmReport1.FindObject("Picture69").Prop["Visible"] = true;
  344. rmReport1.FindObject("Picture70").Prop["Visible"] = false;
  345. //rmReport1.FindObject("Memo44").Prop["Left"] = 0.5;//原图像框
  346. rmReport1.FindObject("Picture46").Prop["Left"] = 0.2;//原图像
  347. rmReport1.FindObject("Picture69").Prop["Left"] = 2.6;//放大图
  348. rmReport1.FindObject("Picture70").Prop["Left"] = 5;//能谱
  349. rmReport1.FindObject("Picture70").Prop["Width"] = 13.8;//能谱长度
  350. }
  351. else if (m_mbszclass.M_KLLBXX.b_ck_kllb_ystx == true && m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx == true && m_mbszclass.M_KLLBXX.b_ck_kllb_npxx == true)//原图开,放大图开,能谱开
  352. {
  353. //rmReport1.FindObject("Memo44").Prop["Visible"] = true;
  354. rmReport1.FindObject("Picture46").Prop["Visible"] = true;
  355. rmReport1.FindObject("Picture69").Prop["Visible"] = true;
  356. rmReport1.FindObject("Picture70").Prop["Visible"] = true;
  357. //rmReport1.FindObject("Memo44").Prop["Left"] = 0.5;//原图像框
  358. rmReport1.FindObject("Picture46").Prop["Left"] = 0.2;//原图像
  359. rmReport1.FindObject("Picture69").Prop["Left"] = 2.6;//放大图
  360. rmReport1.FindObject("Picture70").Prop["Left"] = 5;//能谱
  361. rmReport1.FindObject("Picture70").Prop["Width"] = 13.8;//能谱长度
  362. }
  363. else if (m_mbszclass.M_KLLBXX.b_ck_kllb_ystx == true && m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx == false && m_mbszclass.M_KLLBXX.b_ck_kllb_npxx == true)//原图开,放大图关,能谱开
  364. {
  365. //rmReport1.FindObject("Memo44").Prop["Visible"] = true;
  366. rmReport1.FindObject("Picture46").Prop["Visible"] = true;
  367. rmReport1.FindObject("Picture69").Prop["Visible"] = false;
  368. rmReport1.FindObject("Picture70").Prop["Visible"] = true;
  369. //rmReport1.FindObject("Memo44").Prop["Left"] = 0.5;//原图像框
  370. rmReport1.FindObject("Picture46").Prop["Left"] = 0.2;//原图像
  371. rmReport1.FindObject("Picture70").Prop["Left"] = 2.6;
  372. rmReport1.FindObject("Picture70").Prop["Width"] = 16.2;
  373. }
  374. else if (m_mbszclass.M_KLLBXX.b_ck_kllb_ystx != true && m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx == true && m_mbszclass.M_KLLBXX.b_ck_kllb_npxx == true)//原图关,放大图开,能谱开
  375. {
  376. //rmReport1.FindObject("Memo44").Prop["Visible"] = false;
  377. rmReport1.FindObject("Picture46").Prop["Visible"] = false;
  378. rmReport1.FindObject("Picture69").Prop["Visible"] = true;
  379. rmReport1.FindObject("Picture70").Prop["Visible"] = true;
  380. rmReport1.FindObject("Picture69").Prop["Left"] = 0.2;
  381. rmReport1.FindObject("Picture70").Prop["Left"] = 2.6;
  382. rmReport1.FindObject("Picture70").Prop["Width"] = 16.2;
  383. }
  384. else if (m_mbszclass.M_KLLBXX.b_ck_kllb_ystx != true && m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx != true && m_mbszclass.M_KLLBXX.b_ck_kllb_npxx == true)//原图关,放大图关,能谱开
  385. {
  386. //rmReport1.FindObject("Memo44").Prop["Visible"] = false;
  387. rmReport1.FindObject("Picture46").Prop["Visible"] = false;
  388. rmReport1.FindObject("Picture69").Prop["Visible"] = false;
  389. rmReport1.FindObject("Picture70").Prop["Visible"] = true;
  390. rmReport1.FindObject("Picture70").Prop["Left"] = 0.5;
  391. rmReport1.FindObject("Picture70").Prop["Width"] = 18.6;
  392. }
  393. else if (m_mbszclass.M_KLLBXX.b_ck_kllb_ystx != true && m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx != true && m_mbszclass.M_KLLBXX.b_ck_kllb_npxx != true) //原图关,放大图关,能谱关
  394. {
  395. //rmReport1.FindObject("Memo44").Prop["Visible"] = false;
  396. rmReport1.FindObject("Picture46").Prop["Visible"] = false;
  397. rmReport1.FindObject("Picture69").Prop["Visible"] = false;
  398. rmReport1.FindObject("Picture70").Prop["Visible"] = false;
  399. //最原始的数据
  400. //rmReport1.FindObject("Memo44").Prop["Left"] = 0.5;//原图像框
  401. rmReport1.FindObject("Picture46").Prop["Left"] = 1.4;//原图像
  402. rmReport1.FindObject("Picture69").Prop["Left"] = 2.9;//放大图
  403. rmReport1.FindObject("Picture70").Prop["Left"] = 5.3;//能谱
  404. rmReport1.FindObject("Picture70").Prop["Width"] = 13;//能谱长度
  405. }
  406. else if (m_mbszclass.M_KLLBXX.b_ck_kllb_ystx != true && m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx == true && m_mbszclass.M_KLLBXX.b_ck_kllb_npxx != true)//原图关,放大图开,能谱关
  407. {
  408. rmReport1.FindObject("Memo44").Prop["Visible"] = false;
  409. rmReport1.FindObject("Picture46").Prop["Visible"] = false;
  410. rmReport1.FindObject("Picture69").Prop["Visible"] = true;
  411. rmReport1.FindObject("Picture70").Prop["Visible"] = false;
  412. rmReport1.FindObject("Picture69").Prop["Left"] = 0.2;//放大图
  413. }
  414. }
  415. else
  416. {
  417. }
  418. #endregion
  419. rmReport1.ShowReport();
  420. //修复reportmachine的bug,将路径重新定位到当前路径
  421. Directory.SetCurrentDirectory(AppDomain.CurrentDomain.BaseDirectory);
  422. rmReport1.Dispose();
  423. //回收内存
  424. list_dt.Clear();
  425. }
  426. private void ReportTemplatePrint_GBReport()
  427. {
  428. rmReport1.PreviewOptions.BtnDesignVisible = true;
  429. rmReport1.LoadFromFile("Resources\\ReportTemplate\\GB.rmf");
  430. DataTable ls_dt_GB1_A = list_dt.Where(aa => aa.TableName.Contains("GB1_A")).ToList()[0];
  431. DataTable ls_dt_GB1_B = list_dt.Where(aa => aa.TableName.Contains("GB1_B")).ToList()[0];
  432. DataTable ls_dt_GB1_C = list_dt.Where(aa => aa.TableName.Contains("GB1_C")).ToList()[0];
  433. DataTable ls_dt_GB1_D = list_dt.Where(aa => aa.TableName.Contains("GB1_D")).ToList()[0];
  434. DataTable ls_dt_GB1_DS = list_dt.Where(aa => aa.TableName.Contains("GB1_DS")).ToList()[0];
  435. DataTable ls_dt_GB2_A = list_dt.Where(aa => aa.TableName.Contains("GB2_A")).ToList()[0];
  436. DataTable ls_dt_GB2_B = list_dt.Where(aa => aa.TableName.Contains("GB2_B")).ToList()[0];
  437. DataTable ls_dt_GB2_C = list_dt.Where(aa => aa.TableName.Contains("GB2_C")).ToList()[0];
  438. DataTable ls_dt_GB2_D = list_dt.Where(aa => aa.TableName.Contains("GB2_D")).ToList()[0];
  439. DataTable ls_dt_GB2_D_sulfide = list_dt.Where(aa => aa.TableName.Contains("GB2_D_sulfide")).ToList()[0];
  440. DataTable ls_dt_GB2_DS = list_dt.Where(aa => aa.TableName.Contains("GB2_DS")).ToList()[0];
  441. DataTable ls_resultgrid = list_dt.Where(aa => aa.TableName.Contains("ResultGrid")).ToList()[0];//插入测量结果Grid表格
  442. rmReport1.AddDataSet(ls_dt_GB1_A, "GB1_A");
  443. rmReport1.AddDataSet(ls_dt_GB1_B, "GB1_B");
  444. rmReport1.AddDataSet(ls_dt_GB1_C, "GB1_C");
  445. rmReport1.AddDataSet(ls_dt_GB1_D, "GB1_D");
  446. rmReport1.AddDataSet(ls_dt_GB1_DS, "GB1_DS");
  447. rmReport1.AddDataSet(ls_dt_GB2_A, "GB2_A");
  448. rmReport1.AddDataSet(ls_dt_GB2_B, "GB2_B");
  449. rmReport1.AddDataSet(ls_dt_GB2_C, "GB2_C");
  450. rmReport1.AddDataSet(ls_dt_GB2_D, "GB2_D");
  451. rmReport1.AddDataSet(ls_dt_GB2_D_sulfide, "GB2_D_sulfide");
  452. rmReport1.AddDataSet(ls_dt_GB2_DS, "GB2_DS");
  453. rmReport1.AddDataSet(ls_resultgrid, "ResultGrid");
  454. rmReport1.ShowReport();
  455. //修复reportmachine的bug,将路径重新定位到当前路径
  456. Directory.SetCurrentDirectory(AppDomain.CurrentDomain.BaseDirectory);
  457. rmReport1.Dispose();
  458. //回收内存
  459. list_dt.Clear();
  460. }
  461. /// <summary>
  462. /// 调用预览查看报表,显示颗粒列表
  463. /// </summary>
  464. private void ReportTemplatePrint_PartilceListReport()
  465. {
  466. DataTable ls_dt_largest = list_dt.Where(aa => aa.TableName.Contains("Largest3")).ToList()[0];
  467. rmReport1.LoadFromFile("Resources\\ReportTemplate\\Largest.rmf");
  468. rmReport1.AddDataSet(ls_dt_largest, "Largest3");
  469. rmReport1.PreviewOptions.BtnDesignVisible = true;
  470. rmReport1.ShowReport();
  471. //修复reportmachine的bug,将路径重新定位到当前路径
  472. Directory.SetCurrentDirectory(AppDomain.CurrentDomain.BaseDirectory);
  473. rmReport1.Dispose();
  474. }
  475. #endregion
  476. #region 读取XML模板配置文件
  477. ///<summary>
  478. ///读取xml配置文件
  479. /// </summary>
  480. private void LoadControlsToXml()
  481. {
  482. string path = string.Empty;
  483. OpenFileDialog Load = new OpenFileDialog();
  484. Load.Filter = "PXML文件|*.xml";
  485. Load.InitialDirectory = @System.Windows.Forms.Application.StartupPath + "\\Config\\ProData";
  486. if (Load.ShowDialog() == DialogResult.OK)
  487. path = Load.FileName;//赋值目录
  488. if (path != string.Empty)
  489. {
  490. //tb_mblj.Text = path;
  491. m_mbszclass.M_DZ.route = path;
  492. XmlConfigUtil xmlutil = new XmlConfigUtil(path);
  493. //首页
  494. m_mbszclass.M_SY.str_tb_ZBT = xmlutil.Read("M_SY", "str_tb_ZBT");
  495. m_mbszclass.M_SY.str_tb_FBT = xmlutil.Read("M_SY", "str_tb_FBT");
  496. m_mbszclass.M_SY.str_tb_YPBH = xmlutil.Read("M_SY", "str_tb_YPBH");
  497. m_mbszclass.M_SY.str_tb_CKBZ = xmlutil.Read("M_SY", "str_tb_CKBZ");
  498. m_mbszclass.M_SY.b_ck_ypsm = Convert.ToBoolean(xmlutil.Read("M_SY", "b_ck_ypsm"));
  499. m_mbszclass.M_SY.b_ck_jggk = Convert.ToBoolean(xmlutil.Read("M_SY", "b_ck_jggk"));
  500. //页眉页脚
  501. m_mbszclass.M_YMYJ.str_tb_ymwb = xmlutil.Read("M_YMYJ", "str_tb_ymwb");
  502. m_mbszclass.M_YMYJ.str_tb_KHH = xmlutil.Read("M_YMYJ", "str_tb_KHH");
  503. m_mbszclass.M_YMYJ.b_ck_ym = Convert.ToBoolean(xmlutil.Read("M_YMYJ", "b_ck_ym"));
  504. m_mbszclass.M_YMYJ.str_tb_yjwb = xmlutil.Read("M_YMYJ", "str_tb_yjwb");
  505. MessageBox.Show(m_mbszclass.M_YMYJ.str_tb_ymwb+"!!"+m_mbszclass.M_YMYJ.str_tb_KHH+"!!"+m_mbszclass.M_YMYJ.str_tb_yjwb);
  506. //颗粒分析结果
  507. m_mbszclass.M_KLFXJG.b_ck_klcc_xsmk = Convert.ToBoolean(xmlutil.Read("M_KLFXJG", "b_ck_klcc_xsmk"));//是否显示模块
  508. m_mbszclass.M_KLFXJG.index_cb_klcc_jsfs = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_klcc_jsfs"));//计算方式
  509. m_mbszclass.M_KLFXJG.index_cb_klcc_ljb = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_klcc_ljb"));//粒级表
  510. m_mbszclass.M_KLFXJG.index_cb_klcc_klfw = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_klcc_klfw"));//颗粒范围
  511. m_mbszclass.M_KLFXJG.b_cb_jzwfl_xsmk = Convert.ToBoolean(xmlutil.Read("M_KLFXJG", "b_cb_jzwfl_xsmk"));//是否显示该模块
  512. m_mbszclass.M_KLFXJG.index_cb_jzwfl_xstx = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_jzwfl_xstx"));//选择图像
  513. m_mbszclass.M_KLFXJG.index_cb_jzwfl_jsfs = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_jzwfl_jsfs"));//计算方式
  514. m_mbszclass.M_KLFXJG.index_cb_jzwfl_ljb = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_jzwfl_ljb"));//粒级表
  515. m_mbszclass.M_KLFXJG.index_cb_jzwfl_klfw = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_jzwfl_klfw"));//颗粒范围
  516. //元素分析结果
  517. m_mbszclass.M_YSFXJG.b_ck_ysfx_xsmk = Convert.ToBoolean(xmlutil.Read("M_YSFXJG", "b_ck_ysfx_xsmk")); //是否显示模块
  518. m_mbszclass.M_YSFXJG.index_cb_yxfx_jsfs = Convert.ToInt32(xmlutil.Read("M_YSFXJG", "index_cb_yxfx_jsfs")); //计算方式
  519. m_mbszclass.M_YSFXJG.index_cb_ysfx_klfw = Convert.ToInt32(xmlutil.Read("M_YSFXJG", "index_cb_ysfx_klfw")); //颗粒范围
  520. m_mbszclass.M_YSFXJG.str_tb_ysfx_xsys = xmlutil.Read("M_YSFXJG", "str_tb_ysfx_xsys"); //显示元素
  521. m_mbszclass.M_YSFXJG.list_str_tb_ysfx_xsys.Clear();
  522. for (int i = 0; i < 100; i++) //取得所有元素列表
  523. {
  524. string str = xmlutil.Read("M_YSFXJG", "list_str_tb_ysfx_xsys", "YS" + i.ToString());
  525. if (str == null)
  526. {
  527. break;
  528. }
  529. else
  530. {
  531. m_mbszclass.M_YSFXJG.list_str_tb_ysfx_xsys.Add(str);
  532. }
  533. }
  534. m_mbszclass.M_YSFXJG.b_ck_yscf_xsmk = Convert.ToBoolean(xmlutil.Read("M_YSFXJG", "b_ck_yscf_xsmk")); //是否显示模块
  535. m_mbszclass.M_YSFXJG.index_cb_yscf_xstx = Convert.ToInt32(xmlutil.Read("M_YSFXJG", "index_cb_yscf_xstx")); //显示图形
  536. m_mbszclass.M_YSFXJG.index_cb_yscf_jsfs = Convert.ToInt32(xmlutil.Read("M_YSFXJG", "index_cb_yscf_jsfs")); //计算方式
  537. m_mbszclass.M_YSFXJG.index_cb_yscf_klfw = Convert.ToInt32(xmlutil.Read("M_YSFXJG", "index_cb_yscf_klfw")); //颗粒范围
  538. m_mbszclass.M_YSFXJG.str_tb_yscf_ysxx = xmlutil.Read("M_YSFXJG", "str_tb_yscf_ysxx"); //显示元素
  539. m_mbszclass.M_YSFXJG.list_str_tb_yscf_ysxx.Clear();
  540. for (int i = 0; i < 100; i++) //取得所有元素列表
  541. {
  542. string str = xmlutil.Read("M_YSFXJG", "list_str_tb_yscf_ysxx", "YS" + i.ToString());
  543. if (str == null)
  544. {
  545. break;
  546. }
  547. else
  548. {
  549. m_mbszclass.M_YSFXJG.list_str_tb_yscf_ysxx.Add(str);
  550. }
  551. }
  552. //三元相图
  553. m_mbszclass.M_SYXT.b_ck_syxt_xsmk = Convert.ToBoolean(xmlutil.Read("M_SYXT", "b_ck_syxt_xsmk")); //是否显示模块
  554. m_mbszclass.M_SYXT.index_cb_syxt_jsfs = Convert.ToInt32(xmlutil.Read("M_SYXT", "index_cb_syxt_jsfs")); //计算方式
  555. m_mbszclass.M_SYXT.index_cb_syxt_klfw = Convert.ToInt32(xmlutil.Read("M_SYXT", "index_cb_syxt_klfw")); //颗粒范围
  556. m_mbszclass.M_SYXT.str_cb_syxt_mhxssl = xmlutil.Read("M_SYXT", "str_cb_syxt_mhxssl"); //每行显示数量
  557. m_mbszclass.M_SYXT.list_lbv_syxt_mblb.Clear();
  558. for (int i = 0; i < 100; i++) //取得所有模板列表
  559. {
  560. string str = xmlutil.Read("M_SYXT", "list_lbv_syxt_mblb", "MB" + i.ToString());
  561. if (str == null)
  562. {
  563. break;
  564. }
  565. else
  566. {
  567. m_mbszclass.M_SYXT.list_lbv_syxt_mblb.Add(str);
  568. }
  569. }
  570. m_mbszclass.M_SYXT.list_lbv_syxt_mblb_index.Clear();
  571. for (int i = 0; i < 100; i++) //取得所有模板列表 索引
  572. {
  573. string str = xmlutil.Read("M_SYXT", "list_lbv_syxt_mblb_index", "MBIndex" + i.ToString());
  574. if (str == null)
  575. {
  576. break;
  577. }
  578. else
  579. {
  580. m_mbszclass.M_SYXT.list_lbv_syxt_mblb_index.Add(Convert.ToInt32(str));
  581. }
  582. }
  583. //颗粒列表信息
  584. m_mbszclass.M_KLLBXX.b_ck_kllb_xsmk = Convert.ToBoolean(xmlutil.Read("M_KLLBXX", "b_ck_kllb_xsmk")); //是否显示模块
  585. m_mbszclass.M_KLLBXX.index_cb_kllb_jsfs = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "index_cb_kllb_jsfs")); //计算方式
  586. m_mbszclass.M_KLLBXX.index_cb_kllb_klfw = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "index_cb_kllb_klfw")); //颗粒范围
  587. m_mbszclass.M_KLLBXX.int_tb_kllb_ylsx = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "int_tb_kllb_ylsx")); //数量上限
  588. m_mbszclass.M_KLLBXX.str_tb_kllb_sxys = xmlutil.Read("M_KLLBXX", "str_tb_kllb_sxys"); //显示元素
  589. m_mbszclass.M_KLLBXX.list_str_tb_lllb_sxys.Clear();
  590. for (int i = 0; i < 100; i++) //取得所有元素列表
  591. {
  592. string str = xmlutil.Read("M_KLLBXX", "list_str_tb_lllb_sxys", "YS" + i.ToString());
  593. if (str == null)
  594. {
  595. break;
  596. }
  597. else
  598. {
  599. m_mbszclass.M_KLLBXX.list_str_tb_lllb_sxys.Add(str);
  600. }
  601. }
  602. m_mbszclass.M_KLLBXX.b_ck_kllb_ystx = Convert.ToBoolean(xmlutil.Read("M_KLLBXX", "b_ck_kllb_ystx")); //原始图像
  603. m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx = Convert.ToBoolean(xmlutil.Read("M_KLLBXX", "b_ck_kllb_fdtx")); //放大图像
  604. m_mbszclass.M_KLLBXX.b_ck_kllb_npxx = Convert.ToBoolean(xmlutil.Read("M_KLLBXX", "b_ck_kllb_npxx")); //能谱图像
  605. }
  606. }
  607. ///<summary>
  608. ///从配置文件中读取报告模板信息
  609. /// </summary>
  610. private void LoadRouteclass()
  611. {
  612. string strPath2 = "";
  613. if (m_mbszclass.M_DZ.route == null)
  614. {
  615. //strPath2 = strPath;
  616. m_mbszclass.M_DZ.route = m_arg2;
  617. }
  618. else
  619. if (m_mbszclass.M_DZ.route == "")
  620. {
  621. //strPath2 = strPath;
  622. m_mbszclass.M_DZ.route = m_arg2;
  623. }
  624. else
  625. {
  626. strPath2 = m_mbszclass.M_DZ.route;
  627. }
  628. xmlutil2 = new XmlConfigUtil(strPath2);
  629. //首页
  630. m_mbszclass.M_SY.str_tb_ZBT = xmlutil2.Read("M_SY", "str_tb_ZBT");
  631. m_mbszclass.M_SY.str_tb_FBT = xmlutil2.Read("M_SY", "str_tb_FBT");
  632. m_mbszclass.M_SY.str_tb_YPBH = xmlutil2.Read("M_SY", "str_tb_YPBH");
  633. m_mbszclass.M_SY.str_tb_CKBZ = xmlutil2.Read("M_SY", "str_tb_CKBZ");
  634. m_mbszclass.M_SY.b_ck_ypsm = Convert.ToBoolean(xmlutil2.Read("M_SY", "b_ck_ypsm"));
  635. m_mbszclass.M_SY.b_ck_jggk = Convert.ToBoolean(xmlutil2.Read("M_SY", "b_ck_jggk"));
  636. m_mbszclass.M_SY.str_bz = xmlutil2.Read("M_SY", "str_bz");
  637. //页眉页脚
  638. m_mbszclass.M_YMYJ.str_tb_ymwb = xmlutil2.Read("M_YMYJ", "str_tb_ymwb");
  639. m_mbszclass.M_YMYJ.str_tb_KHH = xmlutil2.Read("M_YMYJ", "str_tb_KHH");
  640. m_mbszclass.M_YMYJ.b_ck_ym = Convert.ToBoolean(xmlutil2.Read("M_YMYJ", "b_ck_ym"));
  641. m_mbszclass.M_YMYJ.str_tb_yjwb = xmlutil2.Read("M_YMYJ", "str_tb_yjwb");
  642. //颗粒分析结果
  643. m_mbszclass.M_KLFXJG.b_ck_klcc_xsmk = Convert.ToBoolean(xmlutil2.Read("M_KLFXJG", "b_ck_klcc_xsmk"));//是否显示模块
  644. m_mbszclass.M_KLFXJG.index_cb_klcc_jsfs = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_klcc_jsfs"));//计算方式
  645. m_mbszclass.M_KLFXJG.index_cb_klcc_ljb = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_klcc_ljb"));//粒级表
  646. m_mbszclass.M_KLFXJG.index_cb_klcc_klfw = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_klcc_klfw"));//颗粒范围
  647. m_mbszclass.M_KLFXJG.b_cb_jzwfl_xsmk = Convert.ToBoolean(xmlutil2.Read("M_KLFXJG", "b_cb_jzwfl_xsmk"));//是否显示该模块
  648. m_mbszclass.M_KLFXJG.index_cb_jzwfl_xstx = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_jzwfl_xstx"));//选择图像
  649. m_mbszclass.M_KLFXJG.index_cb_jzwfl_jsfs = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_jzwfl_jsfs"));//计算方式
  650. m_mbszclass.M_KLFXJG.index_cb_jzwfl_ljb = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_jzwfl_ljb"));//粒级表
  651. m_mbszclass.M_KLFXJG.index_cb_jzwfl_klfw = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_jzwfl_klfw"));//颗粒范围
  652. //元素分析结果
  653. m_mbszclass.M_YSFXJG.b_ck_ysfx_xsmk = Convert.ToBoolean(xmlutil2.Read("M_YSFXJG", "b_ck_ysfx_xsmk")); //是否显示模块
  654. m_mbszclass.M_YSFXJG.index_cb_yxfx_jsfs = Convert.ToInt32(xmlutil2.Read("M_YSFXJG", "index_cb_yxfx_jsfs")); //计算方式
  655. m_mbszclass.M_YSFXJG.index_cb_ysfx_klfw = Convert.ToInt32(xmlutil2.Read("M_YSFXJG", "index_cb_ysfx_klfw")); //颗粒范围
  656. m_mbszclass.M_YSFXJG.str_tb_ysfx_xsys = xmlutil2.Read("M_YSFXJG", "str_tb_ysfx_xsys"); //显示元素
  657. m_mbszclass.M_YSFXJG.list_str_tb_ysfx_xsys.Clear();
  658. for (int i = 0; i < 100; i++) //取得所有元素列表
  659. {
  660. string str = xmlutil2.Read("M_YSFXJG", "list_str_tb_ysfx_xsys", "YS" + i.ToString());
  661. if (str == null)
  662. {
  663. break;
  664. }
  665. else
  666. {
  667. m_mbszclass.M_YSFXJG.list_str_tb_ysfx_xsys.Add(str);
  668. }
  669. }
  670. m_mbszclass.M_YSFXJG.b_ck_yscf_xsmk = Convert.ToBoolean(xmlutil2.Read("M_YSFXJG", "b_ck_yscf_xsmk")); //是否显示模块
  671. m_mbszclass.M_YSFXJG.index_cb_yscf_xstx = Convert.ToInt32(xmlutil2.Read("M_YSFXJG", "index_cb_yscf_xstx")); //显示图形
  672. m_mbszclass.M_YSFXJG.index_cb_yscf_jsfs = Convert.ToInt32(xmlutil2.Read("M_YSFXJG", "index_cb_yscf_jsfs")); //计算方式
  673. m_mbszclass.M_YSFXJG.index_cb_yscf_klfw = Convert.ToInt32(xmlutil2.Read("M_YSFXJG", "index_cb_yscf_klfw")); //颗粒范围
  674. m_mbszclass.M_YSFXJG.str_tb_yscf_ysxx = xmlutil2.Read("M_YSFXJG", "str_tb_yscf_ysxx"); //显示元素
  675. m_mbszclass.M_YSFXJG.list_str_tb_yscf_ysxx.Clear();
  676. for (int i = 0; i < 100; i++) //取得所有元素列表
  677. {
  678. string str = xmlutil2.Read("M_YSFXJG", "list_str_tb_yscf_ysxx", "YS" + i.ToString());
  679. if (str == null)
  680. {
  681. break;
  682. }
  683. else
  684. {
  685. m_mbszclass.M_YSFXJG.list_str_tb_yscf_ysxx.Add(str);
  686. }
  687. }
  688. //三元相图
  689. m_mbszclass.M_SYXT.b_ck_syxt_xsmk = Convert.ToBoolean(xmlutil2.Read("M_SYXT", "b_ck_syxt_xsmk")); //是否显示模块
  690. m_mbszclass.M_SYXT.index_cb_syxt_jsfs = Convert.ToInt32(xmlutil2.Read("M_SYXT", "index_cb_syxt_jsfs")); //计算方式
  691. m_mbszclass.M_SYXT.index_cb_syxt_klfw = Convert.ToInt32(xmlutil2.Read("M_SYXT", "index_cb_syxt_klfw")); //颗粒范围
  692. m_mbszclass.M_SYXT.str_cb_syxt_mhxssl = xmlutil2.Read("M_SYXT", "str_cb_syxt_mhxssl"); //每行显示数量
  693. m_mbszclass.M_SYXT.list_lbv_syxt_mblb.Clear();
  694. for (int i = 0; i < 100; i++) //取得所有模板列表
  695. {
  696. string str = xmlutil2.Read("M_SYXT", "list_lbv_syxt_mblb", "MB" + i.ToString());
  697. if (str == null)
  698. {
  699. break;
  700. }
  701. else
  702. {
  703. m_mbszclass.M_SYXT.list_lbv_syxt_mblb.Add(str);
  704. }
  705. }
  706. m_mbszclass.M_SYXT.list_lbv_syxt_mblb_index.Clear();
  707. for (int i = 0; i < 100; i++) //取得所有模板列表 索引
  708. {
  709. string str = xmlutil2.Read("M_SYXT", "list_lbv_syxt_mblb_index", "MBIndex" + i.ToString());
  710. if (str == null)
  711. {
  712. break;
  713. }
  714. else
  715. {
  716. m_mbszclass.M_SYXT.list_lbv_syxt_mblb_index.Add(Convert.ToInt32(str));
  717. }
  718. }
  719. //颗粒列表信息
  720. m_mbszclass.M_KLLBXX.b_ck_kllb_xsmk = Convert.ToBoolean(xmlutil2.Read("M_KLLBXX", "b_ck_kllb_xsmk")); //是否显示模块
  721. m_mbszclass.M_KLLBXX.index_cb_kllb_jsfs = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "index_cb_kllb_jsfs")); //计算方式
  722. m_mbszclass.M_KLLBXX.index_cb_kllb_klfw = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "index_cb_kllb_klfw")); //颗粒范围
  723. m_mbszclass.M_KLLBXX.int_tb_kllb_ylsx = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "int_tb_kllb_ylsx")); //数量上限
  724. m_mbszclass.M_KLLBXX.str_tb_kllb_sxys = xmlutil2.Read("M_KLLBXX", "str_tb_kllb_sxys"); //显示元素
  725. m_mbszclass.M_KLLBXX.list_str_tb_lllb_sxys.Clear();
  726. for (int i = 0; i < 100; i++) //取得所有元素列表
  727. {
  728. string str = xmlutil2.Read("M_KLLBXX", "list_str_tb_lllb_sxys", "YS" + i.ToString());
  729. if (str == null)
  730. {
  731. break;
  732. }
  733. else
  734. {
  735. m_mbszclass.M_KLLBXX.list_str_tb_lllb_sxys.Add(str);
  736. }
  737. }
  738. m_mbszclass.M_KLLBXX.b_ck_kllb_ystx = Convert.ToBoolean(xmlutil2.Read("M_KLLBXX", "b_ck_kllb_ystx")); //原始图像
  739. m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx = Convert.ToBoolean(xmlutil2.Read("M_KLLBXX", "b_ck_kllb_fdtx")); //放大图像
  740. m_mbszclass.M_KLLBXX.b_ck_kllb_npxx = Convert.ToBoolean(xmlutil2.Read("M_KLLBXX", "b_ck_kllb_npxx")); //能谱图像
  741. m_mbszclass.M_KLLBXX.str_cb_kllb_Sort_p1 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_sort_p1"));//颗粒列表列第一个可选参数
  742. m_mbszclass.M_KLLBXX.str_cb_kllb_Sort_p2 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_sort_p2"));//颗粒列表列第二个可选参数
  743. m_mbszclass.M_KLLBXX.str_cb_kllb_Sort_p3 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_sort_p3"));//颗粒列表列第三个可选参数
  744. m_mbszclass.M_KLLBXX.str_cb_kllb_ChartSort_p1 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_chartSort_p1"));//帧图表列第一个可选参数
  745. m_mbszclass.M_KLLBXX.str_cb_kllb_ChartSort_p2 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_chartSort_p2"));//帧图表列第二个可选参数
  746. }
  747. /// <summary>
  748. /// 从配置文件中读取报告模板路径
  749. /// </summary>
  750. private void LoadMBSZClass()
  751. {
  752. //文件路径
  753. m_mbszclass.M_DZ.route = xmlutil.Read("M_address", "Path");
  754. if (m_mbszclass.M_DZ.route == "")
  755. {
  756. //tb_mblj.Text = strPath;
  757. m_mbszclass.M_DZ.route = m_arg2;
  758. }
  759. else
  760. if (File.Exists(m_mbszclass.M_DZ.route))
  761. {
  762. //tb_mblj.Text = m_mbszclass.M_DZ.route;
  763. }
  764. else
  765. {
  766. //tb_mblj.Text = strPath;
  767. m_mbszclass.M_DZ.route = m_arg2;
  768. }
  769. }
  770. #endregion
  771. #region 读取DB数据库文件
  772. /// <summary>
  773. /// 读取DB数据库文件,主报表部份
  774. /// </summary>
  775. private void LoadReportTemplateDBFile()
  776. {
  777. string strpath = m_arg1;//db数据库路径
  778. SqLiteHelper sh = new SqLiteHelper("data source='" + strpath + "'");
  779. list_dt.Clear();
  780. DataTable ls_ResultGrid = sh.ExecuteQuery("select * from ResultGrid");
  781. ls_ResultGrid.TableName = "ResultGrid";
  782. list_dt.Add(ls_ResultGrid);
  783. DataTable ls_FrameGraphSubTable = sh.ExecuteQuery("select * from FrameGraphSubTable ");
  784. ls_FrameGraphSubTable.TableName = "FrameGraphSubTable";
  785. list_dt.Add(ls_FrameGraphSubTable);
  786. DataTable ls_Largest20 = sh.ExecuteQuery("select * from Largest20");
  787. ls_Largest20.TableName = "Largest20";
  788. list_dt.Add(ls_Largest20);
  789. DataTable ls_AreaRatio = sh.ExecuteQuery("select * from AreaRatio");
  790. ls_AreaRatio.TableName = "AreaRatio";
  791. list_dt.Add(ls_AreaRatio);
  792. DataTable ls_field_dt = sh.ExecuteQuery("select * from field_dt ");
  793. ls_field_dt.TableName = "field_dt";
  794. list_dt.Add(ls_field_dt);
  795. DataTable ls_ElementName = sh.ExecuteQuery("select * from ElementName");
  796. ls_ElementName.TableName = "ElementName";
  797. list_dt.Add(ls_ElementName);
  798. DataTable ls_ElementValue = sh.ExecuteQuery("select * from ElementValue");
  799. ls_ElementValue.TableName = "ElementValue";
  800. list_dt.Add(ls_ElementValue);
  801. DataTable ls_PartSize = sh.ExecuteQuery("select * from PartSize");
  802. ls_PartSize.TableName = "PartSize";
  803. list_dt.Add(ls_PartSize);
  804. DataTable ls_Particel = sh.ExecuteQuery("select * from Particel");
  805. ls_Particel.TableName = "Particel";
  806. list_dt.Add(ls_Particel);
  807. DataTable ls_Particel_subdivision = sh.ExecuteQuery("select * from Particel_subdivision");
  808. ls_Particel_subdivision.TableName = "Particel_subdivision";
  809. list_dt.Add(ls_Particel_subdivision);
  810. DataTable ls_PicYS = sh.ExecuteQuery("select * from PicYS");
  811. ls_PicYS.TableName = "PicYS";
  812. list_dt.Add(ls_PicYS);
  813. DataTable ls_PicInclusionAreaRatio = sh.ExecuteQuery("select * from PicInclusionAreaRatio");
  814. ls_PicInclusionAreaRatio.TableName = "PicInclusionAreaRatio";
  815. list_dt.Add(ls_PicInclusionAreaRatio);
  816. DataTable ls_PicInclusionAreaClassRatio = sh.ExecuteQuery("select * from Pic_InclusionareaClassRatio");
  817. ls_PicInclusionAreaClassRatio.TableName = "Pic_InclusionareaClassRatio";
  818. list_dt.Add(ls_PicInclusionAreaClassRatio);
  819. DataTable ls_PicSYXT2T = sh.ExecuteQuery("select * from PicSYXT2T");
  820. ls_PicSYXT2T.TableName = "PicSYXT2T";
  821. list_dt.Add(ls_PicSYXT2T);
  822. DataTable ls_PicSYXT3T = sh.ExecuteQuery("select * from PicSYXT3T");
  823. ls_PicSYXT3T.TableName = "PicSYXT3T";
  824. list_dt.Add(ls_PicSYXT3T);
  825. DataTable ls_ElementalSubstance_Name = sh.ExecuteQuery("select * from ElementalSubstance_Name");
  826. ls_ElementalSubstance_Name.TableName = "ElementalSubstance_Name";
  827. list_dt.Add(ls_ElementalSubstance_Name);
  828. DataTable ls_ElementalSubstance_Value = sh.ExecuteQuery("select * from ElementalSubstance_Value");
  829. ls_ElementalSubstance_Value.TableName = "ElementalSubstance_Value";
  830. list_dt.Add(ls_ElementalSubstance_Value);
  831. DataTable ls_ElementSubdivision_Name = sh.ExecuteQuery("select * from ElementSubdivision_Name");
  832. ls_ElementSubdivision_Name.TableName = "ElementSubdivision_Name";
  833. list_dt.Add(ls_ElementSubdivision_Name);
  834. DataTable ls_ElementSubdivision_Value = sh.ExecuteQuery("select * from ElementSubdivision_Value");
  835. ls_ElementSubdivision_Value.TableName = "ElementSubdivision_Value";
  836. list_dt.Add(ls_ElementSubdivision_Value);
  837. }
  838. /// <summary>
  839. /// 读取DB数据库文件,颗粒列表部份
  840. /// </summary>
  841. private void LoadReportTemplateDBFile_ParticleList()
  842. {
  843. string strpath = m_arg1;//db数据库路径
  844. SqLiteHelper sh = new SqLiteHelper("data source='" + strpath + "'");
  845. list_dt.Clear();
  846. string strmix = m_arg4.Substring(0, m_arg4.IndexOf("-"));
  847. string strmax = m_arg4.Substring(m_arg4.IndexOf("-") + 1, m_arg4.Length - m_arg4.IndexOf("-") - 1);
  848. DataTable ls_Largest3 = sh.ExecuteQuery("select * from largest3 where cast(pid as int) > " + strmix + " and cast(pid as int) < " + strmax + " ");
  849. ls_Largest3.TableName = "Largest3";
  850. list_dt.Add(ls_Largest3);
  851. }
  852. /// <summary>
  853. /// 读取DB数据库文件,国标部分
  854. /// </summary>
  855. private void LoadReportGBDBFile()
  856. {
  857. string strpath = m_arg1;//db数据库路径
  858. SqLiteHelper sh = new SqLiteHelper("data source='" + strpath + "'");
  859. list_dt.Clear();
  860. DataTable ls_ResultGrid = sh.ExecuteQuery("select * from ResultGrid");
  861. ls_ResultGrid.TableName = "ResultGrid";
  862. list_dt.Add(ls_ResultGrid);
  863. DataTable ls_GB1_A = sh.ExecuteQuery("select * from GB1_A");
  864. ls_GB1_A.TableName = "GB1_A";
  865. list_dt.Add(ls_GB1_A);
  866. DataTable ls_GB1_B = sh.ExecuteQuery("select * from GB1_B");
  867. ls_GB1_B.TableName = "GB1_B";
  868. list_dt.Add(ls_GB1_B);
  869. DataTable ls_GB1_C = sh.ExecuteQuery("select * from GB1_C");
  870. ls_GB1_C.TableName = "GB1_C";
  871. list_dt.Add(ls_GB1_C);
  872. DataTable ls_GB1_D = sh.ExecuteQuery("select * from GB1_D");
  873. ls_GB1_D.TableName = "GB1_D";
  874. list_dt.Add(ls_GB1_D);
  875. DataTable ls_GB1_DS = sh.ExecuteQuery("select * from GB1_DS");
  876. ls_GB1_DS.TableName = "GB1_DS";
  877. list_dt.Add(ls_GB1_DS);
  878. DataTable ls_GB2_A = sh.ExecuteQuery("select * from GB2_A");
  879. ls_GB2_A.TableName = "GB2_A";
  880. list_dt.Add(ls_GB2_A);
  881. DataTable ls_GB2_B = sh.ExecuteQuery("select * from GB2_B");
  882. ls_GB2_B.TableName = "GB2_B";
  883. list_dt.Add(ls_GB2_B);
  884. DataTable ls_GB2_C = sh.ExecuteQuery("select * from GB2_C");
  885. ls_GB2_C.TableName = "GB2_C";
  886. list_dt.Add(ls_GB2_C);
  887. DataTable ls_GB2_D = sh.ExecuteQuery("select * from GB2_D");
  888. ls_GB2_D.TableName = "GB2_D";
  889. list_dt.Add(ls_GB2_D);
  890. DataTable ls_GB2_D_sulfide = sh.ExecuteQuery("select * from GB2_D_sulfide");
  891. ls_GB2_D_sulfide.TableName = "GB2_D_sulfide";
  892. list_dt.Add(ls_GB2_D_sulfide);
  893. DataTable ls_GB2_DS = sh.ExecuteQuery("select * from GB2_DS");
  894. ls_GB2_DS.TableName = "GB2_DS";
  895. list_dt.Add(ls_GB2_DS);
  896. }
  897. #endregion
  898. #region 回收内存
  899. /// <summary>
  900. /// 回收内存
  901. /// </summary>
  902. public void FlushMemory()
  903. {
  904. //回收内存
  905. MemoryManagement mm = new MemoryManagement();
  906. mm.FlushMemory();
  907. }
  908. public class MemoryManagement
  909. {
  910. [System.Runtime.InteropServices.DllImport("kernel32.dll")]
  911. public static extern bool SetProcessWorkingSetSize(IntPtr proc, int min, int max);
  912. public void FlushMemory()
  913. {
  914. GC.Collect();
  915. GC.WaitForPendingFinalizers();
  916. if (Environment.OSVersion.Platform == PlatformID.Win32NT)
  917. { SetProcessWorkingSetSize(System.Diagnostics.Process.GetCurrentProcess().Handle, -1, -1); }
  918. }
  919. }
  920. [System.Runtime.InteropServices.DllImport("coredll.dll")]
  921. [return: System.Runtime.InteropServices.MarshalAs(System.Runtime.InteropServices.UnmanagedType.Bool)]
  922. public static extern bool DeleteObject(IntPtr hgdiobj);
  923. private void timer1_Tick(object sender, EventArgs e)
  924. {
  925. FlushMemory();
  926. }
  927. #endregion
  928. }
  929. #region 模板设置类
  930. /// <summary>
  931. /// 模板设置类
  932. /// </summary>
  933. public class MBSZClass
  934. {
  935. //#region 文件路径
  936. public DZ M_DZ { get; set; }
  937. //#endregion
  938. #region 属性
  939. /// <summary>
  940. /// 首页
  941. /// </summary>
  942. public SY M_SY { get; set; }
  943. /// <summary>
  944. /// 页眉页脚
  945. /// </summary>
  946. public YMYJ M_YMYJ { get; set; }
  947. /// <summary>
  948. /// 颗粒分析结果
  949. /// </summary>
  950. public KLFXJG M_KLFXJG { get; set; }
  951. /// <summary>
  952. /// 元素分析结果
  953. /// </summary>
  954. public YSFXJG M_YSFXJG { get; set; }
  955. /// <summary>
  956. /// 三元相图
  957. /// </summary>
  958. public SYXT M_SYXT { get; set; }
  959. /// <summary>
  960. /// 颗粒列表信息
  961. /// </summary>
  962. public KLLBXX M_KLLBXX { get; set; }
  963. #endregion
  964. #region 构造函数
  965. public MBSZClass()
  966. {
  967. M_SY = new SY();
  968. M_YMYJ = new YMYJ();
  969. M_KLFXJG = new KLFXJG();
  970. M_YSFXJG = new YSFXJG();
  971. M_YSFXJG.list_str_tb_yscf_ysxx = new List<string>();
  972. M_YSFXJG.list_str_tb_ysfx_xsys = new List<string>();
  973. M_SYXT = new SYXT();
  974. M_SYXT.list_lbv_syxt_mblb = new List<string>();
  975. M_SYXT.list_lbv_syxt_mblb_index = new List<int>();
  976. M_KLLBXX = new KLLBXX();
  977. M_KLLBXX.list_str_tb_lllb_sxys = new List<string>();
  978. M_DZ = new DZ();
  979. }
  980. #endregion
  981. public class DZ
  982. {
  983. public string route { get; set; }
  984. }
  985. #region 首页部份
  986. public class SY
  987. {
  988. /// <summary>
  989. /// 主标题
  990. /// </summary>
  991. public string str_tb_ZBT { get; set; }
  992. /// <summary>
  993. /// 副标题
  994. /// </summary>
  995. public string str_tb_FBT { get; set; }
  996. /// <summary>
  997. /// 样品编号
  998. /// </summary>
  999. public string str_tb_YPBH { get; set; }
  1000. /// <summary>
  1001. /// 参考标准
  1002. /// </summary>
  1003. public string str_tb_CKBZ { get; set; }
  1004. /// <summary>
  1005. /// 是否显示样品说明
  1006. /// </summary>
  1007. public bool b_ck_ypsm { get; set; }
  1008. /// <summary>
  1009. /// 是否显示结果概况
  1010. /// </summary>
  1011. public bool b_ck_jggk { get; set; }
  1012. /// <summary>
  1013. /// 备注
  1014. /// </summary>
  1015. public string str_bz { get; set; }
  1016. }
  1017. #endregion
  1018. #region 页眉页脚部份
  1019. public class YMYJ
  1020. {
  1021. /// <summary>
  1022. /// 页眉文本
  1023. /// </summary>
  1024. public string str_tb_ymwb { get; set; }
  1025. /// <summary>
  1026. /// 客户号
  1027. /// </summary>
  1028. public string str_tb_KHH { get; set; }
  1029. /// <summary>
  1030. /// 是否显示页码
  1031. /// </summary>
  1032. public bool b_ck_ym { get; set; }
  1033. /// <summary>
  1034. /// 页脚文本
  1035. /// </summary>
  1036. public string str_tb_yjwb { get; set; }
  1037. }
  1038. #endregion
  1039. #region 颗粒分析结果部份
  1040. public class KLFXJG
  1041. {
  1042. /// <summary>
  1043. /// 是否显示颗粒尺寸分析结果表
  1044. /// </summary>
  1045. public bool b_ck_klcc_xsmk { get; set; }
  1046. /// <summary>
  1047. ///颗粒尺寸分析结果表 计算方式文本
  1048. /// </summary>
  1049. public string str_cb_klcc_jsfs { get; set; }
  1050. /// <summary>
  1051. ///颗粒尺寸分析结果表 计算方式索引
  1052. /// </summary>
  1053. public int index_cb_klcc_jsfs { get; set; }
  1054. /// <summary>
  1055. ///颗粒尺寸分析结果表 粒级表文本
  1056. /// </summary>
  1057. public string str_cb_klcc_ljb { get; set; }
  1058. /// <summary>
  1059. ///颗粒尺寸分析结果表 粒级表索引
  1060. /// </summary>
  1061. public int index_cb_klcc_ljb { get; set; }
  1062. /// <summary>
  1063. ///颗粒尺寸分析结果表 颗粒选择范围文本
  1064. /// </summary>
  1065. public string str_cb_klcc_klfw { get; set; }
  1066. /// <summary>
  1067. ///颗粒尺寸分析结果表 颗粒选择范围索引
  1068. /// </summary>
  1069. public int index_cb_klcc_klfw { get; set; }
  1070. /// <summary>
  1071. /// 夹杂物分类图 是否显示该模块
  1072. /// </summary>
  1073. public bool b_cb_jzwfl_xsmk { get; set; }
  1074. /// <summary>
  1075. ///夹杂物分类图 显示图形选择文本
  1076. /// </summary>
  1077. public string str_cb_jzwfl_xstx { get; set; }
  1078. /// <summary>
  1079. ///夹杂物分类图 显示图形 选择索引
  1080. /// </summary>
  1081. public int index_cb_jzwfl_xstx { get; set; }
  1082. /// <summary>
  1083. ///夹杂物分类图 计算方式 选择文本
  1084. /// </summary>
  1085. public string str_cb_jzwfl_jsfs { get; set; }
  1086. /// <summary>
  1087. ///夹杂物分类图 计算方式 选择索引
  1088. /// </summary>
  1089. public int index_cb_jzwfl_jsfs { get; set; }
  1090. /// <summary>
  1091. ///夹杂物分类图 粒级表 选择文本
  1092. /// </summary>
  1093. public string str_cb_jzwfl_ljb { get; set; }
  1094. /// <summary>
  1095. ///夹杂物分类图 粒级表 选择索引
  1096. /// </summary>
  1097. public int index_cb_jzwfl_ljb { get; set; }
  1098. /// <summary>
  1099. ///夹杂物分类图 颗粒范围 选择文本
  1100. /// </summary>
  1101. public string str_cb_jzwfl_klfw { get; set; }
  1102. /// <summary>
  1103. ///夹杂物分类图 颗粒范围 选择索引
  1104. /// </summary>
  1105. public int index_cb_jzwfl_klfw { get; set; }
  1106. }
  1107. #endregion
  1108. #region 元素分析结果部份
  1109. public class YSFXJG
  1110. {
  1111. /// <summary>
  1112. /// 元素分析表 是否显示该模块
  1113. /// </summary>
  1114. public bool b_ck_ysfx_xsmk { get; set; }
  1115. /// <summary>
  1116. /// 元素分析表 计算方式 选择文本
  1117. /// </summary>
  1118. public string str_cb_yxfx_jsfs { get; set; }
  1119. /// <summary>
  1120. /// 元素分析表 计算方式 选择索引
  1121. /// </summary>
  1122. public int index_cb_yxfx_jsfs { get; set; }
  1123. /// <summary>
  1124. /// 元素分析表 颗粒范围 选择文本
  1125. /// </summary>
  1126. public string str_cb_ysfx_klfw { get; set; }
  1127. /// <summary>
  1128. /// 元素分析表 颗粒范围 选择索引
  1129. /// </summary>
  1130. public int index_cb_ysfx_klfw { get; set; }
  1131. /// <summary>
  1132. /// 元素分析表 显示元素显示文本
  1133. /// </summary>
  1134. public string str_tb_ysfx_xsys { get; set; }
  1135. /// <summary>
  1136. /// 元素分析表 显示元素拆分元素列表
  1137. /// </summary>
  1138. public List<string> list_str_tb_ysfx_xsys { get; set; }
  1139. /// <summary>
  1140. /// 元素成份图 是否显示该模块
  1141. /// </summary>
  1142. public bool b_ck_yscf_xsmk { get; set; }
  1143. /// <summary>
  1144. /// 元素成份图 显示图形 文本
  1145. /// </summary>
  1146. public string str_cb_yscf_xstx { get; set; }
  1147. /// <summary>
  1148. /// 元素成份图 显示图形 索引
  1149. /// </summary>
  1150. public int index_cb_yscf_xstx { get; set; }
  1151. /// <summary>
  1152. /// 元素成份图 计算方式 文本
  1153. /// </summary>
  1154. public string str_cb_yscf_jsfs { get; set; }
  1155. /// <summary>
  1156. /// 元素成份图 计算方式 索引
  1157. /// </summary>
  1158. public int index_cb_yscf_jsfs { get; set; }
  1159. /// <summary>
  1160. /// 元素成份图 颗粒范围 文本
  1161. /// </summary>
  1162. public string str_cb_yscf_klfw { get; set; }
  1163. /// <summary>
  1164. /// 元素成份图 颗粒范围 索引
  1165. /// </summary>
  1166. public int index_cb_yscf_klfw { get; set; }
  1167. /// <summary>
  1168. /// 元素成份图 元素信息
  1169. /// </summary>
  1170. public string str_tb_yscf_ysxx { get; set; }
  1171. /// <summary>
  1172. /// 元素成份图 元素信息列表拆分字符列表
  1173. /// </summary>
  1174. public List<string> list_str_tb_yscf_ysxx { get; set; }
  1175. }
  1176. #endregion
  1177. #region 三元相图部份
  1178. public class SYXT
  1179. {
  1180. /// <summary>
  1181. /// 三元相图 是否显示该模块
  1182. /// </summary>
  1183. public bool b_ck_syxt_xsmk { get; set; }
  1184. /// <summary>
  1185. /// 计算方式 文本
  1186. /// </summary>
  1187. public string str_cb_syxt_jsfs { get; set; }
  1188. /// <summary>
  1189. /// 计算方式 索引
  1190. /// </summary>
  1191. public int index_cb_syxt_jsfs { get; set; }
  1192. /// <summary>
  1193. /// 颗粒范围 文本
  1194. /// </summary>
  1195. public string str_cb_syxt_klfw { get; set; }
  1196. /// <summary>
  1197. /// 颗粒范围 索引
  1198. /// </summary>
  1199. public int index_cb_syxt_klfw { get; set; }
  1200. /// <summary>
  1201. /// 粒级表信息 文本
  1202. /// </summary>
  1203. public string str_cb_syxt_ljb { get; set; }
  1204. /// <summary>
  1205. /// 粒级表信息 索引
  1206. /// </summary>
  1207. public int index_cb_syxt_ljb { get; set; }
  1208. /// <summary>
  1209. /// 每行显示数量 文本
  1210. /// </summary>
  1211. public string str_cb_syxt_mhxssl { get; set; }
  1212. /// <summary>
  1213. /// 每行显示数量 索引
  1214. /// </summary>
  1215. public int index_cb_syxt_mhxssl { get; set; }
  1216. /// <summary>
  1217. /// 三元相图模板集合列表
  1218. /// </summary>
  1219. public List<string> list_lbv_syxt_mblb { get; set; }
  1220. /// <summary>
  1221. /// 三元相图模板索引集合列表
  1222. /// </summary>
  1223. public List<int> list_lbv_syxt_mblb_index { get; set; }
  1224. }
  1225. #endregion
  1226. #region 颗粒列表信息部份
  1227. public class KLLBXX
  1228. {
  1229. /// <summary>
  1230. /// 颗粒列表 是否显示该模块
  1231. /// </summary>
  1232. public bool b_ck_kllb_xsmk { get; set; }
  1233. /// <summary>
  1234. /// 颗粒列表 计算方式 文本
  1235. /// </summary>
  1236. public string str_cb_kllb_jsfs { get; set; }
  1237. /// <summary>
  1238. /// 颗粒列表 计算方式 索引
  1239. /// </summary>
  1240. public int index_cb_kllb_jsfs { get; set; }
  1241. /// <summary>
  1242. /// 颗粒列表 颗粒范围 文本
  1243. /// </summary>
  1244. public string str_cb_kllb_klfw { get; set; }
  1245. /// <summary>
  1246. /// 颗粒列表 颗粒范围 索引
  1247. /// </summary>
  1248. public int index_cb_kllb_klfw { get; set; }
  1249. /// <summary>
  1250. /// 颗粒列表 数量上限
  1251. /// </summary>
  1252. public int int_tb_kllb_ylsx { get; set; }
  1253. /// <summary>
  1254. /// 颗粒列表 显示元素
  1255. /// </summary>
  1256. public string str_tb_kllb_sxys { get; set; }
  1257. /// <summary>
  1258. /// 颗粒列表 显示元素拆分元素列表
  1259. /// </summary>
  1260. public List<string> list_str_tb_lllb_sxys { get; set; }
  1261. /// <summary>
  1262. /// 颗粒列表 是否显示原始图像
  1263. /// </summary>
  1264. public bool b_ck_kllb_ystx { get; set; }
  1265. /// <summary>
  1266. /// 颗粒列表 是否显示放大图像
  1267. /// </summary>
  1268. public bool b_ck_kllb_fdtx { get; set; }
  1269. /// <summary>
  1270. /// 颗粒列表 是否显示能谱信息
  1271. /// </summary>
  1272. public bool b_ck_kllb_npxx { get; set; }
  1273. /// <summary>
  1274. /// 颗粒排序表第一个可选参数
  1275. /// </summary>
  1276. public string str_cb_kllb_Sort_p1 { get; set; }
  1277. /// <summary>
  1278. /// 颗粒排序表第二个可选参数
  1279. /// </summary>
  1280. public string str_cb_kllb_Sort_p2 { get; set; }
  1281. /// <summary>
  1282. /// 颗粒排序表第三个可选参数
  1283. /// </summary>
  1284. public string str_cb_kllb_Sort_p3 { get; set; }
  1285. /// <summary>
  1286. /// 帧图表第一个可选参数
  1287. /// </summary>
  1288. public string str_cb_kllb_ChartSort_p1 { get; set; }
  1289. /// <summary>
  1290. /// 帧图第二个可选参数
  1291. /// </summary>
  1292. public string str_cb_kllb_ChartSort_p2 { get; set; }
  1293. }
  1294. #endregion
  1295. }
  1296. #endregion
  1297. #region 保存ini结构类
  1298. /// <summary>
  1299. /// 内容部份包含结构类
  1300. /// </summary>
  1301. public class TemplateContent
  1302. {
  1303. private string mkm = ""; //模块名
  1304. private int ix = 0; //位置x
  1305. private int iy = 0; //位置y
  1306. private string sjlx = ""; //数据类型
  1307. private string ljb = ""; //粒级表
  1308. private string ccjsfs = ""; //尺寸计算方式
  1309. private string syxtmb = ""; //三元相图模板
  1310. /// <summary>
  1311. /// 模块名
  1312. /// </summary>
  1313. public string MKM
  1314. {
  1315. get { return mkm; }
  1316. set { mkm = value; }
  1317. }
  1318. /// <summary>
  1319. /// 坐标x
  1320. /// </summary>
  1321. public int IX
  1322. {
  1323. get { return ix; }
  1324. set { ix = value; }
  1325. }
  1326. /// <summary>
  1327. /// 坐标y
  1328. /// </summary>
  1329. public int IY
  1330. {
  1331. get { return iy; }
  1332. set { iy = value; }
  1333. }
  1334. /// <summary>
  1335. /// 数据类型,全部颗粒,选择颗粒
  1336. /// </summary>
  1337. public string SJLX
  1338. {
  1339. get { return sjlx; }
  1340. set { sjlx = value; }
  1341. }
  1342. /// <summary>
  1343. /// 所使用粒级表的名称
  1344. /// </summary>
  1345. public string LJB
  1346. {
  1347. get { return ljb; }
  1348. set { ljb = value; }
  1349. }
  1350. /// <summary>
  1351. /// 尺寸计算方式,直径,面积,费雷特直径,等效圆直径,最长直径,最短直径
  1352. /// </summary>
  1353. public string CCJSFS
  1354. {
  1355. get { return ccjsfs; }
  1356. set { ccjsfs = value; }
  1357. }
  1358. /// <summary>
  1359. /// 三元相图模板
  1360. /// </summary>
  1361. public string SYXTMB
  1362. {
  1363. get { return syxtmb; }
  1364. set { syxtmb = value; }
  1365. }
  1366. }
  1367. /// <summary>
  1368. /// 整个模板结构包含类
  1369. /// </summary>
  1370. public class TemplateInfo
  1371. {
  1372. //页眉部份
  1373. private string logopath = ""; //logo路径
  1374. private string ym_xsmc = ""; //报告名称
  1375. //页脚部份
  1376. private string yj_xsmc = ""; //公司名称
  1377. //内容部份
  1378. public List<TemplateContent> mouble_s = new List<TemplateContent>();//内容类列表,包含多个
  1379. /// <summary>
  1380. /// LOGO的图像路径
  1381. /// </summary>
  1382. public string LOGOPath
  1383. {
  1384. get { return logopath; }
  1385. set { logopath = value; }
  1386. }
  1387. /// <summary>
  1388. /// 报告名称
  1389. /// </summary>
  1390. public string YM_XSMC
  1391. {
  1392. get { return ym_xsmc; }
  1393. set { ym_xsmc = value; }
  1394. }
  1395. /// <summary>
  1396. /// 报告名称字体
  1397. /// </summary>
  1398. public string YJ_XSMC
  1399. {
  1400. get { return yj_xsmc; }
  1401. set { yj_xsmc = value; }
  1402. }
  1403. /// <summary>
  1404. /// 模板内容页列表
  1405. /// </summary>
  1406. public List<TemplateContent> MOUBLE_S
  1407. {
  1408. get { return mouble_s; }
  1409. set { mouble_s = value; }
  1410. }
  1411. }
  1412. #endregion
  1413. }