Browse Source

REPORT-37398 非中文设计器-英文下,报表分栏显示不全

主要修改:
1. bug原因是英文环境下一行放不下太多组件,所以被挤掉了,解决办法是增加判断,当系统语言是英文,就增大界面的高度,并将组件按照需求分块,分别用JPanel装起来,这样当第二个JPanel放不下就会自动换行,不会出现显示不全的问题
2. 由于将组件分块了,所以其他语言环境下,界面的高度也需要进行微调
3. 修改了一些代码规范问题
feature/big-screen
Yvan 5 years ago
parent
commit
52175cdf48
  1. 11
      designer-realize/src/main/java/com/fr/design/mainframe/JWorkBook.java
  2. 2
      designer-realize/src/main/java/com/fr/design/mainframe/ReportComponentComposite.java
  3. 79
      designer-realize/src/main/java/com/fr/design/report/ReportColumnsPane.java

11
designer-realize/src/main/java/com/fr/design/mainframe/JWorkBook.java

@ -1206,15 +1206,4 @@ public class JWorkBook extends JTemplate<WorkBook, WorkBookUndoState> {
super.whenClose(); super.whenClose();
reportComposite.doRemoveAction(); reportComposite.doRemoveAction();
} }
/**
* 更新滚动条的值(主要是为了重置滚动条里的BoundedRangeModel的extent值)使滚动条的宽度随着界面缩放而变化
*/
protected void updateScrollValue() {
ElementCasePane elementCasePane = reportComposite.centerCardPane.editingComponet.elementCasePane;
DynamicScrollBar verticalScrollBar = (DynamicScrollBar) elementCasePane.getVerticalScrollBar();
DynamicScrollBar horizontalScrollBar = (DynamicScrollBar) elementCasePane.getHorizontalScrollBar();
verticalScrollBar.setValue(verticalScrollBar.getValue());
horizontalScrollBar.setValue(horizontalScrollBar.getValue());
}
} }

2
designer-realize/src/main/java/com/fr/design/mainframe/ReportComponentComposite.java

@ -88,8 +88,6 @@ public class ReportComponentComposite extends JComponent implements RemoveListen
value = value < MIN ? MIN : value; value = value < MIN ? MIN : value;
int resolution = (int) (ScreenResolution.getScreenResolution() * value / HUND); int resolution = (int) (ScreenResolution.getScreenResolution() * value / HUND);
HistoryTemplateListPane.getInstance().getCurrentEditingTemplate().setScale(resolution); HistoryTemplateListPane.getInstance().getCurrentEditingTemplate().setScale(resolution);
//更新滚动条值,使之随着界面缩放
parent.updateScrollValue();
} }
}; };

79
designer-realize/src/main/java/com/fr/design/report/ReportColumnsPane.java

