我目前正在使用DynamicReports为我的项目构建报告。
我这样做有很多问题,因为这是我第一次在java中使用这样的功能。
我要做的是动态创建列。我已经解决了DynamicDataSource的部分问题,但现在我已经陷入了专栏。
这是我的代码:
public void raports(){
DefaultTableModel model = (DefaultTableModel) jTable1.getModel();
int mColumns = model.getColumnCount();
int mRows = model.getRowCount();
String[] arrColumns = new String[mColumns];
for(int i=0; i<mColumns; i++){
arrColumns[i] = model.getColumnName(i);
}
DRDataSource dataSource = new DRDataSource(arrColumns);
for (int i = 0; i < mRows; i++) {
for (int j = 0; j<mColumns; j++){
dataSource.add(model.getValueAt(i, j).toString());
}
}
JasperReportBuilder report = DynamicReports.report();//a new report
StyleBuilder boldStyle = stl.style().bold();
StyleBuilder titleStyle = stl.style(boldCenteredStyle)
.setVerticalAlignment(VerticalAlignment.MIDDLE)
.setFontSize(15);
StyleBuilder boldCenteredStyle = stl.style(boldStyle)
.setHorizontalAlignment(HorizontalAlignment.CENTER);
StyleBuilder columnTitleStyle = stl.style(boldCenteredStyle)
.setBorder(stl.pen1Point())
.setBackgroundColor(Color.LIGHT_GRAY);
report
.setColumnTitleStyle(columnTitleStyle)
.highlightDetailEvenRows()
.columns(
// Columns.column("Patient ID", "Patient_ID", DataTypes.stringType()).setHorizontalAlignment(HorizontalAlignment.LEFT),
// Columns.column("First Name", "First_Name", DataTypes.stringType()),
// Columns.column("Middle Name", "Middle_Name", DataTypes.stringType()),
// Columns.column("Last Name", "Last_Name", DataTypes.stringType()).setHorizontalAlignment(HorizontalAlignment.LEFT)
)
.title(
cmp.horizontalList()
.add( //cut the code here since this is the only part needed.
Referrences: Dynamic Reports Documentation
答案 0 :(得分:0)
您可以中断报告的调用链,并在for循环中使用以下方法:
report.addColumn(Columns.column("Here will be the name", "Here is the corresponding arrColumns name", DynamicReports.type.integerType()/* here is the column type*/));
我希望它有所帮助。