OTSReport_Export.cs 96 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134
  1. using OTSIncAReportApp.Controls;
  2. using OTSIncAReportApp.DataOperation.DataAccess;
  3. using OTSCommon.Model;
  4. using OTSIncAReportApp.OTSSampleReportInfo;
  5. using OTSIncAReportApp.OTSTemplateDesigner;
  6. using OTSIncAReportApp.SysMgrTools;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.ComponentModel;
  10. using System.Data;
  11. using System.Data.SQLite;
  12. using System.Diagnostics;
  13. using System.Drawing;
  14. using System.IO;
  15. using System.Linq;
  16. using System.Windows.Forms;
  17. using System.Xml;
  18. using OTSIncAReportApp._1_UI.OTSTemplateDesigner;
  19. using DevExpress.XtraReports.UI;
  20. using OTSIncAReportApp.ReportTemplate;
  21. namespace OTSIncAReportApp
  22. {
  23. public partial class OTSReport_Export : Form
  24. {
  25. #region 全局变量
  26. public string m_thread_flag = "无"; //线程操作的标识
  27. public string m_str_tmpbitmappath = "d:\\1.bmp"; //存放临时图片 的路径名和文件名
  28. public string m_str_tmpbitmappath2 = "d:\\2.bmp";
  29. public string m_str_tmpdocxpath = "d:\\1.doc";
  30. public string m_strDBpath = ""; //报表模板数据库文件
  31. public string m_strDBpathGB = ""; //报告国标导出
  32. public string m_strDBpath_ParticleList = ""; //报表模板,颗粒列表数据库文件
  33. public int m_SelectedIndex = 0;
  34. System.Collections.Hashtable table;
  35. public frmReportApp m_ReportApp = null; //报告项目总进程对象
  36. public string m_export_type = "Excel"; //导出文件的格式类型Excel,Word,Pdf
  37. Export_ReportTemplate m_export_reporttemplate;
  38. public string strPath = "./Config/ProData/ReportTemplateConfig.xml"; //报告模板设置文件的路径
  39. public string strPath2;
  40. public XmlConfigUtil xmlutil;
  41. public XmlConfigUtil xmlutil2;
  42. public MBSZClass m_mbszclass = null;
  43. OTS_DEVReport DEVReport;
  44. GBReport GB_Report;
  45. /*public bool ReportExporting = false;*///判断报告是不在是在导出的过程中
  46. #endregion
  47. #region 条件参数变量
  48. /// <summary>
  49. /// 选择的数据类型
  50. /// </summary>
  51. public string SJLX { get; set; }
  52. /// <summary>
  53. /// 尺寸计算方法
  54. /// </summary>
  55. public string CCJSFF { get; set; }
  56. /// <summary>
  57. /// 粒级表
  58. /// </summary>
  59. public string LJB { get; set; }
  60. /// <summary>
  61. /// 三元相图模板
  62. /// </summary>
  63. public string SYXTMB { get; set; }
  64. #endregion
  65. #region 模板设置类
  66. /// <summary>
  67. /// 模板设置类
  68. /// </summary>
  69. public class MBSZClass
  70. {
  71. public DZ M_DZ { get; set; }
  72. #region 属性
  73. /// <summary>
  74. /// 首页
  75. /// </summary>
  76. public SY M_SY { get; set; }
  77. /// <summary>
  78. /// 页眉页脚
  79. /// </summary>
  80. public YMYJ M_YMYJ { get; set; }
  81. /// <summary>
  82. /// 颗粒分析结果
  83. /// </summary>
  84. public KLFXJG M_KLFXJG { get; set; }
  85. /// <summary>
  86. /// 元素分析结果
  87. /// </summary>
  88. public YSFXJG M_YSFXJG { get; set; }
  89. /// <summary>
  90. /// 三元相图
  91. /// </summary>
  92. public SYXT M_SYXT { get; set; }
  93. /// <summary>
  94. /// 颗粒列表信息
  95. /// </summary>
  96. public KLLBXX M_KLLBXX { get; set; }
  97. /// <summary>
  98. /// 夹杂物占比
  99. /// </summary>
  100. public JZWZB M_JZWZB { get; set; }
  101. #endregion
  102. #region 构造函数
  103. public MBSZClass()
  104. {
  105. M_SY = new SY();
  106. M_YMYJ = new YMYJ();
  107. M_KLFXJG = new KLFXJG();
  108. M_YSFXJG = new YSFXJG();
  109. M_YSFXJG.list_str_tb_yscf_ysxx = new List<string>();
  110. M_YSFXJG.list_str_tb_ysfx_xsys = new List<string>();
  111. M_SYXT = new SYXT();
  112. M_SYXT.list_lbv_syxt_mblb = new List<string>();
  113. M_SYXT.list_lbv_syxt_mblb_index = new List<int>();
  114. M_KLLBXX = new KLLBXX();
  115. M_JZWZB = new JZWZB();
  116. M_KLLBXX.list_str_tb_lllb_sxys = new List<string>();
  117. M_DZ = new DZ();
  118. }
  119. #endregion
  120. public class DZ
  121. {
  122. public string route { get; set; }
  123. }
  124. #region 首页部份
  125. public class SY
  126. {
  127. /// <summary>
  128. /// 主标题
  129. /// </summary>
  130. public string str_tb_ZBT { get; set; }
  131. /// <summary>
  132. /// 副标题
  133. /// </summary>
  134. public string str_tb_FBT { get; set; }
  135. /// <summary>
  136. /// 样品编号
  137. /// </summary>
  138. public string str_tb_YPBH { get; set; }
  139. /// <summary>
  140. /// 参考标准
  141. /// </summary>
  142. public string str_tb_CKBZ { get; set; }
  143. /// <summary>
  144. /// 是否显示样品说明
  145. /// </summary>
  146. public bool b_ck_ypsm { get; set; }
  147. /// <summary>
  148. /// 是否显示结果概况
  149. /// </summary>
  150. public bool b_ck_jggk { get; set; }
  151. /// <summary>
  152. /// 报告备注
  153. /// </summary>
  154. public string str_bz { get; set; }
  155. /// <summary>
  156. /// 选择颗粒导出范围_内容
  157. /// </summary>
  158. public string str_xzkl { get; set; }
  159. /// <summary>
  160. /// 选择颗粒导出范围,索引
  161. /// </summary>
  162. public int int_xzkl { get; set; }
  163. }
  164. #endregion
  165. #region 页眉页脚部份
  166. public class YMYJ
  167. {
  168. /// <summary>
  169. /// 页眉文本
  170. /// </summary>
  171. public string str_tb_ymwb { get; set; }
  172. /// <summary>
  173. /// 客户号
  174. /// </summary>
  175. public string str_tb_KHH { get; set; }
  176. /// <summary>
  177. /// 是否显示页码
  178. /// </summary>
  179. public bool b_ck_ym { get; set; }
  180. /// <summary>
  181. /// 页脚文本
  182. /// </summary>
  183. public string str_tb_yjwb { get; set; }
  184. }
  185. #endregion
  186. #region 颗粒分析结果部份
  187. public class KLFXJG
  188. {
  189. /// <summary>
  190. /// 是否显示颗粒尺寸分析结果表
  191. /// </summary>
  192. public bool b_ck_klcc_xsmk { get; set; }
  193. /// <summary>
  194. ///颗粒尺寸分析结果表 计算方式文本
  195. /// </summary>
  196. public string str_cb_klcc_jsfs { get; set; }
  197. /// <summary>
  198. ///颗粒尺寸分析结果表 计算方式索引
  199. /// </summary>
  200. public int index_cb_klcc_jsfs { get; set; }
  201. /// <summary>
  202. ///颗粒尺寸分析结果表 粒级表文本
  203. /// </summary>
  204. public string str_cb_klcc_ljb { get; set; }
  205. /// <summary>
  206. ///颗粒尺寸分析结果表 粒级表索引
  207. /// </summary>
  208. public int index_cb_klcc_ljb { get; set; }
  209. /// <summary>
  210. ///颗粒尺寸分析结果表 颗粒选择范围文本
  211. /// </summary>
  212. public string str_cb_klcc_klfw { get; set; }
  213. /// <summary>
  214. ///颗粒尺寸分析结果表 颗粒选择范围索引
  215. /// </summary>
  216. public int index_cb_klcc_klfw { get; set; }
  217. /// <summary>
  218. /// 夹杂物分类图 是否显示该模块
  219. /// </summary>
  220. public bool b_cb_jzwfl_xsmk { get; set; }
  221. /// <summary>
  222. ///夹杂物分类图 显示图形选择文本
  223. /// </summary>
  224. public string str_cb_jzwfl_xstx { get; set; }
  225. /// <summary>
  226. ///夹杂物分类图 显示图形 选择索引
  227. /// </summary>
  228. public int index_cb_jzwfl_xstx { get; set; }
  229. /// <summary>
  230. ///夹杂物分类图 计算方式 选择文本
  231. /// </summary>
  232. public string str_cb_jzwfl_jsfs { get; set; }
  233. /// <summary>
  234. ///夹杂物分类图 计算方式 选择索引
  235. /// </summary>
  236. public int index_cb_jzwfl_jsfs { get; set; }
  237. /// <summary>
  238. ///夹杂物分类图 粒级表 选择文本
  239. /// </summary>
  240. public string str_cb_jzwfl_ljb { get; set; }
  241. /// <summary>
  242. ///夹杂物分类图 粒级表 选择索引
  243. /// </summary>
  244. public int index_cb_jzwfl_ljb { get; set; }
  245. /// <summary>
  246. ///夹杂物分类图 颗粒范围 选择文本
  247. /// </summary>
  248. public string str_cb_jzwfl_klfw { get; set; }
  249. /// <summary>
  250. ///夹杂物分类图 颗粒范围 选择索引
  251. /// </summary>
  252. public int index_cb_jzwfl_klfw { get; set; }
  253. }
  254. #endregion
  255. #region 元素分析结果部份
  256. public class YSFXJG
  257. {
  258. /// <summary>
  259. /// 元素分析表 是否显示该模块
  260. /// </summary>
  261. public bool b_ck_ysfx_xsmk { get; set; }
  262. /// <summary>
  263. /// 元素分析表 计算方式 选择文本
  264. /// </summary>
  265. public string str_cb_yxfx_jsfs { get; set; }
  266. /// <summary>
  267. /// 元素分析表 计算方式 选择索引
  268. /// </summary>
  269. public int index_cb_yxfx_jsfs { get; set; }
  270. /// <summary>
  271. /// 元素分析表 颗粒范围 选择文本
  272. /// </summary>
  273. public string str_cb_ysfx_klfw { get; set; }
  274. /// <summary>
  275. /// 元素分析表 颗粒范围 选择索引
  276. /// </summary>
  277. public int index_cb_ysfx_klfw { get; set; }
  278. /// <summary>
  279. /// 元素分析表 显示元素显示文本
  280. /// </summary>
  281. public string str_tb_ysfx_xsys { get; set; }
  282. /// <summary>
  283. /// 元素分析表 显示元素拆分元素列表
  284. /// </summary>
  285. public List<string> list_str_tb_ysfx_xsys { get; set; }
  286. /// <summary>
  287. /// 元素成份图 是否显示该模块
  288. /// </summary>
  289. public bool b_ck_yscf_xsmk { get; set; }
  290. /// <summary>
  291. /// 元素成份图 显示图形 文本
  292. /// </summary>
  293. public string str_cb_yscf_xstx { get; set; }
  294. /// <summary>
  295. /// 元素成份图 显示图形 索引
  296. /// </summary>
  297. public int index_cb_yscf_xstx { get; set; }
  298. /// <summary>
  299. /// 元素成份图 计算方式 文本
  300. /// </summary>
  301. public string str_cb_yscf_jsfs { get; set; }
  302. /// <summary>
  303. /// 元素成份图 计算方式 索引
  304. /// </summary>
  305. public int index_cb_yscf_jsfs { get; set; }
  306. /// <summary>
  307. /// 元素成份图 颗粒范围 文本
  308. /// </summary>
  309. public string str_cb_yscf_klfw { get; set; }
  310. /// <summary>
  311. /// 元素成份图 颗粒范围 索引
  312. /// </summary>
  313. public int index_cb_yscf_klfw { get; set; }
  314. /// <summary>
  315. /// 元素成份图 元素信息
  316. /// </summary>
  317. public string str_tb_yscf_ysxx { get; set; }
  318. /// <summary>
  319. /// 元素成份图 元素信息列表拆分字符列表
  320. /// </summary>
  321. public List<string> list_str_tb_yscf_ysxx { get; set; }
  322. }
  323. #endregion
  324. #region 三元相图部份
  325. public class SYXT
  326. {
  327. /// <summary>
  328. /// 三元相图 是否显示该模块
  329. /// </summary>
  330. public bool b_ck_syxt_xsmk { get; set; }
  331. /// <summary>
  332. /// 计算方式 文本
  333. /// </summary>
  334. public string str_cb_syxt_jsfs { get; set; }
  335. /// <summary>
  336. /// 计算方式 索引
  337. /// </summary>
  338. public int index_cb_syxt_jsfs { get; set; }
  339. /// <summary>
  340. /// 颗粒范围 文本
  341. /// </summary>
  342. public string str_cb_syxt_klfw { get; set; }
  343. /// <summary>
  344. /// 颗粒范围 索引
  345. /// </summary>
  346. public int index_cb_syxt_klfw { get; set; }
  347. /// <summary>
  348. /// 粒级表信息 文本
  349. /// </summary>
  350. public string str_cb_syxt_ljb { get; set; }
  351. /// <summary>
  352. /// 粒级表信息 索引
  353. /// </summary>
  354. public int index_cb_syxt_ljb { get; set; }
  355. /// <summary>
  356. /// 每行显示数量 文本
  357. /// </summary>
  358. public string str_cb_syxt_mhxssl { get; set; }
  359. /// <summary>
  360. /// 每行显示数量 索引
  361. /// </summary>
  362. public int index_cb_syxt_mhxssl { get; set; }
  363. /// <summary>
  364. /// 三元相图模板集合列表
  365. /// </summary>
  366. public List<string> list_lbv_syxt_mblb { get; set; }
  367. /// <summary>
  368. /// 三元相图模板索引集合列表
  369. /// </summary>
  370. public List<int> list_lbv_syxt_mblb_index { get; set; }
  371. }
  372. #endregion
  373. #region 颗粒列表信息部份
  374. public class KLLBXX
  375. {
  376. /// <summary>
  377. /// 颗粒列表 是否显示该模块
  378. /// </summary>
  379. public bool b_ck_kllb_xsmk { get; set; }
  380. /// <summary>
  381. /// 颗粒列表 是否显示附加帧图模块
  382. /// </summary>
  383. public bool b_ck_kllb_fjzt { get; set; }
  384. /// <summary>
  385. /// 颗粒列表 计算方式 文本
  386. /// </summary>
  387. public string str_cb_kllb_jsfs { get; set; }
  388. /// <summary>
  389. /// 颗粒列表 计算方式 索引
  390. /// </summary>
  391. public int index_cb_kllb_jsfs { get; set; }
  392. /// <summary>
  393. /// 颗粒列表 颗粒范围 文本
  394. /// </summary>
  395. public string str_cb_kllb_klfw { get; set; }
  396. /// <summary>
  397. /// 颗粒列表 颗粒范围 索引
  398. /// </summary>
  399. public int index_cb_kllb_klfw { get; set; }
  400. /// <summary>
  401. /// 颗粒列表 数量上限
  402. /// </summary>
  403. public int int_tb_kllb_ylsx { get; set; }
  404. /// <summary>
  405. /// 颗粒列表 显示元素
  406. /// </summary>
  407. public string str_tb_kllb_sxys { get; set; }
  408. /// <summary>
  409. /// 颗粒列表 显示元素拆分元素列表
  410. /// </summary>
  411. public List<string> list_str_tb_lllb_sxys { get; set; }
  412. /// <summary>
  413. /// 颗粒列表 是否显示原始图像
  414. /// </summary>
  415. public bool b_ck_kllb_ystx { get; set; }
  416. /// <summary>
  417. /// 颗粒列表 是否显示放大图像
  418. /// </summary>
  419. public bool b_ck_kllb_fdtx { get; set; }
  420. /// <summary>
  421. /// 颗粒列表 是否显示能谱信息
  422. /// </summary>
  423. public bool b_ck_kllb_npxx { get; set; }
  424. /// <summary>
  425. /// 颗粒列表 颗粒排序表行中第一个可选字段 文本
  426. /// </summary>
  427. public string str_cb_kllb_sort_p1 { get; set; }
  428. /// <summary>
  429. /// 颗粒列表 颗粒排序表行中第一个可选字段 索引
  430. /// </summary>
  431. public int index_cb_kllb_sort_p1 { get; set; }
  432. /// <summary>
  433. /// 颗粒列表 颗粒排序表行中第二个可选字段 文本
  434. /// </summary>
  435. public string str_cb_kllb_sort_p2 { get; set; }
  436. /// <summary>
  437. /// 颗粒列表 颗粒排序表行中第二个可选字段 索引
  438. /// </summary>
  439. public int index_cb_kllb_sort_p2 { get; set; }
  440. /// <summary>
  441. /// 颗粒列表 颗粒排序表行中第三个可选字段 文本
  442. /// </summary>
  443. public string str_cb_kllb_sort_p3 { get; set; }
  444. /// <summary>
  445. /// 颗粒列表 颗粒排序表行中第三个可选字段 索引
  446. /// </summary>
  447. public int index_cb_kllb_sort_p3 { get; set; }
  448. /// <summary>
  449. /// 颗粒列表 颗粒帧图表行中第一个可选字段 文本
  450. /// </summary>
  451. public string str_cb_kllb_chartSort_p1 { get; set; }
  452. /// <summary>
  453. /// 颗粒列表 颗粒帧图表行中第一个可选字段 索引
  454. /// </summary>
  455. public int index_cb_kllb_chartSort_p1 { get; set; }
  456. /// <summary>
  457. /// 颗粒列表 颗粒帧图表行中第二个可选字段 文本
  458. /// </summary>
  459. public string str_cb_kllb_chartSort_p2 { get; set; }
  460. /// <summary>
  461. /// 颗粒列表 颗粒帧图表行中第二个可选字段 索引
  462. /// </summary>
  463. public int index_cb_kllb_chartSort_p2 { get; set; }
  464. }
  465. #endregion
  466. #region 夹杂物占比
  467. public class JZWZB
  468. {
  469. /// <summary>
  470. /// 夹杂物占比表
  471. /// </summary>
  472. public bool b_ck_surface { get; set; }
  473. /// <summary>
  474. /// 夹杂物占比图
  475. /// </summary>
  476. public bool b_ck_chart { get; set; }
  477. }
  478. #endregion
  479. }
  480. #endregion
  481. #region 窗体加载及构造函数
  482. public OTSReport_Export(frmReportApp ReportApp)
  483. {
  484. InitializeComponent();
  485. m_ReportApp = ReportApp;
  486. m_export_reporttemplate = new Export_ReportTemplate(this);
  487. //初始化xml类
  488. xmlutil = new XmlConfigUtil(strPath);
  489. m_mbszclass = new MBSZClass();
  490. //读取配置文件中的模板
  491. LoadMBSZClass();
  492. LoadRouteclass();
  493. #region 国际化语言
  494. Language lan = new Language(this);
  495. table = lan.GetNameTable(this.Name);
  496. #endregion
  497. }
  498. ///<summary>
  499. ///从配置文件中读取报告模板信息
  500. /// </summary>
  501. private void LoadRouteclass()
  502. {
  503. if (m_mbszclass.M_DZ.route == null)
  504. {
  505. strPath2 = strPath;
  506. m_mbszclass.M_DZ.route = strPath;
  507. }
  508. else
  509. if (m_mbszclass.M_DZ.route == "")
  510. {
  511. strPath2 = strPath;
  512. m_mbszclass.M_DZ.route = strPath;
  513. }
  514. else
  515. {
  516. strPath2 = m_mbszclass.M_DZ.route;
  517. }
  518. xmlutil2 = new XmlConfigUtil(strPath2);
  519. //首页
  520. m_mbszclass.M_SY.str_tb_ZBT = xmlutil2.Read("M_SY", "str_tb_ZBT");
  521. m_mbszclass.M_SY.str_tb_FBT = xmlutil2.Read("M_SY", "str_tb_FBT");
  522. m_mbszclass.M_SY.str_tb_YPBH = xmlutil2.Read("M_SY", "str_tb_YPBH");
  523. m_mbszclass.M_SY.str_tb_CKBZ = xmlutil2.Read("M_SY", "str_tb_CKBZ");
  524. m_mbszclass.M_SY.str_bz = xmlutil2.Read("M_SY", "str_bz");
  525. m_mbszclass.M_SY.b_ck_ypsm = Convert.ToBoolean(xmlutil2.Read("M_SY", "b_ck_ypsm"));
  526. m_mbszclass.M_SY.b_ck_jggk = Convert.ToBoolean(xmlutil2.Read("M_SY", "b_ck_jggk"));
  527. m_mbszclass.M_SY.str_xzkl= xmlutil2.Read("M_SY", "str_xzkl");
  528. m_mbszclass.M_SY.int_xzkl = Convert.ToInt32(xmlutil2.Read("M_SY", "int_xzkl"));
  529. //页眉页脚
  530. m_mbszclass.M_YMYJ.str_tb_ymwb = xmlutil2.Read("M_YMYJ", "str_tb_ymwb");
  531. m_mbszclass.M_YMYJ.str_tb_KHH = xmlutil2.Read("M_YMYJ", "str_tb_KHH");
  532. m_mbszclass.M_YMYJ.b_ck_ym = Convert.ToBoolean(xmlutil2.Read("M_YMYJ", "b_ck_ym"));
  533. m_mbszclass.M_YMYJ.str_tb_yjwb = xmlutil2.Read("M_YMYJ", "str_tb_yjwb");
  534. //颗粒分析结果
  535. m_mbszclass.M_KLFXJG.b_ck_klcc_xsmk = Convert.ToBoolean(xmlutil2.Read("M_KLFXJG", "b_ck_klcc_xsmk"));//是否显示模块
  536. m_mbszclass.M_KLFXJG.index_cb_klcc_jsfs = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_klcc_jsfs"));//计算方式
  537. m_mbszclass.M_KLFXJG.str_cb_klcc_jsfs = Convert.ToString(xmlutil2.Read("M_KLFXJG", "str_cb_klcc_jsfs"));//计算方式
  538. m_mbszclass.M_KLFXJG.index_cb_klcc_ljb = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_klcc_ljb"));//粒级表
  539. m_mbszclass.M_KLFXJG.index_cb_klcc_klfw = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_klcc_klfw"));//颗粒范围
  540. m_mbszclass.M_KLFXJG.b_cb_jzwfl_xsmk = Convert.ToBoolean(xmlutil2.Read("M_KLFXJG", "b_cb_jzwfl_xsmk"));//是否显示该模块
  541. m_mbszclass.M_KLFXJG.index_cb_jzwfl_xstx = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_jzwfl_xstx"));//选择图像
  542. m_mbszclass.M_KLFXJG.index_cb_jzwfl_jsfs = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_jzwfl_jsfs"));//计算方式
  543. m_mbszclass.M_KLFXJG.index_cb_jzwfl_ljb = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_jzwfl_ljb"));//粒级表
  544. m_mbszclass.M_KLFXJG.index_cb_jzwfl_klfw = Convert.ToInt32(xmlutil2.Read("M_KLFXJG", "index_cb_jzwfl_klfw"));//颗粒范围
  545. //元素分析结果
  546. m_mbszclass.M_YSFXJG.b_ck_ysfx_xsmk = Convert.ToBoolean(xmlutil2.Read("M_YSFXJG", "b_ck_ysfx_xsmk")); //是否显示模块
  547. m_mbszclass.M_YSFXJG.index_cb_yxfx_jsfs = Convert.ToInt32(xmlutil2.Read("M_YSFXJG", "index_cb_yxfx_jsfs")); //计算方式
  548. m_mbszclass.M_YSFXJG.index_cb_ysfx_klfw = Convert.ToInt32(xmlutil2.Read("M_YSFXJG", "index_cb_ysfx_klfw")); //颗粒范围
  549. m_mbszclass.M_YSFXJG.str_tb_ysfx_xsys = xmlutil2.Read("M_YSFXJG", "str_tb_ysfx_xsys"); //显示元素
  550. m_mbszclass.M_YSFXJG.list_str_tb_ysfx_xsys.Clear();
  551. for (int i = 0; i < 100; i++) //取得所有元素列表
  552. {
  553. string str = xmlutil2.Read("M_YSFXJG", "list_str_tb_ysfx_xsys", "YS" + i.ToString());
  554. if (str == null)
  555. {
  556. break;
  557. }
  558. else
  559. {
  560. m_mbszclass.M_YSFXJG.list_str_tb_ysfx_xsys.Add(str);
  561. }
  562. }
  563. m_mbszclass.M_YSFXJG.b_ck_yscf_xsmk = Convert.ToBoolean(xmlutil2.Read("M_YSFXJG", "b_ck_yscf_xsmk")); //是否显示模块
  564. m_mbszclass.M_YSFXJG.index_cb_yscf_xstx = Convert.ToInt32(xmlutil2.Read("M_YSFXJG", "index_cb_yscf_xstx")); //显示图形
  565. m_mbszclass.M_YSFXJG.index_cb_yscf_jsfs = Convert.ToInt32(xmlutil2.Read("M_YSFXJG", "index_cb_yscf_jsfs")); //计算方式
  566. m_mbszclass.M_YSFXJG.index_cb_yscf_klfw = Convert.ToInt32(xmlutil2.Read("M_YSFXJG", "index_cb_yscf_klfw")); //颗粒范围
  567. m_mbszclass.M_YSFXJG.str_tb_yscf_ysxx = xmlutil2.Read("M_YSFXJG", "str_tb_yscf_ysxx"); //显示元素
  568. m_mbszclass.M_YSFXJG.list_str_tb_yscf_ysxx.Clear();
  569. for (int i = 0; i < 100; i++) //取得所有元素列表
  570. {
  571. string str = xmlutil2.Read("M_YSFXJG", "list_str_tb_yscf_ysxx", "YS" + i.ToString());
  572. if (str == null)
  573. {
  574. break;
  575. }
  576. else
  577. {
  578. m_mbszclass.M_YSFXJG.list_str_tb_yscf_ysxx.Add(str);
  579. }
  580. }
  581. //三元相图
  582. m_mbszclass.M_SYXT.b_ck_syxt_xsmk = Convert.ToBoolean(xmlutil2.Read("M_SYXT", "b_ck_syxt_xsmk")); //是否显示模块
  583. m_mbszclass.M_SYXT.index_cb_syxt_jsfs = Convert.ToInt32(xmlutil2.Read("M_SYXT", "index_cb_syxt_jsfs")); //计算方式
  584. m_mbszclass.M_SYXT.index_cb_syxt_klfw = Convert.ToInt32(xmlutil2.Read("M_SYXT", "index_cb_syxt_klfw")); //颗粒范围
  585. m_mbszclass.M_SYXT.str_cb_syxt_mhxssl = xmlutil2.Read("M_SYXT", "str_cb_syxt_mhxssl"); //每行显示数量
  586. m_mbszclass.M_SYXT.list_lbv_syxt_mblb.Clear();
  587. for (int i = 0; i < 100; i++) //取得所有模板列表
  588. {
  589. string str = xmlutil2.Read("M_SYXT", "list_lbv_syxt_mblb", "MB" + i.ToString());
  590. if (str == null)
  591. {
  592. break;
  593. }
  594. else
  595. {
  596. m_mbszclass.M_SYXT.list_lbv_syxt_mblb.Add(str);
  597. }
  598. }
  599. m_mbszclass.M_SYXT.list_lbv_syxt_mblb_index.Clear();
  600. for (int i = 0; i < 100; i++) //取得所有模板列表 索引
  601. {
  602. string str = xmlutil2.Read("M_SYXT", "list_lbv_syxt_mblb_index", "MBIndex" + i.ToString());
  603. if (str == null)
  604. {
  605. break;
  606. }
  607. else
  608. {
  609. m_mbszclass.M_SYXT.list_lbv_syxt_mblb_index.Add(Convert.ToInt32(str));
  610. }
  611. }
  612. //颗粒列表信息
  613. m_mbszclass.M_KLLBXX.b_ck_kllb_xsmk = Convert.ToBoolean(xmlutil2.Read("M_KLLBXX", "b_ck_kllb_xsmk")); //是否显示模块
  614. m_mbszclass.M_KLLBXX.b_ck_kllb_fjzt = Convert.ToBoolean(xmlutil2.Read("M_KLLBXX", "b_ck_kllb_fjzt")); //是否显示帧图模块
  615. m_mbszclass.M_KLLBXX.index_cb_kllb_jsfs = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "index_cb_kllb_jsfs")); //计算方式
  616. m_mbszclass.M_KLLBXX.index_cb_kllb_klfw = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "index_cb_kllb_klfw")); //颗粒范围
  617. m_mbszclass.M_KLLBXX.int_tb_kllb_ylsx = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "int_tb_kllb_ylsx")); //数量上限
  618. m_mbszclass.M_KLLBXX.str_tb_kllb_sxys = xmlutil2.Read("M_KLLBXX", "str_tb_kllb_sxys"); //显示元素
  619. m_mbszclass.M_KLLBXX.list_str_tb_lllb_sxys.Clear();
  620. for (int i = 0; i < 100; i++) //取得所有元素列表
  621. {
  622. string str = xmlutil2.Read("M_KLLBXX", "list_str_tb_lllb_sxys", "YS" + i.ToString());
  623. if (str == null)
  624. {
  625. break;
  626. }
  627. else
  628. {
  629. m_mbszclass.M_KLLBXX.list_str_tb_lllb_sxys.Add(str);
  630. }
  631. }
  632. m_mbszclass.M_KLLBXX.b_ck_kllb_ystx = Convert.ToBoolean(xmlutil2.Read("M_KLLBXX", "b_ck_kllb_ystx")); //原始图像
  633. m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx = Convert.ToBoolean(xmlutil2.Read("M_KLLBXX", "b_ck_kllb_fdtx")); //放大图像
  634. m_mbszclass.M_KLLBXX.b_ck_kllb_npxx = Convert.ToBoolean(xmlutil2.Read("M_KLLBXX", "b_ck_kllb_npxx")); //能谱图像
  635. m_mbszclass.M_KLLBXX.str_cb_kllb_sort_p1 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_sort_p1"));//颗粒列表列中第一个可选参数
  636. m_mbszclass.M_KLLBXX.index_cb_kllb_sort_p1 = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "index_cb_kllb_sort_p1"));
  637. m_mbszclass.M_KLLBXX.str_cb_kllb_sort_p2 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_sort_p2"));//颗粒列表中第二个可选参数
  638. m_mbszclass.M_KLLBXX.index_cb_kllb_sort_p2 = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "index_cb_kllb_sort_p2"));
  639. m_mbszclass.M_KLLBXX.str_cb_kllb_sort_p3 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_sort_p3"));//颗粒列表中第三个可选参数
  640. m_mbszclass.M_KLLBXX.index_cb_kllb_sort_p3 = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "index_cb_kllb_sort_p3"));
  641. m_mbszclass.M_KLLBXX.str_cb_kllb_chartSort_p1 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_chartSort_p1"));//帧图表列中第一个可选参数
  642. m_mbszclass.M_KLLBXX.index_cb_kllb_chartSort_p1 = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "index_cb_kllb_chartSort_p1"));
  643. m_mbszclass.M_KLLBXX.str_cb_kllb_chartSort_p2 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_chartSort_p2"));//帧图表列中第二个可选参数
  644. m_mbszclass.M_KLLBXX.index_cb_kllb_chartSort_p2 = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "index_cb_kllb_chartSort_p2"));
  645. //m_mbszclass.M_KLLBXX.str_cb_kllb_chartSort_p3 = Convert.ToString(xmlutil2.Read("M_KLLBXX", "str_cb_kllb_chartSort_p3"));//帧图表列中第三个可选参数
  646. //m_mbszclass.M_KLLBXX.index_cb_kllb_chartSort_p3 = Convert.ToInt32(xmlutil2.Read("M_KLLBXX", "index_cb_kllb_chartSort_p3"));
  647. //夹杂物占比
  648. m_mbszclass.M_JZWZB.b_ck_surface = Convert.ToBoolean(xmlutil2.Read("M_JZWZB", "b_ck_surface"));//夹杂物占比表
  649. m_mbszclass.M_JZWZB.b_ck_chart= Convert.ToBoolean(xmlutil2.Read("M_JZWZB", "b_ck_chart"));//夹杂物占比图
  650. }
  651. /// <summary>
  652. /// 从配置文件中读取报告模板路径
  653. /// </summary>
  654. private void LoadMBSZClass()
  655. {
  656. //文件路径
  657. m_mbszclass.M_DZ.route = xmlutil.Read("M_address", "Path");
  658. if (m_mbszclass.M_DZ.route == "")
  659. {
  660. tb_mblj.Text = strPath;
  661. m_mbszclass.M_DZ.route = strPath;
  662. }
  663. else
  664. if (File.Exists(m_mbszclass.M_DZ.route))
  665. {
  666. tb_mblj.Text = m_mbszclass.M_DZ.route;
  667. }
  668. else
  669. {
  670. tb_mblj.Text = strPath;
  671. m_mbszclass.M_DZ.route = strPath;
  672. }
  673. }
  674. /// <summary>
  675. /// 将报告模板信息保存到配置文件中
  676. /// </summary>
  677. private void SaveMBSClass()
  678. {
  679. //文件路径
  680. xmlutil.Write(m_mbszclass.M_DZ.route.ToString(), "M_address", "Path");
  681. }
  682. /// <summary>
  683. /// 传入,3个层级的xml结点标识,进行删除结点
  684. /// </summary>
  685. /// <param name="strnode_mk"></param>
  686. /// <param name="strnode_kj"></param>
  687. /// <param name="strnode_xh"></param>
  688. private void RemoveMBSZClassNode(string strnode_mk, string strnode_kj, string strnode_xh, int int_start)
  689. {
  690. for (int i = int_start; i < 1000; i++)
  691. {
  692. string strxh = i.ToString();
  693. if (null != xmlutil.Read(strnode_mk, strnode_kj, strnode_xh + strxh))
  694. {
  695. //删除该节点
  696. xmlutil.RemoveNode(strnode_mk, strnode_kj, strnode_xh + strxh);
  697. }
  698. else
  699. {
  700. break;
  701. }
  702. }
  703. }
  704. /// <summary>
  705. /// 加载报告模板选择项,数据源选项
  706. /// </summary>
  707. private void BindComboBox()
  708. {
  709. //加载数据源
  710. for (int i = 0; i < m_ReportApp.m_rstDataMgr.ResultFilesList.Count; i++)
  711. {
  712. cbo_sjy.Items.Add(m_ReportApp.m_rstDataMgr.ResultFilesList[i].FileName);
  713. }
  714. if (cbo_sjy.Items.Count > 0)
  715. cbo_sjy.SelectedIndex = 0;
  716. }
  717. private void OTSReport_Export_Load(object sender, EventArgs e)
  718. {
  719. //先获取D盘,如果没有,则再获取C盘
  720. string str_drivename = GetSecondDriveName();
  721. if (str_drivename == "")
  722. str_drivename = GetFirstDriveName();
  723. //初始化临时文件位置
  724. m_str_tmpbitmappath = str_drivename + "1.bmp";
  725. m_str_tmpbitmappath2 = str_drivename + "2.bmp";
  726. m_str_tmpdocxpath = str_drivename + "1.doc";
  727. //窗体加载时,初始化Combobox
  728. BindComboBox();
  729. //设置界面线程
  730. backgroundWorker2.WorkerReportsProgress = true;
  731. backgroundWorker2.WorkerSupportsCancellation = true;
  732. //确定报表进程db数据库的路径
  733. string strdbname = "ReportTemplateDB.db";
  734. m_strDBpath = m_ReportApp.m_rstDataMgr.ResultFilesList[cbo_sjy.SelectedIndex].FilePath;
  735. m_strDBpathGB = m_ReportApp.m_rstDataMgr.ResultFilesList[cbo_sjy.SelectedIndex].FilePath;
  736. m_strDBpath = m_strDBpath + "\\" + strdbname;
  737. m_strDBpathGB = m_strDBpathGB + "\\" + "ReportGBDB.db";
  738. string strdbparticlelistname = "ReportTemplateDBParticleList.db";
  739. m_strDBpath_ParticleList = m_ReportApp.m_rstDataMgr.ResultFilesList[cbo_sjy.SelectedIndex].FilePath;
  740. m_strDBpath_ParticleList = m_strDBpath_ParticleList + "\\" + strdbparticlelistname;
  741. }
  742. #endregion
  743. #region 自定义方法
  744. /// <summary>
  745. /// 传入完整的路径及文件名,和需要的扩展名,返回文件加上需要的扩展名
  746. /// </summary>
  747. /// <param name="in_str"></param>
  748. /// <param name="in_extename"></param>
  749. /// <returns></returns>
  750. public string GetFileExteName(string in_str, string in_extename)
  751. {
  752. string ret_str = in_str.Substring(0, in_str.IndexOf('.'));
  753. ret_str = ret_str + in_extename;
  754. return ret_str;
  755. }
  756. /// <summary>
  757. /// 获取第一个磁盘盘符的名称
  758. /// </summary>
  759. /// <returns></returns>
  760. public string GetFirstDriveName()
  761. {
  762. System.IO.DriveInfo[] ls_driveinfo = System.IO.DriveInfo.GetDrives();
  763. if (ls_driveinfo.Count() > 0)
  764. return ls_driveinfo[0].Name;
  765. return "";
  766. }
  767. /// <summary>
  768. /// 获取第二个磁盘盘符的名称,因为有时c盘不会给予读写的权限,所以要用到这个
  769. /// </summary>
  770. /// <returns></returns>
  771. private string GetSecondDriveName()
  772. {
  773. System.IO.DriveInfo[] ls_driveinfo = System.IO.DriveInfo.GetDrives();
  774. if (ls_driveinfo.Count() > 1)
  775. return ls_driveinfo[1].Name;
  776. return "";
  777. }
  778. /// <summary>
  779. /// 将文本追加到RictBox的尾部上
  780. /// </summary>
  781. public void WriteRictBox(string in_str)
  782. {
  783. //追加到rictbox尾部
  784. richTextBox1.AppendText("[" + DateTime.Now.Hour.ToString() + ":"
  785. + DateTime.Now.Minute.ToString() + ":"
  786. + DateTime.Now.Second.ToString() + "]"
  787. + in_str + Environment.NewLine);
  788. richTextBox1.SelectionColor = GetRandomColor30(30);
  789. richTextBox1.ScrollToCaret();
  790. }
  791. /// <summary>
  792. /// 重载输出文本,带有可以指定颜色
  793. /// </summary>
  794. /// <param name="in_str"></param>
  795. /// <param name="in_c"></param>
  796. public void WriteRictBox(string in_str, Color in_c)
  797. {
  798. //追加到rictbox尾部
  799. richTextBox1.AppendText("[" + DateTime.Now.Hour.ToString() + ":"
  800. + DateTime.Now.Minute.ToString() + ":"
  801. + DateTime.Now.Second.ToString() + "]"
  802. + in_str + Environment.NewLine);
  803. richTextBox1.SelectionColor = in_c;
  804. richTextBox1.ScrollToCaret();
  805. }
  806. /// <summary>
  807. /// 根据传入的颜色,及传入Size的大小,返回一个该色的bitmap对象
  808. /// </summary>
  809. /// <param name="in_c"></param>
  810. /// <returns></returns>
  811. public Bitmap GetBitmapByColor(Color in_c, Size in_z)
  812. {
  813. Bitmap bmp = new Bitmap(in_z.Width, in_z.Height); //这里给104是为了左边和右边空出2个像素,剩余的100就是百分比的值
  814. Graphics g = Graphics.FromImage(bmp);
  815. g.Clear(Color.White);
  816. SolidBrush drawBrush = new SolidBrush(Color.Black);
  817. g.FillRectangle(new SolidBrush(in_c), 0, 0, in_z.Width, in_z.Height);
  818. return bmp;
  819. }
  820. /// <summary>
  821. /// [颜色:16进制转成RGB]
  822. /// </summary>
  823. /// <param name="strColor">设置16进制颜色 [返回RGB]</param>
  824. /// <returns></returns>
  825. public System.Drawing.Color colorHx16toRGB(string strHxColor)
  826. {
  827. try
  828. {
  829. if (strHxColor.Length == 0)
  830. {//如果为空
  831. return System.Drawing.Color.FromArgb(0, 0, 0);//设为黑色
  832. }
  833. else
  834. {//转换颜色
  835. if (strHxColor.IndexOf('#') > -1)
  836. {
  837. //如果颜色格式是 #0000FF 格式的
  838. return System.Drawing.Color.FromArgb(System.Int32.Parse(strHxColor.Substring(1, 2), System.Globalization.NumberStyles.AllowHexSpecifier), System.Int32.Parse(strHxColor.Substring(3, 2), System.Globalization.NumberStyles.AllowHexSpecifier), System.Int32.Parse(strHxColor.Substring(5, 2), System.Globalization.NumberStyles.AllowHexSpecifier));
  839. }
  840. else
  841. {
  842. //如果颜色格式是 0000FF 格式的
  843. return System.Drawing.Color.FromArgb(System.Int32.Parse(strHxColor.Substring(0, 2), System.Globalization.NumberStyles.AllowHexSpecifier), System.Int32.Parse(strHxColor.Substring(2, 2), System.Globalization.NumberStyles.AllowHexSpecifier), System.Int32.Parse(strHxColor.Substring(4, 2), System.Globalization.NumberStyles.AllowHexSpecifier));
  844. }
  845. }
  846. }
  847. catch
  848. {//设为黑色
  849. return System.Drawing.Color.FromArgb(0, 0, 0);
  850. }
  851. }
  852. /// <summary>
  853. /// [颜色:RGB转成16进制]专为输出Excel表头格式而定制,其它地方不要使用该方法,或修改返回加#号,例#000000FF
  854. /// </summary>
  855. /// <param name="R">红 int</param>
  856. /// <param name="G">绿 int</param>
  857. /// <param name="B">蓝 int</param>
  858. /// <returns></returns>
  859. public string colorRGBtoHx16ForExcel(Color color)
  860. {
  861. if (color.IsEmpty)
  862. return "000000";
  863. return String.Format("{0:X2}{1:X2}{2:X2}", color.R, color.G, color.B);
  864. }
  865. /// <summary>
  866. /// 将RGB颜色转成整数
  867. /// </summary>
  868. /// <param name="color"></param>
  869. /// <returns></returns>
  870. public int ParseRGB(Color color)
  871. {
  872. return (int)(((int)color.B << 16) | (ushort)(((ushort)color.G << 8) | color.R));
  873. }
  874. /// <summary>
  875. /// 从指定的几种颜色中进行随机颜色,传入30个颜色的范围,越大颜色越多
  876. /// </summary>
  877. /// <returns></returns>
  878. public Color GetRandomColor30(int i_randomrange)
  879. {
  880. Random r = new Random();
  881. int n = r.Next(0, i_randomrange);
  882. Color ret_color;
  883. switch (n)
  884. {
  885. case 1:
  886. ret_color = Color.Aqua;
  887. break;
  888. case 2:
  889. ret_color = Color.Black;
  890. break;
  891. case 3:
  892. ret_color = Color.Blue;
  893. break;
  894. case 4:
  895. ret_color = Color.BlueViolet;
  896. break;
  897. case 5:
  898. ret_color = Color.Brown;
  899. break;
  900. case 6:
  901. ret_color = Color.BurlyWood;
  902. break;
  903. case 7:
  904. ret_color = Color.CadetBlue;
  905. break;
  906. case 8:
  907. ret_color = Color.CadetBlue;
  908. break;
  909. case 9:
  910. ret_color = Color.CornflowerBlue;
  911. break;
  912. case 10:
  913. ret_color = Color.DarkBlue;
  914. break;
  915. case 11:
  916. ret_color = Color.Gray;
  917. break;
  918. case 12:
  919. ret_color = Color.Indigo;
  920. break;
  921. case 13:
  922. ret_color = Color.LightSlateGray;
  923. break;
  924. case 14:
  925. ret_color = Color.Magenta;
  926. break;
  927. case 15:
  928. ret_color = Color.Maroon;
  929. break;
  930. case 16:
  931. ret_color = Color.MediumBlue;
  932. break;
  933. case 17:
  934. ret_color = Color.MediumOrchid;
  935. break;
  936. case 18:
  937. ret_color = Color.MidnightBlue;
  938. break;
  939. case 19:
  940. ret_color = Color.Navy;
  941. break;
  942. case 20:
  943. ret_color = Color.Olive;
  944. break;
  945. case 21:
  946. ret_color = Color.PaleVioletRed;
  947. break;
  948. case 22:
  949. ret_color = Color.Peru;
  950. break;
  951. case 23:
  952. ret_color = Color.Purple;
  953. break;
  954. case 24:
  955. ret_color = Color.Red;
  956. break;
  957. case 25:
  958. ret_color = Color.RosyBrown;
  959. break;
  960. case 26:
  961. ret_color = Color.RoyalBlue;
  962. break;
  963. case 27:
  964. ret_color = Color.SaddleBrown;
  965. break;
  966. case 28:
  967. ret_color = Color.SeaGreen;
  968. break;
  969. case 29:
  970. ret_color = Color.Teal;
  971. break;
  972. case 30:
  973. ret_color = Color.Tomato;
  974. break;
  975. case 31:
  976. ret_color = Color.YellowGreen;
  977. break;
  978. default:
  979. ret_color = Color.Black;
  980. break;
  981. }
  982. return ret_color;
  983. }
  984. /// <summary>
  985. /// 打开报表模板进程
  986. /// </summary>
  987. private void OpenOTSINcAreportTemplateAPP()
  988. {
  989. ReportPrintTool tool = new ReportPrintTool(DEVReport);
  990. tool.ShowPreview();
  991. }
  992. /// <summary>
  993. /// 打开报表模板进程,颗粒列表
  994. /// </summary>
  995. public void OpenOTSINcAreportTemplateAPP_ParticleList(string arg4)
  996. {
  997. //----------------------------------
  998. //共传4个参数
  999. //参数1:是需要打开db数据库的路径
  1000. //参数2:是打开报表模板xml文件的路径
  1001. //参数3:是要执行查看报表的类型,输出主报表,还是输出颗粒列表
  1002. //参数4:打开主报表时是是指定夹杂物的数量,打开颗粒列表时,是颗粒列表显示的范围如,0-50,50-100
  1003. //参数5:是要执行查看报表的类型,输出主报表时,指定读取的标记帧图图像范围,如0-50,50-100,输出颗粒列表时无用
  1004. //----------------------------------
  1005. ProcessStartInfo process = new ProcessStartInfo();
  1006. process.FileName = "ReportTemplateExe\\OTSIncAReportTemplate.exe";//打开app的路径
  1007. string arg1 = m_strDBpath_ParticleList.Replace(" ", "^");//参数1,是需要打开db数据库的路径
  1008. string arg2 = tb_mblj.Text.Trim().Replace(" ", "^");//参数2,是模板文件的路径
  1009. string arg3 = "ParticleListReport";//颗粒列表
  1010. //string arg4 = "";//夹杂物数量,从多少到多少
  1011. string arg5 = "0";//在打开颗粒列表时,传的标记帧图图像数量参数暂不用
  1012. process.Arguments = string.Format("{0} {1} {2} {3} {4}", arg1, arg2, arg3, arg4, arg5); //多个参数用空格隔开
  1013. process.WindowStyle = ProcessWindowStyle.Normal;
  1014. Process.Start(process);
  1015. }
  1016. #endregion
  1017. #region 窗体控件事件
  1018. private void OTSReport_Export_FormClosing(object sender, FormClosingEventArgs e)
  1019. {
  1020. if (backgroundWorker2.IsBusy == true)
  1021. {
  1022. //导出线程正在工作中,不让退出该界面
  1023. MessageBox.Show(table["messagebox1"].ToString(), table["messagebox2"].ToString(), MessageBoxButtons.OK, MessageBoxIcon.Information);
  1024. //然后取消关闭窗体的事件
  1025. e.Cancel = true;
  1026. }
  1027. }
  1028. private void btn_preview_Click(object sender, EventArgs e)
  1029. {
  1030. DEVReport = new OTS_DEVReport(this);
  1031. //DEVReport.Dispose();
  1032. //为防止重复打开报告后,显示数据库占用错误,先确保报告模板进程已关闭
  1033. Process[] processes = Process.GetProcesses();
  1034. foreach (Process proc in processes)
  1035. {
  1036. if (proc.ProcessName == "OTSIncAReportTemplate")
  1037. {
  1038. DialogResult dr = MessageBox.Show(table["messagebox3"].ToString(), table["messagebox4"].ToString(), MessageBoxButtons.OK, MessageBoxIcon.Warning);
  1039. if (dr == DialogResult.OK)
  1040. {
  1041. return;
  1042. }
  1043. }
  1044. }
  1045. //调用模板设计器,预览
  1046. //判断该测量结果文件目录中是否已经有数据库文件,有的话,直接打开,没有则进行导出数据库然后再打开
  1047. if (File.Exists(m_strDBpath))
  1048. {
  1049. DialogResult dr = MessageBox.Show(table["messagebox5"].ToString(), table["messagebox6"].ToString(), MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question);
  1050. if (dr == DialogResult.Yes)
  1051. {
  1052. WriteRictBox(table["messagebox7"].ToString());
  1053. //存在则直接打开报表
  1054. OpenOTSINcAreportTemplateAPP();
  1055. return;
  1056. }
  1057. if (dr == DialogResult.No)
  1058. {
  1059. //GoTo Here;
  1060. //不干预,跳转到下面执行导出操作
  1061. }
  1062. if (dr == DialogResult.Cancel)
  1063. {
  1064. //取消,返回
  1065. return;
  1066. }
  1067. }
  1068. //frmReportConditionChoose frm = new frmReportConditionChoose(m_ReportApp);
  1069. //frm.ShowDataDiagram(DisplayPicutureType.AnalyzeDataChart);
  1070. m_ReportApp.m_rstDataMgr.setSelectedIndex(cbo_sjy.SelectedIndex);
  1071. //重新导出报表数据
  1072. m_ReportApp.m_ChartsWindow.Activate();
  1073. WriteRictBox(table["rictbox1"].ToString());
  1074. progressBar1.Value = 0;
  1075. //预览
  1076. if (backgroundWorker2.IsBusy != true)
  1077. {
  1078. // 启动异步操作
  1079. backgroundWorker2.RunWorkerAsync();
  1080. }
  1081. }
  1082. private void button3_Click(object sender, EventArgs e)
  1083. {
  1084. if (File.Exists(tb_lj.Text.Trim()))
  1085. {
  1086. //打开刚才导出的文件
  1087. System.Diagnostics.Process.Start(tb_lj.Text.Trim());
  1088. }
  1089. else
  1090. {
  1091. WriteRictBox(table["rictbox2"].ToString() + tb_lj.Text.Trim() + table["rictbox3"].ToString());
  1092. }
  1093. }
  1094. private void button2_Click(object sender, EventArgs e)
  1095. {
  1096. //退出
  1097. this.Close();
  1098. }
  1099. private void btn_openfilepath_Click(object sender, EventArgs e)
  1100. {
  1101. LoadControlsToXml();
  1102. SaveMBSClass();
  1103. }
  1104. private void btn_selectPath_Click(object sender, EventArgs e)
  1105. {
  1106. //选择保存文件路径对话框
  1107. SaveFileDialog saveFileDialog1 = new SaveFileDialog();
  1108. //获取默认操作的数据源名,用来当做保存的文件名
  1109. saveFileDialog1.FileName = m_ReportApp.m_rstDataMgr.GetSampleName();
  1110. saveFileDialog1.Filter = "Excel (*.xls)|*.xls|Word (*.doc)|*.doc|PDF (*.pdf)|*.pdf";
  1111. saveFileDialog1.FilterIndex = 1;
  1112. saveFileDialog1.RestoreDirectory = true;
  1113. if (saveFileDialog1.ShowDialog() == DialogResult.OK)
  1114. {
  1115. if (saveFileDialog1.FilterIndex == 1)
  1116. {
  1117. //选择输出Excel
  1118. m_export_type = "Excel";
  1119. }
  1120. if (saveFileDialog1.FilterIndex == 2)
  1121. {
  1122. //选择输出Word
  1123. m_export_type = "Word";
  1124. }
  1125. if (saveFileDialog1.FilterIndex == 3)
  1126. {
  1127. //选择输出PDF
  1128. m_export_type = "PDF";
  1129. }
  1130. tb_lj.Text = saveFileDialog1.FileName;
  1131. }
  1132. }
  1133. //调用编辑模板窗体
  1134. private void btn_TempDes_Click(object sender, EventArgs e)
  1135. {
  1136. //预览设置
  1137. OTSReport_TemplateDesignerRM OtsTemDRM = new OTSReport_TemplateDesignerRM(this);
  1138. if (OtsTemDRM.ShowDialog() == DialogResult.Yes)
  1139. {
  1140. //如果用户点击确定,则将m_mbszclass,模板设置类的内容存到文件中。
  1141. // m_mbszclass.M_DZ.route = tb_mblj.Text;
  1142. m_mbszclass.M_DZ.route = tb_mblj.Text;
  1143. SaveMBSClass();
  1144. }
  1145. }
  1146. #endregion
  1147. #region 导出工作线程部份
  1148. private void backgroundWorker2_DoWork(object sender, DoWorkEventArgs e)
  1149. {
  1150. BackgroundWorker worker = sender as BackgroundWorker;
  1151. //主任务的实现
  1152. #region //获取模板设置的导出的内容-------------------------------------------------
  1153. //获取报告模板设置内容
  1154. worker.ReportProgress(0, table["rictbox4"].ToString());//已获取模板中设置内容为:
  1155. System.Threading.Thread.Sleep(1);
  1156. //更新进度
  1157. worker.ReportProgress(5);
  1158. #endregion //设置模板导出内容结束--------------------------------------------------------
  1159. int processvalue = 12;//各功能模块从进度条为15时开始依次调用
  1160. #region //依次循环调用各功能模块-------------------------------------------------------------
  1161. int i_zz = 0;//增值
  1162. i_zz = 80 / 9;
  1163. //首先将测量结果信息表导出,在表头------------------------------------------------
  1164. worker.ReportProgress(0, table["result_information_ing"].ToString());//加载测量结果信息表模块中....
  1165. worker.ReportProgress(0, table["load_result_information"].ToString());//加载:测量结果信息表
  1166. //更新进度条
  1167. processvalue = processvalue + 1;
  1168. worker.ReportProgress(processvalue);
  1169. lock (m_thread_flag)
  1170. m_thread_flag = table["rictbox7"].ToString();//等待
  1171. while (m_thread_flag == table["rictbox7"].ToString())//等待
  1172. {
  1173. System.Threading.Thread.Sleep(500);
  1174. }
  1175. worker.ReportProgress(0, table["loading_result_information_completed"].ToString());//加载测量结果信息表模块完成
  1176. //-------------------------------------------------------------------------
  1177. //调用,颗粒尺寸分析表------------------------------------------------
  1178. worker.ReportProgress(0, table["dimensional_analysis_table_ing"].ToString());//加载颗粒尺寸分析表模块中....
  1179. worker.ReportProgress(0, table["loading_dimension_analysis_table"].ToString());//加载:颗粒尺寸分析表
  1180. //更新进度条
  1181. processvalue = processvalue + i_zz;
  1182. worker.ReportProgress(processvalue);
  1183. lock (m_thread_flag)
  1184. m_thread_flag = table["rictbox7"].ToString();//等待
  1185. while (m_thread_flag == table["rictbox7"].ToString())//等待
  1186. {
  1187. System.Threading.Thread.Sleep(500);
  1188. }
  1189. worker.ReportProgress(0, table["loading_dimension_analysis_table_completed"].ToString());//加载颗粒尺寸分析表模块完成
  1190. //调用,元素分析表---------------------------------------------
  1191. worker.ReportProgress(0, table["element_analysis_table_ing"].ToString());//加载元素分析表模块中....
  1192. worker.ReportProgress(0, table["load_element_analysis_table"].ToString());//加载:元素分析表
  1193. //更新进度条
  1194. processvalue = processvalue + i_zz;
  1195. worker.ReportProgress(processvalue);
  1196. lock (m_thread_flag)
  1197. m_thread_flag = table["rictbox7"].ToString();//等待
  1198. while (m_thread_flag == table["rictbox7"].ToString())//等待
  1199. {
  1200. System.Threading.Thread.Sleep(500);
  1201. }
  1202. worker.ReportProgress(0, table["loading_element_analysis_table_completed"].ToString());//加载元素分析表模块完成
  1203. //调用,夹杂物面积比表---------------------------------------------
  1204. worker.ReportProgress(0, table["inca_area_ratio_table_ing"].ToString());//加载夹杂物面积比表模块中....
  1205. worker.ReportProgress(0, table["load_inca_area_ratio_table"].ToString());//加载:夹杂物面积比表
  1206. //更新进度条
  1207. processvalue = processvalue + i_zz;
  1208. worker.ReportProgress(processvalue);
  1209. lock (m_thread_flag)
  1210. m_thread_flag = table["rictbox7"].ToString();//等待
  1211. while (m_thread_flag == table["rictbox7"].ToString())//等待
  1212. {
  1213. System.Threading.Thread.Sleep(500);
  1214. }
  1215. worker.ReportProgress(0, table["loading_inca_area_ratio_table_completed"].ToString());//加载夹杂物面积比表模块完成
  1216. //调用,夹杂物面积比图---------------------------------------------
  1217. worker.ReportProgress(0, table["inca_area_ratio_diagram_ing"].ToString());//加载夹杂物面积比图模块中....
  1218. worker.ReportProgress(0, table["load_inca_area_ratio_diagram"].ToString());//加载:夹杂物面积比图
  1219. //更新进度条
  1220. processvalue = processvalue + i_zz;
  1221. worker.ReportProgress(processvalue);
  1222. lock (m_thread_flag)
  1223. m_thread_flag = table["rictbox7"].ToString();//等待
  1224. while (m_thread_flag == table["rictbox7"].ToString())//等待
  1225. {
  1226. System.Threading.Thread.Sleep(500);
  1227. }
  1228. worker.ReportProgress(0, table["loading_inca_area_ratio_diagram_completed"].ToString());//加载夹杂物面积比图模块完成
  1229. System.Threading.Thread.Sleep(2000);
  1230. //调用,三元相图----------------------------------------------
  1231. worker.ReportProgress(0, table["ternary_graph_ing"].ToString());//加载三元相图模块中....
  1232. worker.ReportProgress(0, table["load_ternary_graph"].ToString());//加载:三元相图
  1233. //更新进度条
  1234. processvalue = processvalue + i_zz;
  1235. worker.ReportProgress(processvalue);
  1236. lock (m_thread_flag)
  1237. m_thread_flag = table["rictbox7"].ToString();//等待
  1238. while (m_thread_flag == table["rictbox7"].ToString())//等待
  1239. {
  1240. System.Threading.Thread.Sleep(500);
  1241. }
  1242. worker.ReportProgress(0, table["loading_ternary_graph_completed"].ToString());//加载三元相图模块完成
  1243. //调用输出,颗粒列表----------------------------------------
  1244. worker.ReportProgress(0, table["particle_list_ing"].ToString());//加载颗粒列表模块中....
  1245. worker.ReportProgress(0, table["load_particle_list"].ToString());//加载:颗粒列表
  1246. //更新进度条
  1247. processvalue = processvalue + i_zz;
  1248. worker.ReportProgress(processvalue);
  1249. lock (m_thread_flag)
  1250. m_thread_flag = table["rictbox7"].ToString();//等待
  1251. while (m_thread_flag == table["rictbox7"].ToString())//等待
  1252. {
  1253. System.Threading.Thread.Sleep(500);
  1254. }
  1255. worker.ReportProgress(0, table["loading_particle_list_completed"].ToString());//加载颗粒列表模块完成
  1256. //调用输出,颗粒列表帧图----------------------------------------
  1257. worker.ReportProgress(0, table["particle_list_frame_diagram_ing"].ToString());//加载颗粒列表帧图模块中....
  1258. worker.ReportProgress(0, table["load_particle_list_frame_diagram"].ToString());//加载:颗粒列表帧图
  1259. //更新进度条
  1260. processvalue = processvalue + i_zz;
  1261. worker.ReportProgress(processvalue);
  1262. lock (m_thread_flag)
  1263. m_thread_flag = table["rictbox7"].ToString();//等待
  1264. while (m_thread_flag == table["rictbox7"].ToString())//等待
  1265. {
  1266. System.Threading.Thread.Sleep(500);
  1267. }
  1268. worker.ReportProgress(0, table["loading_particle_list_frame_diagram_completed"].ToString());//加载颗粒列表帧图模块完成
  1269. //生成,模板临时数据库文件----------------------------------------------
  1270. worker.ReportProgress(0, table["rictbox35"].ToString());//生成模板临时数据库文件....
  1271. worker.ReportProgress(0, table["rictbox36"].ToString());//加载:生成模板临时数据库文件
  1272. //更新进度条
  1273. processvalue = processvalue + i_zz;
  1274. worker.ReportProgress(processvalue);
  1275. lock (m_thread_flag)
  1276. m_thread_flag = table["rictbox7"].ToString();//等待
  1277. while (m_thread_flag == table["rictbox7"].ToString())//等待
  1278. {
  1279. System.Threading.Thread.Sleep(500);
  1280. }
  1281. worker.ReportProgress(0, table["rictbox37"].ToString());//模板临时数据库文件完成
  1282. #endregion 依将循环调用各功能模块结束-------------------------------------------------------
  1283. }
  1284. private string AnalyticGraphics(int a_Indexes)
  1285. {
  1286. if (a_Indexes == 0)
  1287. return "pie";//饼图
  1288. else if (a_Indexes == 1)
  1289. return "radius";//圈图
  1290. else if (a_Indexes == 2)
  1291. return "bar";//柱状图
  1292. else if (a_Indexes == 3)
  1293. return "line";//线状图
  1294. else return "stack";//堆叠图
  1295. }
  1296. private void backgroundWorker2_ProgressChanged(object sender, ProgressChangedEventArgs e)
  1297. {
  1298. string strNill = table["rictbox40"].ToString();
  1299. BackgroundWorker worker = sender as BackgroundWorker;
  1300. //更新进度条的进度
  1301. if (e.UserState != null)
  1302. {
  1303. string ls_str = (string)e.UserState;
  1304. WriteRictBox((string)e.UserState);
  1305. string s = AnalyticGraphics(m_mbszclass.M_KLFXJG.index_cb_jzwfl_xstx);
  1306. if (ls_str.IndexOf(table["rictbox12"].ToString()) > -1)//加载:
  1307. {
  1308. if (ls_str.IndexOf(table["result_information"].ToString()) > -1)//测量结果信息表
  1309. {
  1310. DEVReport.setResultGrid(m_mbszclass);
  1311. lock (m_thread_flag)
  1312. m_thread_flag = strNill;
  1313. }
  1314. if (ls_str.IndexOf(table["dimensional_analysis_table"].ToString()) > -1)//颗粒尺寸分析表
  1315. {
  1316. if (m_mbszclass.M_KLFXJG.b_ck_klcc_xsmk)
  1317. DEVReport.setParticleSizeTable(m_mbszclass);
  1318. lock (m_thread_flag)
  1319. m_thread_flag = strNill;
  1320. }
  1321. if (ls_str.IndexOf(table["element_analysis_table"].ToString()) > -1)//元素分析表
  1322. {
  1323. if (m_mbszclass.M_YSFXJG.b_ck_ysfx_xsmk)
  1324. DEVReport.setElementAvgGrid(m_mbszclass);
  1325. lock (m_thread_flag)
  1326. m_thread_flag = strNill;
  1327. }
  1328. if (ls_str.IndexOf(table["inca_area_ratio_table"].ToString()) > -1)//夹杂物面积比表
  1329. {
  1330. if (m_mbszclass.M_JZWZB.b_ck_surface)
  1331. DEVReport.setINCAtable(m_mbszclass);
  1332. lock (m_thread_flag)
  1333. m_thread_flag = strNill;
  1334. }
  1335. if (ls_str.IndexOf(table["inca_area_ratio_diagram"].ToString()) > -1)//夹杂物面积比图
  1336. {
  1337. if (m_mbszclass.M_JZWZB.b_ck_chart)
  1338. {
  1339. DEVReport.set_incaPIC_classify(m_mbszclass);
  1340. DEVReport.set_incaPIC_subdivision(m_mbszclass);
  1341. }
  1342. lock (m_thread_flag)
  1343. m_thread_flag = strNill;
  1344. }
  1345. if (ls_str.IndexOf(table["ternary_graph"].ToString()) > -1)//三元图
  1346. {
  1347. if (m_mbszclass.M_SYXT.b_ck_syxt_xsmk)
  1348. DEVReport.InsertReportTemplateChart_Trianglediagram(m_mbszclass);
  1349. lock (m_thread_flag)
  1350. m_thread_flag = strNill;
  1351. }
  1352. if (ls_str.IndexOf(table["particle_list"].ToString()) > -1)//颗粒列表
  1353. {
  1354. if (m_mbszclass.M_KLLBXX.b_ck_kllb_xsmk)
  1355. DEVReport.set_kllb_data(m_mbszclass);
  1356. lock (m_thread_flag)
  1357. m_thread_flag = strNill;
  1358. }
  1359. if (ls_str.IndexOf(table["particle_list_frame_diagram"].ToString()) > -1)//颗粒帧图列表
  1360. {
  1361. if (m_mbszclass.M_KLLBXX.b_ck_kllb_fjzt)
  1362. DEVReport.set_kllb_data_frame(m_mbszclass);
  1363. lock (m_thread_flag)
  1364. m_thread_flag = strNill;
  1365. }
  1366. if (ls_str.IndexOf(table["rictbox38"].ToString()) > -1)//生成模板临时数据库文件
  1367. {
  1368. DEVReport.International_language(dev_internationalLanguage());
  1369. lock (m_thread_flag)
  1370. m_thread_flag = strNill;
  1371. }
  1372. }
  1373. }
  1374. else
  1375. {
  1376. progressBar1.Value = e.ProgressPercentage;
  1377. WriteRictBox(table["rictbox39"].ToString() + e.ProgressPercentage.ToString() + "%");
  1378. }
  1379. }
  1380. private void backgroundWorker2_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
  1381. {
  1382. WriteRictBox(table["rictbox41"].ToString() + m_export_reporttemplate.m_list_dt.Count.ToString() + table["rictbox42"].ToString(), Color.Red);
  1383. //处理结束后,再将button的状态更新回去
  1384. progressBar1.Value = 100;
  1385. WriteRictBox("-----------------"+ table["rictbox43"].ToString() + "--------------------", Color.Red);
  1386. MemoryManagementClass.FlushMemory();
  1387. //导出完成,打开报表
  1388. OpenOTSINcAreportTemplateAPP();
  1389. m_ReportApp.m_conditionChoose.ShowsTheDefaultPic();
  1390. this.Close();
  1391. }
  1392. #endregion
  1393. #region 读取文件
  1394. private void LoadControlsToXml()
  1395. {
  1396. string path = string.Empty;
  1397. OpenFileDialog Load = new OpenFileDialog();
  1398. Load.Filter = "XML File|*.xml";
  1399. Load.InitialDirectory = @System.Windows.Forms.Application.StartupPath + "\\Config\\ProData";
  1400. if (Load.ShowDialog() == DialogResult.OK)
  1401. path = Load.FileName;//赋值目录
  1402. if (path != string.Empty)
  1403. {
  1404. tb_mblj.Text = path;
  1405. m_mbszclass.M_DZ.route = path;
  1406. OTSIncAReportApp.Controls.XmlConfigUtil xmlutil = new OTSIncAReportApp.Controls.XmlConfigUtil(path);
  1407. //首页
  1408. m_mbszclass.M_SY.str_tb_ZBT = xmlutil.Read("M_SY", "str_tb_ZBT");
  1409. m_mbszclass.M_SY.str_tb_FBT = xmlutil.Read("M_SY", "str_tb_FBT");
  1410. m_mbszclass.M_SY.str_tb_YPBH = xmlutil.Read("M_SY", "str_tb_YPBH");
  1411. m_mbszclass.M_SY.str_tb_CKBZ = xmlutil.Read("M_SY", "str_tb_CKBZ");
  1412. m_mbszclass.M_SY.str_bz = xmlutil.Read("M_SY", "str_bz");
  1413. m_mbszclass.M_SY.b_ck_ypsm = Convert.ToBoolean(xmlutil.Read("M_SY", "b_ck_ypsm"));
  1414. m_mbszclass.M_SY.b_ck_jggk = Convert.ToBoolean(xmlutil.Read("M_SY", "b_ck_jggk"));
  1415. m_mbszclass.M_SY.str_xzkl = xmlutil.Read("M_SY", "str_xzkl");
  1416. m_mbszclass.M_SY.int_xzkl = Convert.ToInt32(xmlutil.Read("M_SY", "int_xzkl"));
  1417. //页眉页脚
  1418. m_mbszclass.M_YMYJ.str_tb_ymwb = xmlutil.Read("M_YMYJ", "str_tb_ymwb");
  1419. m_mbszclass.M_YMYJ.str_tb_KHH = xmlutil.Read("M_YMYJ", "str_tb_KHH");
  1420. m_mbszclass.M_YMYJ.b_ck_ym = Convert.ToBoolean(xmlutil.Read("M_YMYJ", "b_ck_ym"));
  1421. m_mbszclass.M_YMYJ.str_tb_yjwb = xmlutil.Read("M_YMYJ", "str_tb_yjwb");
  1422. //颗粒分析结果
  1423. m_mbszclass.M_KLFXJG.b_ck_klcc_xsmk = Convert.ToBoolean(xmlutil.Read("M_KLFXJG", "b_ck_klcc_xsmk"));//是否显示模块
  1424. m_mbszclass.M_KLFXJG.index_cb_klcc_jsfs = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_klcc_jsfs"));//计算方式
  1425. m_mbszclass.M_KLFXJG.index_cb_klcc_ljb = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_klcc_ljb"));//粒级表
  1426. m_mbszclass.M_KLFXJG.index_cb_klcc_klfw = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_klcc_klfw"));//颗粒范围
  1427. m_mbszclass.M_KLFXJG.b_cb_jzwfl_xsmk = Convert.ToBoolean(xmlutil.Read("M_KLFXJG", "b_cb_jzwfl_xsmk"));//是否显示该模块
  1428. m_mbszclass.M_KLFXJG.index_cb_jzwfl_xstx = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_jzwfl_xstx"));//选择图像
  1429. m_mbszclass.M_KLFXJG.index_cb_jzwfl_jsfs = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_jzwfl_jsfs"));//计算方式
  1430. m_mbszclass.M_KLFXJG.index_cb_jzwfl_ljb = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_jzwfl_ljb"));//粒级表
  1431. m_mbszclass.M_KLFXJG.index_cb_jzwfl_klfw = Convert.ToInt32(xmlutil.Read("M_KLFXJG", "index_cb_jzwfl_klfw"));//颗粒范围
  1432. //元素分析结果
  1433. m_mbszclass.M_YSFXJG.b_ck_ysfx_xsmk = Convert.ToBoolean(xmlutil.Read("M_YSFXJG", "b_ck_ysfx_xsmk")); //是否显示模块
  1434. m_mbszclass.M_YSFXJG.index_cb_yxfx_jsfs = Convert.ToInt32(xmlutil.Read("M_YSFXJG", "index_cb_yxfx_jsfs")); //计算方式
  1435. m_mbszclass.M_YSFXJG.index_cb_ysfx_klfw = Convert.ToInt32(xmlutil.Read("M_YSFXJG", "index_cb_ysfx_klfw")); //颗粒范围
  1436. m_mbszclass.M_YSFXJG.str_tb_ysfx_xsys = xmlutil.Read("M_YSFXJG", "str_tb_ysfx_xsys"); //显示元素
  1437. m_mbszclass.M_YSFXJG.list_str_tb_ysfx_xsys.Clear();
  1438. for (int i = 0; i < 100; i++) //取得所有元素列表
  1439. {
  1440. string str = xmlutil.Read("M_YSFXJG", "list_str_tb_ysfx_xsys", "YS" + i.ToString());
  1441. if (str == null)
  1442. {
  1443. break;
  1444. }
  1445. else
  1446. {
  1447. m_mbszclass.M_YSFXJG.list_str_tb_ysfx_xsys.Add(str);
  1448. }
  1449. }
  1450. m_mbszclass.M_YSFXJG.b_ck_yscf_xsmk = Convert.ToBoolean(xmlutil.Read("M_YSFXJG", "b_ck_yscf_xsmk")); //是否显示模块
  1451. m_mbszclass.M_YSFXJG.index_cb_yscf_xstx = Convert.ToInt32(xmlutil.Read("M_YSFXJG", "index_cb_yscf_xstx")); //显示图形
  1452. m_mbszclass.M_YSFXJG.index_cb_yscf_jsfs = Convert.ToInt32(xmlutil.Read("M_YSFXJG", "index_cb_yscf_jsfs")); //计算方式
  1453. m_mbszclass.M_YSFXJG.index_cb_yscf_klfw = Convert.ToInt32(xmlutil.Read("M_YSFXJG", "index_cb_yscf_klfw")); //颗粒范围
  1454. m_mbszclass.M_YSFXJG.str_tb_yscf_ysxx = xmlutil.Read("M_YSFXJG", "str_tb_yscf_ysxx"); //显示元素
  1455. m_mbszclass.M_YSFXJG.list_str_tb_yscf_ysxx.Clear();
  1456. for (int i = 0; i < 100; i++) //取得所有元素列表
  1457. {
  1458. string str = xmlutil.Read("M_YSFXJG", "list_str_tb_yscf_ysxx", "YS" + i.ToString());
  1459. if (str == null)
  1460. {
  1461. break;
  1462. }
  1463. else
  1464. {
  1465. m_mbszclass.M_YSFXJG.list_str_tb_yscf_ysxx.Add(str);
  1466. }
  1467. }
  1468. //三元相图
  1469. m_mbszclass.M_SYXT.b_ck_syxt_xsmk = Convert.ToBoolean(xmlutil.Read("M_SYXT", "b_ck_syxt_xsmk")); //是否显示模块
  1470. m_mbszclass.M_SYXT.index_cb_syxt_jsfs = Convert.ToInt32(xmlutil.Read("M_SYXT", "index_cb_syxt_jsfs")); //计算方式
  1471. m_mbszclass.M_SYXT.index_cb_syxt_klfw = Convert.ToInt32(xmlutil.Read("M_SYXT", "index_cb_syxt_klfw")); //颗粒范围
  1472. m_mbszclass.M_SYXT.str_cb_syxt_mhxssl = xmlutil.Read("M_SYXT", "str_cb_syxt_mhxssl"); //每行显示数量
  1473. m_mbszclass.M_SYXT.list_lbv_syxt_mblb.Clear();
  1474. for (int i = 0; i < 100; i++) //取得所有模板列表
  1475. {
  1476. string str = xmlutil.Read("M_SYXT", "list_lbv_syxt_mblb", "MB" + i.ToString());
  1477. if (str == null)
  1478. {
  1479. break;
  1480. }
  1481. else
  1482. {
  1483. m_mbszclass.M_SYXT.list_lbv_syxt_mblb.Add(str);
  1484. }
  1485. }
  1486. m_mbszclass.M_SYXT.list_lbv_syxt_mblb_index.Clear();
  1487. for (int i = 0; i < 100; i++) //取得所有模板列表 索引
  1488. {
  1489. string str = xmlutil.Read("M_SYXT", "list_lbv_syxt_mblb_index", "MBIndex" + i.ToString());
  1490. if (str == null)
  1491. {
  1492. break;
  1493. }
  1494. else
  1495. {
  1496. m_mbszclass.M_SYXT.list_lbv_syxt_mblb_index.Add(Convert.ToInt32(str));
  1497. }
  1498. }
  1499. //颗粒列表信息
  1500. m_mbszclass.M_KLLBXX.b_ck_kllb_xsmk = Convert.ToBoolean(xmlutil.Read("M_KLLBXX", "b_ck_kllb_xsmk")); //是否显示模块
  1501. m_mbszclass.M_KLLBXX.index_cb_kllb_jsfs = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "index_cb_kllb_jsfs")); //计算方式
  1502. m_mbszclass.M_KLLBXX.index_cb_kllb_klfw = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "index_cb_kllb_klfw")); //颗粒范围
  1503. m_mbszclass.M_KLLBXX.int_tb_kllb_ylsx = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "int_tb_kllb_ylsx")); //数量上限
  1504. m_mbszclass.M_KLLBXX.str_tb_kllb_sxys = xmlutil.Read("M_KLLBXX", "str_tb_kllb_sxys"); //显示元素
  1505. m_mbszclass.M_KLLBXX.list_str_tb_lllb_sxys.Clear();
  1506. for (int i = 0; i < 100; i++) //取得所有元素列表
  1507. {
  1508. string str = xmlutil.Read("M_KLLBXX", "list_str_tb_lllb_sxys", "YS" + i.ToString());
  1509. if (str == null)
  1510. {
  1511. break;
  1512. }
  1513. else
  1514. {
  1515. m_mbszclass.M_KLLBXX.list_str_tb_lllb_sxys.Add(str);
  1516. }
  1517. }
  1518. m_mbszclass.M_KLLBXX.b_ck_kllb_ystx = Convert.ToBoolean(xmlutil.Read("M_KLLBXX", "b_ck_kllb_ystx")); //原始图像
  1519. m_mbszclass.M_KLLBXX.b_ck_kllb_fdtx = Convert.ToBoolean(xmlutil.Read("M_KLLBXX", "b_ck_kllb_fdtx")); //放大图像
  1520. m_mbszclass.M_KLLBXX.b_ck_kllb_npxx = Convert.ToBoolean(xmlutil.Read("M_KLLBXX", "b_ck_kllb_npxx")); //能谱图像
  1521. m_mbszclass.M_KLLBXX.str_cb_kllb_sort_p1 = Convert.ToString(xmlutil.Read("M_KLLBXX", "str_cb_kllb_sort_p1"));//颗粒列表列中第一个可选参数
  1522. m_mbszclass.M_KLLBXX.index_cb_kllb_sort_p1 = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "index_cb_kllb_sort_p1"));
  1523. m_mbszclass.M_KLLBXX.str_cb_kllb_sort_p2 = Convert.ToString(xmlutil.Read("M_KLLBXX", "str_cb_kllb_sort_p2"));//颗粒列表中第二个可选参数
  1524. m_mbszclass.M_KLLBXX.index_cb_kllb_sort_p2 = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "index_cb_kllb_sort_p2"));
  1525. m_mbszclass.M_KLLBXX.str_cb_kllb_sort_p3 = Convert.ToString(xmlutil.Read("M_KLLBXX", "str_cb_kllb_sort_p3"));//颗粒列表中第三个可选参数
  1526. m_mbszclass.M_KLLBXX.index_cb_kllb_sort_p3 = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "index_cb_kllb_sort_p3"));
  1527. m_mbszclass.M_KLLBXX.str_cb_kllb_chartSort_p1 = Convert.ToString(xmlutil.Read("M_KLLBXX", "str_cb_kllb_chartSort_p1"));//帧图表列中第一个可选参数
  1528. m_mbszclass.M_KLLBXX.index_cb_kllb_chartSort_p1 = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "index_cb_kllb_chartSort_p1"));
  1529. m_mbszclass.M_KLLBXX.str_cb_kllb_chartSort_p2 = Convert.ToString(xmlutil.Read("M_KLLBXX", "str_cb_kllb_chartSort_p2"));//帧图表列中第二个可选参数
  1530. m_mbszclass.M_KLLBXX.index_cb_kllb_chartSort_p2 = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "index_cb_kllb_chartSort_p2"));
  1531. //m_mbszclass.M_KLLBXX.str_cb_kllb_chartSort_p3 = Convert.ToString(xmlutil.Read("M_KLLBXX", "str_cb_kllb_chartSort_p3"));//帧图表列中第三个可选参数
  1532. //m_mbszclass.M_KLLBXX.index_cb_kllb_chartSort_p3 = Convert.ToInt32(xmlutil.Read("M_KLLBXX", "index_cb_kllb_chartSort_p3"));
  1533. }
  1534. }
  1535. #endregion
  1536. private void button7_Click(object sender, EventArgs e)
  1537. {
  1538. GB_Report = new GBReport(this);
  1539. GB_Report.International_language(dev_internationalLanguage());
  1540. ReportPrintTool tool = new ReportPrintTool(GB_Report);
  1541. tool.ShowPreview();
  1542. }
  1543. /// <summary>
  1544. /// 将国标数据保存至DB数据中
  1545. /// </summary>
  1546. private void SaveReportGBTemplateDBFile(List<DataTable> GB1, List<DataTable> GB2, DataTable ResultGrid)
  1547. {
  1548. File.Delete(m_strDBpathGB);//测试时删除数据库文件,为防止第二次打开报告提示数据库占用,挪到方法开始处
  1549. SqlHelper.CreateNewDatabase(m_strDBpathGB);
  1550. SqlHelper sh = new SqlHelper("data source='" + m_strDBpathGB + "'");
  1551. //开始事务
  1552. SQLiteTransaction tr = sh.BeginTranscation();
  1553. //创建表 ResultGrid
  1554. string[] strcolumns_ResultGrid = { "CLJGMC", "YXSJ", "SCZS", "FLFA", "YJCTZ", "SCMJ", "CKBZ", "FDBS" };
  1555. string[] strcoltypes_ResultGrid = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" , "TEXT" };
  1556. sh.CreateTable("ResultGrid", strcolumns_ResultGrid, strcoltypes_ResultGrid);
  1557. //创建表 GB1_A
  1558. string[] strcolumns_GB1_A = { "Class", "Width", "c1", "c2", "c3", "c4", "c5", "c6", "c7", "c8", "c9", "c10", "c11" };
  1559. string[] strcoltypes_GB1_A = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1560. sh.CreateTable("GB1_A", strcolumns_GB1_A, strcoltypes_GB1_A);
  1561. //创建表 GB1_B
  1562. string[] strcolumns_GB1_B = { "Class", "Width", "c1", "c2", "c3", "c4", "c5", "c6", "c7", "c8", "c9", "c10", "c11" };
  1563. string[] strcoltypes_GB1_B = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1564. sh.CreateTable("GB1_B", strcolumns_GB1_B, strcoltypes_GB1_B);
  1565. //创建表 GB1_C
  1566. string[] strcolumns_GB1_C = { "Class", "Width", "c1", "c2", "c3", "c4", "c5", "c6", "c7", "c8", "c9", "c10", "c11" };
  1567. string[] strcoltypes_GB1_C = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1568. sh.CreateTable("GB1_C", strcolumns_GB1_C, strcoltypes_GB1_C);
  1569. //创建表 GB1_D
  1570. string[] strcolumns_GB1_D = { "Class", "Width", "c1", "c2", "c3", "c4", "c5", "c6", "c7", "c8", "c9", "c10", "c11" };
  1571. string[] strcoltypes_GB1_D = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1572. sh.CreateTable("GB1_D", strcolumns_GB1_D, strcoltypes_GB1_D);
  1573. //创建表 GB1_DS
  1574. string[] strcolumns_GB1_DS = { "No", "Area", "MaxFeret", "X", "Y", "Grade" };
  1575. string[] strcoltypes_GB1_DS = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1576. sh.CreateTable("GB1_DS", strcolumns_GB1_DS, strcoltypes_GB1_DS);
  1577. //创建表 GB2_A
  1578. string[] strcolumns_GB2_A = { "Class", "Width", "c1", "c2", "c3", "c4", "c5", "c6", "c7", "c8", "c9", "c10", "c11" };
  1579. string[] strcoltypes_GB2_A = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1580. sh.CreateTable("GB2_A", strcolumns_GB2_A, strcoltypes_GB2_A);
  1581. //创建表 GB2_B
  1582. string[] strcolumns_GB2_B = { "Class", "Width", "c1", "c2", "c3", "c4", "c5", "c6", "c7", "c8", "c9", "c10", "c11" };
  1583. string[] strcoltypes_GB2_B = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1584. sh.CreateTable("GB2_B", strcolumns_GB2_B, strcoltypes_GB2_B);
  1585. //创建表 GB2_C
  1586. string[] strcolumns_GB2_C = { "Class", "Width", "c1", "c2", "c3", "c4", "c5", "c6", "c7", "c8", "c9", "c10", "c11" };
  1587. string[] strcoltypes_GB2_C = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1588. sh.CreateTable("GB2_C", strcolumns_GB2_C, strcoltypes_GB2_C);
  1589. //创建表 GB2_D
  1590. string[] strcolumns_GB2_D = { "Class", "Width", "c1", "c2", "c3", "c4", "c5", "c6", "c7", "c8", "c9", "c10", "c11" };
  1591. string[] strcoltypes_GB2_D = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1592. sh.CreateTable("GB2_D", strcolumns_GB2_D, strcoltypes_GB2_D);
  1593. //创建表 GB2_D_sulfide
  1594. string[] strcolumns_GB2_D_sulfide = { "Class", "Width", "c1", "c2", "c3", "c4", "c5", "c6", "c7", "c8", "c9", "c10", "c11" };
  1595. string[] strcoltypes_GB2_D_sulfide = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1596. sh.CreateTable("GB2_D_sulfide", strcolumns_GB2_D_sulfide, strcoltypes_GB2_D_sulfide);
  1597. //创建表 GB2_DS
  1598. string[] strcolumns_GB2_DS = { "No", "Area", "MaxFeret", "X", "Y", "Grade" };
  1599. string[] strcoltypes_GB2_DS = { "TEXT", "TEXT", "TEXT", "TEXT", "TEXT", "TEXT" };
  1600. sh.CreateTable("GB2_DS", strcolumns_GB2_DS, strcoltypes_GB2_DS);
  1601. for (int i = 0; i < ResultGrid.Rows.Count; i++)
  1602. {
  1603. string ls_sqlstr = "insert into ResultGrid (CLJGMC, YXSJ, SCZS, FLFA, YJCTZ, SCMJ, CKBZ) values('"
  1604. + ResultGrid.Rows[i][0].ToString() + "','"
  1605. + ResultGrid.Rows[i][1].ToString() + "','"
  1606. + ResultGrid.Rows[i][2].ToString() + "','"
  1607. + ResultGrid.Rows[i][3].ToString() + "','"
  1608. + ResultGrid.Rows[i][4].ToString() + "','"
  1609. + ResultGrid.Rows[i][5].ToString() + "','"
  1610. + ResultGrid.Rows[i][6].ToString() + "')";
  1611. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1612. }
  1613. //插入 GB1_A
  1614. for (int i = 0; i < GB1[0].Rows.Count; i++)
  1615. {
  1616. string ls_sqlstr = "insert into GB1_A (Class, Width, c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11 ) values('"
  1617. + GB1[0].Rows[i][0].ToString() + "','"
  1618. + GB1[0].Rows[i][1].ToString() + "','"
  1619. + GB1[0].Rows[i][2].ToString() + "','"
  1620. + GB1[0].Rows[i][3].ToString() + "','"
  1621. + GB1[0].Rows[i][4].ToString() + "','"
  1622. + GB1[0].Rows[i][5].ToString() + "','"
  1623. + GB1[0].Rows[i][6].ToString() + "','"
  1624. + GB1[0].Rows[i][7].ToString() + "','"
  1625. + GB1[0].Rows[i][8].ToString() + "','"
  1626. + GB1[0].Rows[i][9].ToString() + "','"
  1627. + GB1[0].Rows[i][10].ToString() + "','"
  1628. + GB1[0].Rows[i][11].ToString() + "','"
  1629. + GB1[0].Rows[i][12].ToString() + "')";
  1630. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1631. }
  1632. //插入 GB1_B
  1633. for (int i = 0; i < GB1[1].Rows.Count; i++)
  1634. {
  1635. string ls_sqlstr = "insert into GB1_B (Class, Width, c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11 ) values('"
  1636. + GB1[1].Rows[i][0].ToString() + "','"
  1637. + GB1[1].Rows[i][1].ToString() + "','"
  1638. + GB1[1].Rows[i][2].ToString() + "','"
  1639. + GB1[1].Rows[i][3].ToString() + "','"
  1640. + GB1[1].Rows[i][4].ToString() + "','"
  1641. + GB1[1].Rows[i][5].ToString() + "','"
  1642. + GB1[1].Rows[i][6].ToString() + "','"
  1643. + GB1[1].Rows[i][7].ToString() + "','"
  1644. + GB1[1].Rows[i][8].ToString() + "','"
  1645. + GB1[1].Rows[i][9].ToString() + "','"
  1646. + GB1[1].Rows[i][10].ToString() + "','"
  1647. + GB1[1].Rows[i][11].ToString() + "','"
  1648. + GB1[1].Rows[i][12].ToString() + "')";
  1649. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1650. }
  1651. //插入 GB1_C
  1652. for (int i = 0; i < GB1[2].Rows.Count; i++)
  1653. {
  1654. string ls_sqlstr = "insert into GB1_C (Class, Width, c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11 ) values('"
  1655. + GB1[2].Rows[i][0].ToString() + "','"
  1656. + GB1[2].Rows[i][1].ToString() + "','"
  1657. + GB1[2].Rows[i][2].ToString() + "','"
  1658. + GB1[2].Rows[i][3].ToString() + "','"
  1659. + GB1[2].Rows[i][4].ToString() + "','"
  1660. + GB1[2].Rows[i][5].ToString() + "','"
  1661. + GB1[2].Rows[i][6].ToString() + "','"
  1662. + GB1[2].Rows[i][7].ToString() + "','"
  1663. + GB1[2].Rows[i][8].ToString() + "','"
  1664. + GB1[2].Rows[i][9].ToString() + "','"
  1665. + GB1[2].Rows[i][10].ToString() + "','"
  1666. + GB1[2].Rows[i][11].ToString() + "','"
  1667. + GB1[2].Rows[i][12].ToString() + "')";
  1668. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1669. }
  1670. //插入 GB1_D
  1671. for (int i = 0; i < GB1[3].Rows.Count; i++)
  1672. {
  1673. string ls_sqlstr = "insert into GB1_D (Class, Width, c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11 ) values('"
  1674. + GB1[3].Rows[i][0].ToString() + "','"
  1675. + GB1[3].Rows[i][1].ToString() + "','"
  1676. + GB1[3].Rows[i][2].ToString() + "','"
  1677. + GB1[3].Rows[i][3].ToString() + "','"
  1678. + GB1[3].Rows[i][4].ToString() + "','"
  1679. + GB1[3].Rows[i][5].ToString() + "','"
  1680. + GB1[3].Rows[i][6].ToString() + "','"
  1681. + GB1[3].Rows[i][7].ToString() + "','"
  1682. + GB1[3].Rows[i][8].ToString() + "','"
  1683. + GB1[3].Rows[i][9].ToString() + "','"
  1684. + GB1[3].Rows[i][10].ToString() + "','"
  1685. + GB1[3].Rows[i][11].ToString() + "','"
  1686. + GB1[3].Rows[i][12].ToString() + "')";
  1687. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1688. }
  1689. //插入 GB1_DS
  1690. for (int i = 0; i < GB1[4].Rows.Count; i++)
  1691. {
  1692. string ls_sqlstr = "insert into GB1_DS (No, Area, MaxFeret, X, Y, Grade ) values('"
  1693. + GB1[4].Rows[i][0].ToString() + "','"
  1694. + GB1[4].Rows[i][1].ToString() + "','"
  1695. + GB1[4].Rows[i][2].ToString() + "','"
  1696. + GB1[4].Rows[i][3].ToString() + "','"
  1697. + GB1[4].Rows[i][4].ToString() + "','"
  1698. + GB1[4].Rows[i][5].ToString() + "')";
  1699. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1700. }
  1701. //插入 GB2_A
  1702. for (int i = 0; i < GB2[0].Rows.Count; i++)
  1703. {
  1704. string ls_sqlstr = "insert into GB2_A (Class, Width, c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11 ) values('"
  1705. + GB2[0].Rows[i][0].ToString() + "','"
  1706. + GB2[0].Rows[i][1].ToString() + "','"
  1707. + GB2[0].Rows[i][2].ToString() + "','"
  1708. + GB2[0].Rows[i][3].ToString() + "','"
  1709. + GB2[0].Rows[i][4].ToString() + "','"
  1710. + GB2[0].Rows[i][5].ToString() + "','"
  1711. + GB2[0].Rows[i][6].ToString() + "','"
  1712. + GB2[0].Rows[i][7].ToString() + "','"
  1713. + GB2[0].Rows[i][8].ToString() + "','"
  1714. + GB2[0].Rows[i][9].ToString() + "','"
  1715. + GB2[0].Rows[i][10].ToString() + "','"
  1716. + GB2[0].Rows[i][11].ToString() + "','"
  1717. + GB2[0].Rows[i][12].ToString() + "')";
  1718. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1719. }
  1720. //插入 GB2_B
  1721. for (int i = 0; i < GB2[1].Rows.Count; i++)
  1722. {
  1723. string ls_sqlstr = "insert into GB2_B (Class, Width, c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11 ) values('"
  1724. + GB2[1].Rows[i][0].ToString() + "','"
  1725. + GB2[1].Rows[i][1].ToString() + "','"
  1726. + GB2[1].Rows[i][2].ToString() + "','"
  1727. + GB2[1].Rows[i][3].ToString() + "','"
  1728. + GB2[1].Rows[i][4].ToString() + "','"
  1729. + GB2[1].Rows[i][5].ToString() + "','"
  1730. + GB2[1].Rows[i][6].ToString() + "','"
  1731. + GB2[1].Rows[i][7].ToString() + "','"
  1732. + GB2[1].Rows[i][8].ToString() + "','"
  1733. + GB2[1].Rows[i][9].ToString() + "','"
  1734. + GB2[1].Rows[i][10].ToString() + "','"
  1735. + GB2[1].Rows[i][11].ToString() + "','"
  1736. + GB2[1].Rows[i][12].ToString() + "')";
  1737. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1738. }
  1739. //插入 GB2_C
  1740. for (int i = 0; i < GB2[2].Rows.Count; i++)
  1741. {
  1742. string ls_sqlstr = "insert into GB2_C (Class, Width, c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11 ) values('"
  1743. + GB2[2].Rows[i][0].ToString() + "','"
  1744. + GB2[2].Rows[i][1].ToString() + "','"
  1745. + GB2[2].Rows[i][2].ToString() + "','"
  1746. + GB2[2].Rows[i][3].ToString() + "','"
  1747. + GB2[2].Rows[i][4].ToString() + "','"
  1748. + GB2[2].Rows[i][5].ToString() + "','"
  1749. + GB2[2].Rows[i][6].ToString() + "','"
  1750. + GB2[2].Rows[i][7].ToString() + "','"
  1751. + GB2[2].Rows[i][8].ToString() + "','"
  1752. + GB2[2].Rows[i][9].ToString() + "','"
  1753. + GB2[2].Rows[i][10].ToString() + "','"
  1754. + GB2[2].Rows[i][11].ToString() + "','"
  1755. + GB2[2].Rows[i][12].ToString() + "')";
  1756. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1757. }
  1758. //插入 GB1_D
  1759. for (int i = 0; i < GB2[3].Rows.Count; i++)
  1760. {
  1761. string ls_sqlstr = "insert into GB2_D (Class, Width, c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11 ) values('"
  1762. + GB2[3].Rows[i][0].ToString() + "','"
  1763. + GB2[3].Rows[i][1].ToString() + "','"
  1764. + GB2[3].Rows[i][2].ToString() + "','"
  1765. + GB2[3].Rows[i][3].ToString() + "','"
  1766. + GB2[3].Rows[i][4].ToString() + "','"
  1767. + GB2[3].Rows[i][5].ToString() + "','"
  1768. + GB2[3].Rows[i][6].ToString() + "','"
  1769. + GB2[3].Rows[i][7].ToString() + "','"
  1770. + GB2[3].Rows[i][8].ToString() + "','"
  1771. + GB2[3].Rows[i][9].ToString() + "','"
  1772. + GB2[3].Rows[i][10].ToString() + "','"
  1773. + GB2[3].Rows[i][11].ToString() + "','"
  1774. + GB2[3].Rows[i][12].ToString() + "')";
  1775. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1776. }
  1777. //插入 GB2_D_sulfide
  1778. for (int i = 0; i < GB2[4].Rows.Count; i++)
  1779. {
  1780. string ls_sqlstr = "insert into GB2_D_sulfide (Class, Width, c1, c2, c3, c4, c5, c6, c7, c8, c9, c10, c11 ) values('"
  1781. + GB2[4].Rows[i][0].ToString() + "','"
  1782. + GB2[4].Rows[i][1].ToString() + "','"
  1783. + GB2[4].Rows[i][2].ToString() + "','"
  1784. + GB2[4].Rows[i][3].ToString() + "','"
  1785. + GB2[4].Rows[i][4].ToString() + "','"
  1786. + GB2[4].Rows[i][5].ToString() + "','"
  1787. + GB2[4].Rows[i][6].ToString() + "','"
  1788. + GB2[4].Rows[i][7].ToString() + "','"
  1789. + GB2[4].Rows[i][8].ToString() + "','"
  1790. + GB2[4].Rows[i][9].ToString() + "','"
  1791. + GB2[4].Rows[i][10].ToString() + "','"
  1792. + GB2[4].Rows[i][11].ToString() + "','"
  1793. + GB2[4].Rows[i][12].ToString() + "')";
  1794. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1795. }
  1796. //插入 GB1_DS
  1797. for (int i = 0; i < GB2[5].Rows.Count; i++)
  1798. {
  1799. string ls_sqlstr = "insert into GB2_DS (No, Area, MaxFeret, X, Y, Grade ) values('"
  1800. + GB2[5].Rows[i][0].ToString() + "','"
  1801. + GB2[5].Rows[i][1].ToString() + "','"
  1802. + GB2[5].Rows[i][2].ToString() + "','"
  1803. + GB2[5].Rows[i][3].ToString() + "','"
  1804. + GB2[5].Rows[i][4].ToString() + "','"
  1805. + GB2[5].Rows[i][5].ToString() + "')";
  1806. int iresult = sh.ExecuteQueryResult(ls_sqlstr, tr);
  1807. }
  1808. //事务提交
  1809. sh.TranscationCommit(tr);
  1810. //最后关闭连接
  1811. tr.Dispose();
  1812. tr = null;
  1813. sh.CloseConnection();
  1814. //}
  1815. }
  1816. /// <summary>
  1817. /// 打开国标导出
  1818. /// </summary>
  1819. private void OpenOTSINcAreportGBTemplateAPP()
  1820. {
  1821. ProcessStartInfo process = new ProcessStartInfo();
  1822. process.FileName = "ReportTemplateExe\\OTSIncAReportTemplate.exe";//打开app的路径
  1823. string arg1 = m_strDBpathGB.Replace(" ", "^");//参数1,是需要打开db数据库的路径
  1824. string arg2 = tb_mblj.Text.Trim().Replace(" ", "^");//参数2,是模板文件的路径
  1825. string arg3 = "GBReport";//主体报表
  1826. string arg4 = "100";//夹杂物数量
  1827. string arg5 = "0-100";//打开的标记帧图图像数量
  1828. process.Arguments = string.Format("{0} {1} {2} {3} {4}", arg1, arg2, arg3, arg4, arg5); //多个参数用空格隔开
  1829. process.WindowStyle = ProcessWindowStyle.Normal;
  1830. Process.Start(process);
  1831. }
  1832. private void OTSReport_Export_FormClosed(object sender, FormClosedEventArgs e)
  1833. {
  1834. }
  1835. private void button1_Click(object sender, EventArgs e)
  1836. {
  1837. DEVReport = new OTS_DEVReport(this);
  1838. //DEVReport.Dispose();
  1839. //DEVReport = new OTS_DEVReport(this);
  1840. DEVReport.setResultGrid(m_mbszclass);
  1841. DEVReport.setParticleSizeTable(m_mbszclass);
  1842. DEVReport.setElementAvgGrid(m_mbszclass);
  1843. DEVReport.setINCAtable(m_mbszclass);
  1844. DEVReport.set_incaPIC_classify(m_mbszclass);
  1845. DEVReport.set_incaPIC_subdivision(m_mbszclass);
  1846. DEVReport.InsertReportTemplateChart_Trianglediagram(m_mbszclass);
  1847. DEVReport.set_kllb_data(m_mbszclass);
  1848. DEVReport.set_kllb_data_frame(m_mbszclass);
  1849. DEVReport.International_language(dev_internationalLanguage());
  1850. ReportPrintTool tool = new ReportPrintTool(DEVReport);
  1851. tool.ShowPreview();
  1852. }
  1853. /// <summary>
  1854. /// 从数据库中读取语言配置信息
  1855. /// </summary>
  1856. /// <returns></returns>
  1857. private DataTable dev_internationalLanguage()
  1858. {
  1859. string Language = "ZH";
  1860. OTSCommon.SqLiteHelper sh = new OTSCommon.SqLiteHelper("data source='" + System.IO.Directory.GetCurrentDirectory() + "\\ReportProfile\\language.db'");
  1861. DataTable dt_stl = sh.ExecuteQuery("select * from "+ Language);
  1862. return dt_stl;
  1863. }
  1864. }
  1865. }