|
|
|
@ -2,27 +2,40 @@ package com.fr.design.designer.properties;
|
|
|
|
|
|
|
|
|
|
import com.fr.design.beans.GroupModel; |
|
|
|
|
import com.fr.design.designer.creator.XWAbsoluteLayout; |
|
|
|
|
import com.fr.design.designer.creator.XWFitLayout; |
|
|
|
|
import com.fr.design.mainframe.FormDesigner; |
|
|
|
|
import com.fr.design.mainframe.FormSelectionUtils; |
|
|
|
|
import com.fr.design.mainframe.WidgetPropertyPane; |
|
|
|
|
import com.fr.design.mainframe.widget.editors.AbsoluteLayoutDirectionEditor; |
|
|
|
|
import com.fr.design.mainframe.widget.editors.IntegerPropertyEditor; |
|
|
|
|
import com.fr.design.mainframe.widget.editors.LayoutTypeEditor; |
|
|
|
|
import com.fr.design.mainframe.widget.editors.PropertyCellEditor; |
|
|
|
|
import com.fr.form.ui.Widget; |
|
|
|
|
import com.fr.form.ui.container.WAbsoluteLayout; |
|
|
|
|
import com.fr.form.ui.container.WBodyLayoutType; |
|
|
|
|
import com.fr.general.Inter; |
|
|
|
|
|
|
|
|
|
import javax.swing.table.DefaultTableCellRenderer; |
|
|
|
|
import javax.swing.table.TableCellEditor; |
|
|
|
|
import javax.swing.table.TableCellRenderer; |
|
|
|
|
import java.awt.*; |
|
|
|
|
import java.util.Arrays; |
|
|
|
|
import java.util.Comparator; |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* Created by zhouping on 2016/8/1. |
|
|
|
|
*/ |
|
|
|
|
public class FRAbsoluteLayoutPropertiesGroupModel implements GroupModel { |
|
|
|
|
|
|
|
|
|
private PropertyCellEditor editor; |
|
|
|
|
private DefaultTableCellRenderer renderer; |
|
|
|
|
private AbsoluteLayoutDirectionEditor stateEditor; |
|
|
|
|
private AbsoluteStateRenderer stateRenderer; |
|
|
|
|
private WAbsoluteLayout layout; |
|
|
|
|
private XWAbsoluteLayout xwAbsoluteLayout; |
|
|
|
|
private LayoutTypeEditor layoutTypeEditor; |
|
|
|
|
private LayoutTypeRenderer layoutTypeRenderer; |
|
|
|
|
//默认body是0,自适应布局;1,绝对布局.
|
|
|
|
|
private WBodyLayoutType layoutType = WBodyLayoutType.FIT; |
|
|
|
|
|
|
|
|
|
public FRAbsoluteLayoutPropertiesGroupModel(XWAbsoluteLayout xwAbsoluteLayout){ |
|
|
|
|
this.xwAbsoluteLayout = xwAbsoluteLayout; |
|
|
|
@ -33,31 +46,65 @@ public class FRAbsoluteLayoutPropertiesGroupModel implements GroupModel {
|
|
|
|
|
stateRenderer = new AbsoluteStateRenderer(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
public FRAbsoluteLayoutPropertiesGroupModel(XWAbsoluteLayout xwAbsoluteLayout, WBodyLayoutType layoutType){ |
|
|
|
|
this(xwAbsoluteLayout); |
|
|
|
|
this.layoutTypeEditor = new LayoutTypeEditor(); |
|
|
|
|
this.layoutTypeRenderer = new LayoutTypeRenderer(); |
|
|
|
|
this.layoutType = layoutType; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 布局管理器自己的属性 |
|
|
|
|
*/ |
|
|
|
|
@Override |
|
|
|
|
public String getGroupName() { |
|
|
|
|
return Inter.getLocText("FR-Designer-Widget_Area_Scaling"); |
|
|
|
|
return Inter.getLocText(layoutType == WBodyLayoutType.ABSOLUTE ? "FR-Designer_Attr_Layout" : "FR-Designer-Widget_Area_Scaling"); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
public int getRowCount() { |
|
|
|
|
return 1; |
|
|
|
|
return layoutType == WBodyLayoutType.ABSOLUTE ? 2 : 1; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
public TableCellRenderer getRenderer(int row) { |
|
|
|
|
if (layoutType == WBodyLayoutType.ABSOLUTE) { |
|
|
|
|
return row == 0 ? layoutTypeRenderer : stateRenderer; |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
return stateRenderer; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
public TableCellEditor getEditor(int row) { |
|
|
|
|
if (layoutType == WBodyLayoutType.ABSOLUTE) { |
|
|
|
|
return row == 0 ? layoutTypeEditor : stateEditor; |
|
|
|
|
} |
|
|
|
|
else{ |
|
|
|
|
return stateEditor; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
public Object getValue(int row, int column) { |
|
|
|
|
if (layoutType == WBodyLayoutType.ABSOLUTE){ |
|
|
|
|
if (column == 0) { |
|
|
|
|
switch (row) { |
|
|
|
|
case 0: |
|
|
|
|
return Inter.getLocText("FR-Designer_Attr_Layout_Type"); |
|
|
|
|
default: |
|
|
|
|
return Inter.getLocText("FR-Designer-Widget_Scaling_Mode"); |
|
|
|
|
} |
|
|
|
|
} else { |
|
|
|
|
switch (row) { |
|
|
|
|
case 0: |
|
|
|
|
return layoutType.getTypeValue(); |
|
|
|
|
default: |
|
|
|
|
return layout.getCompState(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
if (column == 0) { |
|
|
|
|
return Inter.getLocText("FR-Designer-Widget_Scaling_Mode"); |
|
|
|
|
} else { |
|
|
|
@ -67,6 +114,42 @@ public class FRAbsoluteLayoutPropertiesGroupModel implements GroupModel {
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
public boolean setValue(Object value, int row, int column) { |
|
|
|
|
if (layoutType == WBodyLayoutType.ABSOLUTE){ |
|
|
|
|
int state = 0; |
|
|
|
|
if(value instanceof Integer) { |
|
|
|
|
state = (Integer)value; |
|
|
|
|
} |
|
|
|
|
if (column == 0 || state < 0) { |
|
|
|
|
return false; |
|
|
|
|
} else { |
|
|
|
|
if (row == 0) { |
|
|
|
|
if (state == WBodyLayoutType.FIT.getTypeValue()) { |
|
|
|
|
XWFitLayout xfl = (XWFitLayout) xwAbsoluteLayout.getBackupParent(); |
|
|
|
|
Component[] components = xwAbsoluteLayout.getComponents(); |
|
|
|
|
|
|
|
|
|
Arrays.sort(components, new ComparatorComponentLocation()); |
|
|
|
|
|
|
|
|
|
xfl.getLayoutAdapter().removeBean(xwAbsoluteLayout, xwAbsoluteLayout.getWidth(), xwAbsoluteLayout.getHeight()); |
|
|
|
|
xfl.remove(xwAbsoluteLayout); |
|
|
|
|
xfl.toData().setLayoutType(WBodyLayoutType.FIT); |
|
|
|
|
|
|
|
|
|
for (Component comp : components) { |
|
|
|
|
xfl.add(comp); |
|
|
|
|
} |
|
|
|
|
moveComponents2FitLayout(xfl, components); |
|
|
|
|
FormDesigner formDesigner = WidgetPropertyPane.getInstance().getEditingFormDesigner(); |
|
|
|
|
formDesigner.getSelectionModel().setSelectedCreators( |
|
|
|
|
FormSelectionUtils.rebuildSelection(xfl, new Widget[]{xfl.toData()})); |
|
|
|
|
return true; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
if (row == 1) { |
|
|
|
|
layout.setCompState(state); |
|
|
|
|
return true; |
|
|
|
|
} |
|
|
|
|
return false; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
int state = 0; |
|
|
|
|
if(value instanceof Integer) { |
|
|
|
|
state = (Integer)value; |
|
|
|
@ -91,4 +174,95 @@ public class FRAbsoluteLayoutPropertiesGroupModel implements GroupModel {
|
|
|
|
|
public boolean isEditable(int row) { |
|
|
|
|
return true; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//把绝对布局中的元素按规则移动到自适应布局中
|
|
|
|
|
private void moveComponents2FitLayout(XWFitLayout xwFitLayout, Component[] components) { |
|
|
|
|
int eachRowCount = 4; |
|
|
|
|
if (components.length <= 1){ |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
int layoutWidth = xwFitLayout.getWidth() - xwFitLayout.toData().getMargin().getLeft() - xwFitLayout.toData().getMargin().getRight(); |
|
|
|
|
int layoutHeight = xwFitLayout.getHeight() - xwFitLayout.toData().getMargin().getTop() - xwFitLayout.toData().getMargin().getBottom(); |
|
|
|
|
int leftMargin = xwFitLayout.toData().getMargin().getLeft(); |
|
|
|
|
int topMargin = xwFitLayout.toData().getMargin().getTop(); |
|
|
|
|
int row = (components.length / eachRowCount) + (components.length % eachRowCount == 0 ? 0 : 1); |
|
|
|
|
//最后一行的列数不定
|
|
|
|
|
int column = components.length % eachRowCount; |
|
|
|
|
int componentWidth = layoutWidth / eachRowCount; |
|
|
|
|
int componentHeight = layoutHeight / row; |
|
|
|
|
for(int i = 0;i < row - 1;i++){ |
|
|
|
|
for(int j = 0;j < eachRowCount;j++){ |
|
|
|
|
components[eachRowCount * i + j].setBounds( |
|
|
|
|
leftMargin + componentWidth * j, |
|
|
|
|
topMargin + componentHeight * i, |
|
|
|
|
j == eachRowCount - 1 ? layoutWidth - componentWidth * (eachRowCount-1) : componentWidth, |
|
|
|
|
componentHeight |
|
|
|
|
); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
//最后一行列数是特殊的,要单独处理
|
|
|
|
|
int lastRowWidth = layoutWidth / column; |
|
|
|
|
int lastRowHeight = layoutHeight - componentHeight * (row - 1); |
|
|
|
|
for (int i = 0;i < column;i++) { |
|
|
|
|
components[eachRowCount * (row - 1) + i].setBounds( |
|
|
|
|
leftMargin + lastRowWidth * i, |
|
|
|
|
topMargin + componentHeight * (row - 1), |
|
|
|
|
i == column - 1 ? layoutWidth - lastRowWidth * (column-1) : lastRowWidth, |
|
|
|
|
lastRowHeight |
|
|
|
|
); |
|
|
|
|
} |
|
|
|
|
xwFitLayout.updateBoundsWidget(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
private class ComponentLocationInfo{ |
|
|
|
|
private Component component; |
|
|
|
|
private int horizontalNO; |
|
|
|
|
private int verticalNO; |
|
|
|
|
|
|
|
|
|
public ComponentLocationInfo(Component component, int horizontalNO, int verticalNO){ |
|
|
|
|
this.component = component; |
|
|
|
|
this.horizontalNO = horizontalNO; |
|
|
|
|
this.verticalNO = verticalNO; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
public int getHorizontalNO() { |
|
|
|
|
return this.horizontalNO; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
public int getVerticalNO() { |
|
|
|
|
return this.verticalNO; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
public void setHorizontalNO(int horizontalNO){ |
|
|
|
|
this.horizontalNO = horizontalNO; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
public void setVerticalNO(int verticalNO){ |
|
|
|
|
this.verticalNO = verticalNO; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//以组件的位置来确定先后顺序,y小的在前,x小的在前
|
|
|
|
|
private class ComparatorComponentLocation implements Comparator { |
|
|
|
|
@Override |
|
|
|
|
public int compare(Object o1, Object o2) { |
|
|
|
|
if(((Component)o1).getY() < ((Component)o2).getY()){ |
|
|
|
|
return -1; |
|
|
|
|
} |
|
|
|
|
else if (((Component)o1).getY() > ((Component)o2).getY()) { |
|
|
|
|
return 1; |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
if (((Component)o1).getX() < ((Component)o2).getX()){ |
|
|
|
|
return -1; |
|
|
|
|
} |
|
|
|
|
else if (((Component)o1).getX() > ((Component)o2).getX()) { |
|
|
|
|
return 1; |
|
|
|
|
} |
|
|
|
|
else{ |
|
|
|
|
return 0; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|