OTSReport_Export.cs 116 KB

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