OTSIncAReportTemplate.cs 68 KB

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