ReportsFrm.pas 45 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528
  1. unit ReportsFrm;
  2. interface
  3. // 导出PDF须定义该编译指令
  4. {$DEFINE cplPrint}
  5. // 导出Excel须定义该编译指令
  6. {$DEFINE cplOutputToExcelRange}
  7. uses
  8. ProjectData, ScFileArchiver, ReportManager, ConditionalDefines,
  9. PrintComTypeDefUnit, ADODB, DB, ReportPrepare, ReportConnection,
  10. AuditSelectFrm,
  11. Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  12. Dialogs, PrintCom, PrintComXML, ExtCtrls, ExTreeView, ImgList,
  13. dxBarExtItems, dxBar, ComCtrls, ToolWin, StdCtrls;
  14. type
  15. TReportsForm = class(TForm)
  16. xmReports: TdxBarManager;
  17. xlbPrint: TdxBarLargeButton;
  18. xlbToExcel: TdxBarLargeButton;
  19. xlbToPDF: TdxBarLargeButton;
  20. xlbRealSize: TdxBarLargeButton;
  21. xlbOnePage: TdxBarLargeButton;
  22. xlbTwoPage: TdxBarLargeButton;
  23. xlbFourPage: TdxBarLargeButton;
  24. xcbPages: TdxBarCombo;
  25. xlbFirstPage: TdxBarLargeButton;
  26. xlbPrePage: TdxBarLargeButton;
  27. xlbNextPage: TdxBarLargeButton;
  28. xlbLastPage: TdxBarLargeButton;
  29. xcbStartPage: TdxBarCombo;
  30. xcbEndPage: TdxBarCombo;
  31. xlbSetup: TdxBarLargeButton;
  32. xlbClose: TdxBarLargeButton;
  33. xlbPrintCurPage: TdxBarLargeButton;
  34. dxcciSafePrint: TdxBarControlContainerItem;
  35. ilstLarge: TImageList;
  36. pnlReportsList: TPanel;
  37. extvReport: TExTreeView;
  38. sprReportPreview: TSplitter;
  39. sbReportsPreview: TScrollBox;
  40. PreviewBox: TImage;
  41. PreviewComXML: TPrintComXML;
  42. ilstTree: TImageList;
  43. pnlTopButton: TPanel;
  44. tobaTemplateManager: TToolBar;
  45. tbImportSrt: TToolButton;
  46. tbExportSrt: TToolButton;
  47. tbDeleteSrt: TToolButton;
  48. ilstTemplateContorl: TImageList;
  49. pnlPaperSize: TPanel;
  50. rdbtnA3: TRadioButton;
  51. rdbtnA4: TRadioButton;
  52. chkFillZero: TCheckBox;
  53. dxcciPageSize: TdxBarControlContainerItem;
  54. pnlExcelMode: TPanel;
  55. chkExcelMode: TCheckBox;
  56. chkExcel2010: TCheckBox;
  57. dxcciExcelMode: TdxBarControlContainerItem;
  58. pnlReports: TPanel;
  59. BatchPrintXml: TPrintComXML;
  60. procedure PreviewComXMLGetDataConnection(var ADOCon: TADOConnection);
  61. procedure xlbRealSizeClick(Sender: TObject);
  62. procedure xlbOnePageClick(Sender: TObject);
  63. procedure xlbTwoPageClick(Sender: TObject);
  64. procedure xlbFourPageClick(Sender: TObject);
  65. procedure xlbFirstPageClick(Sender: TObject);
  66. procedure xlbPrePageClick(Sender: TObject);
  67. procedure xlbNextPageClick(Sender: TObject);
  68. procedure xlbLastPageClick(Sender: TObject);
  69. procedure xcbPagesChange(Sender: TObject);
  70. procedure xlbPrintCurPageClick(Sender: TObject);
  71. procedure xcbStartPageChange(Sender: TObject);
  72. procedure xlbPrintClick(Sender: TObject);
  73. procedure xlbToPDFClick(Sender: TObject);
  74. procedure xlbToExcelClick(Sender: TObject);
  75. procedure extvReportClick(Sender: TObject);
  76. procedure xlbCloseClick(Sender: TObject);
  77. procedure tbImportSrtClick(Sender: TObject);
  78. procedure tbDeleteSrtClick(Sender: TObject);
  79. procedure tbExportSrtClick(Sender: TObject);
  80. procedure PreviewComXMLContentDisplay(var contentFontRec: TFontRec;
  81. dataType: Integer; isReading: Boolean; DrawType: Integer;
  82. isPrinting: Boolean);
  83. procedure xlbSetupClick(Sender: TObject);
  84. procedure PreviewComXMLCrossTabLabelShow(valIDX: Integer; var ExLeft,
  85. ExRight: Double; var isShow: Boolean; CrsTabShowType: Integer);
  86. procedure rdbtnA4Click(Sender: TObject);
  87. procedure chkFillZeroClick(Sender: TObject);
  88. procedure PreviewComXMLGetDatasetEvent(DatasetInfo: PDatasetInfoRec;
  89. var ADataset: TDataSet);
  90. private
  91. FProjectData: TProjectData;
  92. FCurPage: Integer;
  93. FiPageGroup: Integer;
  94. FiCenterPerPage: Integer;
  95. FbNormal : Boolean;
  96. FDisplayCount: Integer;
  97. FLockForm: Boolean;
  98. // 数据库管理
  99. FReportCon: TReportConnection;
  100. // 报表数据准备
  101. FReportDataPrepare: TReportPrepare;
  102. procedure InitPageSettings(APrintCom: TPrintComXML);
  103. procedure InitFont(APrintCom: TPrintComXML);
  104. procedure InitPaperSettings(ATemplate: TTemplateNode; APrintCom: TPrintComXML);
  105. function GetHintStr: string;
  106. function AddClassNode(AParent: TExTreeNode; const AName: string): TExTreeNode;
  107. function GetClassNode(ANode: TTemplateNode): TExTreeNode;
  108. function GetSubClassNode(AClassNode: TExTreeNode; ANode: TTemplateNode): TExTreeNode;
  109. procedure AddReportTemplate(ANode: TTemplateNode);
  110. procedure LoadReportTemplets;
  111. procedure SaveAuditOpinion(ATemplate: TTemplateNode);
  112. procedure SaveReportInteractData(ATemplate: TTemplateNode);
  113. procedure ResizePreviewBox;
  114. procedure PreviewReportCurPage;
  115. procedure RepaintCurPagePreview;
  116. procedure LoadTemplet(ATemplate: TTemplateNode; APrintCom: TPrintComXML);
  117. procedure LoadTempletAndDisplay;
  118. procedure BeforeExport;
  119. procedure AfterExport;
  120. procedure LoadExcelBorder(var Border : TColumnLineRec);
  121. procedure PrintReport(ATemplateNode: TTemplateNode; isPDF, isExcel: boolean;
  122. ExcelOutputName, TemplateFileName: string);
  123. procedure ExportXlsReport(AStartPage, AEndPage: Integer; const AFileName: string; APrintCom: TPrintComXML);
  124. procedure ExportCurXlsReport;
  125. procedure ExportAllSelectedXlsReports;
  126. procedure PrintAllSelectedReports;
  127. procedure ExportAllSelectedPDFReports;
  128. procedure SetProjectData(const Value: TProjectData);
  129. procedure SetCurPage(const Value: Integer);
  130. function GetPrintEndPage: Integer;
  131. function GetPrintStartPage: Integer;
  132. function GetPageCount: Integer;
  133. function GetPrecededCount: Integer;
  134. function GetExcelMode: TOutputExcelMode;
  135. function GetIsExcel2010: Boolean;
  136. public
  137. destructor Destroy; override;
  138. procedure InitFormView;
  139. procedure InitReportSettings(APrintCom: TPrintComXML; ATemplate: TTemplateNode = nil);
  140. property ProjectData: TProjectData read FProjectData write SetProjectData;
  141. // 当前预览的页码
  142. property CurPage: Integer read FCurPage write SetCurPage;
  143. // 显示几页
  144. property DisplayCount: Integer read FDisplayCount write FDisplayCount;
  145. // 翻到的页数(例如:当前显示9页,显示4页,则翻到的页数为3)
  146. property PrecededCount: Integer read GetPrecededCount;
  147. property PrintStartPage: Integer read GetPrintStartPage;
  148. property PrintEndPage: Integer read GetPrintEndPage;
  149. property PageCount: Integer read GetPageCount;
  150. property ExcelMode: TOutputExcelMode read GetExcelMode;
  151. property IsExcel2010: Boolean read GetIsExcel2010;
  152. property LockForm: Boolean read FLockForm write FLockForm;
  153. end;
  154. procedure DisplayReportsForm(AProjectData: TProjectData);
  155. implementation
  156. uses
  157. UtilMethods, Math, DirectPrintUnit, Globals, ZhAPI, ReportAdjustFrm,
  158. Contnrs, mEncryptUnit, Printers, WinSpool, MainFrm, ConstUnit,
  159. GclBillsGatherModel;
  160. {$R *.dfm}
  161. procedure DisplayReportsForm(AProjectData: TProjectData);
  162. var
  163. ReportsForm: TReportsForm;
  164. begin
  165. ReportsForm := TReportsForm.Create(nil);
  166. {ReportsForm.BorderIcons := ReportsForm.BorderIcons - [biMaximize];
  167. ReportsForm.WindowState := wsMaximized;}
  168. ReportsForm.ProjectData := AProjectData;
  169. ReportsForm.InitReportSettings(ReportsForm.PreviewComXML);
  170. ReportsForm.InitFormView;
  171. try
  172. ReportsForm.ShowModal;
  173. finally
  174. ReportsForm.Free;
  175. AProjectData.ClearReportCacheData;
  176. end;
  177. end;
  178. { TReportsForm }
  179. procedure TReportsForm.LoadReportTemplets;
  180. var
  181. iTemplate: Integer;
  182. TemplateNode: TTemplateNode;
  183. ClassNode: TExTreeNode;
  184. begin
  185. extvReport.Items.Clear;
  186. for iTemplate := 0 to ReportTemplateManager.Count - 1 do
  187. begin
  188. TemplateNode := ReportTemplateManager.Template[iTemplate];
  189. AddReportTemplate(TemplateNode);
  190. end;
  191. extvReport.AlphaSort;
  192. // 强制展开全部节点
  193. // 某些情况下,创建节点处的展开方法失效
  194. ClassNode := extvReport.Items.GetFirstNode;
  195. while Assigned(ClassNode) do
  196. begin
  197. ClassNode.ForcedExpand(True);
  198. ClassNode := ClassNode.getNextSibling;
  199. end;
  200. extvReport.Selected := extvReport.Items.GetFirstNode;
  201. end;
  202. procedure TReportsForm.LoadTempletAndDisplay;
  203. procedure ResetReportsVariant;
  204. var
  205. iPage: Integer;
  206. begin
  207. FbNormal := False;
  208. xcbPages.Items.Clear;
  209. for iPage := 1 to PreviewComXML.TotalPages do
  210. xcbPages.Items.Add(IntToStr(iPage));
  211. xcbStartPage.Items.Assign(xcbPages.Items);
  212. xcbStartPage.ItemIndex := 0;
  213. xcbEndPage.Items.Assign(xcbPages.Items);
  214. xcbEndPage.ItemIndex := xcbEndPage.Items.Count - 1;
  215. xlbRealSize.Down := True;
  216. DisplayCount := 1;
  217. CurPage := 1;
  218. end;
  219. procedure WaringAndEmptyPreview(AStr: string);
  220. var
  221. OldBrushColor, OldPenColor: TColor;
  222. begin
  223. TipMessage(AStr, Handle);
  224. OldBrushColor := PreviewBox.Canvas.Brush.Color;
  225. OldPenColor := PreviewBox.Canvas.Pen.Color;
  226. try
  227. PreviewBox.Canvas.Brush.Color := clBtnFace;
  228. PreviewBox.Canvas.Pen.Color := clBlack;
  229. PreviewBox.Canvas.Rectangle(PreviewBox.BoundsRect);
  230. finally
  231. PreviewBox.Canvas.Brush.Color := OldBrushColor;
  232. PreviewBox.Canvas.Pen.Color := OldPenColor;
  233. end;
  234. end;
  235. procedure PreviewTemplet;
  236. begin
  237. try
  238. ResizePreviewBox;
  239. ResetReportsVariant;
  240. except
  241. WaringAndEmptyPreview('当前报表显示可能存在问题,请与纵横客服中心联系:(0756)3850888。');
  242. end;
  243. end;
  244. procedure LoadEmptyTempletAndDisplay;
  245. begin
  246. WaringAndEmptyPreview('报表无数据,请选择其他报表。');
  247. end;
  248. var
  249. vTemplateNode: TTemplateNode;
  250. pNode: PTemplateNode;
  251. begin
  252. if not Assigned(extvReport.Selected) then Exit;
  253. vTemplateNode := TTemplateNode(extvReport.Selected.Data);
  254. if not Assigned(vTemplateNode) then Exit;
  255. ReportTemplateManager.Current := vTemplateNode;
  256. // 交互表
  257. if vTemplateNode.InteractFlag <> 0 then
  258. SaveReportInteractData(vTemplateNode);
  259. // 准备额外数据
  260. if vTemplateNode.DataPrepareFlag <> 0 then
  261. FReportDataPrepare.PrepareData(vTemplateNode.DataPrepareFlag);
  262. FReportCon.RefreshConnection(vTemplateNode);
  263. Screen.Cursor := crHourGlass;
  264. try
  265. LoadTemplet(vTemplateNode, PreviewComXML);
  266. if PreviewComXML.TotalPages > 0 then
  267. PreviewTemplet
  268. else
  269. LoadEmptyTempletAndDisplay;
  270. finally
  271. Screen.Cursor := crDefault;
  272. end;
  273. end;
  274. procedure TReportsForm.SetProjectData(const Value: TProjectData);
  275. begin
  276. FProjectData := Value;
  277. FReportDataPrepare := TReportPrepare.Create(FProjectData);
  278. FReportCon := TReportConnection.Create(FProjectData);
  279. extvReport.Selected := extvReport.Items[0];
  280. LoadReportTemplets;
  281. LoadTempletAndDisplay;
  282. end;
  283. procedure TReportsForm.PreviewComXMLGetDataConnection(
  284. var ADOCon: TADOConnection);
  285. begin
  286. ADOCon := FReportCon.Connection;
  287. end;
  288. procedure TReportsForm.PreviewReportCurPage;
  289. begin
  290. if FbNormal then
  291. PreviewComXML.PrintPreviewCanvas(-1, PrecededCount, PreviewBox.Canvas)
  292. else //强制1:1显示
  293. PreviewComXML.PrintPreviewCanvas(CurPage, 0, PreviewBox.Canvas);
  294. end;
  295. procedure TReportsForm.ResizePreviewBox;
  296. var
  297. iHeight, iWidth: Integer;
  298. begin
  299. if FbNormal then
  300. begin
  301. iHeight := sbReportsPreview.ClientHeight;
  302. iWidth := sbReportsPreview.ClientWidth;
  303. end
  304. else
  305. begin
  306. iHeight := Max(PreviewComXML.PrintHeight + 20, sbReportsPreview.ClientHeight);
  307. iWidth := Max(PreviewComXML.PrintWidth + 20, sbReportsPreview.ClientWidth);
  308. end;
  309. if PreviewBox.Height <> iHeight then
  310. begin
  311. PreviewBox.Height := iHeight;
  312. PreviewBox.Picture.Bitmap.Height := iHeight;
  313. end;
  314. if PreviewBox.Width <> iWidth then
  315. begin
  316. PreviewBox.Width := iWidth;
  317. PreviewBox.Picture.Bitmap.Width := iWidth;
  318. end;
  319. end;
  320. procedure TReportsForm.RepaintCurPagePreview;
  321. begin
  322. ResizePreviewBox;
  323. PreviewReportCurPage;
  324. end;
  325. procedure TReportsForm.xlbRealSizeClick(Sender: TObject);
  326. begin
  327. FbNormal := False;
  328. DisplayCount := TdxBarLargeButton(Sender).Tag;
  329. RepaintCurPagePreview;
  330. end;
  331. procedure TReportsForm.xlbOnePageClick(Sender: TObject);
  332. begin
  333. PreviewComXML.PreviewRows := 1;
  334. PreviewComXML.PreviewCols := 1;
  335. DisplayCount := TdxBarLargeButton(Sender).Tag;
  336. FbNormal := True;
  337. RepaintCurPagePreview;
  338. end;
  339. procedure TReportsForm.xlbTwoPageClick(Sender: TObject);
  340. begin
  341. if PreviewComXML.ReportSize.X > PreviewComXML.ReportSize.Y then
  342. begin
  343. PreviewComXML.PreviewRows := 2;
  344. PreviewComXML.PreviewCols := 1;
  345. end
  346. else
  347. begin
  348. PreviewComXML.PreviewRows := 1;
  349. PreviewComXML.PreviewCols := 2;
  350. end;
  351. DisplayCount := TdxBarLargeButton(Sender).Tag;
  352. FbNormal := true;
  353. RepaintCurPagePreview;
  354. end;
  355. procedure TReportsForm.xlbFourPageClick(Sender: TObject);
  356. begin
  357. PreviewComXML.PreviewRows := 2;
  358. PreviewComXML.PreviewCols := 2;
  359. DisplayCount := TdxBarLargeButton(Sender).Tag;
  360. FbNormal := true;
  361. RepaintCurPagePreview;
  362. end;
  363. procedure TReportsForm.xlbFirstPageClick(Sender: TObject);
  364. begin
  365. CurPage := 1;
  366. end;
  367. procedure TReportsForm.SetCurPage(const Value: Integer);
  368. begin
  369. if (Value < 0) or (Value > PageCount) then Exit;
  370. FCurPage := Value;
  371. xcbPages.Text := IntToStr(FCurPage);
  372. //PreviewComXML.FillZero := chkFillZero.Checked;
  373. PreviewReportCurPage;
  374. end;
  375. function TReportsForm.GetPrintEndPage: Integer;
  376. begin
  377. Result := StrToIntDef(xcbEndPage.Text, 0);
  378. end;
  379. function TReportsForm.GetPrintStartPage: Integer;
  380. begin
  381. Result := StrToIntDef(xcbStartPage.Text, 0);
  382. end;
  383. function TReportsForm.GetPageCount: Integer;
  384. begin
  385. Result := PreviewComXML.TotalPages;
  386. end;
  387. function TReportsForm.GetPrecededCount: Integer;
  388. begin
  389. Result := (CurPage + (DisplayCount - 1)) div DisplayCount;
  390. end;
  391. procedure TReportsForm.xlbPrePageClick(Sender: TObject);
  392. begin
  393. if CurPage > 1 then
  394. CurPage := CurPage - 1;
  395. end;
  396. procedure TReportsForm.xlbNextPageClick(Sender: TObject);
  397. begin
  398. if CurPage < PageCount then
  399. CurPage := CurPage + 1;
  400. end;
  401. procedure TReportsForm.xlbLastPageClick(Sender: TObject);
  402. begin
  403. CurPage := PageCount;
  404. end;
  405. procedure TReportsForm.xcbPagesChange(Sender: TObject);
  406. begin
  407. if (StrToIntDef(xcbPages.Text, 0) > 0) and
  408. (StrToIntDef(xcbPages.Text, 0) <= PageCount) then
  409. CurPage := StrToIntDef(xcbPages.Text, 0)
  410. else
  411. xcbPages.Text := IntToStr(CurPage);
  412. end;
  413. procedure TReportsForm.xlbPrintCurPageClick(Sender: TObject);
  414. begin
  415. if _IsEncrypt or G_IsCloud then
  416. PreviewComXML.Print(CurPage, 1)
  417. else
  418. TipMessage(GetHintStr, Handle);
  419. end;
  420. procedure TReportsForm.xcbStartPageChange(Sender: TObject);
  421. begin
  422. if (StrToIntDef(TdxBarCombo(Sender).Text, 0) > 0) and
  423. (StrToIntDef(TdxBarCombo(Sender).Text, 0) <= PageCount) then
  424. TdxBarCombo(Sender).Tag := StrToIntDef(TdxBarCombo(Sender).Text, 0)
  425. else
  426. TdxBarCombo(Sender).Text := IntToStr(TdxBarCombo(Sender).Tag);
  427. end;
  428. procedure TReportsForm.xlbPrintClick(Sender: TObject);
  429. begin
  430. if _IsEncrypt or G_IsCloud then
  431. begin
  432. if extvReport.LeafCheckedCount > 0 then
  433. PrintAllSelectedReports
  434. else
  435. PreviewComXML.PrintMultiPages(PrintStartPage, PrintEndPage);
  436. end
  437. else
  438. TipMessage(GetHintStr, Handle);
  439. end;
  440. procedure TReportsForm.PrintAllSelectedReports;
  441. var
  442. iIndex: Integer;
  443. Node: TExTreeNode;
  444. vTemplateNode: TTemplateNode;
  445. begin
  446. for iIndex := 0 to extvReport.Items.Count - 1 do
  447. begin
  448. Node := extvReport.Items[iIndex];
  449. if Node.HasChildren or (Node.Checked <> csChecked) or (Node.Data = nil) then Continue;
  450. vTemplateNode := TTemplateNode(Node.Data);
  451. if FileExists(vTemplateNode.FileName) then
  452. directPrintReport(PreviewBox.Canvas, vTemplateNode.FileName,
  453. PreviewComXML, False, False, oemNormal,'','', IsExcel2010);
  454. end;
  455. extvReport.ClearChecked;
  456. end;
  457. procedure TReportsForm.xlbToPDFClick(Sender: TObject);
  458. begin
  459. if _IsEncrypt or G_IsCloud then
  460. begin
  461. if extvReport.LeafCheckedCount > 0 then
  462. ExportAllSelectedPDFReports
  463. else
  464. PreviewComXML.PrintPDF(PrintStartPage, PrintEndPage);
  465. end
  466. else
  467. TipMessage(GetHintStr, Handle);
  468. end;
  469. procedure TReportsForm.ExportAllSelectedPDFReports;
  470. var
  471. iIndex: Integer;
  472. Node: TExTreeNode;
  473. vTemplateNode: TTemplateNode;
  474. begin
  475. for iIndex := 0 to extvReport.Items.Count - 1 do
  476. begin
  477. Node := extvReport.Items[iIndex];
  478. if Node.HasChildren or (Node.Checked <> csChecked) or (Node.Data = nil) then Continue;
  479. vTemplateNode := TTemplateNode(Node.Data);
  480. if FileExists(vTemplateNode.FileName) then
  481. PrintReport(vTemplateNode, True, False,'','');
  482. end;
  483. extvReport.ClearChecked;
  484. end;
  485. procedure TReportsForm.xlbToExcelClick(Sender: TObject);
  486. begin
  487. if _IsEncrypt or G_IsCloud then
  488. begin
  489. if extvReport.LeafCheckedCount > 0 then
  490. ExportAllSelectedXlsReports
  491. else
  492. ExportCurXlsReport;
  493. end
  494. else
  495. TipMessage(GetHintStr, Handle);
  496. end;
  497. procedure TReportsForm.ExportAllSelectedXlsReports;
  498. var
  499. iIndex: Integer;
  500. Node: TExTreeNode;
  501. vTemplateNode: TTemplateNode;
  502. sPath, sOutputFileName: String;
  503. begin
  504. if BrowseFolder(sPath, '请选择导出报表路径', Handle) then
  505. begin
  506. for iIndex := 0 to extvReport.Items.Count - 1 do
  507. begin
  508. Node := extvReport.Items[iIndex];
  509. if Node.HasChildren or (Node.Checked <> csChecked) or (Node.Data = nil) then Continue;
  510. vTemplateNode := TTemplateNode(Node.Data);
  511. sOutputFileName := sPath + ExtractSimpleFileName(vTemplateNode.FileName) + '.xls';
  512. if FileExists(vTemplateNode.FileName) then
  513. PrintReport(vTemplateNode, False, True, sOutputFileName, GetTemplateXlsFileName);
  514. end;
  515. extvReport.ClearChecked;
  516. end;
  517. end;
  518. procedure TReportsForm.ExportCurXlsReport;
  519. var
  520. sFileName: string;
  521. begin
  522. sFileName := extvReport.Selected.Text;
  523. if (PrintStartPage <= PrintEndPage) and SaveFile(sFileName, '.xls') then
  524. ExportXlsReport(PrintStartPage, PrintEndPage, sFileName, PreviewComXML);
  525. end;
  526. procedure TReportsForm.AfterExport;
  527. begin
  528. // ToDo - 关闭进度条
  529. // ToDo - 取消设置Update进度条事件
  530. // PreviewComXML.OnProgress := nil;
  531. Screen.Cursor := crDefault;
  532. end;
  533. procedure TReportsForm.BeforeExport;
  534. begin
  535. Screen.Cursor := crHourGlass;
  536. // ToDo - 设置Update进度条事件
  537. // PreviewComXML.OnProgress := PreviewComXMLProgress;
  538. // ToDo - 打开进度条
  539. end;
  540. function TReportsForm.GetExcelMode: TOutputExcelMode;
  541. begin
  542. if chkExcelMode.Checked then
  543. Result := oemOneSheet
  544. else
  545. Result := oemNormal;
  546. end;
  547. procedure TReportsForm.extvReportClick(Sender: TObject);
  548. begin
  549. LoadTempletAndDisplay;
  550. end;
  551. procedure TReportsForm.xlbCloseClick(Sender: TObject);
  552. begin
  553. Close;
  554. end;
  555. procedure TReportsForm.AddReportTemplate(ANode: TTemplateNode);
  556. var
  557. vClassNode, vNode: TExTreeNode;
  558. begin
  559. vClassNode := GetClassNode(ANode);
  560. if ANode.SubClassNum <> '' then
  561. vClassNode := GetSubClassNode(vClassNode, ANode);
  562. vNode := extvReport.Items.AddChildObject(vClassNode, ANode.TemplateName, Pointer(ANode));
  563. vNode.ImageIndex := 2;
  564. vNode.SelectedIndex := 3;
  565. vNode.Checked := csUnchecked;
  566. if (vClassNode <> nil) and not vClassNode.Expanded then
  567. vClassNode.Expanded := True;
  568. end;
  569. function TReportsForm.GetClassNode(ANode: TTemplateNode): TExTreeNode;
  570. function FindClassNode(const AName: string): TExTreeNode;
  571. var
  572. I: Integer;
  573. vNode: TExTreeNode;
  574. begin
  575. Result := nil;
  576. for I := 0 to extvReport.Items.Count - 1 do
  577. begin
  578. vNode := extvReport.Items.Item[I];
  579. if SameText(vNode.Text, AName) then
  580. begin
  581. Result := vNode;
  582. Break;
  583. end;
  584. end;
  585. end;
  586. begin
  587. Result := FindClassNode(ANode.ClassNum + '.' + ANode.ClassName);
  588. if not Assigned(Result) then
  589. Result := AddClassNode(nil, ANode.ClassNum + '.' + ANode.ClassName);
  590. end;
  591. procedure TReportsForm.tbImportSrtClick(Sender: TObject);
  592. procedure ImportReportTemplate(const AFileName: string);
  593. var
  594. sNewFileName: string;
  595. vTemplateNode: TTemplateNode;
  596. begin
  597. sNewFileName := GetReportTemplatePath + ExtractFileName(AFileName);
  598. if not FileExists(sNewFileName) then
  599. begin
  600. CopyFile(PChar(AFileName), PChar(sNewFileName), True);
  601. vTemplateNode := ReportTemplateManager.AddReportTemplate(sNewFileName);
  602. AddReportTemplate(vTemplateNode);
  603. end
  604. else
  605. if QuestMessage('已存在报表模板' + ExtractFileName(AFileName) + ',是否覆盖原模板?', Handle) then
  606. CopyFile(PChar(AFileName), PChar(sNewFileName), False)
  607. else
  608. Exit;
  609. end;
  610. var
  611. sgsFiles: TStrings;
  612. iFile: Integer;
  613. begin
  614. sgsFiles := TStringList.Create;
  615. try
  616. if SelectFiles(sgsFiles, '.srt') then
  617. begin
  618. for iFile := 0 to sgsFiles.Count - 1 do
  619. ImportReportTemplate(sgsFiles.Strings[iFile]);
  620. end;
  621. finally
  622. sgsFiles.Free;
  623. end;
  624. end;
  625. procedure TReportsForm.tbDeleteSrtClick(Sender: TObject);
  626. var
  627. vTemplateNode: TTemplateNode;
  628. begin
  629. if not Assigned(extvReport.Selected) then Exit;
  630. vTemplateNode := TTemplateNode(extvReport.Selected.Data);
  631. if not Assigned(vTemplateNode) then Exit;
  632. extvReport.Items.Delete(extvReport.Selected);
  633. DeleteFile(vTemplateNode.FileName);
  634. ReportTemplateManager.DeleteReportTemplate(vTemplateNode);
  635. LoadTempletAndDisplay;
  636. end;
  637. procedure TReportsForm.tbExportSrtClick(Sender: TObject);
  638. var
  639. vTemplateNode: TTemplateNode;
  640. sFileName: string;
  641. begin
  642. if not Assigned(extvReport.Selected) then Exit;
  643. vTemplateNode := TTemplateNode(extvReport.Selected.Data);
  644. if not Assigned(vTemplateNode) then Exit;
  645. sFileName := vTemplateNode.TemplateName;
  646. if SaveFile(sFileName, '.srt') then
  647. begin
  648. if not FileExists(sFileName) or QuestMessage('存在同名文件,是否覆盖?', Handle) then
  649. CopyFile(PChar(vTemplateNode.FileName), PChar(sFileName), False);
  650. end;
  651. end;
  652. procedure TReportsForm.PreviewComXMLContentDisplay(
  653. var contentFontRec: TFontRec; dataType: Integer; isReading: Boolean;
  654. DrawType: Integer; isPrinting: Boolean);
  655. begin
  656. if ReportConfig.ContentIsNarrow then
  657. begin
  658. if (isReading) then
  659. begin
  660. begin
  661. contentFontRec.FontName := 'Arial Narrow';
  662. contentFontRec.FontHeight := Round(ReportConfig.ContentFont.Size*4/3) * 4 div 3;
  663. end;
  664. end else
  665. begin
  666. if (DrawType = 3) or (DrawType = 5) then
  667. begin
  668. contentFontRec.FontHeight := Round(ReportConfig.ContentFont.Size*4/3);
  669. end else if (isPrinting) then
  670. begin
  671. contentFontRec.FontName := 'Arial Narrow';
  672. contentFontRec.FontHeight := Round(ReportConfig.ContentFont.Size*4/3) * 7 div 6;
  673. end else
  674. begin
  675. contentFontRec.FontHeight := Round(ReportConfig.ContentFont.Size*4/3) * 4 div 3;
  676. end;
  677. end;
  678. end;
  679. end;
  680. procedure TReportsForm.xlbSetupClick(Sender: TObject);
  681. begin
  682. if AdjustReport then
  683. LoadTempletAndDisplay;
  684. end;
  685. procedure TReportsForm.InitReportSettings(APrintCom: TPrintComXML; ATemplate: TTemplateNode);
  686. begin
  687. APrintCom.FillZero := chkFillZero.Checked;
  688. InitPageSettings(APrintCom);
  689. InitPaperSettings(ATemplate, APrintCom);
  690. APrintCom.ShowBackgroundMark := FProjectData.ProjProperties.ShowReportShading;
  691. APrintCom.BackgroundMarkStr := FProjectData.ProjProperties.ReportShading;
  692. end;
  693. procedure TReportsForm.InitPageSettings(APrintCom: TPrintComXML);
  694. begin
  695. // 设置页面大小
  696. APrintCom.setPageSize(ReportConfig.PageSize);
  697. if ReportConfig.PageSize = 'A3' then
  698. APrintCom.PrintPageSizeIdx := DMPAPER_A3
  699. else if ReportConfig.PageSize = 'A4' then
  700. APrintCom.PrintPageSizeIdx := DMPAPER_A4;
  701. // 设置边距
  702. APrintCom.setEdge(0, '', ReportConfig.LeftEdge/10);
  703. APrintCom.setEdge(1, '', ReportConfig.RightEdge/10);
  704. APrintCom.setEdge(2, '', ReportConfig.UpEdge/10);
  705. APrintCom.setEdge(3, '', ReportConfig.DownEdge/10);
  706. end;
  707. procedure TReportsForm.InitPaperSettings(ATemplate: TTemplateNode; APrintCom: TPrintComXML);
  708. procedure InitRepBorderLine;
  709. var
  710. i: Integer;
  711. ObjList : TList;
  712. ShapeRec : PPicRec;
  713. begin
  714. ObjList := TList.Create;
  715. try
  716. APrintCom.getAllShapeObjs(1, ObjList);
  717. for i := 0 to ObjList.Count - 1 do
  718. begin
  719. ShapeRec := ObjList[i];
  720. // 设置报表边框线粗
  721. ShapeRec.PenWidth := ReportConfig.BorderLine;
  722. // 设置是否绘制报表边框横线
  723. if (ShapeRec.ExArea.ExLeft <> ShapeRec.ExArea.ExRight) then
  724. begin
  725. if not ReportConfig.RepBorderUnderLine then
  726. ShapeRec.PenStyle := integer(psClear)
  727. else
  728. ShapeRec.PenStyle := integer(psSolid);
  729. end;
  730. // 设置是否绘制报表边框竖线
  731. if (ShapeRec.ExArea.ExTop <> ShapeRec.ExArea.ExBottom) and
  732. ((ShapeRec.ExArea.ExLeft = 0) or (ShapeRec.ExArea.ExLeft = 100)) then
  733. begin //这里的判断条件是约定好的
  734. if not ReportConfig.RepBorderVerLine then
  735. ShapeRec.PenStyle := integer(psClear)
  736. else
  737. ShapeRec.PenStyle := integer(psSolid)
  738. end;
  739. APrintCom.setShapeObj(ShapeRec);
  740. end;
  741. finally
  742. ObjList.Free;
  743. end;
  744. end;
  745. procedure InitRepCellLine;
  746. var
  747. i: Integer;
  748. ObjList : TList;
  749. ColumnRec : PColumnRec;
  750. FlowContentRec : PContentRec;
  751. CrossContentRec : PCrossContentRec;
  752. begin
  753. ObjList := TList.Create;
  754. try
  755. APrintCom.getAllFlowShowContentObjs(ObjList);
  756. // 设置报表表格横线
  757. for i := 0 to ObjList.Count - 1 do
  758. begin
  759. FlowContentRec := ObjList[i];
  760. FlowContentRec.LineInfo.TopThick := ReportConfig.CellHorLineWidth;
  761. FlowContentRec.LineInfo.BottomThick := ReportConfig.CellHorLineWidth;
  762. APrintCom.setFlowContentObj(FlowContentRec);
  763. end;
  764. APrintCom.getAllCrossContentObjs(ObjList);
  765. for i := 0 to ObjList.Count - 1 do
  766. begin
  767. CrossContentRec := ObjList[i];
  768. CrossContentRec.CrossContent.LineInfo.TopThick := ReportConfig.CellHorLineWidth;
  769. CrossContentRec.CrossContent.LineInfo.BottomThick := ReportConfig.CellHorLineWidth;
  770. APrintCom.setCrossContentObj(CrossContentRec);
  771. end;
  772. // 设置报表表格竖线
  773. APrintCom.getAllFlowShowContentObjs(ObjList);
  774. for i := 0 to ObjList.Count - 1 do
  775. begin
  776. FlowContentRec := ObjList[i];
  777. FlowContentRec.LineInfo.LeftThick := ReportConfig.CellVerLineWidth;
  778. FlowContentRec.LineInfo.RightThick := ReportConfig.CellVerLineWidth;
  779. // 如果设置无表格边框线,则两端的表格竖线线粗为0
  780. if (not ReportConfig.RepBorderVerLine) then
  781. if (i = 0) then
  782. FlowContentRec.LineInfo.LeftThick := 0
  783. else if (i = ObjList.Count - 1) then
  784. FlowContentRec.LineInfo.RightThick := 0;
  785. APrintCom.setFlowContentObj(FlowContentRec);
  786. end;
  787. APrintCom.getAllCrossContentObjs(ObjList);
  788. for i := 0 to ObjList.Count - 1 do
  789. begin
  790. CrossContentRec := ObjList[i];
  791. CrossContentRec.CrossContent.LineInfo.LeftThick := ReportConfig.CellVerLineWidth;
  792. CrossContentRec.CrossContent.LineInfo.RightThick := ReportConfig.CellVerLineWidth;
  793. ColumnRec := CrossContentRec.CrossContent.Column;
  794. //这里还要判断如果没有边框竖线的情况下,表格竖线边缘的线粗也为0
  795. //前提是所属表栏最右位置位于边缘
  796. if (not ReportConfig.RepBorderVerLine) and (ColumnRec<>nil) and
  797. ((ColumnRec.ExArea.ExRight = 100.0) or (ColumnRec.ExArea.ExLeft = 0.0)) then
  798. begin
  799. case CrossContentRec.CrossType of
  800. 0 : //交叉行
  801. begin
  802. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  803. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  804. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  805. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  806. end;
  807. 1 : //交叉列
  808. begin
  809. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  810. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  811. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  812. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  813. //(*
  814. if (CrossContentRec.CrossContent.isSpecialBorder) then
  815. begin
  816. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  817. CrossContentRec.CrossContent.SpecialLineInfo.RightThick := 0;
  818. end;
  819. //*)
  820. end;
  821. 2 : //显示数据
  822. begin
  823. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  824. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  825. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  826. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  827. end;
  828. 3 : //固定LABEL
  829. begin
  830. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  831. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  832. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  833. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  834. end;
  835. 4 : //序号
  836. begin
  837. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  838. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  839. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  840. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  841. end;
  842. 5 : //横向统计
  843. begin
  844. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  845. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  846. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  847. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  848. end;
  849. end;
  850. end;
  851. APrintCom.setCrossContentObj(CrossContentRec);
  852. end;
  853. finally
  854. ObjList.Free;
  855. end;
  856. end;
  857. procedure InitOtherArea;
  858. procedure SetPTRBorder(PTR : PTextRec);
  859. procedure SetLeftRightBorder;
  860. begin
  861. if PTR.ExArea.ExLeft = 0.0 then
  862. begin
  863. if BorderWidth = 0.0 then
  864. PTR.LineInfo.LeftThick := ReportConfig.BorderUnderLineWidth;
  865. end;
  866. if PTR.ExArea.ExRight = 100.0 then
  867. begin
  868. if BorderWidth = 0.0 then
  869. PTR.LineInfo.RightThick := ReportConfig.BorderUnderLineWidth
  870. end;
  871. end;
  872. procedure SetHorLine;
  873. begin
  874. if (PTR.LineInfo.TopThick >= 0.2) and (BorderWidth <= 0.2) then
  875. PTR.LineInfo.TopThick := ReportConfig.CellHorLineWidth;
  876. if (PTR.LineInfo.BottomThick >= 0.2) and (BorderWidth <= 0.2) then
  877. PTR.LineInfo.BottomThick := ReportConfig.CellHorLineWidth;
  878. end;
  879. begin
  880. SetLeftRightBorder;
  881. SetHorLine;
  882. end;
  883. procedure SetPCRBorder(PCR : PColumnRec);
  884. procedure SetLeftRightBorder;
  885. begin
  886. if PCR.ExArea.ExLeft = 0.0 then
  887. begin
  888. if BorderWidth = 0.0 then
  889. PCR.LineInfo.LeftThick := ReportConfig.BorderUnderLineWidth
  890. end;
  891. if PCR.ExArea.ExRight = 100.0 then
  892. begin
  893. if BorderWidth = 0.0 then
  894. PCR.LineInfo.RightThick := ReportConfig.BorderUnderLineWidth;
  895. end;
  896. end;
  897. procedure SetVerLine;
  898. begin
  899. if PCR.ExArea.ExLeft = 0.0 then
  900. PCR.LineInfo.LeftThick := ReportConfig.CellVerLineWidth;
  901. if PCR.ExArea.ExRight = 100.0 then
  902. PCR.LineInfo.RightThick := ReportConfig.CellVerLineWidth;
  903. end;
  904. procedure SetHorLine;
  905. begin
  906. if (PCR.LineInfo.TopThick >= 0.2) and (BorderWidth <= 0.2) then
  907. PCR.LineInfo.TopThick := ReportConfig.CellHorLineWidth;
  908. if (PCR.LineInfo.BottomThick >= 0.2) and (BorderWidth <= 0.2) then
  909. PCR.LineInfo.BottomThick := ReportConfig.CellHorLineWidth;
  910. end;
  911. begin
  912. SetLeftRightBorder;
  913. SetVerLine;
  914. SetHorLine;
  915. end;
  916. var i,k : integer;
  917. ObjList : TList;
  918. ActAreaRec : PActiveAreaRec;
  919. PSR : PShowElementRec;
  920. begin
  921. ObjList := TList.Create;
  922. try
  923. ActAreaRec := nil;
  924. PreviewComXML.getAllActAreaObjs(ObjList);
  925. for i := 0 to ObjList.Count - 1 do
  926. begin
  927. ActAreaRec := ObjList[i];
  928. if (ActAreaRec.ShowType < 0) or (ActAreaRec.ShowType > 2) then Continue;
  929. if not Assigned(ActAreaRec.ElementList) then Continue;
  930. for k := 0 to ActAreaRec.ElementList.Count - 1 do
  931. begin
  932. PSR := PShowElementRec(ActAreaRec.ElementList[k]);
  933. case PSR.ElementType of
  934. 0..2 : SetPTRBorder(PSR.Data); //文本,参数,字段,表栏
  935. 7 : SetPCRBorder(PSR.Data) //Column
  936. end;
  937. APrintCom.setActShowElementObj(PSR);
  938. end;
  939. end;
  940. finally
  941. ObjList.Free;
  942. end;
  943. end;
  944. begin
  945. if not Assigned(ATemplate) or (ATemplate.SelfFormat = 0) then
  946. begin
  947. InitFont(APrintCom); // 各类字体
  948. InitRepBorderLine; // 报表边框
  949. InitRepCellLine; // 报表表格
  950. InitOtherArea; // 活动区域
  951. end;
  952. end;
  953. procedure TReportsForm.PreviewComXMLCrossTabLabelShow(valIDX: Integer;
  954. var ExLeft, ExRight: Double; var isShow: Boolean;
  955. CrsTabShowType: Integer);
  956. var field : PFieldRec;
  957. begin
  958. if (CrsTabShowType = -1) then exit;
  959. field := PreviewComXML.getFieldByID(6);
  960. if (field <> nil) then
  961. begin
  962. if (field.DataLen > valIDX) and (valIDX >= 0) then
  963. begin
  964. if (field.Value[valIDX] = 1.5) then
  965. begin
  966. case CrsTabShowType of
  967. 1 : begin
  968. isShow := false;
  969. end;
  970. 2 : begin
  971. ExLeft := 0;
  972. ExRight := 100;
  973. end;
  974. 3 : begin
  975. //
  976. end
  977. else
  978. begin
  979. //
  980. end;
  981. end;
  982. end;
  983. end;
  984. end;
  985. end;
  986. procedure TReportsForm.rdbtnA4Click(Sender: TObject);
  987. begin
  988. ReportConfig.PageSize := TRadioButton(Sender).Caption;
  989. SetPrinterPageSize(ReportConfig.PageSize);
  990. LoadTempletAndDisplay;
  991. end;
  992. procedure TReportsForm.chkFillZeroClick(Sender: TObject);
  993. begin
  994. PreviewComXML.FillZero := chkFillZero.Checked;
  995. PreviewReportCurPage;
  996. end;
  997. procedure TReportsForm.InitFont(APrintCom: TPrintComXML);
  998. procedure AssignFontRec(AFontRec: TFontRec; AFont: TFont);
  999. begin
  1000. AFontRec.FontName := AFont.Name;
  1001. AFontRec.FontHeight := Round(AFont.Size*4/3) ;
  1002. AFontRec.FontBold := 400 + Integer(fsBold in AFont.Style)*200;
  1003. AFontRec.FontItalic := Integer(fsItalic in AFont.Style);
  1004. AFontRec.FontUnderLine := Integer(fsUnderLine in AFont.Style);
  1005. end;
  1006. procedure InitTitleFont;
  1007. var
  1008. TitleRec : PTitleRec;
  1009. begin
  1010. TitleRec := PreviewComXML.getTitleByID(1);
  1011. if TitleRec <> nil then
  1012. begin
  1013. AssignFontRec(TitleRec.FontRec, ReportConfig.TitleFont);
  1014. APrintCom.setTitleObj(TitleRec);
  1015. end;
  1016. end;
  1017. procedure InitColumnFont;
  1018. procedure InitColumnThick(AColumnRec: PColumnRec);
  1019. begin
  1020. if (ReportConfig.ReportCellLine > 0.2) then
  1021. begin
  1022. if (AColumnRec.LineInfo.LeftThick > 0.2) then
  1023. AColumnRec.LineInfo.LeftThick := ReportConfig.ReportCellLine;
  1024. if (AColumnRec.LineInfo.RightThick > 0.2) then
  1025. AColumnRec.LineInfo.RightThick := ReportConfig.ReportCellLine;
  1026. if (AColumnRec.LineInfo.TopThick > 0.2) then
  1027. AColumnRec.LineInfo.TopThick := ReportConfig.ReportCellLine;
  1028. if (AColumnRec.LineInfo.BottomThick > 0.2) then
  1029. AColumnRec.LineInfo.BottomThick := ReportConfig.ReportCellLine;
  1030. end;
  1031. end;
  1032. var
  1033. i, j: Integer;
  1034. ObjList: TList;
  1035. ColumnRec : PColumnRec;
  1036. AAR : PActiveAreaRec;
  1037. SER : PShowElementRec;
  1038. begin
  1039. ObjList := TList.Create;
  1040. try
  1041. APrintCom.getAllColumnHeadObjs(ObjList);
  1042. for i := 0 to ObjList.Count - 1 do
  1043. begin
  1044. ColumnRec := ObjList[i];
  1045. AssignFontRec(ColumnRec.FontRec, ReportConfig.ColumnFont);
  1046. InitColumnThick(ColumnRec);
  1047. APrintCom.setColumnHeadTailObj(0, ColumnRec);
  1048. end;
  1049. APrintCom.getAllColumnTailObjs(ObjList);
  1050. for i := 0 to ObjList.Count - 1 do
  1051. begin
  1052. ColumnRec := ObjList[i];
  1053. AssignFontRec(ColumnRec.FontRec, ReportConfig.ColumnFont);
  1054. InitColumnThick(ColumnRec);
  1055. APrintCom.setColumnHeadTailObj(1,ColumnRec);
  1056. end;
  1057. APrintCom.getAllActAreaObjs(ObjList);
  1058. for i := 0 to ObjList.Count - 1 do
  1059. begin
  1060. AAR := ObjList[i];
  1061. for j := 0 to AAR.ElementList.Count - 1 do
  1062. begin
  1063. SER := AAR.ElementList[j];
  1064. if (SER.ElementType = 7) then
  1065. begin
  1066. ColumnRec := SER.Data;
  1067. AssignFontRec(ColumnRec.FontRec, ReportConfig.ColumnFont);
  1068. InitColumnThick(ColumnRec);
  1069. APrintCom.setActShowElementObj(SER);
  1070. end;
  1071. end;
  1072. end;
  1073. finally
  1074. ObjList.Free;
  1075. end;
  1076. end;
  1077. procedure InitContentAndGatherFont;
  1078. var
  1079. i, j: Integer;
  1080. ObjList: TList;
  1081. FlowContentRec : PContentRec;
  1082. CrossContentRec : PCrossContentRec;
  1083. SumRec : PSumRec;
  1084. begin
  1085. ObjList := TList.Create;
  1086. try
  1087. // 设置表正文
  1088. APrintCom.getAllFlowShowContentObjs(ObjList);
  1089. for i := 0 to ObjList.Count - 1 do
  1090. begin
  1091. FlowContentRec := ObjList[i];
  1092. if not (FlowContentRec.Fixed) then
  1093. begin
  1094. AssignFontRec(FlowContentRec.FontRec, ReportConfig.ContentFont);
  1095. APrintCom.setFlowContentObj(FlowContentRec);
  1096. end;
  1097. end;
  1098. APrintCom.getAllBillShowContentObjs(ObjList);
  1099. for i := 0 to ObjList.Count - 1 do
  1100. begin
  1101. FlowContentRec := ObjList[i];
  1102. if not(FlowContentRec.Fixed) then
  1103. begin
  1104. AssignFontRec(FlowContentRec.FontRec, ReportConfig.ContentFont);
  1105. APrintCom.setBillContentObj(FlowContentRec);
  1106. end;
  1107. end;
  1108. APrintCom.getAllCrossContentObjs(ObjList);
  1109. for i := 0 to ObjList.Count - 1 do
  1110. begin
  1111. CrossContentRec := ObjList[i];
  1112. if not(CrossContentRec.CrossContent.Fixed) then
  1113. begin
  1114. AssignFontRec(CrossContentRec.CrossContent.FontRec, ReportConfig.ContentFont);
  1115. APrintCom.setCrossContentObj(CrossContentRec);
  1116. end;
  1117. end;
  1118. // 设置表合计
  1119. for i := 0 to 2 do
  1120. begin
  1121. APrintCom.getAllSumObjs(i,ObjList);
  1122. for j := 0 to ObjList.Count - 1 do
  1123. begin
  1124. SumRec := ObjList[j];
  1125. AssignFontRec(SumRec.FontRec, ReportConfig.GatherFont);
  1126. APrintCom.setSumObj(SumRec);
  1127. end;
  1128. end;
  1129. finally
  1130. ObjList.Free;
  1131. end;
  1132. end;
  1133. procedure InitGridHeaderFont;
  1134. var
  1135. i: Integer;
  1136. ObjList: TList;
  1137. HeadTailRec : PHeadRec;
  1138. begin
  1139. ObjList := TList.Create;
  1140. try
  1141. APrintCom.getAllHeadObjs(ObjList);
  1142. for i := 0 to ObjList.Count - 1 do
  1143. begin
  1144. HeadTailRec := ObjList[i];
  1145. AssignFontRec(HeadTailRec.FontRec, ReportConfig.GridHeaderFont);
  1146. APrintCom.setHeadTailObj(0, HeadTailRec);
  1147. end;
  1148. APrintCom.getAllTailObjs(ObjList);
  1149. for i := 0 to ObjList.Count - 1 do
  1150. begin
  1151. HeadTailRec := ObjList[i];
  1152. AssignFontRec(HeadTailRec.FontRec, ReportConfig.GridHeaderFont);
  1153. APrintCom.setHeadTailObj(1, HeadTailRec);
  1154. end;
  1155. finally
  1156. ObjList.Free;
  1157. end;
  1158. end;
  1159. begin
  1160. InitTitleFont;
  1161. InitColumnFont;
  1162. InitContentAndGatherFont;
  1163. InitGridHeaderFont;
  1164. end;
  1165. procedure TReportsForm.PreviewComXMLGetDatasetEvent(
  1166. DatasetInfo: PDatasetInfoRec; var ADataset: TDataSet);
  1167. begin
  1168. if DatasetInfo.ID = 0 then
  1169. ADataSet := MemoryReportManager.GetSqlResultDataSet(ReportTemplateManager.Current.InteractInfo.Sql, FProjectData)
  1170. else
  1171. ADataset := MemoryReportManager.GetMemoryDataSet(DatasetInfo.ID, FProjectData);
  1172. end;
  1173. function TReportsForm.GetIsExcel2010: Boolean;
  1174. begin
  1175. Result := chkExcel2010.Checked;
  1176. end;
  1177. procedure TReportsForm.InitFormView;
  1178. begin
  1179. rdbtnA3.Checked := SameText(rdbtnA3.Caption, ReportConfig.PageSize);
  1180. rdbtnA4.Checked := SameText(rdbtnA4.Caption, ReportConfig.PageSize);
  1181. SetPrinterPageSize(ReportConfig.PageSize);
  1182. end;
  1183. procedure TReportsForm.LoadExcelBorder(var Border: TColumnLineRec);
  1184. begin
  1185. Border.LeftThick := 0.5;
  1186. Border.TopThick := 0.5;
  1187. Border.RightThick := 0.5;
  1188. Border.BottomThick := 0.5;
  1189. if not ReportConfig.RepBorderVerLine then
  1190. begin
  1191. Border.LeftThick := 0;
  1192. Border.RightThick := 0;
  1193. end;
  1194. end;
  1195. procedure TReportsForm.PrintReport(ATemplateNode: TTemplateNode;
  1196. isPDF, isExcel: boolean; ExcelOutputName, TemplateFileName: string);
  1197. function CheckPrinterReady: Boolean;
  1198. var
  1199. PrinterHD: THandle;
  1200. NoJobs: Word;
  1201. s: LongWord;
  1202. Job_Info: Array[0..10] of Job_INFO_1;
  1203. cbNeeded: Cardinal;
  1204. cReturned: Cardinal;
  1205. ret: LongBool;
  1206. begin
  1207. if OpenPrinter(PChar(Printer.Printers[Printer.PrinterIndex]), PrinterHD, 0) then
  1208. begin
  1209. s := SizeOf(Job_Info);
  1210. cbNeeded := 0;
  1211. cReturned := 0;
  1212. NoJobs := 10;
  1213. ret := ENumJobs(PrinterHD, 0, NoJobs, 1, @Job_Info, s, cbNeeded, cReturned);
  1214. Result := not((cReturned > 0) and (Job_Info[0].TotalPages > 0));
  1215. end
  1216. else
  1217. Result := True;
  1218. end;
  1219. procedure PrintTemplet;
  1220. begin
  1221. if isPDF then
  1222. begin
  1223. BatchPrintXml.PrintPDFAll;
  1224. while not CheckPrinterReady do
  1225. Sleep(1000);
  1226. end
  1227. else if not isExcel then
  1228. BatchPrintXml.PrintAll(1)
  1229. else
  1230. ExportXlsReport(1, BatchPrintXml.TotalPages, ExcelOutputName, BatchPrintXml);
  1231. end;
  1232. var
  1233. strRptName : string;
  1234. begin
  1235. if not FileExists(ATemplateNode.FileName) then Exit;
  1236. ClearReportOprList;
  1237. ClearReportFuncList;
  1238. Screen.Cursor := crHourGlass;
  1239. try
  1240. LoadTemplet(ATemplateNode, BatchPrintXml);
  1241. if BatchPrintXml.TotalPages > 0 then
  1242. PrintTemplet
  1243. {else if strRptName <> '' then
  1244. begin
  1245. LoadTemplet(RptArchiverObj, strRptName);
  1246. PrintEmptyTemplet;
  1247. end;}
  1248. finally
  1249. Screen.Cursor := crDefault;
  1250. end;
  1251. end;
  1252. procedure TReportsForm.ExportXlsReport(AStartPage, AEndPage: Integer;
  1253. const AFileName: string; APrintCom: TPrintComXML);
  1254. procedure ExportPagesXlsReport(AStartPage, AEndPage: Integer; const AFileName: string);
  1255. var
  1256. Border : TColumnLineRec;
  1257. begin
  1258. LoadExcelBorder(Border);
  1259. if IsExcel2010 then
  1260. // 康博士代码中写批量打印是,用Printer.Canvas,打印当前时,用PreviewBox.Canvas。不懂为什么
  1261. APrintCom.OutputToExcelRangeXMLEx(PreviewBox.Canvas, AStartPage,
  1262. AEndPage, GetTemplateXlsFileName, AFileName, Border, ExcelMode)
  1263. else
  1264. APrintCom.OutputToExcelFile(PreviewBox.Canvas, AStartPage,
  1265. AEndPage, GetTemplateXlsFileName, AFileName, ExcelMode, Border);
  1266. end;
  1267. var
  1268. iStartPage, iEndPage, iCount: Integer;
  1269. sFileName: string;
  1270. begin
  1271. BeforeExport;
  1272. try
  1273. if (ExcelMode = oemNormal) and (PrintEndPage - PrintStartPage > 30) then
  1274. begin
  1275. iStartPage := PrintStartPage;
  1276. iEndPage := iStartPage + 19;
  1277. iCount := 1;
  1278. repeat
  1279. begin
  1280. sFileName := Format('%s[%d].xls', [ExtractSimpleFileName(AFileName), iCount]);
  1281. ExportPagesXlsReport(iStartPage, iEndPage, sFileName);
  1282. iStartPage := iStartPage + 20;
  1283. iEndPage := Min(iEndPage + 20, PrintEndPage);
  1284. Inc(iCount);
  1285. end
  1286. until iStartPage > iEndPage;
  1287. end
  1288. else
  1289. ExportPagesXlsReport(AStartPage, AEndPage, AFileName);
  1290. finally
  1291. AfterExport;
  1292. end;
  1293. end;
  1294. procedure TReportsForm.LoadTemplet(ATemplate: TTemplateNode; APrintCom: TPrintComXML);
  1295. var
  1296. RptArchiverObj: TReportArchiver;
  1297. Mem: TMemoryStream;
  1298. begin
  1299. RptArchiverObj := TReportArchiver.Create;
  1300. if ATemplate.IsMulti then
  1301. RptArchiverObj.FileName := ATemplate.MultiFileNames[FProjectData.PhaseIndex]
  1302. else
  1303. RptArchiverObj.FileName := ATemplate.FileName;
  1304. Mem := RptArchiverObj.Extract;
  1305. try
  1306. // 以下代码有顺序限制,不可修改,主要保证在不修改报表模板文件的基础上可以用户定制报表格式
  1307. // 私以为,原因在于这些设置修改后,并不能生效,需要保存再读取方可生效
  1308. // 读取报表模板
  1309. if not APrintCom.ReadReportStream(Mem) then Exit;
  1310. // 将报表设置中的数据覆盖掉原模板的数据
  1311. InitReportSettings(APrintCom, ATemplate);
  1312. // 保存
  1313. APrintCom.SaveToStream(Mem);
  1314. // 再次读取,使报表设置中的设置生效
  1315. APrintCom.ReadReportStream(Mem);
  1316. // ReadReportStream之后会将PreviewComXML的FillZero值赋为True,故再赋值一次
  1317. APrintCom.FillZero := chkFillZero.Checked;
  1318. InitPageSettings(APrintCom);
  1319. APrintCom.ReadDBData;
  1320. APrintCom.AnalyseData;
  1321. finally
  1322. if Mem <> nil then
  1323. Mem.Free;
  1324. RptArchiverObj.Free;
  1325. end;
  1326. end;
  1327. function TReportsForm.GetHintStr: string;
  1328. begin
  1329. Result := #13#10 +
  1330. '对不起,学习版不提供报表打印、导出功能。'#13#10 +
  1331. #13#10 +
  1332. '以下为收费服务项目,请在必要时联系纵横:'#13#10 +
  1333. #13#10 +
  1334. '企业QQ:800003850 客服热线:(0756)3850888';
  1335. end;
  1336. function TReportsForm.GetSubClassNode(AClassNode: TExTreeNode;
  1337. ANode: TTemplateNode): TExTreeNode;
  1338. function FindNode(AParent: TExTreeNode; const AName: string): TExTreeNode;
  1339. var
  1340. I: Integer;
  1341. vNode: TExTreeNode;
  1342. begin
  1343. Result := nil;
  1344. if Assigned(AParent) then
  1345. vNode := AParent.getFirstChild
  1346. else
  1347. vNode := extvReport.Items.GetFirstNode;
  1348. while not Assigned(Result) and Assigned(vNode) do
  1349. begin
  1350. if SameText(vNode.Text, AName) then
  1351. Result := vNode;
  1352. vNode := vNode.getNextSibling;
  1353. end;
  1354. end;
  1355. begin
  1356. Result := FindNode(AClassNode, ANode.SubClassNum + '.' + ANode.SubClassName);
  1357. if not Assigned(Result) then
  1358. Result := AddClassNode(AClassNode, ANode.SubClassNum + '.' + ANode.SubClassName);
  1359. end;
  1360. function TReportsForm.AddClassNode(AParent: TExTreeNode;
  1361. const AName: string): TExTreeNode;
  1362. begin
  1363. Result := extvReport.Items.AddChildObject(AParent, AName, Pointer(nil));
  1364. Result.ImageIndex := 0;
  1365. Result.SelectedIndex := 1;
  1366. Result.Checked := csUnchecked;
  1367. Result.Expanded := True;
  1368. end;
  1369. procedure TReportsForm.SaveReportInteractData(ATemplate: TTemplateNode);
  1370. begin
  1371. case ATemplate.InteractFlag of
  1372. 1: SaveAuditOpinion(ATemplate);
  1373. end;
  1374. end;
  1375. procedure TReportsForm.SaveAuditOpinion(ATemplate: TTemplateNode);
  1376. var
  1377. SelectForm: TAuditSelctForm;
  1378. begin
  1379. SelectForm := TAuditSelctForm.Create(FProjectData, ATemplate);
  1380. try
  1381. if SelectForm.ShowModal = mrOk then
  1382. SelectForm.SaveAuditData;
  1383. finally
  1384. SelectForm.Free;
  1385. end;
  1386. end;
  1387. destructor TReportsForm.Destroy;
  1388. begin
  1389. FReportCon.Free;
  1390. FReportDataPrepare.Free;
  1391. inherited;
  1392. end;
  1393. end.