@ -14,6 +14,7 @@ import com.fr.design.gui.itextfield.UITextField;
import com.fr.design.layout.FRGUIPaneFactory; import com.fr.design.layout.FRGUIPaneFactory;
import com.fr.design.utils.gui.GUICoreUtils; import com.fr.design.utils.gui.GUICoreUtils;
import com.fr.general.FRFont; import com.fr.general.FRFont;
import com.fr.general.GeneralContext;
import com.fr.general.IOUtils; import com.fr.general.IOUtils;
import com.fr.report.stable.WorkSheetAttr; import com.fr.report.stable.WorkSheetAttr;
import com.fr.report.worksheet.WorkSheet; import com.fr.report.worksheet.WorkSheet;
@ -41,6 +42,7 @@ import java.awt.event.ActionListener;
public class ReportColumnsPane extends BasicPane{ public class ReportColumnsPane extends BasicPane{
public static final int ROW = 0; public static final int ROW = 0;
public static final int COLUMN = 1; public static final int COLUMN = 1;
private static final String LOCALE_LANGUAGE_EN = "en";
private int rowOrColumn; private int rowOrColumn;
private boolean isRepeate; private boolean isRepeate;
@ -58,7 +60,7 @@ public class ReportColumnsPane extends BasicPane{
com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Columns_Repeat_Row"), com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Columns_Repeat_Row"),
com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Columns_Repeat_Column") com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Columns_Repeat_Column")
}; };
private static final String FONT_NAME = "simsun"; private static final String FONT_NAME = "simsun";
private static final int FONT_SIZE = 14; private static final int FONT_SIZE = 14;
@ -87,6 +89,7 @@ public class ReportColumnsPane extends BasicPane{
this.setLayout(FRGUIPaneFactory.createBorderLayout()); this.setLayout(FRGUIPaneFactory.createBorderLayout());
JPanel north = new JPanel(new BorderLayout()) { JPanel north = new JPanel(new BorderLayout()) {
@Override
public void paint(Graphics g) { public void paint(Graphics g) {
super.paint(g); super.paint(g);
super.paintBorder(g); super.paintBorder(g);
@ -122,7 +125,7 @@ public class ReportColumnsPane extends BasicPane{
this.add(north, BorderLayout.NORTH); this.add(north, BorderLayout.NORTH);
this.add(createRowColumnPane(), BorderLayout.CENTER); this.add(createRowColumnPane(), BorderLayout.CENTER);
} }
private ActionListener onOffListener = new ActionListener() { private ActionListener onOffListener = new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
@ -220,7 +223,7 @@ public class ReportColumnsPane extends BasicPane{
sampleLablePane.add(cPane); sampleLablePane.add(cPane);
return sampleLablePane; return sampleLablePane;
} }
private ActionListener rowChangeListener = new ActionListener() { private ActionListener rowChangeListener = new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
@ -233,7 +236,7 @@ public class ReportColumnsPane extends BasicPane{
} }
} }
}; };
private ActionListener colChangeListener = new ActionListener() { private ActionListener colChangeListener = new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
@ -275,7 +278,7 @@ public class ReportColumnsPane extends BasicPane{
RowMaxOrSetPane.add(setRowRadioPane); RowMaxOrSetPane.add(setRowRadioPane);
return RowMaxOrSetPane; return RowMaxOrSetPane;
} }
private ActionListener toXBtnListener = new ActionListener() { private ActionListener toXBtnListener = new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
@ -288,7 +291,7 @@ public class ReportColumnsPane extends BasicPane{
} }
} }
}; };
private ActionListener maxBtnListener = new ActionListener() { private ActionListener maxBtnListener = new ActionListener() {
@Override @Override
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
@ -310,27 +313,39 @@ public class ReportColumnsPane extends BasicPane{
UITitledBorder explainBorder = UITitledBorder.createBorderWithTitle(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Column_Area")); UITitledBorder explainBorder = UITitledBorder.createBorderWithTitle(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Column_Area"));
rowPane.setBorder(explainBorder); rowPane.setBorder(explainBorder);
rowPane.setLayout(new FlowLayout(FlowLayout.LEFT, 5,13)); rowPane.setLayout(new FlowLayout(FlowLayout.LEFT, 5,13));
rowPane.setPreferredSize(new Dimension(500,80)); // Yvan: REPORT-37398 判断设计器语言是否为英文
rowPane.add(new UILabel(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Column_Data") + ":")); if (StringUtils.equals(GeneralContext.getLocale().getLanguage(), LOCALE_LANGUAGE_EN)) {
// 如果是英文,需要为这个panel设置更大的height,否则显示不全
rowPane.setPreferredSize(new Dimension(500,135));
} else {
// 其它语言环境下也需要将height调高一点点,因为后面将组件分块了,如果不调整height会造成上下间距不等
rowPane.setPreferredSize(new Dimension(500,90));
}
// 将组件分成两块,分别装在各自的JPanel中,然后把两个JPanel添加到rowPane中,第二个JPanel放不下时会自动换行
// 左边的JPanel:分栏数据
JPanel multiData = new JPanel();
multiData.add(new UILabel(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Column_Data") + ":"));
repeatColDataTextField = new UITextField(); repeatColDataTextField = new UITextField();
repeatColDataTextField.setPreferredSize(new Dimension(107,24)); repeatColDataTextField.setPreferredSize(new Dimension(107,24));
rowPane.add(repeatColDataTextField); multiData.add(repeatColDataTextField);
rowPane.add(new UILabel(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Base_Format") + ": A2:D5 ")); multiData.add(new UILabel(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Base_Format") + ": A2:D5 "));
// 右边的JPanel:复制行序列
JPanel copyRowSequence = new JPanel();
copyLabel = new UILabel(REPORT_COLUMN_RAPEAT[rowOrColumn] + ":"); copyLabel = new UILabel(REPORT_COLUMN_RAPEAT[rowOrColumn] + ":");
rowPane.add(copyLabel); copyRowSequence.add(copyLabel);
copyTitleTextField = new UITextField(); copyTitleTextField = new UITextField();
copyTitleTextField.setPreferredSize(new Dimension(107,24)); copyTitleTextField.setPreferredSize(new Dimension(107,24));
rowPane.add(copyTitleTextField); copyRowSequence.add(copyTitleTextField);
rowPane.add(new UILabel(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Base_Format") + ": 1,2-3,5,18")); copyRowSequence.add(new UILabel(com.fr.design.i18n.Toolkit.i18nText("Fine-Design_Report_Base_Format") + ": 1,2-3,5,18"));
// 添加JPanel
rowPane.add(multiData);
rowPane.add(copyRowSequence);
return rowPane; return rowPane;
} }
/** /**
* 从worksheetAttr中populate数据给界面 * 从worksheetAttr中populate数据给界面
* *
* @param attr 当前ElementCase的worksheet属性 * @param attr 当前ElementCase的worksheet属性
* @param rowCount 总行数 * @param rowCount 总行数
* @param colCount 总列数 * @param colCount 总列数
@ -355,7 +370,7 @@ public class ReportColumnsPane extends BasicPane{
colOrRowConvert(); colOrRowConvert();
checkEnable(); checkEnable();
} }
/** /**
* populate列分栏数据 * populate列分栏数据
*/ */
@ -376,7 +391,7 @@ public class ReportColumnsPane extends BasicPane{
this.maxNumberSpinner.setEnabled(true); this.maxNumberSpinner.setEnabled(true);
} }
} }
/** /**
* populate行分栏 * populate行分栏
*/ */
@ -400,7 +415,7 @@ public class ReportColumnsPane extends BasicPane{
/** /**
* 从worksheet中populate数据 * 从worksheet中populate数据
* *
* @param worksheet 当前worksheet * @param worksheet 当前worksheet
*/ */
public void populate(WorkSheet worksheet) { public void populate(WorkSheet worksheet) {
@ -422,11 +437,11 @@ public class ReportColumnsPane extends BasicPane{
private void setValueText(WorkSheetAttr attr, int rowCount, int colCount, UITextField repeatColDataTextField, private void setValueText(WorkSheetAttr attr, int rowCount, int colCount, UITextField repeatColDataTextField,
UITextField copyTitleTextField, UICheckBox showBlankCheckBox) { UITextField copyTitleTextField, UICheckBox showBlankCheckBox) {
int startRow,endRow = -1,startColumn,endColumn = -1; int startRow,endRow = -1,startColumn,endColumn = -1;
if(attr.getStartIndex() == -1 && attr.getEndIndex() == -1){ if(attr.getStartIndex() == -1 && attr.getEndIndex() == -1){
return; return;
} }
if (attr.getDirection() == ROW) { if (attr.getDirection() == ROW) {
startRow = attr.getStartIndex(); startRow = attr.getStartIndex();
endRow = attr.getEndIndex() == -1 ? rowCount - 1 : attr.getEndIndex(); endRow = attr.getEndIndex() == -1 ? rowCount - 1 : attr.getEndIndex();
@ -438,13 +453,13 @@ public class ReportColumnsPane extends BasicPane{
startColumn = attr.getStartIndex(); startColumn = attr.getStartIndex();
endColumn = attr.getEndIndex() == -1 ? colCount - 1 : attr.getEndIndex(); endColumn = attr.getEndIndex() == -1 ? colCount - 1 : attr.getEndIndex();
} }
repeatColDataTextField.setText(ColumnRow.valueOf(startColumn, startRow).toString() +":" repeatColDataTextField.setText(ColumnRow.valueOf(startColumn, startRow).toString() +":"
+ ColumnRow.valueOf(endColumn, endRow).toString()); + ColumnRow.valueOf(endColumn, endRow).toString());
copyTitleTextField.setText(attr.getIndexsToCopy()); copyTitleTextField.setText(attr.getIndexsToCopy());
showBlankCheckBox.setSelected(attr.isShowBlank()); showBlankCheckBox.setSelected(attr.isShowBlank());
} }
/** /**
* update行数据 * update行数据
*/ */
@ -463,7 +478,7 @@ public class ReportColumnsPane extends BasicPane{
} }
} }
} }
/** /**
* update列数据 * update列数据
*/ */
@ -482,7 +497,7 @@ public class ReportColumnsPane extends BasicPane{
} }
} }
} }
/** /**
* update数据给WorksheetAttr * update数据给WorksheetAttr
* *
@ -491,8 +506,8 @@ public class ReportColumnsPane extends BasicPane{
if (!isRepeate) { if (!isRepeate) {
attr.setDirection(Constants.NONE); attr.setDirection(Constants.NONE);
return; return;
} }
switch (rowOrColumn) { switch (rowOrColumn) {
case ROW: case ROW:
updateRow(attr); updateRow(attr);
@ -510,7 +525,7 @@ public class ReportColumnsPane extends BasicPane{
/** /**
* update数据给worksheet * update数据给worksheet
* *
* @param worksheet 当前worksheet * @param worksheet 当前worksheet
*/ */
public void update(WorkSheet worksheet) { public void update(WorkSheet worksheet) {
@ -527,7 +542,7 @@ public class ReportColumnsPane extends BasicPane{
/** /**
* 从界面中赋值给WorkSheetAttr * 从界面中赋值给WorkSheetAttr
* *
* @param attr 报表分栏属性 * @param attr 报表分栏属性
* @param repeatColDataTextField 从哪行开始复制 * @param repeatColDataTextField 从哪行开始复制
* @param copyTitleTextField 复制列序列 * @param copyTitleTextField 复制列序列
@ -560,7 +575,7 @@ public class ReportColumnsPane extends BasicPane{
attr.setIndexsToCopy(copyTitleTextField.getText()); attr.setIndexsToCopy(copyTitleTextField.getText());
attr.setShowBlank(showBlankCheckBox.isSelected()); attr.setShowBlank(showBlankCheckBox.isSelected());
} }
/** /**
* 判断输入是否合法 * 判断输入是否合法
@ -571,7 +586,7 @@ public class ReportColumnsPane extends BasicPane{
if(StringUtils.isEmpty(repeatText)){ if(StringUtils.isEmpty(repeatText)){
return; return;
} }
boolean valid = true; boolean valid = true;
if(!repeatText.matches("[a-zA-Z]+[0-9]+[:][a-zA-Z]+[0-9]+")){ if(!repeatText.matches("[a-zA-Z]+[0-9]+[:][a-zA-Z]+[0-9]+")){
valid = false; valid = false;

Loading…
Cancel
Save