ReportsFrm.pas 45 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532
  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, 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. PrintReport(vTemplateNode, False, False, '', '');
  453. end;
  454. extvReport.ClearChecked;
  455. end;
  456. procedure TReportsForm.xlbToPDFClick(Sender: TObject);
  457. begin
  458. if _IsEncrypt or G_IsCloud then
  459. begin
  460. if extvReport.LeafCheckedCount > 0 then
  461. ExportAllSelectedPDFReports
  462. else
  463. PreviewComXML.PrintPDF(PrintStartPage, PrintEndPage);
  464. end
  465. else
  466. TipMessage(GetHintStr, Handle);
  467. end;
  468. procedure TReportsForm.ExportAllSelectedPDFReports;
  469. var
  470. iIndex: Integer;
  471. Node: TExTreeNode;
  472. vTemplateNode: TTemplateNode;
  473. begin
  474. for iIndex := 0 to extvReport.Items.Count - 1 do
  475. begin
  476. Node := extvReport.Items[iIndex];
  477. if Node.HasChildren or (Node.Checked <> csChecked) or (Node.Data = nil) then Continue;
  478. vTemplateNode := TTemplateNode(Node.Data);
  479. if FileExists(vTemplateNode.FileName) then
  480. PrintReport(vTemplateNode, True, False,'','');
  481. end;
  482. extvReport.ClearChecked;
  483. end;
  484. procedure TReportsForm.xlbToExcelClick(Sender: TObject);
  485. begin
  486. if _IsEncrypt or G_IsCloud then
  487. begin
  488. if extvReport.LeafCheckedCount > 0 then
  489. ExportAllSelectedXlsReports
  490. else
  491. ExportCurXlsReport;
  492. end
  493. else
  494. TipMessage(GetHintStr, Handle);
  495. end;
  496. procedure TReportsForm.ExportAllSelectedXlsReports;
  497. var
  498. iIndex: Integer;
  499. Node: TExTreeNode;
  500. vTemplateNode: TTemplateNode;
  501. sPath, sOutputFileName: String;
  502. begin
  503. if BrowseFolder(sPath, '请选择导出报表路径', Handle) then
  504. begin
  505. for iIndex := 0 to extvReport.Items.Count - 1 do
  506. begin
  507. Node := extvReport.Items[iIndex];
  508. if Node.HasChildren or (Node.Checked <> csChecked) or (Node.Data = nil) then Continue;
  509. vTemplateNode := TTemplateNode(Node.Data);
  510. sOutputFileName := sPath + ExtractSimpleFileName(vTemplateNode.FileName) + '.xls';
  511. if FileExists(vTemplateNode.FileName) then
  512. PrintReport(vTemplateNode, False, True, sOutputFileName, GetTemplateXlsFileName);
  513. end;
  514. extvReport.ClearChecked;
  515. end;
  516. end;
  517. procedure TReportsForm.ExportCurXlsReport;
  518. var
  519. sFileName: string;
  520. begin
  521. sFileName := extvReport.Selected.Text;
  522. if (PrintStartPage <= PrintEndPage) and SaveFile(sFileName, '.xls') then
  523. ExportXlsReport(PrintStartPage, PrintEndPage, sFileName, PreviewComXML);
  524. end;
  525. procedure TReportsForm.AfterExport;
  526. begin
  527. // ToDo - 关闭进度条
  528. // ToDo - 取消设置Update进度条事件
  529. // PreviewComXML.OnProgress := nil;
  530. Screen.Cursor := crDefault;
  531. end;
  532. procedure TReportsForm.BeforeExport;
  533. begin
  534. Screen.Cursor := crHourGlass;
  535. // ToDo - 设置Update进度条事件
  536. // PreviewComXML.OnProgress := PreviewComXMLProgress;
  537. // ToDo - 打开进度条
  538. end;
  539. function TReportsForm.GetExcelMode: TOutputExcelMode;
  540. begin
  541. if chkExcelMode.Checked then
  542. Result := oemOneSheet
  543. else
  544. Result := oemNormal;
  545. end;
  546. procedure TReportsForm.extvReportClick(Sender: TObject);
  547. begin
  548. LoadTempletAndDisplay;
  549. end;
  550. procedure TReportsForm.xlbCloseClick(Sender: TObject);
  551. begin
  552. Close;
  553. end;
  554. procedure TReportsForm.AddReportTemplate(ANode: TTemplateNode);
  555. var
  556. vClassNode, vNode: TExTreeNode;
  557. begin
  558. vClassNode := GetClassNode(ANode);
  559. if ANode.SubClassNum <> '' then
  560. vClassNode := GetSubClassNode(vClassNode, ANode);
  561. vNode := extvReport.Items.AddChildObject(vClassNode, ANode.TemplateName, Pointer(ANode));
  562. vNode.ImageIndex := 2;
  563. vNode.SelectedIndex := 3;
  564. vNode.Checked := csUnchecked;
  565. if (vClassNode <> nil) and not vClassNode.Expanded then
  566. vClassNode.Expanded := True;
  567. end;
  568. function TReportsForm.GetClassNode(ANode: TTemplateNode): TExTreeNode;
  569. function FindClassNode(const AName: string): TExTreeNode;
  570. var
  571. I: Integer;
  572. vNode: TExTreeNode;
  573. begin
  574. Result := nil;
  575. for I := 0 to extvReport.Items.Count - 1 do
  576. begin
  577. vNode := extvReport.Items.Item[I];
  578. if SameText(vNode.Text, AName) then
  579. begin
  580. Result := vNode;
  581. Break;
  582. end;
  583. end;
  584. end;
  585. begin
  586. Result := FindClassNode(ANode.ClassNum + '.' + ANode.ClassName);
  587. if not Assigned(Result) then
  588. Result := AddClassNode(nil, ANode.ClassNum + '.' + ANode.ClassName);
  589. end;
  590. procedure TReportsForm.tbImportSrtClick(Sender: TObject);
  591. procedure ImportReportTemplate(const AFileName: string);
  592. var
  593. sNewFileName: string;
  594. vTemplateNode: TTemplateNode;
  595. begin
  596. sNewFileName := GetReportTemplatePath + ExtractFileName(AFileName);
  597. if not FileExists(sNewFileName) then
  598. begin
  599. CopyFile(PChar(AFileName), PChar(sNewFileName), True);
  600. vTemplateNode := ReportTemplateManager.AddReportTemplate(sNewFileName);
  601. AddReportTemplate(vTemplateNode);
  602. end
  603. else
  604. if QuestMessage('已存在报表模板' + ExtractFileName(AFileName) + ',是否覆盖原模板?', Handle) then
  605. begin
  606. CopyFile(PChar(AFileName), PChar(sNewFileName), False);
  607. vTemplateNode := ReportTemplateManager.FindTemplate(sNewFileName);
  608. if Assigned(vTemplateNode) then
  609. vTemplateNode.RefreshTemplateProperties;
  610. end
  611. else
  612. Exit;
  613. end;
  614. var
  615. sgsFiles: TStrings;
  616. iFile: Integer;
  617. begin
  618. sgsFiles := TStringList.Create;
  619. try
  620. if SelectFiles(sgsFiles, '.srt') then
  621. begin
  622. for iFile := 0 to sgsFiles.Count - 1 do
  623. ImportReportTemplate(sgsFiles.Strings[iFile]);
  624. end;
  625. finally
  626. sgsFiles.Free;
  627. end;
  628. end;
  629. procedure TReportsForm.tbDeleteSrtClick(Sender: TObject);
  630. var
  631. vTemplateNode: TTemplateNode;
  632. begin
  633. if not Assigned(extvReport.Selected) then Exit;
  634. vTemplateNode := TTemplateNode(extvReport.Selected.Data);
  635. if not Assigned(vTemplateNode) then Exit;
  636. extvReport.Items.Delete(extvReport.Selected);
  637. DeleteFile(vTemplateNode.FileName);
  638. ReportTemplateManager.DeleteReportTemplate(vTemplateNode);
  639. LoadTempletAndDisplay;
  640. end;
  641. procedure TReportsForm.tbExportSrtClick(Sender: TObject);
  642. var
  643. vTemplateNode: TTemplateNode;
  644. sFileName: string;
  645. begin
  646. if not Assigned(extvReport.Selected) then Exit;
  647. vTemplateNode := TTemplateNode(extvReport.Selected.Data);
  648. if not Assigned(vTemplateNode) then Exit;
  649. sFileName := vTemplateNode.TemplateName;
  650. if SaveFile(sFileName, '.srt') then
  651. begin
  652. if not FileExists(sFileName) or QuestMessage('存在同名文件,是否覆盖?', Handle) then
  653. CopyFile(PChar(vTemplateNode.FileName), PChar(sFileName), False);
  654. end;
  655. end;
  656. procedure TReportsForm.PreviewComXMLContentDisplay(
  657. var contentFontRec: TFontRec; dataType: Integer; isReading: Boolean;
  658. DrawType: Integer; isPrinting: Boolean);
  659. begin
  660. if ReportConfig.ContentIsNarrow then
  661. begin
  662. if (isReading) then
  663. begin
  664. begin
  665. contentFontRec.FontName := 'Arial Narrow';
  666. contentFontRec.FontHeight := Round(ReportConfig.ContentFont.Size*4/3) * 4 div 3;
  667. end;
  668. end else
  669. begin
  670. if (DrawType = 3) or (DrawType = 5) then
  671. begin
  672. contentFontRec.FontHeight := Round(ReportConfig.ContentFont.Size*4/3);
  673. end else if (isPrinting) then
  674. begin
  675. contentFontRec.FontName := 'Arial Narrow';
  676. contentFontRec.FontHeight := Round(ReportConfig.ContentFont.Size*4/3) * 7 div 6;
  677. end else
  678. begin
  679. contentFontRec.FontHeight := Round(ReportConfig.ContentFont.Size*4/3) * 4 div 3;
  680. end;
  681. end;
  682. end;
  683. end;
  684. procedure TReportsForm.xlbSetupClick(Sender: TObject);
  685. begin
  686. if AdjustReport then
  687. LoadTempletAndDisplay;
  688. end;
  689. procedure TReportsForm.InitReportSettings(APrintCom: TPrintComXML; ATemplate: TTemplateNode);
  690. begin
  691. APrintCom.FillZero := chkFillZero.Checked;
  692. InitPageSettings(APrintCom);
  693. InitPaperSettings(ATemplate, APrintCom);
  694. APrintCom.ShowBackgroundMark := FProjectData.ProjProperties.ShowReportShading;
  695. APrintCom.BackgroundMarkStr := FProjectData.ProjProperties.ReportShading;
  696. end;
  697. procedure TReportsForm.InitPageSettings(APrintCom: TPrintComXML);
  698. begin
  699. // 设置页面大小
  700. APrintCom.setPageSize(ReportConfig.PageSize);
  701. if ReportConfig.PageSize = 'A3' then
  702. APrintCom.PrintPageSizeIdx := DMPAPER_A3
  703. else if ReportConfig.PageSize = 'A4' then
  704. APrintCom.PrintPageSizeIdx := DMPAPER_A4;
  705. // 设置边距
  706. APrintCom.setEdge(0, '', ReportConfig.LeftEdge/10);
  707. APrintCom.setEdge(1, '', ReportConfig.RightEdge/10);
  708. APrintCom.setEdge(2, '', ReportConfig.UpEdge/10);
  709. APrintCom.setEdge(3, '', ReportConfig.DownEdge/10);
  710. end;
  711. procedure TReportsForm.InitPaperSettings(ATemplate: TTemplateNode; APrintCom: TPrintComXML);
  712. procedure InitRepBorderLine;
  713. var
  714. i: Integer;
  715. ObjList : TList;
  716. ShapeRec : PPicRec;
  717. begin
  718. ObjList := TList.Create;
  719. try
  720. APrintCom.getAllShapeObjs(1, ObjList);
  721. for i := 0 to ObjList.Count - 1 do
  722. begin
  723. ShapeRec := ObjList[i];
  724. // 设置报表边框线粗
  725. ShapeRec.PenWidth := ReportConfig.BorderLine;
  726. // 设置是否绘制报表边框横线
  727. if (ShapeRec.ExArea.ExLeft <> ShapeRec.ExArea.ExRight) then
  728. begin
  729. if not ReportConfig.RepBorderUnderLine then
  730. ShapeRec.PenStyle := integer(psClear)
  731. else
  732. ShapeRec.PenStyle := integer(psSolid);
  733. end;
  734. // 设置是否绘制报表边框竖线
  735. if (ShapeRec.ExArea.ExTop <> ShapeRec.ExArea.ExBottom) and
  736. ((ShapeRec.ExArea.ExLeft = 0) or (ShapeRec.ExArea.ExLeft = 100)) then
  737. begin //这里的判断条件是约定好的
  738. if not ReportConfig.RepBorderVerLine then
  739. ShapeRec.PenStyle := integer(psClear)
  740. else
  741. ShapeRec.PenStyle := integer(psSolid)
  742. end;
  743. APrintCom.setShapeObj(ShapeRec);
  744. end;
  745. finally
  746. ObjList.Free;
  747. end;
  748. end;
  749. procedure InitRepCellLine;
  750. var
  751. i: Integer;
  752. ObjList : TList;
  753. ColumnRec : PColumnRec;
  754. FlowContentRec : PContentRec;
  755. CrossContentRec : PCrossContentRec;
  756. begin
  757. ObjList := TList.Create;
  758. try
  759. APrintCom.getAllFlowShowContentObjs(ObjList);
  760. // 设置报表表格横线
  761. for i := 0 to ObjList.Count - 1 do
  762. begin
  763. FlowContentRec := ObjList[i];
  764. FlowContentRec.LineInfo.TopThick := ReportConfig.CellHorLineWidth;
  765. FlowContentRec.LineInfo.BottomThick := ReportConfig.CellHorLineWidth;
  766. APrintCom.setFlowContentObj(FlowContentRec);
  767. end;
  768. APrintCom.getAllCrossContentObjs(ObjList);
  769. for i := 0 to ObjList.Count - 1 do
  770. begin
  771. CrossContentRec := ObjList[i];
  772. CrossContentRec.CrossContent.LineInfo.TopThick := ReportConfig.CellHorLineWidth;
  773. CrossContentRec.CrossContent.LineInfo.BottomThick := ReportConfig.CellHorLineWidth;
  774. APrintCom.setCrossContentObj(CrossContentRec);
  775. end;
  776. // 设置报表表格竖线
  777. APrintCom.getAllFlowShowContentObjs(ObjList);
  778. for i := 0 to ObjList.Count - 1 do
  779. begin
  780. FlowContentRec := ObjList[i];
  781. FlowContentRec.LineInfo.LeftThick := ReportConfig.CellVerLineWidth;
  782. FlowContentRec.LineInfo.RightThick := ReportConfig.CellVerLineWidth;
  783. // 如果设置无表格边框线,则两端的表格竖线线粗为0
  784. if (not ReportConfig.RepBorderVerLine) then
  785. if (i = 0) then
  786. FlowContentRec.LineInfo.LeftThick := 0
  787. else if (i = ObjList.Count - 1) then
  788. FlowContentRec.LineInfo.RightThick := 0;
  789. APrintCom.setFlowContentObj(FlowContentRec);
  790. end;
  791. APrintCom.getAllCrossContentObjs(ObjList);
  792. for i := 0 to ObjList.Count - 1 do
  793. begin
  794. CrossContentRec := ObjList[i];
  795. CrossContentRec.CrossContent.LineInfo.LeftThick := ReportConfig.CellVerLineWidth;
  796. CrossContentRec.CrossContent.LineInfo.RightThick := ReportConfig.CellVerLineWidth;
  797. ColumnRec := CrossContentRec.CrossContent.Column;
  798. //这里还要判断如果没有边框竖线的情况下,表格竖线边缘的线粗也为0
  799. //前提是所属表栏最右位置位于边缘
  800. if (not ReportConfig.RepBorderVerLine) and (ColumnRec<>nil) and
  801. ((ColumnRec.ExArea.ExRight = 100.0) or (ColumnRec.ExArea.ExLeft = 0.0)) then
  802. begin
  803. case CrossContentRec.CrossType of
  804. 0 : //交叉行
  805. begin
  806. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  807. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  808. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  809. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  810. end;
  811. 1 : //交叉列
  812. begin
  813. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  814. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  815. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  816. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  817. //(*
  818. if (CrossContentRec.CrossContent.isSpecialBorder) then
  819. begin
  820. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  821. CrossContentRec.CrossContent.SpecialLineInfo.RightThick := 0;
  822. end;
  823. //*)
  824. end;
  825. 2 : //显示数据
  826. begin
  827. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  828. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  829. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  830. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  831. end;
  832. 3 : //固定LABEL
  833. begin
  834. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  835. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  836. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  837. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  838. end;
  839. 4 : //序号
  840. begin
  841. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  842. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  843. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  844. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  845. end;
  846. 5 : //横向统计
  847. begin
  848. if (CrossContentRec.CrossContent.ExArea.ExLeft = ColumnRec.ExArea.ExLeft ) then
  849. CrossContentRec.CrossContent.LineInfo.LeftThick := 0;
  850. if (CrossContentRec.CrossContent.ExArea.ExRight = ColumnRec.ExArea.ExRight ) then
  851. CrossContentRec.CrossContent.LineInfo.RightThick := 0;
  852. end;
  853. end;
  854. end;
  855. APrintCom.setCrossContentObj(CrossContentRec);
  856. end;
  857. finally
  858. ObjList.Free;
  859. end;
  860. end;
  861. procedure InitOtherArea;
  862. procedure SetPTRBorder(PTR : PTextRec);
  863. procedure SetLeftRightBorder;
  864. begin
  865. if PTR.ExArea.ExLeft = 0.0 then
  866. begin
  867. if BorderWidth = 0.0 then
  868. PTR.LineInfo.LeftThick := ReportConfig.BorderUnderLineWidth;
  869. end;
  870. if PTR.ExArea.ExRight = 100.0 then
  871. begin
  872. if BorderWidth = 0.0 then
  873. PTR.LineInfo.RightThick := ReportConfig.BorderUnderLineWidth
  874. end;
  875. end;
  876. procedure SetHorLine;
  877. begin
  878. if (PTR.LineInfo.TopThick >= 0.2) and (BorderWidth <= 0.2) then
  879. PTR.LineInfo.TopThick := ReportConfig.CellHorLineWidth;
  880. if (PTR.LineInfo.BottomThick >= 0.2) and (BorderWidth <= 0.2) then
  881. PTR.LineInfo.BottomThick := ReportConfig.CellHorLineWidth;
  882. end;
  883. begin
  884. SetLeftRightBorder;
  885. SetHorLine;
  886. end;
  887. procedure SetPCRBorder(PCR : PColumnRec);
  888. procedure SetLeftRightBorder;
  889. begin
  890. if PCR.ExArea.ExLeft = 0.0 then
  891. begin
  892. if BorderWidth = 0.0 then
  893. PCR.LineInfo.LeftThick := ReportConfig.BorderUnderLineWidth
  894. end;
  895. if PCR.ExArea.ExRight = 100.0 then
  896. begin
  897. if BorderWidth = 0.0 then
  898. PCR.LineInfo.RightThick := ReportConfig.BorderUnderLineWidth;
  899. end;
  900. end;
  901. procedure SetVerLine;
  902. begin
  903. if PCR.ExArea.ExLeft = 0.0 then
  904. PCR.LineInfo.LeftThick := ReportConfig.CellVerLineWidth;
  905. if PCR.ExArea.ExRight = 100.0 then
  906. PCR.LineInfo.RightThick := ReportConfig.CellVerLineWidth;
  907. end;
  908. procedure SetHorLine;
  909. begin
  910. if (PCR.LineInfo.TopThick >= 0.2) and (BorderWidth <= 0.2) then
  911. PCR.LineInfo.TopThick := ReportConfig.CellHorLineWidth;
  912. if (PCR.LineInfo.BottomThick >= 0.2) and (BorderWidth <= 0.2) then
  913. PCR.LineInfo.BottomThick := ReportConfig.CellHorLineWidth;
  914. end;
  915. begin
  916. SetLeftRightBorder;
  917. SetVerLine;
  918. SetHorLine;
  919. end;
  920. var i,k : integer;
  921. ObjList : TList;
  922. ActAreaRec : PActiveAreaRec;
  923. PSR : PShowElementRec;
  924. begin
  925. ObjList := TList.Create;
  926. try
  927. ActAreaRec := nil;
  928. PreviewComXML.getAllActAreaObjs(ObjList);
  929. for i := 0 to ObjList.Count - 1 do
  930. begin
  931. ActAreaRec := ObjList[i];
  932. if (ActAreaRec.ShowType < 0) or (ActAreaRec.ShowType > 2) then Continue;
  933. if not Assigned(ActAreaRec.ElementList) then Continue;
  934. for k := 0 to ActAreaRec.ElementList.Count - 1 do
  935. begin
  936. PSR := PShowElementRec(ActAreaRec.ElementList[k]);
  937. case PSR.ElementType of
  938. 0..2 : SetPTRBorder(PSR.Data); //文本,参数,字段,表栏
  939. 7 : SetPCRBorder(PSR.Data) //Column
  940. end;
  941. APrintCom.setActShowElementObj(PSR);
  942. end;
  943. end;
  944. finally
  945. ObjList.Free;
  946. end;
  947. end;
  948. begin
  949. if not Assigned(ATemplate) or (ATemplate.SelfFormat = 0) then
  950. begin
  951. InitFont(APrintCom); // 各类字体
  952. InitRepBorderLine; // 报表边框
  953. InitRepCellLine; // 报表表格
  954. InitOtherArea; // 活动区域
  955. end;
  956. end;
  957. procedure TReportsForm.PreviewComXMLCrossTabLabelShow(valIDX: Integer;
  958. var ExLeft, ExRight: Double; var isShow: Boolean;
  959. CrsTabShowType: Integer);
  960. var field : PFieldRec;
  961. begin
  962. if (CrsTabShowType = -1) then exit;
  963. field := PreviewComXML.getFieldByID(6);
  964. if (field <> nil) then
  965. begin
  966. if (field.DataLen > valIDX) and (valIDX >= 0) then
  967. begin
  968. if (field.Value[valIDX] = 1.5) then
  969. begin
  970. case CrsTabShowType of
  971. 1 : begin
  972. isShow := false;
  973. end;
  974. 2 : begin
  975. ExLeft := 0;
  976. ExRight := 100;
  977. end;
  978. 3 : begin
  979. //
  980. end
  981. else
  982. begin
  983. //
  984. end;
  985. end;
  986. end;
  987. end;
  988. end;
  989. end;
  990. procedure TReportsForm.rdbtnA4Click(Sender: TObject);
  991. begin
  992. ReportConfig.PageSize := TRadioButton(Sender).Caption;
  993. SetPrinterPageSize(ReportConfig.PageSize);
  994. LoadTempletAndDisplay;
  995. end;
  996. procedure TReportsForm.chkFillZeroClick(Sender: TObject);
  997. begin
  998. PreviewComXML.FillZero := chkFillZero.Checked;
  999. PreviewReportCurPage;
  1000. end;
  1001. procedure TReportsForm.InitFont(APrintCom: TPrintComXML);
  1002. procedure AssignFontRec(AFontRec: TFontRec; AFont: TFont);
  1003. begin
  1004. AFontRec.FontName := AFont.Name;
  1005. AFontRec.FontHeight := Round(AFont.Size*4/3) ;
  1006. AFontRec.FontBold := 400 + Integer(fsBold in AFont.Style)*200;
  1007. AFontRec.FontItalic := Integer(fsItalic in AFont.Style);
  1008. AFontRec.FontUnderLine := Integer(fsUnderLine in AFont.Style);
  1009. end;
  1010. procedure InitTitleFont;
  1011. var
  1012. TitleRec : PTitleRec;
  1013. begin
  1014. TitleRec := PreviewComXML.getTitleByID(1);
  1015. if TitleRec <> nil then
  1016. begin
  1017. AssignFontRec(TitleRec.FontRec, ReportConfig.TitleFont);
  1018. APrintCom.setTitleObj(TitleRec);
  1019. end;
  1020. end;
  1021. procedure InitColumnFont;
  1022. procedure InitColumnThick(AColumnRec: PColumnRec);
  1023. begin
  1024. if (ReportConfig.ReportCellLine > 0.2) then
  1025. begin
  1026. if (AColumnRec.LineInfo.LeftThick > 0.2) then
  1027. AColumnRec.LineInfo.LeftThick := ReportConfig.ReportCellLine;
  1028. if (AColumnRec.LineInfo.RightThick > 0.2) then
  1029. AColumnRec.LineInfo.RightThick := ReportConfig.ReportCellLine;
  1030. if (AColumnRec.LineInfo.TopThick > 0.2) then
  1031. AColumnRec.LineInfo.TopThick := ReportConfig.ReportCellLine;
  1032. if (AColumnRec.LineInfo.BottomThick > 0.2) then
  1033. AColumnRec.LineInfo.BottomThick := ReportConfig.ReportCellLine;
  1034. end;
  1035. end;
  1036. var
  1037. i, j: Integer;
  1038. ObjList: TList;
  1039. ColumnRec : PColumnRec;
  1040. AAR : PActiveAreaRec;
  1041. SER : PShowElementRec;
  1042. begin
  1043. ObjList := TList.Create;
  1044. try
  1045. APrintCom.getAllColumnHeadObjs(ObjList);
  1046. for i := 0 to ObjList.Count - 1 do
  1047. begin
  1048. ColumnRec := ObjList[i];
  1049. AssignFontRec(ColumnRec.FontRec, ReportConfig.ColumnFont);
  1050. InitColumnThick(ColumnRec);
  1051. APrintCom.setColumnHeadTailObj(0, ColumnRec);
  1052. end;
  1053. APrintCom.getAllColumnTailObjs(ObjList);
  1054. for i := 0 to ObjList.Count - 1 do
  1055. begin
  1056. ColumnRec := ObjList[i];
  1057. AssignFontRec(ColumnRec.FontRec, ReportConfig.ColumnFont);
  1058. InitColumnThick(ColumnRec);
  1059. APrintCom.setColumnHeadTailObj(1,ColumnRec);
  1060. end;
  1061. APrintCom.getAllActAreaObjs(ObjList);
  1062. for i := 0 to ObjList.Count - 1 do
  1063. begin
  1064. AAR := ObjList[i];
  1065. for j := 0 to AAR.ElementList.Count - 1 do
  1066. begin
  1067. SER := AAR.ElementList[j];
  1068. if (SER.ElementType = 7) then
  1069. begin
  1070. ColumnRec := SER.Data;
  1071. AssignFontRec(ColumnRec.FontRec, ReportConfig.ColumnFont);
  1072. InitColumnThick(ColumnRec);
  1073. APrintCom.setActShowElementObj(SER);
  1074. end;
  1075. end;
  1076. end;
  1077. finally
  1078. ObjList.Free;
  1079. end;
  1080. end;
  1081. procedure InitContentAndGatherFont;
  1082. var
  1083. i, j: Integer;
  1084. ObjList: TList;
  1085. FlowContentRec : PContentRec;
  1086. CrossContentRec : PCrossContentRec;
  1087. SumRec : PSumRec;
  1088. begin
  1089. ObjList := TList.Create;
  1090. try
  1091. // 设置表正文
  1092. APrintCom.getAllFlowShowContentObjs(ObjList);
  1093. for i := 0 to ObjList.Count - 1 do
  1094. begin
  1095. FlowContentRec := ObjList[i];
  1096. if not (FlowContentRec.Fixed) then
  1097. begin
  1098. AssignFontRec(FlowContentRec.FontRec, ReportConfig.ContentFont);
  1099. APrintCom.setFlowContentObj(FlowContentRec);
  1100. end;
  1101. end;
  1102. APrintCom.getAllBillShowContentObjs(ObjList);
  1103. for i := 0 to ObjList.Count - 1 do
  1104. begin
  1105. FlowContentRec := ObjList[i];
  1106. if not(FlowContentRec.Fixed) then
  1107. begin
  1108. AssignFontRec(FlowContentRec.FontRec, ReportConfig.ContentFont);
  1109. APrintCom.setBillContentObj(FlowContentRec);
  1110. end;
  1111. end;
  1112. APrintCom.getAllCrossContentObjs(ObjList);
  1113. for i := 0 to ObjList.Count - 1 do
  1114. begin
  1115. CrossContentRec := ObjList[i];
  1116. if not(CrossContentRec.CrossContent.Fixed) then
  1117. begin
  1118. AssignFontRec(CrossContentRec.CrossContent.FontRec, ReportConfig.ContentFont);
  1119. APrintCom.setCrossContentObj(CrossContentRec);
  1120. end;
  1121. end;
  1122. // 设置表合计
  1123. for i := 0 to 2 do
  1124. begin
  1125. APrintCom.getAllSumObjs(i,ObjList);
  1126. for j := 0 to ObjList.Count - 1 do
  1127. begin
  1128. SumRec := ObjList[j];
  1129. AssignFontRec(SumRec.FontRec, ReportConfig.GatherFont);
  1130. APrintCom.setSumObj(SumRec);
  1131. end;
  1132. end;
  1133. finally
  1134. ObjList.Free;
  1135. end;
  1136. end;
  1137. procedure InitGridHeaderFont;
  1138. var
  1139. i: Integer;
  1140. ObjList: TList;
  1141. HeadTailRec : PHeadRec;
  1142. begin
  1143. ObjList := TList.Create;
  1144. try
  1145. APrintCom.getAllHeadObjs(ObjList);
  1146. for i := 0 to ObjList.Count - 1 do
  1147. begin
  1148. HeadTailRec := ObjList[i];
  1149. AssignFontRec(HeadTailRec.FontRec, ReportConfig.GridHeaderFont);
  1150. APrintCom.setHeadTailObj(0, HeadTailRec);
  1151. end;
  1152. APrintCom.getAllTailObjs(ObjList);
  1153. for i := 0 to ObjList.Count - 1 do
  1154. begin
  1155. HeadTailRec := ObjList[i];
  1156. AssignFontRec(HeadTailRec.FontRec, ReportConfig.GridHeaderFont);
  1157. APrintCom.setHeadTailObj(1, HeadTailRec);
  1158. end;
  1159. finally
  1160. ObjList.Free;
  1161. end;
  1162. end;
  1163. begin
  1164. InitTitleFont;
  1165. InitColumnFont;
  1166. InitContentAndGatherFont;
  1167. InitGridHeaderFont;
  1168. end;
  1169. procedure TReportsForm.PreviewComXMLGetDatasetEvent(
  1170. DatasetInfo: PDatasetInfoRec; var ADataset: TDataSet);
  1171. begin
  1172. if DatasetInfo.ID = 0 then
  1173. ADataSet := MemoryReportManager.GetSqlResultDataSet(ReportTemplateManager.Current.InteractInfo.Sql, FProjectData)
  1174. else
  1175. ADataset := MemoryReportManager.GetMemoryDataSet(DatasetInfo.ID, FProjectData);
  1176. end;
  1177. function TReportsForm.GetIsExcel2010: Boolean;
  1178. begin
  1179. Result := chkExcel2010.Checked;
  1180. end;
  1181. procedure TReportsForm.InitFormView;
  1182. begin
  1183. rdbtnA3.Checked := SameText(rdbtnA3.Caption, ReportConfig.PageSize);
  1184. rdbtnA4.Checked := SameText(rdbtnA4.Caption, ReportConfig.PageSize);
  1185. SetPrinterPageSize(ReportConfig.PageSize);
  1186. end;
  1187. procedure TReportsForm.LoadExcelBorder(var Border: TColumnLineRec);
  1188. begin
  1189. Border.LeftThick := 0.5;
  1190. Border.TopThick := 0.5;
  1191. Border.RightThick := 0.5;
  1192. Border.BottomThick := 0.5;
  1193. if not ReportConfig.RepBorderVerLine then
  1194. begin
  1195. Border.LeftThick := 0;
  1196. Border.RightThick := 0;
  1197. end;
  1198. end;
  1199. procedure TReportsForm.PrintReport(ATemplateNode: TTemplateNode;
  1200. isPDF, isExcel: boolean; ExcelOutputName, TemplateFileName: string);
  1201. function CheckPrinterReady: Boolean;
  1202. var
  1203. PrinterHD: THandle;
  1204. NoJobs: Word;
  1205. s: LongWord;
  1206. Job_Info: Array[0..10] of Job_INFO_1;
  1207. cbNeeded: Cardinal;
  1208. cReturned: Cardinal;
  1209. ret: LongBool;
  1210. begin
  1211. if OpenPrinter(PChar(Printer.Printers[Printer.PrinterIndex]), PrinterHD, 0) then
  1212. begin
  1213. s := SizeOf(Job_Info);
  1214. cbNeeded := 0;
  1215. cReturned := 0;
  1216. NoJobs := 10;
  1217. ret := ENumJobs(PrinterHD, 0, NoJobs, 1, @Job_Info, s, cbNeeded, cReturned);
  1218. Result := not((cReturned > 0) and (Job_Info[0].TotalPages > 0));
  1219. end
  1220. else
  1221. Result := True;
  1222. end;
  1223. procedure PrintTemplet;
  1224. begin
  1225. if isPDF then
  1226. begin
  1227. BatchPrintXml.PrintPDFAll;
  1228. while not CheckPrinterReady do
  1229. Sleep(1000);
  1230. end
  1231. else if not isExcel then
  1232. BatchPrintXml.PrintAll(1)
  1233. else
  1234. ExportXlsReport(1, BatchPrintXml.TotalPages, ExcelOutputName, BatchPrintXml);
  1235. end;
  1236. var
  1237. strRptName : string;
  1238. begin
  1239. if not FileExists(ATemplateNode.FileName) then Exit;
  1240. ClearReportOprList;
  1241. ClearReportFuncList;
  1242. Screen.Cursor := crHourGlass;
  1243. try
  1244. LoadTemplet(ATemplateNode, BatchPrintXml);
  1245. if BatchPrintXml.TotalPages > 0 then
  1246. PrintTemplet
  1247. {else if strRptName <> '' then
  1248. begin
  1249. LoadTemplet(RptArchiverObj, strRptName);
  1250. PrintEmptyTemplet;
  1251. end;}
  1252. finally
  1253. Screen.Cursor := crDefault;
  1254. end;
  1255. end;
  1256. procedure TReportsForm.ExportXlsReport(AStartPage, AEndPage: Integer;
  1257. const AFileName: string; APrintCom: TPrintComXML);
  1258. procedure ExportPagesXlsReport(AStartPage, AEndPage: Integer; const AFileName: string);
  1259. var
  1260. Border : TColumnLineRec;
  1261. begin
  1262. LoadExcelBorder(Border);
  1263. if IsExcel2010 then
  1264. // 康博士代码中写批量打印是,用Printer.Canvas,打印当前时,用PreviewBox.Canvas。不懂为什么
  1265. APrintCom.OutputToExcelRangeXMLEx(PreviewBox.Canvas, AStartPage,
  1266. AEndPage, GetTemplateXlsFileName, AFileName, Border, ExcelMode)
  1267. else
  1268. APrintCom.OutputToExcelFile(PreviewBox.Canvas, AStartPage,
  1269. AEndPage, GetTemplateXlsFileName, AFileName, ExcelMode, Border);
  1270. end;
  1271. var
  1272. iStartPage, iEndPage, iCount: Integer;
  1273. sFileName: string;
  1274. begin
  1275. BeforeExport;
  1276. try
  1277. if (ExcelMode = oemNormal) and (PrintEndPage - PrintStartPage > 30) then
  1278. begin
  1279. iStartPage := PrintStartPage;
  1280. iEndPage := iStartPage + 19;
  1281. iCount := 1;
  1282. repeat
  1283. begin
  1284. sFileName := Format('%s[%d].xls', [ExtractSimpleFileName(AFileName), iCount]);
  1285. ExportPagesXlsReport(iStartPage, iEndPage, sFileName);
  1286. iStartPage := iStartPage + 20;
  1287. iEndPage := Min(iEndPage + 20, PrintEndPage);
  1288. Inc(iCount);
  1289. end
  1290. until iStartPage > iEndPage;
  1291. end
  1292. else
  1293. ExportPagesXlsReport(AStartPage, AEndPage, AFileName);
  1294. finally
  1295. AfterExport;
  1296. end;
  1297. end;
  1298. procedure TReportsForm.LoadTemplet(ATemplate: TTemplateNode; APrintCom: TPrintComXML);
  1299. var
  1300. RptArchiverObj: TReportArchiver;
  1301. Mem: TMemoryStream;
  1302. begin
  1303. RptArchiverObj := TReportArchiver.Create;
  1304. if ATemplate.IsMulti then
  1305. RptArchiverObj.FileName := ATemplate.MultiFileNames[FProjectData.PhaseIndex]
  1306. else
  1307. RptArchiverObj.FileName := ATemplate.FileName;
  1308. Mem := RptArchiverObj.Extract;
  1309. try
  1310. // 以下代码有顺序限制,不可修改,主要保证在不修改报表模板文件的基础上可以用户定制报表格式
  1311. // 私以为,原因在于这些设置修改后,并不能生效,需要保存再读取方可生效
  1312. // 读取报表模板
  1313. if not APrintCom.ReadReportStream(Mem) then Exit;
  1314. // 将报表设置中的数据覆盖掉原模板的数据
  1315. InitReportSettings(APrintCom, ATemplate);
  1316. // 保存
  1317. APrintCom.SaveToStream(Mem);
  1318. // 再次读取,使报表设置中的设置生效
  1319. APrintCom.ReadReportStream(Mem);
  1320. // ReadReportStream之后会将PreviewComXML的FillZero值赋为True,故再赋值一次
  1321. APrintCom.FillZero := chkFillZero.Checked;
  1322. InitPageSettings(APrintCom);
  1323. APrintCom.ReadDBData;
  1324. APrintCom.AnalyseData;
  1325. finally
  1326. if Mem <> nil then
  1327. Mem.Free;
  1328. RptArchiverObj.Free;
  1329. end;
  1330. end;
  1331. function TReportsForm.GetHintStr: string;
  1332. begin
  1333. Result := #13#10 +
  1334. '对不起,学习版不提供报表打印、导出功能。'#13#10 +
  1335. #13#10 +
  1336. '以下为收费服务项目,请在必要时联系纵横:'#13#10 +
  1337. #13#10 +
  1338. '企业QQ:800003850 客服热线:(0756)3850888';
  1339. end;
  1340. function TReportsForm.GetSubClassNode(AClassNode: TExTreeNode;
  1341. ANode: TTemplateNode): TExTreeNode;
  1342. function FindNode(AParent: TExTreeNode; const AName: string): TExTreeNode;
  1343. var
  1344. I: Integer;
  1345. vNode: TExTreeNode;
  1346. begin
  1347. Result := nil;
  1348. if Assigned(AParent) then
  1349. vNode := AParent.getFirstChild
  1350. else
  1351. vNode := extvReport.Items.GetFirstNode;
  1352. while not Assigned(Result) and Assigned(vNode) do
  1353. begin
  1354. if SameText(vNode.Text, AName) then
  1355. Result := vNode;
  1356. vNode := vNode.getNextSibling;
  1357. end;
  1358. end;
  1359. begin
  1360. Result := FindNode(AClassNode, ANode.SubClassNum + '.' + ANode.SubClassName);
  1361. if not Assigned(Result) then
  1362. Result := AddClassNode(AClassNode, ANode.SubClassNum + '.' + ANode.SubClassName);
  1363. end;
  1364. function TReportsForm.AddClassNode(AParent: TExTreeNode;
  1365. const AName: string): TExTreeNode;
  1366. begin
  1367. Result := extvReport.Items.AddChildObject(AParent, AName, Pointer(nil));
  1368. Result.ImageIndex := 0;
  1369. Result.SelectedIndex := 1;
  1370. Result.Checked := csUnchecked;
  1371. Result.Expanded := True;
  1372. end;
  1373. procedure TReportsForm.SaveReportInteractData(ATemplate: TTemplateNode);
  1374. begin
  1375. case ATemplate.InteractFlag of
  1376. 1: SaveAuditOpinion(ATemplate);
  1377. end;
  1378. end;
  1379. procedure TReportsForm.SaveAuditOpinion(ATemplate: TTemplateNode);
  1380. var
  1381. SelectForm: TAuditSelctForm;
  1382. begin
  1383. SelectForm := TAuditSelctForm.Create(FProjectData, ATemplate);
  1384. try
  1385. if SelectForm.ShowModal = mrOk then
  1386. SelectForm.SaveAuditData;
  1387. finally
  1388. SelectForm.Free;
  1389. end;
  1390. end;
  1391. destructor TReportsForm.Destroy;
  1392. begin
  1393. FReportCon.Free;
  1394. FReportDataPrepare.Free;
  1395. inherited;
  1396. end;
  1397. end.