【Stimulsoft Reports Java教程】运行时创建报表

下载Stimulsoft Reports Java最新版本

此示例项目显示了在运行时创建报表并在查看器中显示报表的可能性。您只需要显示报表的本机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

下载示例

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Stimulsoft Reports.Web ——适用于Web的报表生成器。Stimulsoft Reports.Web是一个报表工具,其设计的目的在于通过Web浏览器创建和渲染报表。您可以创建报表,显示报表,打印报表,导出报表Stimulsoft Reports.Web将提供完整的报表创建周期,从报表模板开始到在浏览器中显示报表为止。这一过程可在web浏览器未被关闭时完成。 Stimulsoft Reports.Web是第一款可以让您直接在Web中编辑报表报表工具。在您的客户端的机器里不需要安装.Net框架、ActiveX控件或其他特殊 插件。所有你需要的只是一个带有Flash Player 9的Web浏览器。 这是首次一个报表生成器能让您在web浏览器的窗口中编辑您的报表。唯一的需求是一个web浏览器和Flash Player 9。Stimulsoft Reports.Web能具有最高程度、带状界面、可视化控件开发程序、剪贴板、点击查看大图表格编辑、缩放以及其他多种功能,可以方便快捷的进行报表编辑。 您可以在浏览器的窗口中查看报表。您可以打印一份报表。您可以导出一份报表,其导出格式超过了20种:PDF、XPS、Excel、Word、HTML、 RTF以及XML等格式。这一切能在基于Ajax的报表Web浏览器中完成,也能直接通过Web应用程序中的一段代码来完成。 Stimulsoft Reports.Web支持多种类型的.Net数据,DataSet、DataTable、DataView以及DataRelation等。所有数据输出都要考虑在 DataSet中的数据的分级结构。所有的数据都是典型数据。其次,另外还支持Ado.Net不同类型的商业对象。您也可以直接从MS SQL、Oracle、ODBC、OleDB、FirebirdSQL、PostgeSQL、SQLCE与SQLite等数据库中获取数据。获取XML文 件的数据也没有问题。除此之外,还可以进行分类、过滤、分组、合并以及汇总。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值