* commit 'ee78c63f92afe56ea6112748becef733305a637b': (72 commits) 国际化 无JIRA任务,国际化翻译更新 无JIRA任务,国际化翻译更新 REPORT-2626 移除国际化文件中的无效key REPORT-2626 移除国际化文件中的无效key 国际化修改 design部分第51-750个key的翻译修改 庄奇syoki 20170509 Signed-off-by: unknown <李晓丽> 国际化修改 design部分 1-50个 1901-结束部分key的翻译修改 20170508 庄奇syoki REPORT-2483 & REPORT-2484 国际化key转移;外文版的国际化文件和中文版不一致 无JIRA任务 新release合并遗漏 无任务,line separator REPORT-2537 无任务,冲突调整,release到dev 无JIRA任务,国际化,把release、master中的key合并到dev中 无JIRA任务,解决冲突 ct ct ct ct 1 ...master
@ -1,171 +1,176 @@
|
||||
package com.fr.design.actions.server; |
||||
|
||||
import com.fr.base.BaseUtils; |
||||
import com.fr.base.Env; |
||||
import com.fr.base.FRContext; |
||||
import com.fr.base.ModifiedTable; |
||||
import com.fr.data.impl.Connection; |
||||
import com.fr.dav.LocalEnv; |
||||
import com.fr.design.actions.UpdateAction; |
||||
import com.fr.design.data.datapane.connect.ConnectionManagerPane; |
||||
import com.fr.design.dialog.BasicDialog; |
||||
import com.fr.design.dialog.DialogActionAdapter; |
||||
import com.fr.design.mainframe.DesignerContext; |
||||
import com.fr.design.mainframe.DesignerFrame; |
||||
import com.fr.design.menu.MenuKeySet; |
||||
import com.fr.file.DatasourceManager; |
||||
import com.fr.file.DatasourceManagerProvider; |
||||
import com.fr.general.Inter; |
||||
|
||||
import javax.swing.*; |
||||
import java.awt.event.ActionEvent; |
||||
import java.util.HashMap; |
||||
|
||||
/** |
||||
* DatasourceList Action |
||||
*/ |
||||
public class ConnectionListAction extends UpdateAction { |
||||
private static final int BYTENUM = 1444; |
||||
|
||||
public ConnectionListAction() { |
||||
this.setMenuKeySet(DEFINE_DATA_CONNECTION); |
||||
this.setName(getMenuKeySet().getMenuKeySetName()); |
||||
this.setMnemonic(getMenuKeySet().getMnemonic()); |
||||
this.setSmallIcon(BaseUtils.readIcon("/com/fr/design/images/m_web/connection.png")); |
||||
} |
||||
|
||||
public static final MenuKeySet DEFINE_DATA_CONNECTION = new MenuKeySet() { |
||||
@Override |
||||
public char getMnemonic() { |
||||
return 'D'; |
||||
} |
||||
|
||||
@Override |
||||
public String getMenuName() { |
||||
return Inter.getLocText("Server-Define_Data_Connection"); |
||||
} |
||||
|
||||
@Override |
||||
public KeyStroke getKeyStroke() { |
||||
return null; |
||||
} |
||||
}; |
||||
|
||||
/** |
||||
* 执行动作 |
||||
* |
||||
* @param evt 事件 |
||||
*/ |
||||
public void actionPerformed(ActionEvent evt) { |
||||
DesignerFrame designerFrame = DesignerContext.getDesignerFrame(); |
||||
final DatasourceManagerProvider datasourceManager = DatasourceManager.getProviderInstance(); |
||||
final DatasourceManager backupManager = datasourceManager.getBackUpManager(); |
||||
final ConnectionManagerPane databaseManagerPane = new ConnectionManagerPane() { |
||||
public void complete() { |
||||
populate(datasourceManager); |
||||
} |
||||
|
||||
protected void renameConnection(String oldName, String newName) { |
||||
datasourceManager.getConnectionLocalModifyTable().rename(oldName, newName); |
||||
} |
||||
}; |
||||
final BasicDialog databaseListDialog = databaseManagerPane.showLargeWindow(designerFrame, null); |
||||
databaseListDialog.addDialogActionListener(new DialogActionAdapter() { |
||||
public void doOk() { |
||||
if (!databaseManagerPane.isNamePermitted()) { |
||||
databaseListDialog.setDoOKSucceed(false); |
||||
return; |
||||
} |
||||
if (!doWithDatasourceManager(datasourceManager, backupManager, databaseManagerPane, databaseListDialog)) { |
||||
//如果更新失败,则不关闭对话框,也不写xml文件,并且将对话框定位在请重命名的那个对象页面
|
||||
return; |
||||
} |
||||
// marks:保存数据
|
||||
writeFile(datasourceManager); |
||||
} |
||||
|
||||
public void doCancel() { |
||||
datasourceManager.synchronizedWithServer(); |
||||
} |
||||
}); |
||||
databaseListDialog.setVisible(true); |
||||
} |
||||
|
||||
|
||||
private void writeFile(DatasourceManagerProvider datasourceManager) { |
||||
Env currentEnv = FRContext.getCurrentEnv(); |
||||
try { |
||||
boolean isSuccess = currentEnv.writeResource(datasourceManager); |
||||
if (!isSuccess) { |
||||
throw new RuntimeException(Inter.getLocText("FR-Designer_Already_exist")); |
||||
} |
||||
} catch (Exception e) { |
||||
throw new RuntimeException(Inter.getLocText("FR-Designer_Already_exist")); |
||||
} |
||||
DesignerContext.getDesignerBean("databasename").refreshBeanElement(); |
||||
} |
||||
|
||||
/** |
||||
* 是否正常更新完datasourceManager |
||||
* |
||||
* @param datasourceManager |
||||
* @param databaseManagerPane |
||||
* @return |
||||
*/ |
||||
private boolean doWithDatasourceManager(DatasourceManagerProvider datasourceManager, DatasourceManager backupManager, |
||||
ConnectionManagerPane databaseManagerPane, BasicDialog databaseListDialog) { |
||||
databaseManagerPane.update(datasourceManager); |
||||
HashMap<String, Connection> modifyDetails = datasourceManager.getConnectionModifyDetails(); |
||||
modifyDetails.clear(); |
||||
Env currentEnv = FRContext.getCurrentEnv(); |
||||
ModifiedTable localModifiedTable = datasourceManager.checkConnectionModifyTable(backupManager, currentEnv.getUserID()); |
||||
boolean isFailed = false; |
||||
if (currentEnv.isSupportLocalFileOperate() && !((LocalEnv) currentEnv).isNoRemoteUser()) { |
||||
//如果是本地,并且有远程用户时则更新自己的修改表
|
||||
datasourceManager.updateSelfConnectionTotalModifiedTable(localModifiedTable, ModifiedTable.LOCAL_MODIFIER); |
||||
} else { |
||||
if (!currentEnv.isSupportLocalFileOperate()) { |
||||
//如果是远程,则去取服务器的最新的修改表,检查有没有冲突
|
||||
ModifiedTable currentServerModifyTable = currentEnv.getDataSourceModifiedTables(DatasourceManager.CONNECTION); |
||||
if (localModifiedTable.checkModifiedTableConflictWithServer(currentServerModifyTable, currentEnv.getUserID())) { |
||||
//有冲突,进行提示
|
||||
String title = Inter.getLocText(new String[]{"Select", "Single", "Setting"}); |
||||
int returnVal = JOptionPane.showConfirmDialog(DesignerContext.getDesignerFrame(), localModifiedTable.getWaringMessage(), title, JOptionPane.YES_NO_OPTION, JOptionPane.QUESTION_MESSAGE); |
||||
if (returnVal == JOptionPane.YES_OPTION) { |
||||
//点击是,进行相应刷新去冲突
|
||||
datasourceManager.synchronizedWithServer(backupManager, DatasourceManager.CONNECTION); |
||||
//要是有重命名冲突的,则对详细的修改表先进行修改
|
||||
datasourceManager.doWithConnectionConflict(localModifiedTable); |
||||
localModifiedTable.removeConfilct(); |
||||
modifyDetails.clear(); |
||||
//更新面板
|
||||
databaseManagerPane.populate(datasourceManager); |
||||
} else { |
||||
//更新失败,继续停留页面
|
||||
isFailed = true; |
||||
} |
||||
|
||||
} |
||||
} |
||||
} |
||||
//存在请重命名则不能更新
|
||||
int index = datasourceManager.isConnectionMapContainsRename(); |
||||
if (index != -1) { |
||||
isFailed = true; |
||||
databaseManagerPane.setSelectedIndex(index); |
||||
} |
||||
databaseListDialog.setDoOKSucceed(!isFailed); |
||||
//如果修改成功,则去远程端增量修改修改表
|
||||
if (!isFailed && !currentEnv.isSupportLocalFileOperate()) { |
||||
currentEnv.writeDataSourceModifiedTables(localModifiedTable, DatasourceManager.CONNECTION); |
||||
localModifiedTable.clear(); |
||||
modifyDetails.clear(); |
||||
} |
||||
return !isFailed; |
||||
} |
||||
|
||||
|
||||
public void update() { |
||||
this.setEnabled(true); |
||||
} |
||||
package com.fr.design.actions.server; |
||||
|
||||
import com.fr.base.BaseUtils; |
||||
import com.fr.base.Env; |
||||
import com.fr.base.FRContext; |
||||
import com.fr.base.ModifiedTable; |
||||
import com.fr.data.impl.Connection; |
||||
import com.fr.dav.LocalEnv; |
||||
import com.fr.design.actions.UpdateAction; |
||||
import com.fr.design.data.datapane.connect.ConnectionManagerPane; |
||||
import com.fr.design.data.datapane.connect.ConnectionShowPane; |
||||
import com.fr.design.dialog.BasicDialog; |
||||
import com.fr.design.dialog.DialogActionAdapter; |
||||
import com.fr.design.mainframe.DesignerContext; |
||||
import com.fr.design.mainframe.DesignerFrame; |
||||
import com.fr.design.menu.MenuKeySet; |
||||
import com.fr.file.DatasourceManager; |
||||
import com.fr.file.DatasourceManagerProvider; |
||||
import com.fr.general.Inter; |
||||
|
||||
import javax.swing.*; |
||||
import java.awt.event.ActionEvent; |
||||
import java.util.HashMap; |
||||
|
||||
/** |
||||
* DatasourceList Action |
||||
*/ |
||||
public class ConnectionListAction extends UpdateAction { |
||||
|
||||
public ConnectionListAction() { |
||||
this.setMenuKeySet(DEFINE_DATA_CONNECTION); |
||||
this.setName(getMenuKeySet().getMenuKeySetName()); |
||||
this.setMnemonic(getMenuKeySet().getMnemonic()); |
||||
this.setSmallIcon(BaseUtils.readIcon("/com/fr/design/images/m_web/connection.png")); |
||||
} |
||||
|
||||
public static final MenuKeySet DEFINE_DATA_CONNECTION = new MenuKeySet() { |
||||
@Override |
||||
public char getMnemonic() { |
||||
return 'D'; |
||||
} |
||||
|
||||
@Override |
||||
public String getMenuName() { |
||||
return Inter.getLocText("Server-Define_Data_Connection"); |
||||
} |
||||
|
||||
@Override |
||||
public KeyStroke getKeyStroke() { |
||||
return null; |
||||
} |
||||
}; |
||||
|
||||
/** |
||||
* 执行动作 |
||||
* |
||||
* @param evt 事件 |
||||
*/ |
||||
public void actionPerformed(ActionEvent evt) { |
||||
DesignerFrame designerFrame = DesignerContext.getDesignerFrame(); |
||||
final DatasourceManagerProvider datasourceManager = DatasourceManager.getProviderInstance(); |
||||
final DatasourceManager backupManager = datasourceManager.getBackUpManager(); |
||||
final ConnectionManagerPane databaseManagerPane = new ConnectionManagerPane() { |
||||
public void complete() { |
||||
populate(datasourceManager); |
||||
} |
||||
|
||||
protected void renameConnection(String oldName, String newName) { |
||||
datasourceManager.getConnectionLocalModifyTable().rename(oldName, newName); |
||||
} |
||||
}; |
||||
final BasicDialog databaseListDialog = databaseManagerPane.showLargeWindow(designerFrame, null); |
||||
databaseListDialog.addDialogActionListener(new DialogActionAdapter() { |
||||
public void doOk() { |
||||
if (!databaseManagerPane.isNamePermitted()) { |
||||
databaseListDialog.setDoOKSucceed(false); |
||||
return; |
||||
} |
||||
if (!doWithDatasourceManager(datasourceManager, backupManager, databaseManagerPane, databaseListDialog)) { |
||||
//如果更新失败,则不关闭对话框,也不写xml文件,并且将对话框定位在请重命名的那个对象页面
|
||||
return; |
||||
} |
||||
// marks:保存数据
|
||||
writeFile(datasourceManager); |
||||
} |
||||
|
||||
public void doCancel() { |
||||
datasourceManager.synchronizedWithServer(); |
||||
} |
||||
}); |
||||
databaseListDialog.setVisible(true); |
||||
} |
||||
|
||||
|
||||
/** |
||||
* @param datasourceManager |
||||
*/ |
||||
public static void writeFile(DatasourceManagerProvider datasourceManager) { |
||||
Env currentEnv = FRContext.getCurrentEnv(); |
||||
try { |
||||
boolean isSuccess = currentEnv.writeResource(datasourceManager); |
||||
if (!isSuccess) { |
||||
throw new RuntimeException(Inter.getLocText("FR-Designer_Already_exist")); |
||||
} |
||||
} catch (Exception e) { |
||||
throw new RuntimeException(Inter.getLocText("FR-Designer_Already_exist")); |
||||
} |
||||
DesignerContext.getDesignerBean("databasename").refreshBeanElement(); |
||||
} |
||||
|
||||
/** |
||||
* 更新datasourceManager |
||||
* |
||||
* @param datasourceManager datasource管理对象 |
||||
* @param backupManager datasource管理对象备份 |
||||
* @param connectionShowPane datasource面板 |
||||
* @param databaseListDialog datasource管理对话框 |
||||
* @return boolean 是否更新成功 |
||||
*/ |
||||
public static boolean doWithDatasourceManager(DatasourceManagerProvider datasourceManager, DatasourceManager |
||||
backupManager, ConnectionShowPane connectionShowPane, BasicDialog databaseListDialog) { |
||||
connectionShowPane.update(datasourceManager); |
||||
HashMap<String, Connection> modifyDetails = datasourceManager.getConnectionModifyDetails(); |
||||
modifyDetails.clear(); |
||||
Env currentEnv = FRContext.getCurrentEnv(); |
||||
ModifiedTable localModifiedTable = datasourceManager.checkConnectionModifyTable(backupManager, currentEnv.getUserID()); |
||||
boolean isFailed = false; |
||||
if (currentEnv.isSupportLocalFileOperate() && !((LocalEnv) currentEnv).isNoRemoteUser()) { |
||||
//如果是本地,并且有远程用户时则更新自己的修改表
|
||||
datasourceManager.updateSelfConnectionTotalModifiedTable(localModifiedTable, ModifiedTable.LOCAL_MODIFIER); |
||||
} else { |
||||
if (!currentEnv.isSupportLocalFileOperate()) { |
||||
//如果是远程,则去取服务器的最新的修改表,检查有没有冲突
|
||||
ModifiedTable currentServerModifyTable = currentEnv.getDataSourceModifiedTables(DatasourceManager.CONNECTION); |
||||
if (localModifiedTable.checkModifiedTableConflictWithServer(currentServerModifyTable, currentEnv.getUserID())) { |
||||
//有冲突,进行提示
|
||||
String title = Inter.getLocText(new String[]{"Select", "Single", "Setting"}); |
||||
int returnVal = JOptionPane.showConfirmDialog(DesignerContext.getDesignerFrame(), localModifiedTable.getWaringMessage(), title, JOptionPane.YES_NO_OPTION, JOptionPane.QUESTION_MESSAGE); |
||||
if (returnVal == JOptionPane.YES_OPTION) { |
||||
//点击是,进行相应刷新去冲突
|
||||
datasourceManager.synchronizedWithServer(backupManager, DatasourceManager.CONNECTION); |
||||
//要是有重命名冲突的,则对详细的修改表先进行修改
|
||||
datasourceManager.doWithConnectionConflict(localModifiedTable); |
||||
localModifiedTable.removeConfilct(); |
||||
modifyDetails.clear(); |
||||
//更新面板
|
||||
connectionShowPane.populate(datasourceManager); |
||||
} else { |
||||
//更新失败,继续停留页面
|
||||
isFailed = true; |
||||
} |
||||
|
||||
} |
||||
} |
||||
} |
||||
//存在请重命名则不能更新
|
||||
int index = datasourceManager.isConnectionMapContainsRename(); |
||||
if (index != -1) { |
||||
isFailed = true; |
||||
connectionShowPane.setSelectedIndex(index); |
||||
} |
||||
databaseListDialog.setDoOKSucceed(!isFailed); |
||||
//如果修改成功,则去远程端增量修改修改表
|
||||
if (!isFailed && !currentEnv.isSupportLocalFileOperate()) { |
||||
currentEnv.writeDataSourceModifiedTables(localModifiedTable, DatasourceManager.CONNECTION); |
||||
localModifiedTable.clear(); |
||||
modifyDetails.clear(); |
||||
} |
||||
return !isFailed; |
||||
} |
||||
|
||||
|
||||
public void update() { |
||||
this.setEnabled(true); |
||||
} |
||||
} |
@ -1,45 +0,0 @@
|
||||
package com.fr.design.beans.location; |
||||
|
||||
import com.fr.base.BaseUtils; |
||||
import com.fr.design.gui.ibutton.UIButton; |
||||
import com.fr.design.icon.IconPathConstants; |
||||
import com.fr.general.Inter; |
||||
|
||||
import javax.swing.*; |
||||
|
||||
/** |
||||
* Created by zhouping on 2016/7/24. |
||||
*/ |
||||
public class WidgetForbidWindow extends JWindow { |
||||
|
||||
private static final int WIDTH = 150; |
||||
private static final int HEIGHT = 20; |
||||
|
||||
private UIButton promptButton = new UIButton(Inter.getLocText("FR-Designer_Forbid_Widgets_Intersects"), BaseUtils.readIcon(IconPathConstants.FORBID_ICON_PATH)); |
||||
|
||||
/** |
||||
* 构造函数 |
||||
*/ |
||||
public WidgetForbidWindow() { |
||||
this.add(promptButton); |
||||
this.setSize(WIDTH, HEIGHT); |
||||
} |
||||
|
||||
/** |
||||
* 在指定位置显示窗口, 默认将window的中心点放到指定位置上 |
||||
* |
||||
* @param x x坐标 |
||||
* @param y y坐标 |
||||
*/ |
||||
public void showWindow(int x, int y) { |
||||
this.setLocation(x - WIDTH / 2, y - HEIGHT / 2); |
||||
this.setVisible(true); |
||||
} |
||||
|
||||
/** |
||||
* 隐藏当前窗口 |
||||
*/ |
||||
public void hideWindow() { |
||||
this.setVisible(false); |
||||
} |
||||
} |
@ -1,128 +1,140 @@
|
||||
package com.fr.design.data.datapane.connect; |
||||
|
||||
import com.fr.base.Env; |
||||
import com.fr.base.FRContext; |
||||
import com.fr.data.impl.AbstractDatabaseConnection; |
||||
import com.fr.data.impl.Connection; |
||||
import com.fr.data.impl.NameDatabaseConnection; |
||||
import com.fr.design.DesignerEnvManager; |
||||
import com.fr.design.dialog.BasicDialog; |
||||
import com.fr.design.dialog.DialogActionAdapter; |
||||
import com.fr.file.DatasourceManager; |
||||
import com.fr.file.DatasourceManagerProvider; |
||||
import com.fr.general.ComparatorUtils; |
||||
import com.fr.stable.StringUtils; |
||||
|
||||
import javax.swing.*; |
||||
import java.awt.event.ItemEvent; |
||||
import java.awt.event.ItemListener; |
||||
import java.util.ArrayList; |
||||
import java.util.List; |
||||
|
||||
/** |
||||
* 选择数据连接的下拉框 |
||||
* |
||||
* @editor zhou |
||||
* @since 2012-3-28下午3:02:30 |
||||
*/ |
||||
public class ConnectionComboBoxPanel extends ItemEditableComboBoxPanel { |
||||
/** |
||||
* |
||||
*/ |
||||
private static final long serialVersionUID = 1L; |
||||
private Class<? extends Connection> cls; // 所取的Connection都是cls及其子类
|
||||
private java.util.List<String> nameList = new ArrayList<String>(); |
||||
|
||||
public ConnectionComboBoxPanel(Class<? extends Connection> cls) { |
||||
super(); |
||||
|
||||
this.cls = cls; |
||||
|
||||
// alex:添加item change监听,当改变时改变DesignerEnvManager中的最近选中的数据连接
|
||||
this.itemComboBox.addItemListener(new ItemListener() { |
||||
public void itemStateChanged(ItemEvent e) { |
||||
String selected = ConnectionComboBoxPanel.this.getSelectedItem(); |
||||
if (StringUtils.isNotBlank(selected)) { |
||||
DesignerEnvManager.getEnvManager().setRecentSelectedConnection(selected); |
||||
} |
||||
} |
||||
}); |
||||
refreshItems(); |
||||
} |
||||
|
||||
/* |
||||
* 刷新ComboBox.items |
||||
*/ |
||||
protected java.util.Iterator<String> items() { |
||||
nameList = new ArrayList<String>(); |
||||
|
||||
DatasourceManagerProvider mgr = DatasourceManager.getProviderInstance(); |
||||
java.util.Iterator<String> nameIt = mgr.getConnectionNameIterator(); |
||||
while (nameIt.hasNext()) { |
||||
String conName = nameIt.next(); |
||||
Connection connection = mgr.getConnection(conName); |
||||
filterConnection(connection, conName, nameList); |
||||
} |
||||
|
||||
return nameList.iterator(); |
||||
} |
||||
|
||||
protected void filterConnection(Connection connection, String conName, List<String> nameList) { |
||||
connection.addConnection(nameList, conName, new Class[]{AbstractDatabaseConnection.class}); |
||||
} |
||||
|
||||
|
||||
public int getConnectionSize() { |
||||
return nameList.size(); |
||||
} |
||||
|
||||
public String getConnection(int i) { |
||||
return nameList.get(i); |
||||
} |
||||
|
||||
/* |
||||
* 弹出对话框编辑Items |
||||
*/ |
||||
protected void editItems() { |
||||
final ConnectionListPane connectionListPane = new ConnectionListPane(); |
||||
final DatasourceManagerProvider datasourceManager = DatasourceManager.getProviderInstance(); |
||||
connectionListPane.populate(datasourceManager); |
||||
BasicDialog connectionListDialog = connectionListPane.showLargeWindow( |
||||
SwingUtilities.getWindowAncestor(ConnectionComboBoxPanel.this), new DialogActionAdapter() { |
||||
public void doOk() { |
||||
connectionListPane.update(datasourceManager); |
||||
// marks:保存数据
|
||||
Env currentEnv = FRContext.getCurrentEnv(); |
||||
try { |
||||
currentEnv.writeResource(datasourceManager); |
||||
} catch (Exception ex) { |
||||
FRContext.getLogger().error(ex.getMessage(), ex); |
||||
} |
||||
} |
||||
}); |
||||
connectionListDialog.setVisible(true); |
||||
refreshItems(); |
||||
} |
||||
|
||||
public void populate(com.fr.data.impl.Connection connection) { |
||||
editButton.setEnabled(FRContext.getCurrentEnv().isRoot()); |
||||
if (connection instanceof NameDatabaseConnection) { |
||||
this.setSelectedItem(((NameDatabaseConnection) connection).getName()); |
||||
} else { |
||||
String s = DesignerEnvManager.getEnvManager().getRecentSelectedConnection(); |
||||
if (StringUtils.isNotBlank(s)) { |
||||
for (int i = 0; i < this.getConnectionSize(); i++) { |
||||
String t = this.getConnection(i); |
||||
if (ComparatorUtils.equals(s, t)) { |
||||
this.setSelectedItem(s); |
||||
break; |
||||
} |
||||
} |
||||
} |
||||
// alex:如果这个ComboBox还是没有选中,那么选中第一个
|
||||
if (StringUtils.isBlank(this.getSelectedItem()) && this.getConnectionSize() > 0) { |
||||
this.setSelectedItem(this.getConnection(0)); |
||||
} |
||||
} |
||||
} |
||||
package com.fr.design.data.datapane.connect; |
||||
|
||||
import com.fr.base.FRContext; |
||||
import com.fr.data.impl.AbstractDatabaseConnection; |
||||
import com.fr.data.impl.Connection; |
||||
import com.fr.data.impl.NameDatabaseConnection; |
||||
import com.fr.design.DesignerEnvManager; |
||||
import com.fr.design.actions.server.ConnectionListAction; |
||||
import com.fr.design.dialog.BasicDialog; |
||||
import com.fr.design.dialog.DialogActionAdapter; |
||||
import com.fr.file.DatasourceManager; |
||||
import com.fr.file.DatasourceManagerProvider; |
||||
import com.fr.general.ComparatorUtils; |
||||
import com.fr.stable.StringUtils; |
||||
|
||||
import javax.swing.*; |
||||
import java.awt.event.ItemEvent; |
||||
import java.awt.event.ItemListener; |
||||
import java.util.ArrayList; |
||||
import java.util.Iterator; |
||||
import java.util.List; |
||||
|
||||
/** |
||||
* 选择数据连接的下拉框 |
||||
* |
||||
* @editor zhou |
||||
* @since 2012-3-28下午3:02:30 |
||||
*/ |
||||
public class ConnectionComboBoxPanel extends ItemEditableComboBoxPanel { |
||||
/** |
||||
* |
||||
*/ |
||||
private static final long serialVersionUID = 1L; |
||||
private Class<? extends Connection> cls; // 所取的Connection都是cls及其子类
|
||||
private List<String> nameList = new ArrayList<String>(); |
||||
|
||||
public ConnectionComboBoxPanel(Class<? extends Connection> cls) { |
||||
super(); |
||||
|
||||
this.cls = cls; |
||||
|
||||
// alex:添加item change监听,当改变时改变DesignerEnvManager中的最近选中的数据连接
|
||||
this.itemComboBox.addItemListener(new ItemListener() { |
||||
public void itemStateChanged(ItemEvent e) { |
||||
String selected = ConnectionComboBoxPanel.this.getSelectedItem(); |
||||
if (StringUtils.isNotBlank(selected)) { |
||||
DesignerEnvManager.getEnvManager().setRecentSelectedConnection(selected); |
||||
} |
||||
} |
||||
}); |
||||
refreshItems(); |
||||
} |
||||
|
||||
/* |
||||
* 刷新ComboBox.items |
||||
*/ |
||||
protected Iterator<String> items() { |
||||
nameList = new ArrayList<String>(); |
||||
|
||||
DatasourceManagerProvider mgr = DatasourceManager.getProviderInstance(); |
||||
Iterator<String> nameIt = mgr.getConnectionNameIterator(); |
||||
while (nameIt.hasNext()) { |
||||
String conName = nameIt.next(); |
||||
Connection connection = mgr.getConnection(conName); |
||||
filterConnection(connection, conName, nameList); |
||||
} |
||||
|
||||
return nameList.iterator(); |
||||
} |
||||
|
||||
protected void filterConnection(Connection connection, String conName, List<String> nameList) { |
||||
connection.addConnection(nameList, conName, new Class[]{AbstractDatabaseConnection.class}); |
||||
} |
||||
|
||||
public int getConnectionSize() { |
||||
return nameList.size(); |
||||
} |
||||
|
||||
public String getConnection(int i) { |
||||
return nameList.get(i); |
||||
} |
||||
|
||||
/* |
||||
* 弹出对话框编辑Items |
||||
*/ |
||||
protected void editItems() { |
||||
final ConnectionListPane connectionListPane = new ConnectionListPane(); |
||||
final DatasourceManagerProvider datasourceManager = DatasourceManager.getProviderInstance(); |
||||
final DatasourceManager backupManager = datasourceManager.getBackUpManager(); |
||||
connectionListPane.populate(datasourceManager); |
||||
final BasicDialog connectionListDialog = connectionListPane.showLargeWindow( |
||||
SwingUtilities.getWindowAncestor(ConnectionComboBoxPanel.this), null); |
||||
connectionListDialog.addDialogActionListener(new DialogActionAdapter() { |
||||
public void doOk() { |
||||
if (!connectionListPane.isNamePermitted()) { |
||||
connectionListDialog.setDoOKSucceed(false); |
||||
return; |
||||
} |
||||
if (!ConnectionListAction.doWithDatasourceManager(datasourceManager, backupManager, connectionListPane, |
||||
connectionListDialog)) { |
||||
//如果更新失败,则不关闭对话框,也不写xml文件,并且将对话框定位在请重命名的那个对象页面
|
||||
return; |
||||
} |
||||
// marks:保存数据
|
||||
ConnectionListAction.writeFile(datasourceManager); |
||||
} |
||||
|
||||
public void doCancel() { |
||||
datasourceManager.synchronizedWithServer(); |
||||
} |
||||
}); |
||||
connectionListDialog.setVisible(true); |
||||
refreshItems(); |
||||
} |
||||
|
||||
/** |
||||
* @param connection 数据库链接 |
||||
*/ |
||||
public void populate(Connection connection) { |
||||
editButton.setEnabled(FRContext.getCurrentEnv().isRoot()); |
||||
if (connection instanceof NameDatabaseConnection) { |
||||
this.setSelectedItem(((NameDatabaseConnection) connection).getName()); |
||||
} else { |
||||
String s = DesignerEnvManager.getEnvManager().getRecentSelectedConnection(); |
||||
if (StringUtils.isNotBlank(s)) { |
||||
for (int i = 0; i < this.getConnectionSize(); i++) { |
||||
String t = this.getConnection(i); |
||||
if (ComparatorUtils.equals(s, t)) { |
||||
this.setSelectedItem(s); |
||||
break; |
||||
} |
||||
} |
||||
} |
||||
// alex:如果这个ComboBox还是没有选中,那么选中第一个
|
||||
if (StringUtils.isBlank(this.getSelectedItem()) && this.getConnectionSize() > 0) { |
||||
this.setSelectedItem(this.getConnection(0)); |
||||
} |
||||
} |
||||
} |
||||
} |
@ -1,163 +1,163 @@
|
||||
package com.fr.design.data.datapane.connect; |
||||
|
||||
import com.fr.data.impl.Connection; |
||||
import com.fr.data.impl.JDBCDatabaseConnection; |
||||
import com.fr.data.impl.JNDIDatabaseConnection; |
||||
import com.fr.design.ExtraDesignClassManager; |
||||
import com.fr.design.fun.ConnectionProvider; |
||||
import com.fr.design.gui.controlpane.JListControlPane; |
||||
import com.fr.design.gui.controlpane.NameObjectCreator; |
||||
import com.fr.design.gui.controlpane.NameableCreator; |
||||
import com.fr.file.DatasourceManagerProvider; |
||||
import com.fr.general.ComparatorUtils; |
||||
import com.fr.general.Inter; |
||||
import com.fr.general.NameObject; |
||||
import com.fr.stable.ArrayUtils; |
||||
import com.fr.stable.Nameable; |
||||
import com.fr.stable.StringUtils; |
||||
import com.fr.stable.core.PropertyChangeAdapter; |
||||
|
||||
import javax.swing.*; |
||||
import java.util.*; |
||||
|
||||
/** |
||||
* Connection List Pane. |
||||
*/ |
||||
public class ConnectionListPane extends JListControlPane { |
||||
public static final String TITLE_NAME = Inter.getLocText("Server-Define_Data_Connection"); |
||||
private boolean isNamePermitted = true; |
||||
private HashMap<String, String> renameMap = new HashMap<String, String>(); |
||||
|
||||
public ConnectionListPane() { |
||||
renameMap.clear(); |
||||
this.addEditingListner(new PropertyChangeAdapter() { |
||||
public void propertyChange() { |
||||
isNamePermitted = true; |
||||
String[] allListNames = nameableList.getAllNames(); |
||||
allListNames[nameableList.getSelectedIndex()] = StringUtils.EMPTY; |
||||
String tempName = getEditingName(); |
||||
if (StringUtils.isEmpty(tempName)) { |
||||
String[] warning = new String[]{"NOT_NULL_Des", "Please_Rename"}; |
||||
String[] sign = new String[]{",", "!"}; |
||||
nameableList.stopEditing(); |
||||
JOptionPane.showMessageDialog(SwingUtilities.getWindowAncestor(ConnectionListPane.this), Inter.getLocText(warning, sign)); |
||||
setWarnigText(editingIndex); |
||||
isNamePermitted = false; |
||||
return; |
||||
} |
||||
if (!ComparatorUtils.equals(tempName, selectedName) |
||||
&& isNameRepeted(new List[]{Arrays.asList(allListNames)}, tempName)) { |
||||
isNamePermitted = false; |
||||
nameableList.stopEditing(); |
||||
String message = Inter.getLocText(new String[]{"Utils-has_been_existed", "DashBoard-ConnectionList", "Please_Rename"}, new String[]{"", tempName + ",", "!"}); |
||||
JOptionPane.showMessageDialog(SwingUtilities.getWindowAncestor(ConnectionListPane.this), message); |
||||
setWarnigText(editingIndex); |
||||
} |
||||
if (isNamePermitted && !ComparatorUtils.equals(tempName, selectedName)) { |
||||
rename(selectedName, tempName); |
||||
} |
||||
|
||||
} |
||||
}); |
||||
} |
||||
|
||||
|
||||
protected void rename(String oldName, String newName) { |
||||
if (renameMap.containsKey(selectedName)) { |
||||
renameMap.remove(selectedName); |
||||
} |
||||
renameMap.put(selectedName, newName); |
||||
} |
||||
|
||||
/** |
||||
* 名字是否允许 |
||||
* |
||||
* @return 是/否 |
||||
*/ |
||||
public boolean isNamePermitted() { |
||||
return isNamePermitted; |
||||
} |
||||
|
||||
/** |
||||
* 检查按钮可用状态 Check button enabled. |
||||
*/ |
||||
public void checkButtonEnabled() { |
||||
super.checkButtonEnabled(); |
||||
isNamePermitted = !isContainsRename(); |
||||
} |
||||
|
||||
|
||||
public HashMap<String, String> getRenameMap() { |
||||
return renameMap; |
||||
} |
||||
|
||||
/** |
||||
* 创建菜单项 |
||||
* |
||||
* @return 菜单项 |
||||
*/ |
||||
public NameableCreator[] createNameableCreators() { |
||||
NameableCreator[] creators = new NameableCreator[]{new NameObjectCreator( |
||||
"JDBC", |
||||
"/com/fr/design/images/data/source/jdbcTableData.png", |
||||
JDBCDatabaseConnection.class, |
||||
DatabaseConnectionPane.JDBC.class |
||||
), new NameObjectCreator( |
||||
"JNDI", |
||||
"/com/fr/design/images/data/source/jdbcTableData.png", |
||||
JNDIDatabaseConnection.class, |
||||
DatabaseConnectionPane.JNDI.class |
||||
)}; |
||||
Set<ConnectionProvider> pluginCreators = ExtraDesignClassManager.getInstance().getArray(ConnectionProvider.XML_TAG); |
||||
for (ConnectionProvider provider : pluginCreators) { |
||||
NameObjectCreator creator = new NameObjectCreator( |
||||
provider.nameForConnection(), |
||||
provider.iconPathForConnection(), |
||||
provider.classForConnection(), |
||||
provider.appearanceForConnection() |
||||
); |
||||
creators = ArrayUtils.add(creators, creator); |
||||
} |
||||
|
||||
return creators; |
||||
} |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return TITLE_NAME; |
||||
} |
||||
|
||||
/** |
||||
* Populate. |
||||
* |
||||
* @param datasourceManager the new datasourceManager. |
||||
*/ |
||||
public void populate(DatasourceManagerProvider datasourceManager) { |
||||
Iterator<String> nameIt = datasourceManager.getConnectionNameIterator(); |
||||
|
||||
List<NameObject> nameObjectList = new ArrayList<NameObject>(); |
||||
while (nameIt.hasNext()) { |
||||
String name = nameIt.next(); |
||||
nameObjectList.add(new NameObject(name, datasourceManager.getConnection(name))); |
||||
} |
||||
this.populate(nameObjectList.toArray(new NameObject[nameObjectList.size()])); |
||||
|
||||
} |
||||
|
||||
/** |
||||
* Update. |
||||
*/ |
||||
public void update(DatasourceManagerProvider datasourceManager) { |
||||
// Nameable[]居然不能强转成NameObject[],一定要这么写...
|
||||
Nameable[] res = this.update(); |
||||
NameObject[] res_array = new NameObject[res.length]; |
||||
java.util.Arrays.asList(res).toArray(res_array); |
||||
|
||||
datasourceManager.clearAllConnection(); |
||||
|
||||
for (int i = 0; i < res_array.length; i++) { |
||||
NameObject nameObject = res_array[i]; |
||||
datasourceManager.putConnection(nameObject.getName(), (Connection) nameObject.getObject()); |
||||
} |
||||
} |
||||
package com.fr.design.data.datapane.connect; |
||||
|
||||
import com.fr.data.impl.Connection; |
||||
import com.fr.data.impl.JDBCDatabaseConnection; |
||||
import com.fr.data.impl.JNDIDatabaseConnection; |
||||
import com.fr.design.ExtraDesignClassManager; |
||||
import com.fr.design.fun.ConnectionProvider; |
||||
import com.fr.design.gui.controlpane.JListControlPane; |
||||
import com.fr.design.gui.controlpane.NameObjectCreator; |
||||
import com.fr.design.gui.controlpane.NameableCreator; |
||||
import com.fr.file.DatasourceManagerProvider; |
||||
import com.fr.general.ComparatorUtils; |
||||
import com.fr.general.Inter; |
||||
import com.fr.general.NameObject; |
||||
import com.fr.stable.ArrayUtils; |
||||
import com.fr.stable.Nameable; |
||||
import com.fr.stable.StringUtils; |
||||
import com.fr.stable.core.PropertyChangeAdapter; |
||||
|
||||
import javax.swing.*; |
||||
import java.util.*; |
||||
|
||||
/** |
||||
* Connection List Pane. |
||||
*/ |
||||
public class ConnectionListPane extends JListControlPane implements ConnectionShowPane { |
||||
public static final String TITLE_NAME = Inter.getLocText("Server-Define_Data_Connection"); |
||||
private boolean isNamePermitted = true; |
||||
private HashMap<String, String> renameMap = new HashMap<String, String>(); |
||||
|
||||
public ConnectionListPane() { |
||||
renameMap.clear(); |
||||
this.addEditingListner(new PropertyChangeAdapter() { |
||||
public void propertyChange() { |
||||
isNamePermitted = true; |
||||
String[] allListNames = nameableList.getAllNames(); |
||||
allListNames[nameableList.getSelectedIndex()] = StringUtils.EMPTY; |
||||
String tempName = getEditingName(); |
||||
if (StringUtils.isEmpty(tempName)) { |
||||
String[] warning = new String[]{"NOT_NULL_Des", "Please_Rename"}; |
||||
String[] sign = new String[]{",", "!"}; |
||||
nameableList.stopEditing(); |
||||
JOptionPane.showMessageDialog(SwingUtilities.getWindowAncestor(ConnectionListPane.this), Inter.getLocText(warning, sign)); |
||||
setWarnigText(editingIndex); |
||||
isNamePermitted = false; |
||||
return; |
||||
} |
||||
if (!ComparatorUtils.equals(tempName, selectedName) |
||||
&& isNameRepeted(new List[]{Arrays.asList(allListNames)}, tempName)) { |
||||
isNamePermitted = false; |
||||
nameableList.stopEditing(); |
||||
String message = Inter.getLocText(new String[]{"Utils-has_been_existed", "DashBoard-ConnectionList", "Please_Rename"}, new String[]{"", tempName + ",", "!"}); |
||||
JOptionPane.showMessageDialog(SwingUtilities.getWindowAncestor(ConnectionListPane.this), message); |
||||
setWarnigText(editingIndex); |
||||
} |
||||
if (isNamePermitted && !ComparatorUtils.equals(tempName, selectedName)) { |
||||
rename(selectedName, tempName); |
||||
} |
||||
|
||||
} |
||||
}); |
||||
} |
||||
|
||||
|
||||
protected void rename(String oldName, String newName) { |
||||
if (renameMap.containsKey(selectedName)) { |
||||
renameMap.remove(selectedName); |
||||
} |
||||
renameMap.put(selectedName, newName); |
||||
} |
||||
|
||||
/** |
||||
* 名字是否允许 |
||||
* |
||||
* @return 是/否 |
||||
*/ |
||||
public boolean isNamePermitted() { |
||||
return isNamePermitted; |
||||
} |
||||
|
||||
/** |
||||
* 检查按钮可用状态 Check button enabled. |
||||
*/ |
||||
public void checkButtonEnabled() { |
||||
super.checkButtonEnabled(); |
||||
isNamePermitted = !isContainsRename(); |
||||
} |
||||
|
||||
|
||||
public HashMap<String, String> getRenameMap() { |
||||
return renameMap; |
||||
} |
||||
|
||||
/** |
||||
* 创建菜单项 |
||||
* |
||||
* @return 菜单项 |
||||
*/ |
||||
public NameableCreator[] createNameableCreators() { |
||||
NameableCreator[] creators = new NameableCreator[]{new NameObjectCreator( |
||||
"JDBC", |
||||
"/com/fr/design/images/data/source/jdbcTableData.png", |
||||
JDBCDatabaseConnection.class, |
||||
DatabaseConnectionPane.JDBC.class |
||||
), new NameObjectCreator( |
||||
"JNDI", |
||||
"/com/fr/design/images/data/source/jdbcTableData.png", |
||||
JNDIDatabaseConnection.class, |
||||
DatabaseConnectionPane.JNDI.class |
||||
)}; |
||||
Set<ConnectionProvider> pluginCreators = ExtraDesignClassManager.getInstance().getArray(ConnectionProvider.XML_TAG); |
||||
for (ConnectionProvider provider : pluginCreators) { |
||||
NameObjectCreator creator = new NameObjectCreator( |
||||
provider.nameForConnection(), |
||||
provider.iconPathForConnection(), |
||||
provider.classForConnection(), |
||||
provider.appearanceForConnection() |
||||
); |
||||
creators = ArrayUtils.add(creators, creator); |
||||
} |
||||
|
||||
return creators; |
||||
} |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return TITLE_NAME; |
||||
} |
||||
|
||||
/** |
||||
* Populate. |
||||
* |
||||
* @param datasourceManager the new datasourceManager. |
||||
*/ |
||||
public void populate(DatasourceManagerProvider datasourceManager) { |
||||
Iterator<String> nameIt = datasourceManager.getConnectionNameIterator(); |
||||
|
||||
List<NameObject> nameObjectList = new ArrayList<NameObject>(); |
||||
while (nameIt.hasNext()) { |
||||
String name = nameIt.next(); |
||||
nameObjectList.add(new NameObject(name, datasourceManager.getConnection(name))); |
||||
} |
||||
this.populate(nameObjectList.toArray(new NameObject[nameObjectList.size()])); |
||||
|
||||
} |
||||
|
||||
/** |
||||
* Update. |
||||
*/ |
||||
public void update(DatasourceManagerProvider datasourceManager) { |
||||
// Nameable[]居然不能强转成NameObject[],一定要这么写...
|
||||
Nameable[] res = this.update(); |
||||
NameObject[] res_array = new NameObject[res.length]; |
||||
java.util.Arrays.asList(res).toArray(res_array); |
||||
|
||||
datasourceManager.clearAllConnection(); |
||||
|
||||
for (int i = 0; i < res_array.length; i++) { |
||||
NameObject nameObject = res_array[i]; |
||||
datasourceManager.putConnection(nameObject.getName(), (Connection) nameObject.getObject()); |
||||
} |
||||
} |
||||
} |
@ -1,78 +1,79 @@
|
||||
package com.fr.design.data.datapane.connect; |
||||
|
||||
import com.fr.base.FRContext; |
||||
import com.fr.design.gui.frpane.LoadingBasicPane; |
||||
import com.fr.design.gui.ilable.UILabel; |
||||
import com.fr.design.gui.itextfield.UITextField; |
||||
import com.fr.design.layout.FRGUIPaneFactory; |
||||
import com.fr.file.DatasourceManagerProvider; |
||||
import com.fr.general.Inter; |
||||
import com.fr.stable.project.ProjectConstants; |
||||
|
||||
import javax.swing.*; |
||||
import java.awt.*; |
||||
import java.io.File; |
||||
import java.util.HashMap; |
||||
|
||||
public class ConnectionManagerPane extends LoadingBasicPane { |
||||
private UITextField connectionTextField; |
||||
private ConnectionListPane connectionListPane; |
||||
|
||||
protected void initComponents(JPanel container) { |
||||
container.setLayout(FRGUIPaneFactory.createBorderLayout()); |
||||
|
||||
JPanel connectionPathPane = FRGUIPaneFactory.createBorderLayout_L_Pane(); |
||||
container.add(connectionPathPane, BorderLayout.NORTH); |
||||
|
||||
connectionPathPane.setBorder(BorderFactory.createEmptyBorder(6, 2, 2, 2)); |
||||
|
||||
connectionPathPane.add(new UILabel(Inter.getLocText("FR-Designer_Save_Path") + ":"), BorderLayout.WEST); |
||||
this.connectionTextField = new UITextField(); |
||||
connectionPathPane.add(connectionTextField, BorderLayout.CENTER); |
||||
this.connectionTextField.setEditable(false); |
||||
connectionListPane = new ConnectionListPane(){ |
||||
protected void rename(String oldName,String newName) { |
||||
super.rename(oldName,newName); |
||||
renameConnection(oldName,newName); |
||||
} |
||||
}; |
||||
container.add(connectionListPane, BorderLayout.CENTER); |
||||
} |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return Inter.getLocText("Server-Define_Data_Connection"); |
||||
} |
||||
|
||||
public HashMap<String, String> getRenameMap() { |
||||
return connectionListPane.getRenameMap(); |
||||
} |
||||
|
||||
public void populate(DatasourceManagerProvider datasourceManager) { |
||||
this.connectionTextField.setText(FRContext.getCurrentEnv().getPath() + File.separator + ProjectConstants.RESOURCES_NAME |
||||
+ File.separator + datasourceManager.fileName()); |
||||
this.connectionListPane.populate(datasourceManager); |
||||
} |
||||
|
||||
public void update(DatasourceManagerProvider datasourceManager) { |
||||
this.connectionListPane.update(datasourceManager); |
||||
} |
||||
|
||||
/** |
||||
* 设置选中项 |
||||
* |
||||
* @param index 选中项的序列号 |
||||
*/ |
||||
public void setSelectedIndex(int index) { |
||||
this.connectionListPane.setSelectedIndex(index); |
||||
} |
||||
|
||||
/** |
||||
* 名字是否允许 |
||||
* @return 允许返回true |
||||
*/ |
||||
public boolean isNamePermitted() { |
||||
return connectionListPane.isNamePermitted(); |
||||
} |
||||
|
||||
package com.fr.design.data.datapane.connect; |
||||
|
||||
import com.fr.base.FRContext; |
||||
import com.fr.design.gui.frpane.LoadingBasicPane; |
||||
import com.fr.design.gui.ilable.UILabel; |
||||
import com.fr.design.gui.itextfield.UITextField; |
||||
import com.fr.design.layout.FRGUIPaneFactory; |
||||
import com.fr.file.DatasourceManagerProvider; |
||||
import com.fr.general.Inter; |
||||
import com.fr.stable.project.ProjectConstants; |
||||
|
||||
import javax.swing.*; |
||||
import java.awt.*; |
||||
import java.io.File; |
||||
import java.util.HashMap; |
||||
|
||||
public class ConnectionManagerPane extends LoadingBasicPane implements ConnectionShowPane { |
||||
private UITextField connectionTextField; |
||||
private ConnectionListPane connectionListPane; |
||||
|
||||
protected void initComponents(JPanel container) { |
||||
container.setLayout(FRGUIPaneFactory.createBorderLayout()); |
||||
|
||||
JPanel connectionPathPane = FRGUIPaneFactory.createBorderLayout_L_Pane(); |
||||
container.add(connectionPathPane, BorderLayout.NORTH); |
||||
|
||||
connectionPathPane.setBorder(BorderFactory.createEmptyBorder(6, 2, 2, 2)); |
||||
|
||||
connectionPathPane.add(new UILabel(Inter.getLocText("FR-Designer_Save_Path") + ":"), BorderLayout.WEST); |
||||
this.connectionTextField = new UITextField(); |
||||
connectionPathPane.add(connectionTextField, BorderLayout.CENTER); |
||||
this.connectionTextField.setEditable(false); |
||||
connectionListPane = new ConnectionListPane() { |
||||
protected void rename(String oldName, String newName) { |
||||
super.rename(oldName, newName); |
||||
renameConnection(oldName, newName); |
||||
} |
||||
}; |
||||
container.add(connectionListPane, BorderLayout.CENTER); |
||||
} |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return Inter.getLocText("Server-Define_Data_Connection"); |
||||
} |
||||
|
||||
public HashMap<String, String> getRenameMap() { |
||||
return connectionListPane.getRenameMap(); |
||||
} |
||||
|
||||
public void populate(DatasourceManagerProvider datasourceManager) { |
||||
this.connectionTextField.setText(FRContext.getCurrentEnv().getPath() + File.separator + ProjectConstants.RESOURCES_NAME |
||||
+ File.separator + datasourceManager.fileName()); |
||||
this.connectionListPane.populate(datasourceManager); |
||||
} |
||||
|
||||
public void update(DatasourceManagerProvider datasourceManager) { |
||||
this.connectionListPane.update(datasourceManager); |
||||
} |
||||
|
||||
/** |
||||
* 设置选中项 |
||||
* |
||||
* @param index 选中项的序列号 |
||||
*/ |
||||
public void setSelectedIndex(int index) { |
||||
this.connectionListPane.setSelectedIndex(index); |
||||
} |
||||
|
||||
/** |
||||
* 名字是否允许 |
||||
* |
||||
* @return 允许返回true |
||||
*/ |
||||
public boolean isNamePermitted() { |
||||
return connectionListPane.isNamePermitted(); |
||||
} |
||||
|
||||
} |
@ -0,0 +1,15 @@
|
||||
package com.fr.design.data.datapane.connect; |
||||
|
||||
import com.fr.file.DatasourceManagerProvider; |
||||
|
||||
/** |
||||
* Created by yaoh.wu on 2017/4/22. |
||||
* 数据链接显示面板 |
||||
*/ |
||||
public interface ConnectionShowPane { |
||||
void update(DatasourceManagerProvider datasourceManager); |
||||
|
||||
void populate(DatasourceManagerProvider datasourceManager); |
||||
|
||||
void setSelectedIndex(int index); |
||||
} |
After Width: | Height: | Size: 248 B |
After Width: | Height: | Size: 250 B |
After Width: | Height: | Size: 264 B |
After Width: | Height: | Size: 264 B |
After Width: | Height: | Size: 265 B |
After Width: | Height: | Size: 257 B |
After Width: | Height: | Size: 272 B |
After Width: | Height: | Size: 273 B |
@ -1,112 +1,104 @@
|
||||
package com.fr.design.style.color; |
||||
|
||||
import java.awt.BorderLayout; |
||||
import java.awt.Color; |
||||
import java.awt.Dimension; |
||||
import com.fr.design.dialog.BasicPane; |
||||
import com.fr.design.layout.FRGUIPaneFactory; |
||||
import com.fr.general.Inter; |
||||
|
||||
import javax.swing.JColorChooser; |
||||
import javax.swing.JPanel; |
||||
import javax.swing.*; |
||||
import javax.swing.colorchooser.AbstractColorChooserPanel; |
||||
import javax.swing.colorchooser.ColorSelectionModel; |
||||
import javax.swing.event.ChangeEvent; |
||||
import javax.swing.event.ChangeListener; |
||||
|
||||
import com.fr.design.dialog.BasicPane; |
||||
import com.fr.design.layout.FRGUIPaneFactory; |
||||
import com.fr.general.Inter; |
||||
import java.awt.*; |
||||
|
||||
/** |
||||
* 颜色选择器更多颜色面板 |
||||
* @author focus |
||||
* |
||||
* @author focus |
||||
*/ |
||||
public class ColorSelectDetailPane extends BasicPane{ |
||||
private static final int SELECT_PANEL_HEIGHT = 245; |
||||
// Selected color
|
||||
private Color color; |
||||
|
||||
// 颜色选择器面板
|
||||
JColorChooser selectedPanel; |
||||
|
||||
// 最近使用颜色面板
|
||||
JPanel recentUsePanel; |
||||
|
||||
// 预览
|
||||
JPanel previewPanel; |
||||
|
||||
public JColorChooser getSelectedPanel() { |
||||
return selectedPanel; |
||||
} |
||||
|
||||
public void setSelectedPanel(JColorChooser selectedPanel) { |
||||
this.selectedPanel = selectedPanel; |
||||
} |
||||
|
||||
public Color getColor() { |
||||
return color; |
||||
} |
||||
|
||||
public void setColor(Color color) { |
||||
this.color = color; |
||||
} |
||||
|
||||
public ColorSelectDetailPane() { |
||||
super(); |
||||
} |
||||
|
||||
public ColorSelectDetailPane(Color color){ |
||||
if(color == null){ |
||||
color = Color.white; |
||||
} |
||||
this.color = color; |
||||
initComponents(); |
||||
} |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return null; |
||||
} |
||||
|
||||
protected void initComponents() { |
||||
this.setLayout(FRGUIPaneFactory.createBorderLayout()); |
||||
|
||||
// 颜色选择器面板
|
||||
selectedPanel = new JColorChooser(this.color); |
||||
selectedPanel.setPreferredSize(new Dimension(selectedPanel.getWidth(),SELECT_PANEL_HEIGHT)); |
||||
AbstractColorChooserPanel[] choosers = selectedPanel.getChooserPanels(); |
||||
for(int i=0;i<choosers.length;i++){ |
||||
selectedPanel.removeChooserPanel(choosers[i]); |
||||
} |
||||
selectedPanel.setPreviewPanel(new JPanel()); |
||||
|
||||
AbstractColorChooserPanel swatchChooserPanel = new SwatchChooserPanel(); |
||||
AbstractColorChooserPanel customChooserPanel = new CustomChooserPanel(); |
||||
selectedPanel.addChooserPanel(swatchChooserPanel); |
||||
selectedPanel.addChooserPanel(customChooserPanel); |
||||
this.add(selectedPanel, BorderLayout.NORTH); |
||||
|
||||
// 最近使用面板
|
||||
recentUsePanel = FRGUIPaneFactory.createTitledBorderPane(Inter.getLocText("FR-Designer_Used")); |
||||
RecentUseColorPane recent = new RecentUseColorPane(selectedPanel); |
||||
recentUsePanel.add(recent); |
||||
|
||||
this.add(recentUsePanel,BorderLayout.CENTER); |
||||
|
||||
selectedPanel.setPreviewPanel(new JPanel()); |
||||
|
||||
// 预览
|
||||
previewPanel = FRGUIPaneFactory.createTitledBorderPaneCenter(Inter.getLocText("FR-Designer_Preview")); |
||||
final ColorChooserPreview colorChooserPreview = new ColorChooserPreview(); |
||||
ColorSelectionModel model = selectedPanel.getSelectionModel(); |
||||
model.addChangeListener(new ChangeListener() { |
||||
@Override |
||||
public void stateChanged(ChangeEvent e) { |
||||
ColorSelectionModel model = (ColorSelectionModel) e.getSource(); |
||||
colorChooserPreview.setMyColor(model.getSelectedColor()); |
||||
colorChooserPreview.paint(colorChooserPreview.getGraphics()); |
||||
} |
||||
}); |
||||
previewPanel.add(colorChooserPreview); |
||||
this.add(previewPanel, BorderLayout.SOUTH); |
||||
} |
||||
public class ColorSelectDetailPane extends BasicPane { |
||||
private static final int SELECT_PANEL_HEIGHT = 245; |
||||
// Selected color
|
||||
private Color color; |
||||
|
||||
// 颜色选择器面板
|
||||
private JColorChooser selectedPanel; |
||||
|
||||
// 最近使用颜色面板
|
||||
private JPanel recentUsePanel; |
||||
|
||||
// 预览
|
||||
private JPanel previewPanel; |
||||
|
||||
public JColorChooser getSelectedPanel() { |
||||
return selectedPanel; |
||||
} |
||||
|
||||
public void setSelectedPanel(JColorChooser selectedPanel) { |
||||
this.selectedPanel = selectedPanel; |
||||
} |
||||
|
||||
public Color getColor() { |
||||
return color; |
||||
} |
||||
|
||||
public void setColor(Color color) { |
||||
this.color = color; |
||||
} |
||||
|
||||
public ColorSelectDetailPane(Color color) { |
||||
if (color == null) { |
||||
color = Color.white; |
||||
} |
||||
this.color = color; |
||||
initComponents(); |
||||
} |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return null; |
||||
} |
||||
|
||||
protected void initComponents() { |
||||
this.setLayout(FRGUIPaneFactory.createBorderLayout()); |
||||
|
||||
// 颜色选择器面板
|
||||
selectedPanel = new JColorChooser(this.color); |
||||
selectedPanel.setPreferredSize(new Dimension(selectedPanel.getWidth(), SELECT_PANEL_HEIGHT)); |
||||
AbstractColorChooserPanel[] choosers = selectedPanel.getChooserPanels(); |
||||
for (int i = 0; i < choosers.length; i++) { |
||||
selectedPanel.removeChooserPanel(choosers[i]); |
||||
} |
||||
selectedPanel.setPreviewPanel(new JPanel()); |
||||
|
||||
AbstractColorChooserPanel swatchChooserPanel = new SwatchChooserPanel(); |
||||
AbstractColorChooserPanel customChooserPanel = new CustomChooserPanel(); |
||||
selectedPanel.addChooserPanel(swatchChooserPanel); |
||||
selectedPanel.addChooserPanel(customChooserPanel); |
||||
this.add(selectedPanel, BorderLayout.NORTH); |
||||
|
||||
// 最近使用面板
|
||||
recentUsePanel = FRGUIPaneFactory.createTitledBorderPane(Inter.getLocText("FR-Designer_Used")); |
||||
RecentUseColorPane recent = new RecentUseColorPane(selectedPanel); |
||||
recentUsePanel.add(recent); |
||||
|
||||
this.add(recentUsePanel, BorderLayout.CENTER); |
||||
|
||||
selectedPanel.setPreviewPanel(new JPanel()); |
||||
|
||||
// 预览
|
||||
previewPanel = FRGUIPaneFactory.createTitledBorderPaneCenter(Inter.getLocText("FR-Designer_Preview")); |
||||
final ColorChooserPreview colorChooserPreview = new ColorChooserPreview(); |
||||
ColorSelectionModel model = selectedPanel.getSelectionModel(); |
||||
model.addChangeListener(new ChangeListener() { |
||||
@Override |
||||
public void stateChanged(ChangeEvent e) { |
||||
ColorSelectionModel model = (ColorSelectionModel) e.getSource(); |
||||
colorChooserPreview.setMyColor(model.getSelectedColor()); |
||||
colorChooserPreview.paint(colorChooserPreview.getGraphics()); |
||||
} |
||||
}); |
||||
previewPanel.add(colorChooserPreview); |
||||
this.add(previewPanel, BorderLayout.SOUTH); |
||||
} |
||||
} |
@ -1,215 +1,205 @@
|
||||
package com.fr.design.style.color; |
||||
|
||||
import java.awt.BorderLayout; |
||||
import java.awt.Color; |
||||
import java.awt.Cursor; |
||||
import java.awt.Dimension; |
||||
import java.awt.GridLayout; |
||||
import java.awt.event.ActionEvent; |
||||
import java.awt.event.ActionListener; |
||||
import java.awt.event.MouseAdapter; |
||||
import java.awt.event.MouseEvent; |
||||
import java.util.ArrayList; |
||||
|
||||
import javax.swing.BorderFactory; |
||||
import javax.swing.Box; |
||||
import javax.swing.JPanel; |
||||
import javax.swing.event.ChangeEvent; |
||||
import javax.swing.event.ChangeListener; |
||||
|
||||
import com.fr.design.constants.UIConstants; |
||||
import com.fr.design.border.UIRoundedBorder; |
||||
import com.fr.design.constants.UIConstants; |
||||
import com.fr.design.dialog.BasicPane; |
||||
import com.fr.design.gui.ibutton.UIButton; |
||||
import com.fr.design.layout.FRGUIPaneFactory; |
||||
import com.fr.design.mainframe.DesignerContext; |
||||
import com.fr.design.dialog.BasicPane; |
||||
import com.fr.general.Inter; |
||||
|
||||
import javax.swing.*; |
||||
import javax.swing.event.ChangeEvent; |
||||
import javax.swing.event.ChangeListener; |
||||
import java.awt.*; |
||||
import java.awt.event.ActionEvent; |
||||
import java.awt.event.ActionListener; |
||||
import java.awt.event.MouseAdapter; |
||||
import java.awt.event.MouseEvent; |
||||
import java.util.ArrayList; |
||||
|
||||
|
||||
/** |
||||
* |
||||
* @author zhou |
||||
* @since 2012-5-29上午10:39:35 |
||||
*/ |
||||
public class NewColorSelectPane extends BasicPane implements ColorSelectable { |
||||
private static final long serialVersionUID = -8634152305687249392L; |
||||
|
||||
private Color color = null; // color
|
||||
// color setting action.
|
||||
private ArrayList<ChangeListener> colorChangeListenerList = new ArrayList<ChangeListener>(); |
||||
|
||||
// 颜色选择器
|
||||
private ColorSelectDetailPane pane; |
||||
// 是否支持透明
|
||||
private boolean isSupportTransparent; |
||||
|
||||
private final static int TRANSPANENT_WINDOW_HEIGHT = 165; |
||||
private final static int WINDWO_HEIGHT = 150; |
||||
|
||||
// 最近使用颜色
|
||||
UsedColorPane usedColorPane; |
||||
|
||||
/** |
||||
* Constructor. |
||||
*/ |
||||
public NewColorSelectPane() { |
||||
this(false); |
||||
} |
||||
|
||||
/** |
||||
* Constructor. |
||||
*/ |
||||
public NewColorSelectPane(boolean isSupportTransparent) { |
||||
this.isSupportTransparent = isSupportTransparent; |
||||
this.setLayout(FRGUIPaneFactory.createBorderLayout()); |
||||
this.setBorder(new UIRoundedBorder(UIConstants.LINE_COLOR, 1, 5)); |
||||
if (isSupportTransparent) { |
||||
UIButton transpanrentButton = new UIButton(Inter.getLocText("FR-Designer_ChartF-Transparency")); |
||||
this.add(transpanrentButton, BorderLayout.NORTH); |
||||
transpanrentButton.addActionListener(new ActionListener() { |
||||
|
||||
@Override |
||||
public void actionPerformed(ActionEvent e) { |
||||
doTransparent(); |
||||
} |
||||
}); |
||||
} |
||||
|
||||
// center
|
||||
JPanel centerPane = FRGUIPaneFactory.createY_AXISBoxInnerContainer_S_Pane(); |
||||
this.add(centerPane, BorderLayout.CENTER); |
||||
|
||||
// 第一行
|
||||
JPanel row1Pane = new JPanel(FRGUIPaneFactory.createBorderLayout()); |
||||
row1Pane.setBorder(BorderFactory.createEmptyBorder(8, 8, 0, 0)); |
||||
row1Pane.setPreferredSize(new Dimension(135, 16)); // 宽度为 16 * 8 + 7
|
||||
centerPane.add(row1Pane); |
||||
// 最近使用
|
||||
usedColorPane = new UsedColorPane(1, 8, 1, ColorSelectConfigManager.getInstance().getColors(), this, true, false); |
||||
usedColorPane.getPane().setBorder(BorderFactory.createEmptyBorder(0, 0, 0, 8)); |
||||
row1Pane.add(usedColorPane.getPane()); |
||||
|
||||
JPanel menuColorPane1 = new JPanel(); |
||||
centerPane.add(menuColorPane1); |
||||
|
||||
menuColorPane1.setLayout(new GridLayout(5, 8, 1, 1)); |
||||
menuColorPane1.setBorder(BorderFactory.createEmptyBorder(8, 8, 0, 8)); |
||||
for (int i = 0; i < ColorFactory.MenuColors.length; i++) { |
||||
menuColorPane1.add(new ColorCell(ColorFactory.MenuColors[i], this)); |
||||
} |
||||
|
||||
centerPane.add(Box.createVerticalStrut(1)); |
||||
|
||||
// mod by anchore 16/11/16
|
||||
UIButton customButton = new UIButton(Inter.getLocText("FR-Designer-Basic_More_Color")); |
||||
//UIButton customButton = new UIButton(Inter.getLocText(new String[]{"More", "Color"}) + "...");
|
||||
|
||||
customButton.addMouseListener(new MouseAdapter() { |
||||
@Override |
||||
public void mousePressed(MouseEvent e) { |
||||
customButtonPressed(); |
||||
} |
||||
}); |
||||
customButton.setCursor(new Cursor(Cursor.HAND_CURSOR)); |
||||
JPanel centerPane1 = FRGUIPaneFactory.createBorderLayout_S_Pane(); |
||||
centerPane1.setBorder(BorderFactory.createEmptyBorder(2, 8, 0, 8)); |
||||
centerPane1.add(customButton, BorderLayout.NORTH); |
||||
centerPane.add(centerPane1); |
||||
} |
||||
|
||||
|
||||
|
||||
/** |
||||
* 添加监听 |
||||
* @param 监听列表 |
||||
* Add change listener. |
||||
*/ |
||||
public void addChangeListener(ChangeListener changeListener) { |
||||
this.colorChangeListenerList.add(changeListener); |
||||
} |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return "Color"; |
||||
} |
||||
|
||||
/** |
||||
* 获取颜色 |
||||
* @return 颜色 |
||||
* Return the color. |
||||
*/ |
||||
public Color getColor() { |
||||
return color; |
||||
} |
||||
|
||||
/** |
||||
* 获取颜色 |
||||
* |
||||
* @return 颜色 |
||||
*/ |
||||
public Color getNotNoneColor() { |
||||
if (color == null) { |
||||
setColor(Color.WHITE); |
||||
return Color.WHITE; |
||||
} |
||||
return color; |
||||
} |
||||
|
||||
/** |
||||
* Set the color. |
||||
* |
||||
* @param color |
||||
* the new color. |
||||
*/ |
||||
@Override |
||||
public void setColor(Color color) { |
||||
this.color = color; |
||||
|
||||
// fire color change.
|
||||
if (!colorChangeListenerList.isEmpty()) { |
||||
ChangeEvent evt = new ChangeEvent(this); |
||||
|
||||
for (int i = 0; i < colorChangeListenerList.size(); i++) { |
||||
this.colorChangeListenerList.get(i).stateChanged(evt); |
||||
} |
||||
} |
||||
ColorSelectConfigManager.getInstance().addToColorQueue(color); |
||||
this.repaint(); |
||||
} |
||||
|
||||
/** |
||||
* 设置颜色 |
||||
* @param 颜色位置 |
||||
*/ |
||||
@Override |
||||
public void colorSetted(ColorCell colorCell) { |
||||
colorCell.repaint(); |
||||
} |
||||
|
||||
protected void doTransparent() { |
||||
setColor(null); |
||||
} |
||||
protected void customButtonPressed() { |
||||
pane = new ColorSelectDetailPane(Color.WHITE); |
||||
ColorSelectDialog.showDialog(DesignerContext.getDesignerFrame(), pane, Color.WHITE, this); |
||||
} |
||||
|
||||
@Override |
||||
public Dimension getPreferredSize() { |
||||
if(isSupportTransparent){ |
||||
return new Dimension(super.getPreferredSize().width, TRANSPANENT_WINDOW_HEIGHT); |
||||
} |
||||
return new Dimension(super.getPreferredSize().width, WINDWO_HEIGHT); |
||||
} |
||||
|
||||
/** |
||||
* 更新最近使用颜色 |
||||
* |
||||
*/ |
||||
public void updateUsedColor(){ |
||||
usedColorPane.updateUsedColor(); |
||||
} |
||||
|
||||
private static final long serialVersionUID = -8634152305687249392L; |
||||
|
||||
private Color color = null; // color
|
||||
// color setting action.
|
||||
private ArrayList<ChangeListener> colorChangeListenerList = new ArrayList<ChangeListener>(); |
||||
|
||||
// 颜色选择器
|
||||
private ColorSelectDetailPane pane; |
||||
// 是否支持透明
|
||||
private boolean isSupportTransparent; |
||||
|
||||
private final static int TRANSPANENT_WINDOW_HEIGHT = 165; |
||||
private final static int WINDWO_HEIGHT = 150; |
||||
|
||||
// 最近使用颜色
|
||||
private UsedColorPane usedColorPane; |
||||
|
||||
/** |
||||
* Constructor. |
||||
*/ |
||||
public NewColorSelectPane() { |
||||
this(false); |
||||
} |
||||
|
||||
/** |
||||
* Constructor. |
||||
*/ |
||||
public NewColorSelectPane(boolean isSupportTransparent) { |
||||
this.isSupportTransparent = isSupportTransparent; |
||||
this.setLayout(FRGUIPaneFactory.createBorderLayout()); |
||||
this.setBorder(new UIRoundedBorder(UIConstants.LINE_COLOR, 1, 5)); |
||||
if (isSupportTransparent) { |
||||
UIButton transpanrentButton = new UIButton(Inter.getLocText("FR-Designer_ChartF-Transparency")); |
||||
this.add(transpanrentButton, BorderLayout.NORTH); |
||||
transpanrentButton.addActionListener(new ActionListener() { |
||||
|
||||
@Override |
||||
public void actionPerformed(ActionEvent e) { |
||||
doTransparent(); |
||||
} |
||||
}); |
||||
} |
||||
|
||||
// center
|
||||
JPanel centerPane = FRGUIPaneFactory.createY_AXISBoxInnerContainer_S_Pane(); |
||||
this.add(centerPane, BorderLayout.CENTER); |
||||
|
||||
// 第一行
|
||||
JPanel row1Pane = new JPanel(FRGUIPaneFactory.createBorderLayout()); |
||||
row1Pane.setBorder(BorderFactory.createEmptyBorder(8, 8, 0, 0)); |
||||
row1Pane.setPreferredSize(new Dimension(135, 16)); // 宽度为 16 * 8 + 7
|
||||
centerPane.add(row1Pane); |
||||
// 最近使用
|
||||
usedColorPane = new UsedColorPane(1, 8, 1, this, true, false); |
||||
usedColorPane.getPane().setBorder(BorderFactory.createEmptyBorder(0, 0, 0, 8)); |
||||
row1Pane.add(usedColorPane.getPane()); |
||||
|
||||
JPanel menuColorPane1 = new JPanel(); |
||||
centerPane.add(menuColorPane1); |
||||
|
||||
menuColorPane1.setLayout(new GridLayout(5, 8, 1, 1)); |
||||
menuColorPane1.setBorder(BorderFactory.createEmptyBorder(8, 8, 0, 8)); |
||||
for (int i = 0; i < ColorFactory.MenuColors.length; i++) { |
||||
menuColorPane1.add(new ColorCell(ColorFactory.MenuColors[i], this)); |
||||
} |
||||
|
||||
centerPane.add(Box.createVerticalStrut(1)); |
||||
|
||||
// mod by anchore 16/11/16
|
||||
UIButton customButton = new UIButton(Inter.getLocText("FR-Designer-Basic_More_Color")); |
||||
|
||||
customButton.addMouseListener(new MouseAdapter() { |
||||
@Override |
||||
public void mousePressed(MouseEvent e) { |
||||
customButtonPressed(); |
||||
} |
||||
}); |
||||
customButton.setCursor(new Cursor(Cursor.HAND_CURSOR)); |
||||
JPanel centerPane1 = FRGUIPaneFactory.createBorderLayout_S_Pane(); |
||||
centerPane1.setBorder(BorderFactory.createEmptyBorder(2, 8, 0, 8)); |
||||
centerPane1.add(customButton, BorderLayout.NORTH); |
||||
centerPane.add(centerPane1); |
||||
} |
||||
|
||||
|
||||
/** |
||||
* 添加监听 |
||||
* |
||||
* @param 监听列表 Add change listener. |
||||
*/ |
||||
public void addChangeListener(ChangeListener changeListener) { |
||||
this.colorChangeListenerList.add(changeListener); |
||||
} |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return "Color"; |
||||
} |
||||
|
||||
/** |
||||
* 获取颜色 |
||||
* |
||||
* @return 颜色 |
||||
* Return the color. |
||||
*/ |
||||
public Color getColor() { |
||||
return color; |
||||
} |
||||
|
||||
/** |
||||
* 获取颜色 |
||||
* |
||||
* @return 颜色 |
||||
*/ |
||||
public Color getNotNoneColor() { |
||||
if (color == null) { |
||||
setColor(Color.WHITE); |
||||
return Color.WHITE; |
||||
} |
||||
return color; |
||||
} |
||||
|
||||
/** |
||||
* Set the color. |
||||
* |
||||
* @param color the new color. |
||||
*/ |
||||
@Override |
||||
public void setColor(Color color) { |
||||
this.color = color; |
||||
|
||||
// fire color change.
|
||||
if (!colorChangeListenerList.isEmpty()) { |
||||
ChangeEvent evt = new ChangeEvent(this); |
||||
|
||||
for (int i = 0; i < colorChangeListenerList.size(); i++) { |
||||
this.colorChangeListenerList.get(i).stateChanged(evt); |
||||
} |
||||
} |
||||
ColorSelectConfigManager.getInstance().addToColorQueue(color); |
||||
this.repaint(); |
||||
} |
||||
|
||||
/** |
||||
* 设置颜色 |
||||
* |
||||
* @param 颜色位置 |
||||
*/ |
||||
@Override |
||||
public void colorSetted(ColorCell colorCell) { |
||||
colorCell.repaint(); |
||||
} |
||||
|
||||
protected void doTransparent() { |
||||
setColor(null); |
||||
} |
||||
|
||||
protected void customButtonPressed() { |
||||
pane = new ColorSelectDetailPane(Color.WHITE); |
||||
ColorSelectDialog.showDialog(DesignerContext.getDesignerFrame(), pane, Color.WHITE, this); |
||||
} |
||||
|
||||
@Override |
||||
public Dimension getPreferredSize() { |
||||
if (isSupportTransparent) { |
||||
return new Dimension(super.getPreferredSize().width, TRANSPANENT_WINDOW_HEIGHT); |
||||
} |
||||
return new Dimension(super.getPreferredSize().width, WINDWO_HEIGHT); |
||||
} |
||||
|
||||
/** |
||||
* 更新最近使用颜色 |
||||
*/ |
||||
public void updateUsedColor() { |
||||
usedColorPane.updateUsedColor(); |
||||
} |
||||
|
||||
|
||||
} |
@ -1,55 +1,48 @@
|
||||
package com.fr.design.style.color; |
||||
|
||||
import java.awt.BorderLayout; |
||||
import java.awt.Color; |
||||
|
||||
import javax.swing.JColorChooser; |
||||
import javax.swing.JPanel; |
||||
|
||||
import com.fr.design.dialog.BasicPane; |
||||
import com.fr.design.layout.FRGUIPaneFactory; |
||||
|
||||
public class RecentUseColorPane extends BasicPane implements ColorSelectable{ |
||||
|
||||
JColorChooser chooser; |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return null; |
||||
} |
||||
|
||||
public RecentUseColorPane() { |
||||
} |
||||
|
||||
public RecentUseColorPane(JColorChooser chooser) { |
||||
this.chooser = chooser; |
||||
|
||||
// center
|
||||
JPanel centerPane = FRGUIPaneFactory.createY_AXISBoxInnerContainer_S_Pane(); |
||||
this.add(centerPane, BorderLayout.CENTER); |
||||
// 最近使用
|
||||
UsedColorPane pane = new UsedColorPane(2, 10, ColorSelectConfigManager.getInstance().getColors(),this); |
||||
centerPane.add(pane.getPane()); |
||||
} |
||||
|
||||
/** |
||||
* 选中颜色 |
||||
* |
||||
* @param 颜色 |
||||
*/ |
||||
@Override |
||||
public void colorSetted(ColorCell color) { |
||||
|
||||
} |
||||
|
||||
@Override |
||||
public Color getColor() { |
||||
return null; |
||||
} |
||||
|
||||
@Override |
||||
public void setColor(Color color) { |
||||
chooser.getSelectionModel().setSelectedColor(color); |
||||
} |
||||
|
||||
import javax.swing.*; |
||||
import java.awt.*; |
||||
|
||||
public class RecentUseColorPane extends BasicPane implements ColorSelectable { |
||||
|
||||
private JColorChooser chooser; |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return null; |
||||
} |
||||
|
||||
|
||||
public RecentUseColorPane(JColorChooser chooser) { |
||||
this.chooser = chooser; |
||||
|
||||
// center
|
||||
JPanel centerPane = FRGUIPaneFactory.createY_AXISBoxInnerContainer_S_Pane(); |
||||
this.add(centerPane, BorderLayout.CENTER); |
||||
// 最近使用
|
||||
UsedColorPane pane = new UsedColorPane(2, 10, this); |
||||
centerPane.add(pane.getPane()); |
||||
} |
||||
|
||||
/** |
||||
* 选中颜色 |
||||
*/ |
||||
@Override |
||||
public void colorSetted(ColorCell color) { |
||||
|
||||
} |
||||
|
||||
@Override |
||||
public Color getColor() { |
||||
return null; |
||||
} |
||||
|
||||
@Override |
||||
public void setColor(Color color) { |
||||
chooser.getSelectionModel().setSelectedColor(color); |
||||
} |
||||
|
||||
} |
@ -1,119 +1,112 @@
|
||||
package com.fr.design.style.color; |
||||
|
||||
import java.awt.Color; |
||||
import java.awt.GridLayout; |
||||
|
||||
import javax.swing.BorderFactory; |
||||
import javax.swing.JPanel; |
||||
|
||||
import com.fr.design.dialog.BasicPane; |
||||
import com.fr.design.gui.ibutton.SpecialUIButton; |
||||
|
||||
public class UsedColorPane extends BasicPane{ |
||||
|
||||
public static final Color DEFAULT_COLOR = new Color(222,222,222); |
||||
|
||||
// 最近使用面板列数
|
||||
private int columns; |
||||
// 最近使用面板行数
|
||||
private int rows; |
||||
// 留白的单元格数量
|
||||
private int reserveCells; |
||||
// 是否需要取色器按钮
|
||||
private boolean needPickColorButton; |
||||
// 是否在取色时实时设定颜色
|
||||
private boolean setColorRealTime; |
||||
// 最近使用颜色
|
||||
private Object[] colors; |
||||
// 最近使用面板
|
||||
private JPanel pane; |
||||
|
||||
private ColorSelectable selectable; |
||||
|
||||
public JPanel getPane() { |
||||
return pane; |
||||
} |
||||
|
||||
public void setPane(JPanel pane) { |
||||
this.pane = pane; |
||||
} |
||||
|
||||
public UsedColorPane(){ |
||||
|
||||
} |
||||
|
||||
/** |
||||
* 构造函数 |
||||
* |
||||
* @param rows 行 |
||||
* @param columns 列 |
||||
* @param reserveCells 留白的单元格个数 |
||||
* @param colors 最近使用的颜色 |
||||
* @param needPickColorButton 是否需要加上取色器按钮 |
||||
* @param setColorRealTime 取色器是否实时设定颜色 |
||||
*/ |
||||
public UsedColorPane(int rows,int columns,int reserveCells, Object[] colors, ColorSelectable selectable, boolean needPickColorButton, boolean setColorRealTime){ |
||||
this.columns = columns; |
||||
this.rows = rows; |
||||
this.reserveCells = reserveCells; |
||||
this.colors = colors; |
||||
this.selectable = selectable; |
||||
this.needPickColorButton = needPickColorButton; |
||||
this.setColorRealTime = setColorRealTime; |
||||
initialComponents(); |
||||
} |
||||
|
||||
public UsedColorPane(int rows,int columns, Object[] colors,ColorSelectable selectable){ |
||||
this(rows, columns, 0, colors, selectable, false, false); |
||||
} |
||||
|
||||
private void initialComponents(){ |
||||
int total = columns * rows; |
||||
JPanel panel = new JPanel(); |
||||
panel.setLayout(new GridLayout(rows,columns, 1, 1)); |
||||
panel.setBorder(BorderFactory.createEmptyBorder(8, 8, 0, 8)); |
||||
Color[] colors = ColorSelectConfigManager.getInstance().getColors(); |
||||
int size = colors.length; |
||||
|
||||
int i = 0; |
||||
if (needPickColorButton) { |
||||
// 取色按钮
|
||||
SpecialUIButton pickColorButton = PickColorButtonFactory.getPickColorButton(selectable, PickColorButtonFactory.IconType.ICON16, setColorRealTime); |
||||
panel.add(pickColorButton); |
||||
i++; |
||||
this.reserveCells += 1; |
||||
} |
||||
while (i < this.reserveCells) { |
||||
ColorCell cc = new ColorCell(DEFAULT_COLOR, selectable); |
||||
cc.setVisible(false); |
||||
panel.add(cc); |
||||
i++; |
||||
} |
||||
while (i < total) { |
||||
Color color = i < size ? colors[size-1-i]: DEFAULT_COLOR; |
||||
panel.add(new ColorCell(color == null ? DEFAULT_COLOR : color, selectable)); |
||||
i++; |
||||
} |
||||
this.pane = panel; |
||||
} |
||||
|
||||
/** |
||||
* 更新最近使用颜色 |
||||
* |
||||
*/ |
||||
public void updateUsedColor(){ |
||||
int total = columns * rows; |
||||
Color[] colors = ColorSelectConfigManager.getInstance().getColors(); |
||||
int size = colors.length; |
||||
for(int i=this.reserveCells; i<total; i++){ |
||||
ColorCell cell = (ColorCell) this.pane.getComponent(i); |
||||
Color color = i < size ? colors[size-1-i]: DEFAULT_COLOR; |
||||
cell.setColor(color == null ? DEFAULT_COLOR : color); |
||||
} |
||||
} |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return null; |
||||
} |
||||
import javax.swing.*; |
||||
import java.awt.*; |
||||
|
||||
public class UsedColorPane extends BasicPane { |
||||
|
||||
// 默认显示颜色
|
||||
public static final Color DEFAULT_COLOR = new Color(222, 222, 222); |
||||
|
||||
// 最近使用面板列数
|
||||
private int columns; |
||||
// 最近使用面板行数
|
||||
private int rows; |
||||
// 留白的单元格数量
|
||||
private int reserveCells; |
||||
// 是否需要取色器按钮
|
||||
private boolean needPickColorButton; |
||||
// 是否在取色时实时设定颜色
|
||||
private boolean setColorRealTime; |
||||
|
||||
// 最近使用面板
|
||||
private JPanel pane; |
||||
|
||||
private ColorSelectable selectable; |
||||
|
||||
public JPanel getPane() { |
||||
return pane; |
||||
} |
||||
|
||||
public void setPane(JPanel pane) { |
||||
this.pane = pane; |
||||
} |
||||
|
||||
|
||||
/** |
||||
* 构造函数 |
||||
* |
||||
* @param rows 行 |
||||
* @param columns 列 |
||||
* @param reserveCells 留白的单元格个数 |
||||
* @param colors 最近使用的颜色 |
||||
* @param needPickColorButton 是否需要加上取色器按钮 |
||||
* @param setColorRealTime 取色器是否实时设定颜色 |
||||
*/ |
||||
public UsedColorPane(int rows, int columns, int reserveCells, ColorSelectable selectable, boolean needPickColorButton, boolean setColorRealTime) { |
||||
this.columns = columns; |
||||
this.rows = rows; |
||||
this.reserveCells = reserveCells; |
||||
this.selectable = selectable; |
||||
this.needPickColorButton = needPickColorButton; |
||||
this.setColorRealTime = setColorRealTime; |
||||
initialComponents(); |
||||
} |
||||
|
||||
public UsedColorPane(int rows, int columns, ColorSelectable selectable) { |
||||
this(rows, columns, 0, selectable, false, false); |
||||
} |
||||
|
||||
private void initialComponents() { |
||||
int total = columns * rows; |
||||
JPanel panel = new JPanel(); |
||||
panel.setLayout(new GridLayout(rows, columns, 1, 1)); |
||||
panel.setBorder(BorderFactory.createEmptyBorder(8, 8, 0, 8)); |
||||
//最近使用颜色
|
||||
Color[] colors = ColorSelectConfigManager.getInstance().getColors(); |
||||
int size = colors.length; |
||||
|
||||
int i = 0; |
||||
if (needPickColorButton) { |
||||
// 取色按钮
|
||||
SpecialUIButton pickColorButton = PickColorButtonFactory.getPickColorButton(selectable, PickColorButtonFactory.IconType.ICON16, setColorRealTime); |
||||
panel.add(pickColorButton); |
||||
i++; |
||||
this.reserveCells += 1; |
||||
} |
||||
while (i < this.reserveCells) { |
||||
ColorCell cc = new ColorCell(DEFAULT_COLOR, selectable); |
||||
cc.setVisible(false); |
||||
panel.add(cc); |
||||
i++; |
||||
} |
||||
while (i < total) { |
||||
Color color = i < size ? colors[size - (i - this.reserveCells) - 1] : DEFAULT_COLOR; |
||||
panel.add(new ColorCell(color == null ? DEFAULT_COLOR : color, selectable)); |
||||
i++; |
||||
} |
||||
this.pane = panel; |
||||
} |
||||
|
||||
/** |
||||
* 更新最近使用颜色 |
||||
*/ |
||||
public void updateUsedColor() { |
||||
int total = columns * rows; |
||||
Color[] colors = ColorSelectConfigManager.getInstance().getColors(); |
||||
int size = colors.length; |
||||
for (int i = this.reserveCells; i < total; i++) { |
||||
ColorCell cell = (ColorCell) this.pane.getComponent(i); |
||||
Color color = i < size ? colors[size - (i - this.reserveCells) - 1] : DEFAULT_COLOR; |
||||
cell.setColor(color == null ? DEFAULT_COLOR : color); |
||||
} |
||||
} |
||||
|
||||
@Override |
||||
protected String title4PopupWindow() { |
||||
return null; |
||||
} |
||||
} |
@ -1,346 +1,341 @@
|
||||
package com.fr.design.designer.beans.adapters.layout; |
||||
|
||||
import com.fr.design.beans.GroupModel; |
||||
import com.fr.design.designer.beans.ConstraintsGroupModel; |
||||
import com.fr.design.designer.beans.HoverPainter; |
||||
import com.fr.design.designer.beans.painters.FRAbsoluteLayoutPainter; |
||||
import com.fr.design.designer.creator.*; |
||||
import com.fr.design.designer.properties.BoundsGroupModel; |
||||
import com.fr.design.designer.properties.FRAbsoluteLayoutPropertiesGroupModel; |
||||
import com.fr.design.utils.ComponentUtils; |
||||
import com.fr.design.utils.gui.LayoutUtils; |
||||
import com.fr.form.ui.container.WAbsoluteLayout; |
||||
import com.fr.general.ComparatorUtils; |
||||
import com.fr.general.FRLogger; |
||||
|
||||
import java.awt.*; |
||||
|
||||
public class FRAbsoluteLayoutAdapter extends FRBodyLayoutAdapter { |
||||
//是不是添加到父容器上
|
||||
private boolean isAdd2ParentLayout = false; |
||||
private HoverPainter painter; |
||||
|
||||
public FRAbsoluteLayoutAdapter(XLayoutContainer container) { |
||||
super(container); |
||||
painter = new FRAbsoluteLayoutPainter(container); |
||||
initMinSize(); |
||||
} |
||||
|
||||
private void initMinSize() { |
||||
XWAbsoluteLayout layout = (XWAbsoluteLayout) container; |
||||
minWidth = layout.getActualMinWidth(); |
||||
minHeight = layout.getActualMinHeight(); |
||||
actualVal = layout.getAcualInterval(); |
||||
margin = layout.toData().getMargin(); |
||||
} |
||||
|
||||
@Override |
||||
public HoverPainter getPainter() { |
||||
return painter; |
||||
} |
||||
|
||||
/** |
||||
* 是否能在指定位置添加组件 |
||||
* |
||||
* @param creator 组件 |
||||
* @param x 坐标x |
||||
* @param y 坐标y |
||||
* @return 能则返回true |
||||
*/ |
||||
//这个地方的逻辑非常复杂,
|
||||
// 1.当前绝对布局是不可编辑且是最外层,那么其他控件添加在它周围,
|
||||
// 2.当前绝对布局是不可编辑且不是最外层,那么控件不可添加,(嵌套)
|
||||
// 3.当前绝对布局可编辑,那么控件添加
|
||||
@Override |
||||
public boolean accept(XCreator creator, int x, int y) { |
||||
Component comp = container.getComponentAt(x, y); |
||||
//布局控件要先判断是不是可编辑
|
||||
//可以编辑,按原有逻辑判断
|
||||
//不可编辑,当成一整个控件处理
|
||||
if (comp == null) { |
||||
return false; |
||||
} |
||||
//参数面板内的组件不允许拖往绝对布局中
|
||||
if (creator.getParent() != null && ((XCreator) creator.getParent()).acceptType(XWParameterLayout.class)) { |
||||
Rectangle rec = creator.getBounds(); |
||||
rec.y = creator.getParent().getHeight() - rec.height; |
||||
creator.setBounds(rec); |
||||
return false; |
||||
} |
||||
//判断组件能不能拖入绝对布局
|
||||
if (!creator.canEnterIntoAbsolutePane()) { |
||||
return false; |
||||
} |
||||
XLayoutContainer topLayout = XCreatorUtils.getHotspotContainer((XCreator) comp).getTopLayout(); |
||||
if (topLayout != null) { |
||||
if (topLayout.isEditable()) { |
||||
return topLayoutAccept(creator, x, y); |
||||
} |
||||
//绝对布局嵌套,处于内层,不可编辑,不添加,topLayout只能获取到最外层可编辑的布局
|
||||
else if (((XLayoutContainer) topLayout.getParent()).acceptType(XWAbsoluteLayout.class)) { |
||||
return false; |
||||
} else { |
||||
return acceptWidget(x, y); |
||||
} |
||||
} else { |
||||
FRLogger.getLogger().error("top layout is null!"); |
||||
} |
||||
|
||||
return false; |
||||
} |
||||
|
||||
//topLayout假如可以编辑的话就往里面添加组件
|
||||
private boolean topLayoutAccept(XCreator creator, int x, int y) { |
||||
//允许组件重叠,可以不判断有没有和当前控件重叠
|
||||
//先计算当前控件的位置
|
||||
int creatorX, creatorY; |
||||
if (XCreatorUtils.getParentXLayoutContainer(creator) != null) { |
||||
Rectangle creatorRectangle = ComponentUtils.getRelativeBounds(creator); |
||||
creatorX = creatorRectangle.x; |
||||
creatorY = creatorRectangle.y; |
||||
} else { |
||||
//这边计算得到的组件其实位置是正确的,
|
||||
//因为传入的x和y已经加上了宽度或者高度的一半,再减去相同的宽度和高度的一半是没区别的,
|
||||
// 例如高度为21,那么就是+10-10;
|
||||
// 高度为20,那么就是+10-10; 没区别
|
||||
int w = creator.getWidth() / 2; |
||||
int h = creator.getHeight() / 2; |
||||
creatorX = x - w; |
||||
creatorY = y - h; |
||||
} |
||||
if (creatorX < 0 || creatorX + creator.getWidth() > container.getWidth()) { |
||||
return false; |
||||
} |
||||
if (creatorY < 0 || creatorY + creator.getHeight() > container.getHeight()) { |
||||
return false; |
||||
} |
||||
return x >= 0 && y >= 0 && creator.getHeight() <= container.getHeight() |
||||
&& creator.getWidth() <= container.getWidth(); |
||||
} |
||||
|
||||
/** |
||||
* 判断是否鼠标在组件的三等分区域,如果组件在布局管理器中间,上下左右都可能会三等分 |
||||
* |
||||
* @param parentComp 鼠标所在区域的组件 |
||||
* @param x 坐标x |
||||
* @param y 坐标y |
||||
* @return 是则返回true |
||||
*/ |
||||
public boolean isTrisectionArea(Component parentComp, int x, int y) { |
||||
XCreator creator = (XCreator) parentComp; |
||||
trisectAreaDirect = 0; |
||||
if (container.getComponentCount() <= 1) { |
||||
return false; |
||||
} |
||||
int maxWidth = parentComp.getWidth(); |
||||
int maxHeight = parentComp.getHeight(); |
||||
int xL = parentComp.getX(); |
||||
int yL = parentComp.getY(); |
||||
// 组件宽高的十分之一和默认值取大
|
||||
int minRangeWidth = Math.max(maxWidth / BORDER_PROPORTION, DEFAULT_AREA_LENGTH); |
||||
int minRangeHeight = Math.max(maxHeight / BORDER_PROPORTION, DEFAULT_AREA_LENGTH); |
||||
if (y < yL + minRangeHeight) { |
||||
// 在组件上侧三等分
|
||||
trisectAreaDirect = COMP_TOP; |
||||
} else if (y > yL + maxHeight - minRangeHeight) { |
||||
// 在组件下侧三等分
|
||||
trisectAreaDirect = COMP_BOTTOM; |
||||
} else if (x < xL + minRangeWidth) { |
||||
// 在组件左侧三等分
|
||||
trisectAreaDirect = COMP_LEFT; |
||||
} else if (x > xL + maxWidth - minRangeWidth) { |
||||
// 在组件右侧三等分
|
||||
trisectAreaDirect = COMP_RIGHT; |
||||
} |
||||
// tab布局的边界特殊处理,不进行三等分
|
||||
if (!creator.getTargetChildrenList().isEmpty()) { |
||||
return false; |
||||
} |
||||
|
||||
return !ComparatorUtils.equals(trisectAreaDirect, 0); |
||||
} |
||||
|
||||
//当前绝对布局不可编辑,就当成一个控件,组件添加在周围
|
||||
private boolean acceptWidget(int x, int y) { |
||||
isFindRelatedComps = false; |
||||
//拖入组件判断时,先判断是否为交叉点区域,其次三等分区域,再次平分区域
|
||||
Component comp = container.getComponentAt(x, y); |
||||
//如果当前处于边缘地带, 那么就把他贴到父容器上
|
||||
XLayoutContainer parent = container.findNearestFit(); |
||||
container = parent != null ? parent : container; |
||||
isAdd2ParentLayout = true; |
||||
|
||||
int componentHeight = comp.getHeight(); |
||||
int componentWidth = comp.getWidth(); |
||||
//上半部分高度
|
||||
int upHeight = (int) (componentHeight * TOP_HALF) + comp.getY(); |
||||
//下半部分高度
|
||||
int downHeight = (int) (componentHeight * BOTTOM_HALF) + comp.getY(); |
||||
|
||||
if (isCrossPointArea(comp, x, y)) { |
||||
return canAcceptWhileCrossPoint(comp, x, y); |
||||
} |
||||
|
||||
if (isTrisectionArea(comp, x, y)) { |
||||
return canAcceptWhileTrisection(comp, x, y); |
||||
} |
||||
|
||||
boolean horizonValid = componentWidth >= minWidth * 2 + actualVal; |
||||
boolean verticalValid = componentHeight >= minHeight * 2 + actualVal; |
||||
return y > upHeight && y < downHeight ? horizonValid : verticalValid; |
||||
} |
||||
|
||||
/** |
||||
* 组件的ComponentAdapter在添加组件时,如果发现布局管理器不为空,会继而调用该布局管理器的 |
||||
* addComp方法来完成组件的具体添加。在该方法内,布局管理器可以提供额外的功能。 |
||||
* |
||||
* @param creator 被添加的新组件 |
||||
* @param x 添加的位置x,该位置是相对于container的 |
||||
* @param y 添加的位置y,该位置是相对于container的 |
||||
* @return 是否添加成功,成功返回true,否则false |
||||
*/ |
||||
@Override |
||||
public boolean addBean(XCreator creator, int x, int y) { |
||||
Rectangle rect = ComponentUtils.getRelativeBounds(container); |
||||
|
||||
int posX = x + rect.x; |
||||
int posY = y + rect.y; |
||||
if (!accept(creator, x, y)) { |
||||
return false; |
||||
} |
||||
addComp(creator, posX, posY); |
||||
((XWidgetCreator) creator).recalculateChildrenSize(); |
||||
return true; |
||||
} |
||||
|
||||
@Override |
||||
protected void addComp(XCreator creator, int x, int y) { |
||||
if (!isAdd2ParentLayout) { |
||||
Rectangle r = ComponentUtils.getRelativeBounds(container); |
||||
x = x - r.x; |
||||
y = y - r.y; |
||||
if (XCreatorUtils.getParentXLayoutContainer(creator) != null) { |
||||
|
||||
Rectangle creatorRectangle = ComponentUtils.getRelativeBounds(creator); |
||||
x = creatorRectangle.x - r.x; |
||||
y = creatorRectangle.y - r.y; |
||||
} else { |
||||
int w = creator.getWidth() / 2; |
||||
int h = creator.getHeight() / 2; |
||||
x = x - w; |
||||
y = y - h; |
||||
} |
||||
fix(creator, x, y); |
||||
|
||||
if (creator.hasTitleStyle()) { |
||||
addParentCreator(creator); |
||||
} else { |
||||
container.add(creator, creator.toData().getWidgetName(), 0); |
||||
} |
||||
XWAbsoluteLayout layout = (XWAbsoluteLayout) container; |
||||
layout.updateBoundsWidget(creator); |
||||
updateCreatorBackBound(); |
||||
LayoutUtils.layoutRootContainer(container); |
||||
} else { |
||||
fixAbsolute(creator, x, y); |
||||
if (creator.shouldScaleCreator() || creator.hasTitleStyle()) { |
||||
addParentCreator(creator); |
||||
} else { |
||||
container.add(creator, creator.toData().getWidgetName(), 0); |
||||
} |
||||
XWFitLayout layout = (XWFitLayout) container; |
||||
// 更新对应的BoundsWidget
|
||||
layout.updateBoundsWidget(); |
||||
updateCreatorBackBound(); |
||||
} |
||||
} |
||||
|
||||
private void updateCreatorBackBound() { |
||||
for (int i = 0, size = container.getComponentCount(); i < size; i++) { |
||||
XCreator creator = (XCreator) container.getComponent(i); |
||||
creator.updateChildBound(minHeight); |
||||
creator.setBackupBound(creator.getBounds()); |
||||
} |
||||
} |
||||
|
||||
private void addParentCreator(XCreator child) { |
||||
XLayoutContainer parentPanel = child.initCreatorWrapper(child.getHeight()); |
||||
container.add(parentPanel, child.toData().getWidgetName(), 0); |
||||
} |
||||
|
||||
/** |
||||
* 新拖入组件时,计算调整其他关联组件位置大小 |
||||
* |
||||
* @param child 新拖入的组件 |
||||
* @param x 鼠标所在x坐标 |
||||
* @param y 鼠标所在y坐标 |
||||
*/ |
||||
private void fixAbsolute(XCreator child, int x, int y) { |
||||
Component parentComp = container.getComponentAt(x, y); |
||||
if (container.getComponentCount() == 0) { |
||||
child.setLocation(0, 0); |
||||
child.setSize(parentComp.getWidth(), parentComp.getHeight()); |
||||
} else if (isCrossPointArea(parentComp, x, y)) { |
||||
//交叉区域插入组件时,根据具体位置进行上下或者左右或者相邻三个组件的位置大小插入
|
||||
fixCrossPointArea(parentComp, child, x, y); |
||||
return; |
||||
} else if (isTrisectionArea(parentComp, x, y)) { |
||||
// 在边界三等分区域,就不再和组件二等分了
|
||||
fixTrisect(parentComp, child, x, y); |
||||
return; |
||||
} else { |
||||
fixHalve(parentComp, child, x, y); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 组件拖拽后调整大小 |
||||
* |
||||
* @param creator 组件 |
||||
*/ |
||||
@Override |
||||
public void fix(XCreator creator) { |
||||
WAbsoluteLayout wabs = (WAbsoluteLayout) container.toData(); |
||||
fix(creator, creator.getX(), creator.getY()); |
||||
wabs.setBounds(creator.toData(), creator.getBounds()); |
||||
|
||||
XWAbsoluteLayout layout = (XWAbsoluteLayout) container; |
||||
layout.updateBoundsWidget(creator); |
||||
} |
||||
|
||||
/** |
||||
* 调整组件大小到合适尺寸位置 |
||||
* |
||||
* @param creator 组件 |
||||
* @param x 坐标x |
||||
* @param y 坐标y |
||||
*/ |
||||
public void fix(XCreator creator, int x, int y) { |
||||
int height = creator.getHeight(); |
||||
int width = creator.getWidth(); |
||||
if (x < 0) { |
||||
x = container.getX(); |
||||
} else if (x + creator.getWidth() > container.getWidth()) { |
||||
x = container.getWidth() - width; |
||||
} |
||||
|
||||
if (y < 0) { |
||||
y = container.getY(); |
||||
} else if (y + creator.getHeight() > container.getHeight()) { |
||||
y = container.getHeight() - height; |
||||
} |
||||
|
||||
creator.setBounds(x, y, width, height); |
||||
} |
||||
|
||||
@Override |
||||
public ConstraintsGroupModel getLayoutConstraints(XCreator creator) { |
||||
return new BoundsGroupModel((XWAbsoluteLayout) container, creator); |
||||
} |
||||
|
||||
@Override |
||||
public GroupModel getLayoutProperties() { |
||||
XWAbsoluteLayout xwAbsoluteLayout = (XWAbsoluteLayout) container; |
||||
return new FRAbsoluteLayoutPropertiesGroupModel(xwAbsoluteLayout); |
||||
} |
||||
package com.fr.design.designer.beans.adapters.layout; |
||||
|
||||
import com.fr.design.beans.GroupModel; |
||||
import com.fr.design.designer.beans.ConstraintsGroupModel; |
||||
import com.fr.design.designer.beans.HoverPainter; |
||||
import com.fr.design.designer.beans.painters.FRAbsoluteLayoutPainter; |
||||
import com.fr.design.designer.creator.*; |
||||
import com.fr.design.designer.properties.BoundsGroupModel; |
||||
import com.fr.design.designer.properties.FRAbsoluteLayoutPropertiesGroupModel; |
||||
import com.fr.design.utils.ComponentUtils; |
||||
import com.fr.design.utils.gui.LayoutUtils; |
||||
import com.fr.form.ui.container.WAbsoluteLayout; |
||||
import com.fr.general.ComparatorUtils; |
||||
import com.fr.general.FRLogger; |
||||
|
||||
import java.awt.*; |
||||
|
||||
public class FRAbsoluteLayoutAdapter extends FRBodyLayoutAdapter { |
||||
//是不是添加到父容器上
|
||||
private boolean isAdd2ParentLayout = false; |
||||
private HoverPainter painter; |
||||
|
||||
public FRAbsoluteLayoutAdapter(XLayoutContainer container) { |
||||
super(container); |
||||
painter = new FRAbsoluteLayoutPainter(container); |
||||
initMinSize(); |
||||
} |
||||
|
||||
private void initMinSize() { |
||||
XWAbsoluteLayout layout = (XWAbsoluteLayout) container; |
||||
minWidth = layout.getActualMinWidth(); |
||||
minHeight = layout.getActualMinHeight(); |
||||
actualVal = layout.getAcualInterval(); |
||||
margin = layout.toData().getMargin(); |
||||
} |
||||
|
||||
@Override |
||||
public HoverPainter getPainter() { |
||||
return painter; |
||||
} |
||||
|
||||
/** |
||||
* 是否能在指定位置添加组件 |
||||
* @param creator 组件 |
||||
* @param x 坐标x |
||||
* @param y 坐标y |
||||
* @return 能则返回true |
||||
*/ |
||||
//这个地方的逻辑非常复杂,
|
||||
// 1.当前绝对布局是不可编辑且是最外层,那么其他控件添加在它周围,
|
||||
// 2.当前绝对布局是不可编辑且不是最外层,那么控件不可添加,(嵌套)
|
||||
// 3.当前绝对布局可编辑,那么控件添加
|
||||
@Override |
||||
public boolean accept(XCreator creator, int x, int y) { |
||||
Component comp = container.getComponentAt(x, y); |
||||
//布局控件要先判断是不是可编辑
|
||||
//可以编辑,按原有逻辑判断
|
||||
//不可编辑,当成一整个控件处理
|
||||
if (comp == null){ |
||||
return false; |
||||
} |
||||
//参数面板内的组件不允许拖往绝对布局中
|
||||
if (creator.getParent() != null && ((XCreator)creator.getParent()).acceptType(XWParameterLayout.class)){ |
||||
Rectangle rec = creator.getBounds(); |
||||
rec.y = creator.getParent().getHeight() - rec.height; |
||||
creator.setBounds(rec); |
||||
return false; |
||||
} |
||||
//判断下组件能不能拖入绝对布局
|
||||
if (!creator.canEnterIntoAbsolutePane()){ |
||||
return false; |
||||
} |
||||
XLayoutContainer topLayout = XCreatorUtils.getHotspotContainer((XCreator)comp).getTopLayout(); |
||||
if(topLayout != null){ |
||||
if (topLayout.isEditable()){ |
||||
return topLayoutAccept(creator, x, y); |
||||
} |
||||
//绝对布局嵌套,处于内层,不可编辑,不添加,topLayout只能获取到最外层可编辑的布局
|
||||
else if (((XLayoutContainer)topLayout.getParent()).acceptType(XWAbsoluteLayout.class)) { |
||||
return false; |
||||
} else { |
||||
return acceptWidget(x, y); |
||||
} |
||||
} else { |
||||
FRLogger.getLogger().error("top layout is null!"); |
||||
} |
||||
|
||||
return false; |
||||
} |
||||
|
||||
//topLayout假如可以编辑的话就往里面添加组件
|
||||
private boolean topLayoutAccept(XCreator creator, int x, int y) { |
||||
//允许组件重叠,可以不判断有没有和当前控件重叠
|
||||
//先计算当前控件的位置
|
||||
int creatorX, creatorY; |
||||
if (XCreatorUtils.getParentXLayoutContainer(creator) != null) { |
||||
Rectangle creatorRectangle = ComponentUtils.getRelativeBounds(creator); |
||||
creatorX = creatorRectangle.x; |
||||
creatorY = creatorRectangle.y; |
||||
} else { |
||||
//这边计算得到的组件其实位置是正确的,
|
||||
//因为传入的x和y已经加上了宽度或者高度的一半,再减去相同的宽度和高度的一半是没区别的,
|
||||
// 例如高度为21,那么就是+10-10;
|
||||
// 高度为20,那么就是+10-10; 没区别
|
||||
int w = creator.getWidth() / 2; |
||||
int h = creator.getHeight() / 2; |
||||
creatorX = x - w; |
||||
creatorY = y - h; |
||||
} |
||||
if (creatorX < 0 || creatorX + creator.getWidth() > container.getWidth()) { |
||||
return false; |
||||
} |
||||
if (creatorY < 0 || creatorY + creator.getHeight() > container.getHeight()){ |
||||
return false; |
||||
} |
||||
return x >= 0 && y >= 0 && creator.getHeight() <= container.getHeight() |
||||
&& creator.getWidth() <= container.getWidth(); |
||||
} |
||||
|
||||
/** |
||||
* 判断是否鼠标在组件的三等分区域,如果组件在布局管理器中间,上下左右都可能会三等分 |
||||
* @param parentComp 鼠标所在区域的组件 |
||||
* @param x 坐标x |
||||
* @param y 坐标y |
||||
* @return 是则返回true |
||||
*/ |
||||
public boolean isTrisectionArea(Component parentComp, int x, int y) { |
||||
XCreator creator = (XCreator)parentComp; |
||||
trisectAreaDirect = 0; |
||||
if (container.getComponentCount()<=1) { |
||||
return false; |
||||
} |
||||
int maxWidth = parentComp.getWidth(); |
||||
int maxHeight = parentComp.getHeight(); |
||||
int xL = parentComp.getX(); |
||||
int yL = parentComp.getY(); |
||||
// 组件宽高的十分之一和默认值取大
|
||||
int minRangeWidth = Math.max(maxWidth/BORDER_PROPORTION, DEFAULT_AREA_LENGTH); |
||||
int minRangeHeight = Math.max(maxHeight/BORDER_PROPORTION, DEFAULT_AREA_LENGTH); |
||||
if(y<yL+minRangeHeight ) { |
||||
// 在组件上侧三等分
|
||||
trisectAreaDirect = COMP_TOP; |
||||
} else if(y>yL+maxHeight-minRangeHeight) { |
||||
// 在组件下侧三等分
|
||||
trisectAreaDirect = COMP_BOTTOM; |
||||
} else if (x<xL+minRangeWidth) { |
||||
// 在组件左侧三等分
|
||||
trisectAreaDirect = COMP_LEFT; |
||||
} else if(x>xL+maxWidth-minRangeWidth) { |
||||
// 在组件右侧三等分
|
||||
trisectAreaDirect = COMP_RIGHT; |
||||
} |
||||
// tab布局的边界特殊处理,不进行三等分
|
||||
if(!creator.getTargetChildrenList().isEmpty()){ |
||||
return false; |
||||
} |
||||
|
||||
return !ComparatorUtils.equals(trisectAreaDirect, 0); |
||||
} |
||||
|
||||
//当前绝对布局不可编辑,就当成一个控件,组件添加在周围
|
||||
private boolean acceptWidget(int x, int y) { |
||||
isFindRelatedComps = false; |
||||
//拖入组件判断时,先判断是否为交叉点区域,其次三等分区域,再次平分区域
|
||||
Component comp = container.getComponentAt(x, y); |
||||
//如果当前处于边缘地带, 那么就把他贴到父容器上
|
||||
XLayoutContainer parent = container.findNearestFit(); |
||||
container = parent != null ? parent : container; |
||||
isAdd2ParentLayout = true; |
||||
|
||||
int componentHeight = comp.getHeight(); |
||||
int componentWidth = comp.getWidth(); |
||||
//上半部分高度
|
||||
int upHeight = (int) (componentHeight * TOP_HALF) + comp.getY(); |
||||
//下半部分高度
|
||||
int downHeight = (int) (componentHeight * BOTTOM_HALF) + comp.getY(); |
||||
|
||||
if (isCrossPointArea(comp, x, y)) { |
||||
return canAcceptWhileCrossPoint(comp, x, y); |
||||
} |
||||
|
||||
if (isTrisectionArea(comp, x, y)) { |
||||
return canAcceptWhileTrisection(comp, x, y); |
||||
} |
||||
|
||||
boolean horizonValid = componentWidth >= minWidth * 2 + actualVal; |
||||
boolean verticalValid = componentHeight >= minHeight * 2 + actualVal; |
||||
return y > upHeight && y < downHeight ? horizonValid : verticalValid; |
||||
} |
||||
|
||||
/** |
||||
* 组件的ComponentAdapter在添加组件时,如果发现布局管理器不为空,会继而调用该布局管理器的 |
||||
* addComp方法来完成组件的具体添加。在该方法内,布局管理器可以提供额外的功能。 |
||||
* |
||||
* @param creator 被添加的新组件 |
||||
* @param x 添加的位置x,该位置是相对于container的 |
||||
* @param y 添加的位置y,该位置是相对于container的 |
||||
* @return 是否添加成功,成功返回true,否则false |
||||
*/ |
||||
@Override |
||||
public boolean addBean(XCreator creator, int x, int y) { |
||||
Rectangle rect = ComponentUtils.getRelativeBounds(container); |
||||
|
||||
int posX = x + rect.x; |
||||
int posY = y + rect.y; |
||||
if (!accept(creator, x, y)) { |
||||
return false; |
||||
} |
||||
addComp(creator, posX, posY); |
||||
((XWidgetCreator) creator).recalculateChildrenSize(); |
||||
return true; |
||||
} |
||||
|
||||
@Override |
||||
protected void addComp(XCreator creator, int x, int y) { |
||||
if(!isAdd2ParentLayout) { |
||||
Rectangle r = ComponentUtils.getRelativeBounds(container); |
||||
x = x - r.x; |
||||
y = y - r.y; |
||||
if (XCreatorUtils.getParentXLayoutContainer(creator) != null) { |
||||
|
||||
Rectangle creatorRectangle = ComponentUtils.getRelativeBounds(creator); |
||||
x = creatorRectangle.x - r.x; |
||||
y = creatorRectangle.y - r.y; |
||||
} else { |
||||
int w = creator.getWidth() / 2; |
||||
int h = creator.getHeight() / 2; |
||||
x = x - w; |
||||
y = y - h; |
||||
} |
||||
fix(creator, x, y); |
||||
|
||||
if (creator.hasTitleStyle()) { |
||||
addParentCreator(creator); |
||||
} else { |
||||
container.add(creator, creator.toData().getWidgetName(),0); |
||||
} |
||||
XWAbsoluteLayout layout = (XWAbsoluteLayout) container; |
||||
layout.updateBoundsWidget(creator); |
||||
updateCreatorBackBound(); |
||||
LayoutUtils.layoutRootContainer(container); |
||||
}else{ |
||||
fixAbsolute(creator, x, y); |
||||
if (creator.shouldScaleCreator() || creator.hasTitleStyle()) { |
||||
addParentCreator(creator); |
||||
} else { |
||||
container.add(creator, creator.toData().getWidgetName(),0); |
||||
} |
||||
XWFitLayout layout = (XWFitLayout) container; |
||||
// 更新对应的BoundsWidget
|
||||
layout.updateBoundsWidget(); |
||||
updateCreatorBackBound(); |
||||
} |
||||
} |
||||
|
||||
private void updateCreatorBackBound() { |
||||
for (int i=0,size=container.getComponentCount(); i<size; i++) { |
||||
XCreator creator = (XCreator) container.getComponent(i); |
||||
creator.updateChildBound(minHeight); |
||||
creator.setBackupBound(creator.getBounds()); |
||||
} |
||||
} |
||||
|
||||
private void addParentCreator(XCreator child) { |
||||
XLayoutContainer parentPanel = child.initCreatorWrapper(child.getHeight()); |
||||
container.add(parentPanel, child.toData().getWidgetName(),0); |
||||
} |
||||
|
||||
/** |
||||
* 新拖入组件时,计算调整其他关联组件位置大小 |
||||
* @param child 新拖入的组件 |
||||
* @param x 鼠标所在x坐标 |
||||
* @param y 鼠标所在y坐标 |
||||
*/ |
||||
private void fixAbsolute(XCreator child, int x, int y) { |
||||
Component parentComp = container.getComponentAt(x, y); |
||||
if (container.getComponentCount()==0){ |
||||
child.setLocation(0, 0); |
||||
child.setSize(parentComp.getWidth(), parentComp.getHeight()); |
||||
} else if(isCrossPointArea(parentComp, x, y)){ |
||||
//交叉区域插入组件时,根据具体位置进行上下或者左右或者相邻三个组件的位置大小插入
|
||||
fixCrossPointArea(parentComp, child, x, y); |
||||
return; |
||||
} else if (isTrisectionArea(parentComp, x, y)) { |
||||
// 在边界三等分区域,就不再和组件二等分了
|
||||
fixTrisect(parentComp, child, x, y); |
||||
return; |
||||
} else{ |
||||
fixHalve(parentComp, child, x, y); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 组件拖拽后调整大小 |
||||
* @param creator 组件 |
||||
*/ |
||||
@Override |
||||
public void fix(XCreator creator) { |
||||
WAbsoluteLayout wabs = (WAbsoluteLayout)container.toData(); |
||||
fix(creator,creator.getX(),creator.getY()); |
||||
wabs.setBounds(creator.toData(),creator.getBounds()); |
||||
|
||||
XWAbsoluteLayout layout = (XWAbsoluteLayout) container; |
||||
layout.updateBoundsWidget(creator); |
||||
} |
||||
|
||||
/** |
||||
* 调整组件大小到合适尺寸位置 |
||||
* @param creator 组件 |
||||
* @param x 坐标x |
||||
* @param y 坐标y |
||||
*/ |
||||
public void fix(XCreator creator ,int x, int y) { |
||||
int height = creator.getHeight(); |
||||
int width = creator.getWidth(); |
||||
if (x < 0) { |
||||
x = container.getX(); |
||||
} else if (x + creator.getWidth() > container.getWidth()) { |
||||
x = container.getWidth() - width; |
||||
} |
||||
|
||||
if (y < 0) { |
||||
y = container.getY(); |
||||
} else if (y + creator.getHeight() > container.getHeight()) { |
||||
y = container.getHeight() - height; |
||||
} |
||||
|
||||
creator.setBounds(x, y, width, height); |
||||
} |
||||
|
||||
@Override |
||||
public ConstraintsGroupModel getLayoutConstraints(XCreator creator) { |
||||
return new BoundsGroupModel((XWAbsoluteLayout)container, creator); |
||||
} |
||||
|
||||
@Override |
||||
public GroupModel getLayoutProperties() { |
||||
XWAbsoluteLayout xwAbsoluteLayout = (XWAbsoluteLayout) container; |
||||
return new FRAbsoluteLayoutPropertiesGroupModel(xwAbsoluteLayout); |
||||
} |
||||
} |
@ -1,141 +1,141 @@
|
||||
package com.fr.design.designer.beans.models; |
||||
|
||||
import java.awt.Rectangle; |
||||
|
||||
import com.fr.design.designer.creator.XWAbsoluteLayout; |
||||
import com.fr.design.mainframe.FormDesigner; |
||||
import com.fr.design.designer.beans.AdapterBus; |
||||
import com.fr.design.designer.beans.ComponentAdapter; |
||||
import com.fr.design.designer.beans.adapters.component.CompositeComponentAdapter; |
||||
import com.fr.design.designer.creator.XCreator; |
||||
import com.fr.design.designer.creator.XLayoutContainer; |
||||
import com.fr.design.designer.creator.XWParameterLayout; |
||||
import com.fr.design.utils.ComponentUtils; |
||||
import com.fr.general.ComparatorUtils; |
||||
|
||||
/** |
||||
* 添加状态下的model |
||||
*/ |
||||
public class AddingModel { |
||||
|
||||
// 当前要添加的组件
|
||||
private XCreator creator; |
||||
// 记录当前鼠标的位置信息
|
||||
private int currentX; |
||||
private int currentY; |
||||
private boolean added; |
||||
|
||||
public AddingModel(FormDesigner designer, XCreator xCreator) { |
||||
String creatorName = getXCreatorName(designer, xCreator); |
||||
this.creator = xCreator; |
||||
instantiateCreator(designer, creatorName); |
||||
// 初始的时候隐藏该组件的图标
|
||||
currentY = -this.creator.getWidth(); |
||||
currentX = -this.creator.getHeight(); |
||||
} |
||||
|
||||
/** |
||||
* 待说明 |
||||
* |
||||
* @param designer 设计器 |
||||
* @param creatorName 组件名 |
||||
*/ |
||||
public void instantiateCreator(FormDesigner designer, String creatorName) { |
||||
creator.toData().setWidgetName(creatorName); |
||||
ComponentAdapter adapter = new CompositeComponentAdapter(designer, creator); |
||||
adapter.initialize(); |
||||
creator.addNotify(); |
||||
creator.putClientProperty(AdapterBus.CLIENT_PROPERTIES, adapter); |
||||
} |
||||
|
||||
public AddingModel(XCreator xCreator, int x, int y) { |
||||
this.creator = xCreator; |
||||
this.creator.backupCurrentSize(); |
||||
this.creator.backupParent(); |
||||
this.creator.setSize(xCreator.initEditorSize()); |
||||
currentX = x - (xCreator.getWidth() / 2); |
||||
currentY = y - (xCreator.getHeight() / 2); |
||||
} |
||||
|
||||
/** |
||||
* 隐藏当前组件的图标 |
||||
*/ |
||||
public void reset() { |
||||
currentX = -this.creator.getWidth(); |
||||
currentY = -this.creator.getHeight(); |
||||
} |
||||
|
||||
public String getXCreatorName(FormDesigner designer, XCreator x) { |
||||
String def = x.createDefaultName(); |
||||
if (x.acceptType(XWParameterLayout.class)) { |
||||
return def; |
||||
} |
||||
int i = 0; |
||||
while (designer.getTarget().isNameExist(def + i)) { |
||||
i++; |
||||
} |
||||
return def + i; |
||||
} |
||||
|
||||
public int getCurrentX() { |
||||
return currentX; |
||||
} |
||||
|
||||
public int getCurrentY() { |
||||
return currentY; |
||||
} |
||||
|
||||
|
||||
/** |
||||
* 移动组件图标到鼠标事件发生的位置 |
||||
* |
||||
* @param x 坐标 |
||||
* @param y 坐标 |
||||
*/ |
||||
public void moveTo(int x, int y) { |
||||
currentX = x - (this.creator.getWidth() / 2); |
||||
currentY = y - (this.creator.getHeight() / 2); |
||||
} |
||||
|
||||
public XCreator getXCreator() { |
||||
return this.creator; |
||||
} |
||||
|
||||
/** |
||||
* 当前组件是否已经添加到某个容器中 |
||||
* |
||||
* @return 是返回true |
||||
*/ |
||||
public boolean isCreatorAdded() { |
||||
return added; |
||||
} |
||||
|
||||
/** |
||||
* 加入容器 |
||||
* |
||||
* @param designer 设计器 |
||||
* @param container 容器 |
||||
* @param x 坐标 |
||||
* @param y 坐标 |
||||
* @return 成功返回true |
||||
*/ |
||||
public boolean add2Container(FormDesigner designer, XLayoutContainer container, int x, int y) { |
||||
//考虑不同布局嵌套的情况,获取顶层容器
|
||||
XLayoutContainer xLayoutContainer = container.getTopLayout(); |
||||
if (xLayoutContainer != null && xLayoutContainer.acceptType(XWAbsoluteLayout.class)) { |
||||
container = xLayoutContainer; |
||||
} |
||||
|
||||
Rectangle rect = ComponentUtils.getRelativeBounds(container); |
||||
if (!ComparatorUtils.equals(container.getOuterLayout(), container.getBackupParent())) { |
||||
added = container.getLayoutAdapter().addBean(creator, |
||||
x + designer.getArea().getHorizontalValue(), |
||||
y + designer.getArea().getVerticalValue()); |
||||
return added; |
||||
} |
||||
added = container.getLayoutAdapter().addBean(creator, |
||||
x + designer.getArea().getHorizontalValue() - rect.x, |
||||
y + designer.getArea().getVerticalValue() - rect.y); |
||||
return added; |
||||
} |
||||
package com.fr.design.designer.beans.models; |
||||
|
||||
import java.awt.Rectangle; |
||||
|
||||
import com.fr.design.designer.creator.XWAbsoluteLayout; |
||||
import com.fr.design.mainframe.FormDesigner; |
||||
import com.fr.design.designer.beans.AdapterBus; |
||||
import com.fr.design.designer.beans.ComponentAdapter; |
||||
import com.fr.design.designer.beans.adapters.component.CompositeComponentAdapter; |
||||
import com.fr.design.designer.creator.XCreator; |
||||
import com.fr.design.designer.creator.XLayoutContainer; |
||||
import com.fr.design.designer.creator.XWParameterLayout; |
||||
import com.fr.design.utils.ComponentUtils; |
||||
import com.fr.general.ComparatorUtils; |
||||
|
||||
/** |
||||
* 添加状态下的model |
||||
*/ |
||||
public class AddingModel { |
||||
|
||||
// 当前要添加的组件
|
||||
private XCreator creator; |
||||
// 记录当前鼠标的位置信息
|
||||
private int currentX; |
||||
private int currentY; |
||||
private boolean added; |
||||
|
||||
public AddingModel(FormDesigner designer, XCreator xCreator) { |
||||
String creatorName = getXCreatorName(designer, xCreator); |
||||
this.creator = xCreator; |
||||
instantiateCreator(designer, creatorName); |
||||
// 初始的时候隐藏该组件的图标
|
||||
currentY = -this.creator.getWidth(); |
||||
currentX = -this.creator.getHeight(); |
||||
} |
||||
|
||||
/** |
||||
* 待说明 |
||||
* |
||||
* @param designer 设计器 |
||||
* @param creatorName 组件名 |
||||
*/ |
||||
public void instantiateCreator(FormDesigner designer, String creatorName) { |
||||
creator.toData().setWidgetName(creatorName); |
||||
ComponentAdapter adapter = new CompositeComponentAdapter(designer, creator); |
||||
adapter.initialize(); |
||||
creator.addNotify(); |
||||
creator.putClientProperty(AdapterBus.CLIENT_PROPERTIES, adapter); |
||||
} |
||||
|
||||
public AddingModel(XCreator xCreator, int x, int y) { |
||||
this.creator = xCreator; |
||||
this.creator.backupCurrentSize(); |
||||
this.creator.backupParent(); |
||||
this.creator.setSize(xCreator.initEditorSize()); |
||||
currentX = x - (xCreator.getWidth() / 2); |
||||
currentY = y - (xCreator.getHeight() / 2); |
||||
} |
||||
|
||||
/** |
||||
* 隐藏当前组件的图标 |
||||
*/ |
||||
public void reset() { |
||||
currentX = -this.creator.getWidth(); |
||||
currentY = -this.creator.getHeight(); |
||||
} |
||||
|
||||
public String getXCreatorName(FormDesigner designer, XCreator x) { |
||||
String def = x.createDefaultName(); |
||||
if (x.acceptType(XWParameterLayout.class)) { |
||||
return def; |
||||
} |
||||
int i = 0; |
||||
while (designer.getTarget().isNameExist(def + i)) { |
||||
i++; |
||||
} |
||||
return def + i; |
||||
} |
||||
|
||||
public int getCurrentX() { |
||||
return currentX; |
||||
} |
||||
|
||||
public int getCurrentY() { |
||||
return currentY; |
||||
} |
||||
|
||||
|
||||
/** |
||||
* 移动组件图标到鼠标事件发生的位置 |
||||
* |
||||
* @param x 坐标 |
||||
* @param y 坐标 |
||||
*/ |
||||
public void moveTo(int x, int y) { |
||||
currentX = x - (this.creator.getWidth() / 2); |
||||
currentY = y - (this.creator.getHeight() / 2); |
||||
} |
||||
|
||||
public XCreator getXCreator() { |
||||
return this.creator; |
||||
} |
||||
|
||||
/** |
||||
* 当前组件是否已经添加到某个容器中 |
||||
* |
||||
* @return 是返回true |
||||
*/ |
||||
public boolean isCreatorAdded() { |
||||
return added; |
||||
} |
||||
|
||||
/** |
||||
* 加入容器 |
||||
* |
||||
* @param designer 设计器 |
||||
* @param container 容器 |
||||
* @param x 坐标 |
||||
* @param y 坐标 |
||||
* @return 成功返回true |
||||
*/ |
||||
public boolean add2Container(FormDesigner designer, XLayoutContainer container, int x, int y) { |
||||
//考虑不同布局嵌套的情况,获取顶层容器
|
||||
XLayoutContainer xLayoutContainer = container.getTopLayout(); |
||||
if (xLayoutContainer != null && xLayoutContainer.acceptType(XWAbsoluteLayout.class)) { |
||||
container = xLayoutContainer; |
||||
} |
||||
|
||||
Rectangle rect = ComponentUtils.getRelativeBounds(container); |
||||
if (!ComparatorUtils.equals(container.getOuterLayout(), container.getBackupParent())) { |
||||
added = container.getLayoutAdapter().addBean(creator, |
||||
x + designer.getArea().getHorizontalValue(), |
||||
y + designer.getArea().getVerticalValue()); |
||||
return added; |
||||
} |
||||
added = container.getLayoutAdapter().addBean(creator, |
||||
x + designer.getArea().getHorizontalValue() - rect.x, |
||||
y + designer.getArea().getVerticalValue() - rect.y); |
||||
return added; |
||||
} |
||||
} |
@ -1,476 +1,476 @@
|
||||
package com.fr.design.designer.beans.models; |
||||
|
||||
import com.fr.design.beans.location.Absorptionline; |
||||
import com.fr.design.designer.beans.AdapterBus; |
||||
import com.fr.design.designer.beans.HoverPainter; |
||||
import com.fr.design.designer.beans.LayoutAdapter; |
||||
import com.fr.design.designer.beans.events.DesignerEvent; |
||||
import com.fr.design.designer.beans.location.Direction; |
||||
import com.fr.design.designer.beans.location.Location; |
||||
import com.fr.design.designer.creator.*; |
||||
import com.fr.design.mainframe.FormDesigner; |
||||
import com.fr.design.mainframe.FormSelectionUtils; |
||||
import com.fr.design.utils.ComponentUtils; |
||||
|
||||
import java.awt.*; |
||||
import java.awt.event.MouseEvent; |
||||
import java.util.ArrayList; |
||||
|
||||
/** |
||||
* 普通模式下的状态model |
||||
*/ |
||||
public class StateModel { |
||||
// 对应的selection model
|
||||
|
||||
private SelectionModel selectionModel; |
||||
// 当前鼠标进入拖拽区域的位置类型
|
||||
private Direction driection; |
||||
|
||||
// 当前拖拽的起始位置
|
||||
private int currentX; |
||||
private int currentY; |
||||
|
||||
//拖拽组件原始位置大小备份
|
||||
private Rectangle selectedPositionBackup; |
||||
|
||||
private Point startPoint = new Point(); |
||||
private Point currentPoint = new Point(); |
||||
|
||||
private Absorptionline lineInX; |
||||
private Absorptionline lineInY; |
||||
//等距线
|
||||
private Absorptionline lineEquidistant; |
||||
|
||||
// 当前是否处于拖拽选择状态
|
||||
private boolean selecting; |
||||
private boolean dragging; |
||||
|
||||
private boolean addable; |
||||
|
||||
private FormDesigner designer; |
||||
|
||||
public StateModel(FormDesigner designer) { |
||||
this.designer = designer; |
||||
selectionModel = designer.getSelectionModel(); |
||||
} |
||||
|
||||
/** |
||||
* 返回direction |
||||
* |
||||
* @return direction方向 |
||||
*/ |
||||
public Direction getDirection() { |
||||
return driection; |
||||
} |
||||
|
||||
/** |
||||
* 是否有组件正被选中 |
||||
* |
||||
* @return true 如果至少一个组件被选中 |
||||
*/ |
||||
public boolean isSelecting() { |
||||
return selecting; |
||||
} |
||||
|
||||
/** |
||||
* 是否能拖拽 |
||||
* |
||||
* @return 非outer且选中为空 |
||||
*/ |
||||
public boolean dragable() { |
||||
return ((driection != Location.outer) && !selecting); |
||||
} |
||||
|
||||
/** |
||||
* 拖拽中是否可以转换为添加模式: |
||||
* 如果拖拽组件只有一个,鼠标当前所在位置的最底层表单容器与这个组件的容器不同; |
||||
* 如果拖拽组件为多个,鼠标当前所在位置的最底层表单容器除了要求要跟这些组件的容器不同外,还必须是绝对定位布局 |
||||
*/ |
||||
private void checkAddable(MouseEvent e) { |
||||
addable = false; |
||||
designer.setPainter(null); |
||||
|
||||
if (driection != Location.inner) { |
||||
return; |
||||
} |
||||
|
||||
XCreator comp = designer.getComponentAt(e.getX(), e.getY(), selectionModel.getSelection().getSelectedCreators()); |
||||
XLayoutContainer container = XCreatorUtils.getHotspotContainer(comp); |
||||
XCreator creator = selectionModel.getSelection().getSelectedCreator(); |
||||
Component creatorContainer = XCreatorUtils.getParentXLayoutContainer(creator); |
||||
if (creatorContainer != null && creatorContainer != container |
||||
&& (selectionModel.getSelection().size() == 1 || container instanceof XWAbsoluteLayout)) { |
||||
HoverPainter painter = AdapterBus.getContainerPainter(designer, container); |
||||
designer.setPainter(painter); |
||||
if (painter != null) { |
||||
Rectangle rect = ComponentUtils.getRelativeBounds(container); |
||||
rect.x -= designer.getArea().getHorizontalValue(); |
||||
rect.y -= designer.getArea().getVerticalValue(); |
||||
painter.setRenderingBounds(rect); |
||||
painter.setHotspot(new Point(e.getX(), e.getY())); |
||||
painter.setCreator(creator); |
||||
} |
||||
addable = true; |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* @param container 容器 |
||||
* @param mouseX 鼠标释放位置X |
||||
* @param mouseY 鼠标释放位置Y |
||||
* @return 是否成功 |
||||
*/ |
||||
private boolean addBean(XLayoutContainer container, int mouseX, int mouseY) { |
||||
LayoutAdapter adapter = container.getLayoutAdapter(); |
||||
Rectangle rectangleContainer = ComponentUtils.getRelativeBounds(container); |
||||
if (selectionModel.getSelection().size() == 1) { |
||||
return adapter.addBean(selectionModel.getSelection().getSelectedCreator(), |
||||
mouseX + designer.getArea().getHorizontalValue() - rectangleContainer.x, |
||||
mouseY + designer.getArea().getVerticalValue() - rectangleContainer.y); |
||||
} |
||||
for (XCreator creator : selectionModel.getSelection().getSelectedCreators()) { |
||||
adapter.addBean(creator, |
||||
mouseX + designer.getArea().getHorizontalValue() - rectangleContainer.x, |
||||
mouseY + designer.getArea().getVerticalValue() - rectangleContainer.y); |
||||
} |
||||
return true; |
||||
} |
||||
|
||||
/** |
||||
* @param mouseReleasedX 鼠标释放位置X |
||||
* @param mouseReleasedY 鼠标释放位置Y |
||||
*/ |
||||
private void adding(int mouseReleasedX, int mouseReleasedY) { |
||||
// 当前鼠标所在的组件
|
||||
XCreator hoveredComponent = designer.getComponentAt(mouseReleasedX, mouseReleasedY, selectionModel.getSelection().getSelectedCreators()); |
||||
|
||||
// 获取该组件所在的焦点容器
|
||||
XLayoutContainer container = XCreatorUtils.getHotspotContainer(hoveredComponent); |
||||
|
||||
boolean success = false; |
||||
|
||||
if (container != null) { |
||||
// 如果是容器,则调用其acceptComponent接受组件
|
||||
success = addBean(container, mouseReleasedX, mouseReleasedY); |
||||
} |
||||
|
||||
if (success) { |
||||
FormSelectionUtils.rebuildSelection(designer); |
||||
designer.getEditListenerTable().fireCreatorModified( |
||||
selectionModel.getSelection().getSelectedCreator(), DesignerEvent.CREATOR_ADDED); |
||||
} else { |
||||
selectionModel.getSelection().setSelectionBounds(selectedPositionBackup, designer); |
||||
Toolkit.getDefaultToolkit().beep(); |
||||
} |
||||
// 取消提示
|
||||
designer.setPainter(null); |
||||
} |
||||
|
||||
/** |
||||
* 是否拖拽 |
||||
* |
||||
* @return dragging状态 |
||||
*/ |
||||
public boolean isDragging() { |
||||
return dragging; |
||||
} |
||||
|
||||
/** |
||||
* 是否可以开始画线 |
||||
* |
||||
* @return startPoint不为空返回true |
||||
*/ |
||||
public boolean prepareForDrawLining() { |
||||
return startPoint != null; |
||||
} |
||||
|
||||
/** |
||||
* 设置开始位置 |
||||
* |
||||
* @param p point位置 |
||||
*/ |
||||
public void setStartPoint(Point p) { |
||||
this.startPoint = p; |
||||
} |
||||
|
||||
/** |
||||
* 返回开始位置 |
||||
* |
||||
* @return 点位置 |
||||
*/ |
||||
public Point getStartPoint() { |
||||
return startPoint; |
||||
} |
||||
|
||||
/** |
||||
* 返回当前点位置 |
||||
* |
||||
* @return 点位置 |
||||
*/ |
||||
public Point getEndPoint() { |
||||
return currentPoint; |
||||
} |
||||
|
||||
/** |
||||
* 当前选中组件 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void startSelecting(MouseEvent e) { |
||||
selecting = true; |
||||
selectionModel.setHotspotBounds(new Rectangle()); |
||||
currentX = getMouseXY(e).x; |
||||
currentY = getMouseXY(e).y; |
||||
} |
||||
|
||||
/** |
||||
* 当前鼠标的xy |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void startResizing(MouseEvent e) { |
||||
if (!selectionModel.getSelection().isEmpty()) { |
||||
driection.backupBounds(designer); |
||||
} |
||||
currentX = getMouseXY(e).x; |
||||
currentY = getMouseXY(e).y; |
||||
} |
||||
|
||||
/** |
||||
* 起始点开始DrawLine |
||||
* |
||||
* @param p 点位置 |
||||
*/ |
||||
public void startDrawLine(Point p) { |
||||
this.startPoint = p; |
||||
if (p != null) { |
||||
try { |
||||
designer.setCursor(XConnector.connectorCursor); |
||||
} catch (Exception e) { |
||||
} |
||||
} else { |
||||
designer.setCursor(Cursor.getPredefinedCursor(Cursor.DEFAULT_CURSOR)); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 鼠标释放时所在的区域及圈中的组件 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void selectCreators(MouseEvent e) { |
||||
int x = getMouseXY(e).x; |
||||
int y = getMouseXY(e).y; |
||||
|
||||
Rectangle bounds = createCurrentBounds(x, y); |
||||
|
||||
if ((x != currentX) || (y != currentY)) { |
||||
selectionModel.setSelectedCreators(getHotspotCreators(bounds, designer.getRootComponent())); |
||||
} |
||||
selectionModel.setHotspotBounds(null); |
||||
} |
||||
|
||||
/** |
||||
* 画所在区域线 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void drawLine(MouseEvent e) { |
||||
designer.getDrawLineHelper().setDrawLine(true); |
||||
Point p = designer.getDrawLineHelper().getNearWidgetPoint(e); |
||||
if (p != null) { |
||||
currentPoint = p; |
||||
} else { |
||||
currentPoint.x = e.getX() + designer.getArea().getHorizontalValue(); |
||||
currentPoint.y = e.getY() + designer.getArea().getVerticalValue(); |
||||
} |
||||
} |
||||
|
||||
private Rectangle createCurrentBounds(int x, int y) { |
||||
Rectangle bounds = new Rectangle(); |
||||
|
||||
bounds.x = Math.min(x, currentX); |
||||
bounds.y = Math.min(y, currentY); |
||||
bounds.width = Math.max(x, currentX) - bounds.x; |
||||
bounds.height = Math.max(y, currentY) - bounds.y; |
||||
|
||||
return bounds; |
||||
} |
||||
|
||||
private ArrayList<XCreator> getHotspotCreators(Rectangle selection, XCreator root) { |
||||
ArrayList<XCreator> creators = new ArrayList<>(); |
||||
|
||||
if (!root.isVisible() && !designer.isRoot(root)) { |
||||
return creators; |
||||
} |
||||
|
||||
if (root instanceof XLayoutContainer) { |
||||
XLayoutContainer container = (XLayoutContainer) root; |
||||
int count = container.getXCreatorCount(); |
||||
Rectangle clipped = new Rectangle(selection); |
||||
|
||||
for (int i = count - 1; i >= 0; i--) { |
||||
XCreator child = container.getXCreator(i); |
||||
|
||||
if (selection.contains(child.getBounds())) { |
||||
creators.add(child); |
||||
} else { |
||||
clipped.x = selection.x - child.getX(); |
||||
clipped.y = selection.y - child.getY(); |
||||
creators.addAll(getHotspotCreators(clipped, child)); |
||||
} |
||||
} |
||||
} |
||||
|
||||
return creators; |
||||
} |
||||
|
||||
|
||||
/** |
||||
* 重置model |
||||
*/ |
||||
public void resetModel() { |
||||
dragging = false; |
||||
selecting = false; |
||||
} |
||||
|
||||
/** |
||||
* 重置 |
||||
*/ |
||||
public void reset() { |
||||
driection = Location.outer; |
||||
dragging = false; |
||||
selecting = false; |
||||
} |
||||
|
||||
/** |
||||
* 取消拖拽 |
||||
*/ |
||||
public void draggingCancel() { |
||||
designer.repaint(); |
||||
reset(); |
||||
} |
||||
|
||||
/** |
||||
* 设置可拉伸方向 |
||||
* |
||||
* @param dir 拉伸方向 |
||||
*/ |
||||
public void setDirection(Direction dir) { |
||||
if (driection != dir) { |
||||
this.driection = dir; |
||||
driection.updateCursor(designer); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* x吸附线赋值 |
||||
* |
||||
* @param line 线 |
||||
*/ |
||||
public void setXAbsorptionline(Absorptionline line) { |
||||
this.lineInX = line; |
||||
} |
||||
|
||||
/** |
||||
* y吸附线赋值 |
||||
* |
||||
* @param line 线 |
||||
*/ |
||||
public void setYAbsorptionline(Absorptionline line) { |
||||
this.lineInY = line; |
||||
} |
||||
|
||||
/** |
||||
* 等距线赋值 |
||||
* |
||||
* @param line 线 |
||||
*/ |
||||
public void setEquidistantLine(Absorptionline line) { |
||||
this.lineEquidistant = line; |
||||
} |
||||
|
||||
/** |
||||
* 画吸附线 |
||||
* |
||||
* @param g Graphics类 |
||||
*/ |
||||
public void paintAbsorptionline(Graphics g) { |
||||
if (lineInX != null) { |
||||
lineInX.paint(g, designer.getArea()); |
||||
} |
||||
if (lineInY != null) { |
||||
lineInY.paint(g, designer.getArea()); |
||||
} |
||||
if (lineEquidistant != null) { |
||||
lineEquidistant.paint(g, designer.getArea()); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 拖拽 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void dragging(MouseEvent e) { |
||||
//进入dragging状态时备份组件大小和位置
|
||||
if (!dragging) { |
||||
selectedPositionBackup = selectionModel.getSelection().getRelativeBounds(); |
||||
} |
||||
checkAddable(e); |
||||
setDependLinePainter(e); |
||||
driection.drag(getMouseXY(e).x - currentX, getMouseXY(e).y - currentY, designer); |
||||
this.dragging = true; |
||||
} |
||||
|
||||
// 拖拽时画依附线用到的painter
|
||||
private void setDependLinePainter(MouseEvent e) { |
||||
XCreator comp = designer.getComponentAt(e.getX(), e.getY(), selectionModel.getSelection().getSelectedCreators()); |
||||
XLayoutContainer container = XCreatorUtils.getHotspotContainer(comp); |
||||
XCreator creator = selectionModel.getSelection().getSelectedCreator(); |
||||
HoverPainter painter = AdapterBus.getContainerPainter(designer, container); |
||||
designer.setPainter(painter); |
||||
if (painter != null) { |
||||
painter.setHotspot(new Point(e.getX(), e.getY())); |
||||
painter.setCreator(creator); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 释放捕获 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void releaseDragging(MouseEvent e) { |
||||
this.dragging = false; |
||||
if (addable) { |
||||
adding(e.getX(), e.getY()); |
||||
} else if (!selectionModel.getSelection().isEmpty()) { |
||||
selectionModel.releaseDragging(); |
||||
} |
||||
designer.repaint(); |
||||
} |
||||
|
||||
/** |
||||
* 改变选择区域 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void changeSelection(MouseEvent e) { |
||||
Rectangle bounds = createCurrentBounds(getMouseXY(e).x, getMouseXY(e).y); |
||||
selectionModel.setHotspotBounds(bounds); |
||||
} |
||||
|
||||
/** |
||||
* 返回鼠标所在的x、y 考虑滚动条的值 |
||||
* |
||||
* @param e 鼠标事件 |
||||
* @return xy值 |
||||
*/ |
||||
public Point getMouseXY(MouseEvent e) { |
||||
Point p1 = new Point(e.getX() + designer.getArea().getHorizontalValue(), e.getY() |
||||
+ designer.getArea().getVerticalValue()); |
||||
return p1; |
||||
} |
||||
|
||||
package com.fr.design.designer.beans.models; |
||||
|
||||
import com.fr.design.beans.location.Absorptionline; |
||||
import com.fr.design.designer.beans.AdapterBus; |
||||
import com.fr.design.designer.beans.HoverPainter; |
||||
import com.fr.design.designer.beans.LayoutAdapter; |
||||
import com.fr.design.designer.beans.events.DesignerEvent; |
||||
import com.fr.design.designer.beans.location.Direction; |
||||
import com.fr.design.designer.beans.location.Location; |
||||
import com.fr.design.designer.creator.*; |
||||
import com.fr.design.mainframe.FormDesigner; |
||||
import com.fr.design.mainframe.FormSelectionUtils; |
||||
import com.fr.design.utils.ComponentUtils; |
||||
|
||||
import java.awt.*; |
||||
import java.awt.event.MouseEvent; |
||||
import java.util.ArrayList; |
||||
|
||||
/** |
||||
* 普通模式下的状态model |
||||
*/ |
||||
public class StateModel { |
||||
// 对应的selection model
|
||||
|
||||
private SelectionModel selectionModel; |
||||
// 当前鼠标进入拖拽区域的位置类型
|
||||
private Direction driection; |
||||
|
||||
// 当前拖拽的起始位置
|
||||
private int currentX; |
||||
private int currentY; |
||||
|
||||
//拖拽组件原始位置大小备份
|
||||
private Rectangle selectedPositionBackup; |
||||
|
||||
private Point startPoint = new Point(); |
||||
private Point currentPoint = new Point(); |
||||
|
||||
private Absorptionline lineInX; |
||||
private Absorptionline lineInY; |
||||
//等距线
|
||||
private Absorptionline lineEquidistant; |
||||
|
||||
// 当前是否处于拖拽选择状态
|
||||
private boolean selecting; |
||||
private boolean dragging; |
||||
|
||||
private boolean addable; |
||||
|
||||
private FormDesigner designer; |
||||
|
||||
public StateModel(FormDesigner designer) { |
||||
this.designer = designer; |
||||
selectionModel = designer.getSelectionModel(); |
||||
} |
||||
|
||||
/** |
||||
* 返回direction |
||||
* |
||||
* @return direction方向 |
||||
*/ |
||||
public Direction getDirection() { |
||||
return driection; |
||||
} |
||||
|
||||
/** |
||||
* 是否有组件正被选中 |
||||
* |
||||
* @return true 如果至少一个组件被选中 |
||||
*/ |
||||
public boolean isSelecting() { |
||||
return selecting; |
||||
} |
||||
|
||||
/** |
||||
* 是否能拖拽 |
||||
* |
||||
* @return 非outer且选中为空 |
||||
*/ |
||||
public boolean dragable() { |
||||
return ((driection != Location.outer) && !selecting); |
||||
} |
||||
|
||||
/** |
||||
* 拖拽中是否可以转换为添加模式: |
||||
* 如果拖拽组件只有一个,鼠标当前所在位置的最底层表单容器与这个组件的容器不同; |
||||
* 如果拖拽组件为多个,鼠标当前所在位置的最底层表单容器除了要求要跟这些组件的容器不同外,还必须是绝对定位布局 |
||||
*/ |
||||
private void checkAddable(MouseEvent e) { |
||||
addable = false; |
||||
designer.setPainter(null); |
||||
|
||||
if (driection != Location.inner) { |
||||
return; |
||||
} |
||||
|
||||
XCreator comp = designer.getComponentAt(e.getX(), e.getY(), selectionModel.getSelection().getSelectedCreators()); |
||||
XLayoutContainer container = XCreatorUtils.getHotspotContainer(comp); |
||||
XCreator creator = selectionModel.getSelection().getSelectedCreator(); |
||||
Component creatorContainer = XCreatorUtils.getParentXLayoutContainer(creator); |
||||
if (creatorContainer != null && creatorContainer != container |
||||
&& (selectionModel.getSelection().size() == 1 || container instanceof XWAbsoluteLayout)) { |
||||
HoverPainter painter = AdapterBus.getContainerPainter(designer, container); |
||||
designer.setPainter(painter); |
||||
if (painter != null) { |
||||
Rectangle rect = ComponentUtils.getRelativeBounds(container); |
||||
rect.x -= designer.getArea().getHorizontalValue(); |
||||
rect.y -= designer.getArea().getVerticalValue(); |
||||
painter.setRenderingBounds(rect); |
||||
painter.setHotspot(new Point(e.getX(), e.getY())); |
||||
painter.setCreator(creator); |
||||
} |
||||
addable = true; |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* @param container 容器 |
||||
* @param mouseX 鼠标释放位置X |
||||
* @param mouseY 鼠标释放位置Y |
||||
* @return 是否成功 |
||||
*/ |
||||
private boolean addBean(XLayoutContainer container, int mouseX, int mouseY) { |
||||
LayoutAdapter adapter = container.getLayoutAdapter(); |
||||
Rectangle rectangleContainer = ComponentUtils.getRelativeBounds(container); |
||||
if (selectionModel.getSelection().size() == 1) { |
||||
return adapter.addBean(selectionModel.getSelection().getSelectedCreator(), |
||||
mouseX + designer.getArea().getHorizontalValue() - rectangleContainer.x, |
||||
mouseY + designer.getArea().getVerticalValue() - rectangleContainer.y); |
||||
} |
||||
for (XCreator creator : selectionModel.getSelection().getSelectedCreators()) { |
||||
adapter.addBean(creator, |
||||
mouseX + designer.getArea().getHorizontalValue() - rectangleContainer.x, |
||||
mouseY + designer.getArea().getVerticalValue() - rectangleContainer.y); |
||||
} |
||||
return true; |
||||
} |
||||
|
||||
/** |
||||
* @param mouseReleasedX 鼠标释放位置X |
||||
* @param mouseReleasedY 鼠标释放位置Y |
||||
*/ |
||||
private void adding(int mouseReleasedX, int mouseReleasedY) { |
||||
// 当前鼠标所在的组件
|
||||
XCreator hoveredComponent = designer.getComponentAt(mouseReleasedX, mouseReleasedY, selectionModel.getSelection().getSelectedCreators()); |
||||
|
||||
// 获取该组件所在的焦点容器
|
||||
XLayoutContainer container = XCreatorUtils.getHotspotContainer(hoveredComponent); |
||||
|
||||
boolean success = false; |
||||
|
||||
if (container != null) { |
||||
// 如果是容器,则调用其acceptComponent接受组件
|
||||
success = addBean(container, mouseReleasedX, mouseReleasedY); |
||||
} |
||||
|
||||
if (success) { |
||||
FormSelectionUtils.rebuildSelection(designer); |
||||
designer.getEditListenerTable().fireCreatorModified( |
||||
selectionModel.getSelection().getSelectedCreator(), DesignerEvent.CREATOR_ADDED); |
||||
} else { |
||||
selectionModel.getSelection().setSelectionBounds(selectedPositionBackup, designer); |
||||
Toolkit.getDefaultToolkit().beep(); |
||||
} |
||||
// 取消提示
|
||||
designer.setPainter(null); |
||||
} |
||||
|
||||
/** |
||||
* 是否拖拽 |
||||
* |
||||
* @return dragging状态 |
||||
*/ |
||||
public boolean isDragging() { |
||||
return dragging; |
||||
} |
||||
|
||||
/** |
||||
* 是否可以开始画线 |
||||
* |
||||
* @return startPoint不为空返回true |
||||
*/ |
||||
public boolean prepareForDrawLining() { |
||||
return startPoint != null; |
||||
} |
||||
|
||||
/** |
||||
* 设置开始位置 |
||||
* |
||||
* @param p point位置 |
||||
*/ |
||||
public void setStartPoint(Point p) { |
||||
this.startPoint = p; |
||||
} |
||||
|
||||
/** |
||||
* 返回开始位置 |
||||
* |
||||
* @return 点位置 |
||||
*/ |
||||
public Point getStartPoint() { |
||||
return startPoint; |
||||
} |
||||
|
||||
/** |
||||
* 返回当前点位置 |
||||
* |
||||
* @return 点位置 |
||||
*/ |
||||
public Point getEndPoint() { |
||||
return currentPoint; |
||||
} |
||||
|
||||
/** |
||||
* 当前选中组件 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void startSelecting(MouseEvent e) { |
||||
selecting = true; |
||||
selectionModel.setHotspotBounds(new Rectangle()); |
||||
currentX = getMouseXY(e).x; |
||||
currentY = getMouseXY(e).y; |
||||
} |
||||
|
||||
/** |
||||
* 当前鼠标的xy |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void startResizing(MouseEvent e) { |
||||
if (!selectionModel.getSelection().isEmpty()) { |
||||
driection.backupBounds(designer); |
||||
} |
||||
currentX = getMouseXY(e).x; |
||||
currentY = getMouseXY(e).y; |
||||
} |
||||
|
||||
/** |
||||
* 起始点开始DrawLine |
||||
* |
||||
* @param p 点位置 |
||||
*/ |
||||
public void startDrawLine(Point p) { |
||||
this.startPoint = p; |
||||
if (p != null) { |
||||
try { |
||||
designer.setCursor(XConnector.connectorCursor); |
||||
} catch (Exception e) { |
||||
} |
||||
} else { |
||||
designer.setCursor(Cursor.getPredefinedCursor(Cursor.DEFAULT_CURSOR)); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 鼠标释放时所在的区域及圈中的组件 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void selectCreators(MouseEvent e) { |
||||
int x = getMouseXY(e).x; |
||||
int y = getMouseXY(e).y; |
||||
|
||||
Rectangle bounds = createCurrentBounds(x, y); |
||||
|
||||
if ((x != currentX) || (y != currentY)) { |
||||
selectionModel.setSelectedCreators(getHotspotCreators(bounds, designer.getRootComponent())); |
||||
} |
||||
selectionModel.setHotspotBounds(null); |
||||
} |
||||
|
||||
/** |
||||
* 画所在区域线 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void drawLine(MouseEvent e) { |
||||
designer.getDrawLineHelper().setDrawLine(true); |
||||
Point p = designer.getDrawLineHelper().getNearWidgetPoint(e); |
||||
if (p != null) { |
||||
currentPoint = p; |
||||
} else { |
||||
currentPoint.x = e.getX() + designer.getArea().getHorizontalValue(); |
||||
currentPoint.y = e.getY() + designer.getArea().getVerticalValue(); |
||||
} |
||||
} |
||||
|
||||
private Rectangle createCurrentBounds(int x, int y) { |
||||
Rectangle bounds = new Rectangle(); |
||||
|
||||
bounds.x = Math.min(x, currentX); |
||||
bounds.y = Math.min(y, currentY); |
||||
bounds.width = Math.max(x, currentX) - bounds.x; |
||||
bounds.height = Math.max(y, currentY) - bounds.y; |
||||
|
||||
return bounds; |
||||
} |
||||
|
||||
private ArrayList<XCreator> getHotspotCreators(Rectangle selection, XCreator root) { |
||||
ArrayList<XCreator> creators = new ArrayList<>(); |
||||
|
||||
if (!root.isVisible() && !designer.isRoot(root)) { |
||||
return creators; |
||||
} |
||||
|
||||
if (root instanceof XLayoutContainer) { |
||||
XLayoutContainer container = (XLayoutContainer) root; |
||||
int count = container.getXCreatorCount(); |
||||
Rectangle clipped = new Rectangle(selection); |
||||
|
||||
for (int i = count - 1; i >= 0; i--) { |
||||
XCreator child = container.getXCreator(i); |
||||
|
||||
if (selection.contains(child.getBounds())) { |
||||
creators.add(child); |
||||
} else { |
||||
clipped.x = selection.x - child.getX(); |
||||
clipped.y = selection.y - child.getY(); |
||||
creators.addAll(getHotspotCreators(clipped, child)); |
||||
} |
||||
} |
||||
} |
||||
|
||||
return creators; |
||||
} |
||||
|
||||
|
||||
/** |
||||
* 重置model |
||||
*/ |
||||
public void resetModel() { |
||||
dragging = false; |
||||
selecting = false; |
||||
} |
||||
|
||||
/** |
||||
* 重置 |
||||
*/ |
||||
public void reset() { |
||||
driection = Location.outer; |
||||
dragging = false; |
||||
selecting = false; |
||||
} |
||||
|
||||
/** |
||||
* 取消拖拽 |
||||
*/ |
||||
public void draggingCancel() { |
||||
designer.repaint(); |
||||
reset(); |
||||
} |
||||
|
||||
/** |
||||
* 设置可拉伸方向 |
||||
* |
||||
* @param dir 拉伸方向 |
||||
*/ |
||||
public void setDirection(Direction dir) { |
||||
if (driection != dir) { |
||||
this.driection = dir; |
||||
driection.updateCursor(designer); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* x吸附线赋值 |
||||
* |
||||
* @param line 线 |
||||
*/ |
||||
public void setXAbsorptionline(Absorptionline line) { |
||||
this.lineInX = line; |
||||
} |
||||
|
||||
/** |
||||
* y吸附线赋值 |
||||
* |
||||
* @param line 线 |
||||
*/ |
||||
public void setYAbsorptionline(Absorptionline line) { |
||||
this.lineInY = line; |
||||
} |
||||
|
||||
/** |
||||
* 等距线赋值 |
||||
* |
||||
* @param line 线 |
||||
*/ |
||||
public void setEquidistantLine(Absorptionline line) { |
||||
this.lineEquidistant = line; |
||||
} |
||||
|
||||
/** |
||||
* 画吸附线 |
||||
* |
||||
* @param g Graphics类 |
||||
*/ |
||||
public void paintAbsorptionline(Graphics g) { |
||||
if (lineInX != null) { |
||||
lineInX.paint(g, designer.getArea()); |
||||
} |
||||
if (lineInY != null) { |
||||
lineInY.paint(g, designer.getArea()); |
||||
} |
||||
if (lineEquidistant != null) { |
||||
lineEquidistant.paint(g, designer.getArea()); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 拖拽 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void dragging(MouseEvent e) { |
||||
//进入dragging状态时备份组件大小和位置
|
||||
if (!dragging) { |
||||
selectedPositionBackup = selectionModel.getSelection().getRelativeBounds(); |
||||
} |
||||
checkAddable(e); |
||||
setDependLinePainter(e); |
||||
driection.drag(getMouseXY(e).x - currentX, getMouseXY(e).y - currentY, designer); |
||||
this.dragging = true; |
||||
} |
||||
|
||||
// 拖拽时画依附线用到的painter
|
||||
private void setDependLinePainter(MouseEvent e) { |
||||
XCreator comp = designer.getComponentAt(e.getX(), e.getY(), selectionModel.getSelection().getSelectedCreators()); |
||||
XLayoutContainer container = XCreatorUtils.getHotspotContainer(comp); |
||||
XCreator creator = selectionModel.getSelection().getSelectedCreator(); |
||||
HoverPainter painter = AdapterBus.getContainerPainter(designer, container); |
||||
designer.setPainter(painter); |
||||
if (painter != null) { |
||||
painter.setHotspot(new Point(e.getX(), e.getY())); |
||||
painter.setCreator(creator); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 释放捕获 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void releaseDragging(MouseEvent e) { |
||||
this.dragging = false; |
||||
if (addable) { |
||||
adding(e.getX(), e.getY()); |
||||
} else if (!selectionModel.getSelection().isEmpty()) { |
||||
selectionModel.releaseDragging(); |
||||
} |
||||
designer.repaint(); |
||||
} |
||||
|
||||
/** |
||||
* 改变选择区域 |
||||
* |
||||
* @param e 鼠标事件 |
||||
*/ |
||||
public void changeSelection(MouseEvent e) { |
||||
Rectangle bounds = createCurrentBounds(getMouseXY(e).x, getMouseXY(e).y); |
||||
selectionModel.setHotspotBounds(bounds); |
||||
} |
||||
|
||||
/** |
||||
* 返回鼠标所在的x、y 考虑滚动条的值 |
||||
* |
||||
* @param e 鼠标事件 |
||||
* @return xy值 |
||||
*/ |
||||
public Point getMouseXY(MouseEvent e) { |
||||
Point p1 = new Point(e.getX() + designer.getArea().getHorizontalValue(), e.getY() |
||||
+ designer.getArea().getVerticalValue()); |
||||
return p1; |
||||
} |
||||
|
||||
} |
@ -1,96 +1,96 @@
|
||||
package com.fr.design.designer.beans.painters; |
||||
|
||||
import java.awt.Color; |
||||
import java.awt.Graphics; |
||||
import java.awt.Graphics2D; |
||||
import java.awt.Point; |
||||
import java.awt.Rectangle; |
||||
import java.awt.Stroke; |
||||
|
||||
import com.fr.design.designer.beans.HoverPainter; |
||||
import com.fr.design.designer.creator.XCreator; |
||||
import com.fr.design.designer.creator.XLayoutContainer; |
||||
import com.fr.design.form.util.XCreatorConstants; |
||||
import com.fr.general.Inter; |
||||
|
||||
public abstract class AbstractPainter implements HoverPainter { |
||||
|
||||
protected Point hotspot; |
||||
protected Rectangle hotspot_bounds; |
||||
protected XLayoutContainer container; |
||||
protected XCreator creator; |
||||
|
||||
/** |
||||
* 构造函数 |
||||
* |
||||
* @param container 容器 |
||||
*/ |
||||
public AbstractPainter(XLayoutContainer container) { |
||||
this.container = container; |
||||
} |
||||
|
||||
@Override |
||||
public void setHotspot(Point p) { |
||||
hotspot = p; |
||||
} |
||||
|
||||
/** |
||||
* 画初始区域 |
||||
* |
||||
* @param g 画图类 |
||||
* @param startX 起始x位置 |
||||
* @param startY 起始y位置 |
||||
*/ |
||||
public void paint(Graphics g, int startX, int startY) { |
||||
if (hotspot_bounds != null) { |
||||
drawHotspot(g, hotspot_bounds.x, hotspot_bounds.y, hotspot_bounds.width, hotspot_bounds.height, Color.lightGray, true, false); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 设置边界 |
||||
* |
||||
* @param rect 位置 |
||||
*/ |
||||
@Override |
||||
public void setRenderingBounds(Rectangle rect) { |
||||
hotspot_bounds = rect; |
||||
} |
||||
|
||||
@Override |
||||
public void setCreator(XCreator component) { |
||||
this.creator = component; |
||||
} |
||||
|
||||
protected void drawHotspot(Graphics g, int x, int y, int width, int height, boolean accept) { |
||||
Color bColor = accept ? XCreatorConstants.LAYOUT_HOTSPOT_COLOR : XCreatorConstants.LAYOUT_FORBIDDEN_COLOR; |
||||
drawHotspot(g, x, y, width, height, bColor, accept, false); |
||||
} |
||||
|
||||
/** |
||||
* 自适应布局那边渲染提示,要画整个背景,不是画边框 |
||||
*/ |
||||
protected void drawRegionBackground(Graphics g, int x, int y, int width, int height, Color bColor, boolean accept) { |
||||
drawHotspot(g, x, y, width, height, bColor, accept, true); |
||||
} |
||||
|
||||
protected void drawHotspot(Graphics g, int x, int y, int width, int height, Color bColor, boolean accept, boolean drawBackground) { |
||||
Graphics2D g2d = (Graphics2D) g; |
||||
Color color = g2d.getColor(); |
||||
Stroke backup = g2d.getStroke(); |
||||
// 设置线条的样式
|
||||
g2d.setStroke(XCreatorConstants.STROKE); |
||||
g2d.setColor(bColor); |
||||
if (!accept) { |
||||
g2d.drawString(Inter.getLocText("Cannot-Add_To_This_Area") + "!", x + width / 3, y + height / 2); |
||||
} else if (drawBackground) { |
||||
g2d.fillRect(x, y, width, height); |
||||
} else { |
||||
g2d.drawRect(x, y, width, height); |
||||
} |
||||
g2d.setStroke(backup); |
||||
g2d.setColor(color); |
||||
} |
||||
|
||||
|
||||
package com.fr.design.designer.beans.painters; |
||||
|
||||
import java.awt.Color; |
||||
import java.awt.Graphics; |
||||
import java.awt.Graphics2D; |
||||
import java.awt.Point; |
||||
import java.awt.Rectangle; |
||||
import java.awt.Stroke; |
||||
|
||||
import com.fr.design.designer.beans.HoverPainter; |
||||
import com.fr.design.designer.creator.XCreator; |
||||
import com.fr.design.designer.creator.XLayoutContainer; |
||||
import com.fr.design.form.util.XCreatorConstants; |
||||
import com.fr.general.Inter; |
||||
|
||||
public abstract class AbstractPainter implements HoverPainter { |
||||
|
||||
protected Point hotspot; |
||||
protected Rectangle hotspot_bounds; |
||||
protected XLayoutContainer container; |
||||
protected XCreator creator; |
||||
|
||||
/** |
||||
* 构造函数 |
||||
* |
||||
* @param container 容器 |
||||
*/ |
||||
public AbstractPainter(XLayoutContainer container) { |
||||
this.container = container; |
||||
} |
||||
|
||||
@Override |
||||
public void setHotspot(Point p) { |
||||
hotspot = p; |
||||
} |
||||
|
||||
/** |
||||
* 画初始区域 |
||||
* |
||||
* @param g 画图类 |
||||
* @param startX 起始x位置 |
||||
* @param startY 起始y位置 |
||||
*/ |
||||
public void paint(Graphics g, int startX, int startY) { |
||||
if (hotspot_bounds != null) { |
||||
drawHotspot(g, hotspot_bounds.x, hotspot_bounds.y, hotspot_bounds.width, hotspot_bounds.height, Color.lightGray, true, false); |
||||
} |
||||
} |
||||
|
||||
/** |
||||
* 设置边界 |
||||
* |
||||
* @param rect 位置 |
||||
*/ |
||||
@Override |
||||
public void setRenderingBounds(Rectangle rect) { |
||||
hotspot_bounds = rect; |
||||
} |
||||
|
||||
@Override |
||||
public void setCreator(XCreator component) { |
||||
this.creator = component; |
||||
} |
||||
|
||||
protected void drawHotspot(Graphics g, int x, int y, int width, int height, boolean accept) { |
||||
Color bColor = accept ? XCreatorConstants.LAYOUT_HOTSPOT_COLOR : XCreatorConstants.LAYOUT_FORBIDDEN_COLOR; |
||||
drawHotspot(g, x, y, width, height, bColor, accept, false); |
||||
} |
||||
|
||||
/** |
||||
* 自适应布局那边渲染提示,要画整个背景,不是画边框 |
||||
*/ |
||||
protected void drawRegionBackground(Graphics g, int x, int y, int width, int height, Color bColor, boolean accept) { |
||||
drawHotspot(g, x, y, width, height, bColor, accept, true); |
||||
} |
||||
|
||||
protected void drawHotspot(Graphics g, int x, int y, int width, int height, Color bColor, boolean accept, boolean drawBackground) { |
||||
Graphics2D g2d = (Graphics2D) g; |
||||
Color color = g2d.getColor(); |
||||
Stroke backup = g2d.getStroke(); |
||||
// 设置线条的样式
|
||||
g2d.setStroke(XCreatorConstants.STROKE); |
||||
g2d.setColor(bColor); |
||||
if (!accept) { |
||||
g2d.drawString(Inter.getLocText("Cannot-Add_To_This_Area") + "!", x + width / 3, y + height / 2); |
||||
} else if (drawBackground) { |
||||
g2d.fillRect(x, y, width, height); |
||||
} else { |
||||
g2d.drawRect(x, y, width, height); |
||||
} |
||||
g2d.setStroke(backup); |
||||
g2d.setColor(color); |
||||
} |
||||
|
||||
|
||||
} |