基于eclipse GEF开发Google GWT矢量图形应用(eclipse gef on gwt)
下面这个整合案例来自http://code.google.com/p/gwt-html5-graph/
实际的运行案例:
Demo1(GEF Sample): http://euml.trufun.net/drawx/gef-sample/Gef_sample.html
源码:
1、在gwt.xml中加入对GEF的依赖:
<inherits name='GEF' />
2、按照GEF API,开发相应的editparts, figures, commands, editpolicies,actions,context menus,以及图形数据的序列化
3、整合GEF和GWT。
3.1)继承drawx提供的DiagramEditorWithPalette,如下:
import org.drawx.gef.sample.client.tool.example.model.CanvasModel;
import org.drawx.gef.sample.client.tool.example.model.MyConnectionModel;
import org.drawx.gef.sample.client.tool.example.model.OrangeModel;
import org.drawx.gef.ui.editor.DiagramEditorWithPalette;
import org.drawx.gef.ui.editor.ToolPalette;
import org.eclipse.gef.EditPartFactory;
import org.eclipse.gef.requests.CreationFactory;
import org.eclipse.swt.widgets.internal.menu.MenuManager;
import com.google.gwt.user.client.ui.Image;
public class MyDiagramEditor extends DiagramEditorWithPalette{
public MyDiagramEditor(boolean b) {
super(b);
}
@Override
public EditPartFactory getEditPartFactory() {
return new org.drawx.gef.sample.client.tool.example.editparts.MyEditPartFactory();
}
@Override
public Object getContents() {
return new CanvasModel();
}
@Override
public void initPalette(ToolPalette palette) {
palette.addCreationTool("Create Node", new Image(Images.INSTANCE.newModel().getURL()), new CreationFactory() {
public Object getNewObject() {
return new OrangeModel();
}
public Object getObjectType() {
return OrangeModel.class;
}
});
palette.addConnectionTool("Create Connection", new Image(Images.INSTANCE.newConnection().getURL()), new CreationFactory() {
public Object getNewObject() {
return new MyConnectionModel();
}
public Object getObjectType() {
return MyConnectionModel.class;
}
});
}
@Override
protected void doSave() {
}
@Override
protected void createAppActions() {
}
@Override
protected MenuManager getContextMenu() {
return new MyContextMenuProvider(this.getGraphicalViewer(), this
.getActionRegistry());
}
}
3.2)将diagram editor加入到WEB页面上
private void createTab1(TabLayoutPanel p) {
DiagramEditorWithPalette editor = new MyDiagramEditor(true);
p.add(editor.getWidget(), "Fill Canvas");
}