提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:王香|2018-11-22 15:48:58.000|阅读 322 次
概述:此示例项目显示了在运行时创建报表并在查看器中显示报表的可能性。您只需要显示报表的本机Java查看器,以及使用组件创建报表的几行代码。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
此示例项目显示了在运行时创建报表并在查看器中显示报表的可能性。您只需要显示报表的本机Java查看器,以及使用组件创建报表的几行代码。
首先,我们需要创建Java查看器。创建JFrame,设置必要的选项并添加查看器控件。
public class CreateReport extends JPanel { private static final long serialVersionUID = 330448692680237867L; private static final Dimension FRAME_SIZE = new Dimension(800, 800); public static void main(final String[] args) { SwingUtilities.invokeLater(new Runnable() { public void run() { try { JFrame frame = new JFrame(); frame.add(new CreateReport(frame)); frame.setSize(FRAME_SIZE); frame.setLocationRelativeTo(null); frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); frame.setVisible(true); } catch (Throwable e) { StiExceptionProvider.show(e, null); } } }); } public CreateReport(final JFrame parentFrame) throws FileNotFoundException { setLayout(new BoxLayout(this, BoxLayout.Y_AXIS)); setPreferredSize(FRAME_SIZE); StiViewerFx viewerPanel = new StiViewerFx(parentFrame); add(viewerPanel); ...
接下来,创建新的报表对象,然后使用Demo XML和XSD文件的路径创建XML数据集对象,并将其添加到报表中。
... StiReport report = new StiReport(); StiPage page = new StiPage(report); report.getPages().add(page); page.setName(StiNameCreation.createName(report, StiNameCreation.generateName(page))); String xsdPath = "/samples/Demo.xsd"; StiXmlDatabase xmlDatabase = new StiXmlDatabase("Demo", StiResourceUtil.getStream(xsdPath), StiResourceUtil.getStream("/samples/Demo.xml")); report.setDictionary(new StiDictionary(report)); report.getDictionary().getDatabases().add(xmlDatabase); ...
接下来,从Demo数据库中提取信息,并使用Categories名称创建TableSource 。
... StiXmlTableFieldsRequest tables = StiDataColumnsUtil.parceXSDSchema(StiResourceUtil.getStream(xsdPath)); StiDataTableSource tableSource = null; for (StiXmlTable table : tables.getTables()) { if (table.getName().equals("Categories")) { tableSource = new StiDataTableSource("Demo." + table.getName(), table.getName(), table.getName()); tableSource.setColumns(new StiDataColumnsCollection()); for (StiSqlField field : table.getColumns()) { StiDataColumn column = new StiDataColumn(field.getName(), field.getName(), field.getSystemType()); tableSource.getColumns().add(column); } tableSource.setDictionary(report.getDictionary()); report.getDictionary().getDataSources().add(tableSource); } } ...
现在我们需要创建报表组件。首先,使用Text组件将Header band添加到报告页面。这些组件将显示报表标题。
... // Create TitleBand StiHeaderBand titleBand = new StiHeaderBand(); titleBand.setHeight(0.85); titleBand.setName("TitleBand"); page.getComponents().add(titleBand); // Create Title text on header StiText headerText = new StiText(new StiRectangle(0, 0, page.getWidth(), 0.85)); headerText.setTextInternal("Tacticdescription"); headerText.setHorAlignment(StiTextHorAlignment.Left); headerText.setName("TitleHeader"); headerText.setFont(new StiFont("Arial", 12F, StiFontStyle.Bold)); titleBand.getComponents().add(headerText); // Create HeaderBand StiHeaderBand headerBand = new StiHeaderBand(); headerBand.setHeight(0.5); headerBand.setName("HeaderBand"); page.getComponents().add(headerBand); ...
接下来,使用“Text”字段和“Image”字段添加“Data”区域。这些组件将显示报表数据。
... double pos = 0; double columnWidth = page.getWidth() / tableSource.getColumns().size(); Integer nameIndex = 1; for (StiDataColumn dataColumn : tableSource.getColumns()) { // Create text on header StiText hText = new StiText(new StiRectangle(pos, 0, columnWidth, 0.5)); hText.setTextInternal(dataColumn.getName()); hText.setHorAlignment(StiTextHorAlignment.Center); hText.setName("HeaderText" + nameIndex.toString()); hText.setBrush(new StiSolidBrush(StiColorEnum.Orange.color())); hText.getBorder().setSide(StiBorderSides.All); headerBand.getComponents().add(hText); if (dataColumn.getName().equals("Picture")) { StiImage dataImage = new StiImage(new StiRectangle(pos, 0, columnWidth, 0.5)); dataImage.setDataColumn("Categories." + dataColumn.getName()); dataImage.setName("DataImage" + nameIndex.toString()); dataImage.getBorder().setSide(StiBorderSides.All); dataBand.getComponents().add(dataImage); } else { StiText dataText = new StiText(new StiRectangle(pos, 0, columnWidth, 0.5)); dataText.setText("{Categories." + dataColumn.getName() + "}"); dataText.setName("DataText" + nameIndex.toString()); dataText.getBorder().setSide(StiBorderSides.All); dataBand.getComponents().add(dataText); } pos = pos + columnWidth; nameIndex++; } ...
最后,渲染报表并在查看器中显示它。
... report.Render(); viewerPanel.getStiViewModel().getEventDispatcher().dispatchStiEvent( new StiViewCommonEvent(StiViewCommonEvent.DOCUMENT_FILE_LOADED, new StiDocument(report), null)); }
在下面的屏幕截图中,您可以看到示例代码的结果。
购买Stimulsoft正版授权,请点击“”哟!
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn
本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@pclwef.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