- 浏览: 987542 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
运乃强谦:
老哥,你确定这个wsdl 地址 可以访问?
[CXF] Server与Client实现方式五:HTTPS -
wangyudong:
由CXF实现的微服务需要有比较好的工具去测试RESTful A ...
[CXF] Server与Client实现方式四:JMS -
dengmiao:
JAXB学习三 (验证) -
panamera:
你好。可以提供maven pom配置是怎么配置的?不知道你使用 ...
[CXF] Server与Client实现方式四:JMS -
u010221220:
请问楼主一二三部分的代码都应该放在哪个函数体中。
使用JDI监听Java程序运行
一、增加属性页的支持
return null; } public IPropertyDescriptor[] getPropertyDescriptors() { IPropertyDescriptor[] descriptors = new IPropertyDescriptor[5]; descriptors[0] = new TextPropertyDescriptor(HelloWorldModel.P_TEXT, "name"); descriptors[1] = new TextPropertyDescriptor("x", "x"); descriptors[2] = new TextPropertyDescriptor("y", "y"); descriptors[3] = new TextPropertyDescriptor("width", "width"); descriptors[4] = new TextPropertyDescriptor("height", "height"); return descriptors; } public Object getPropertyValue(Object id) { HelloWorldModel model = (HelloWorldModel) getModel(); Rectangle constraints = model.getConstraints(); if (id.equals(HelloWorldModel.P_TEXT)) { return model.getText(); } else if (id.equals("x")) { return constraints.x+""; } else if (id.equals("y")) { return constraints.y+""; } else if (id.equals("width")) { return constraints.width+""; } else if (id.equals("height")) { return constraints.height+""; } return null; } public boolean isPropertySet(Object id) { return true; } public void resetPropertyValue(Object id) { HelloWorldModel model = (HelloWorldModel) getModel(); if (id.equals(HelloWorldModel.P_TEXT)) { (model).setText("<unname>"); } else { model.setConstraints(new Rectangle(0, 0, 100, 20)); } } public void setPropertyValue(Object id, Object value) { HelloWorldModel model = (HelloWorldModel) getModel(); Rectangle constraints = model.getConstraints(); if (id.equals(HelloWorldModel.P_TEXT)) { ((HelloWorldModel) getModel()).setText(value.toString()); } else { int parseInt = Integer.parseInt(value.toString()); if (id.equals("x")) { constraints = new Rectangle(parseInt, constraints.y, constraints.width, constraints.height); } else if (id.equals("y")) { constraints = new Rectangle(constraints.x, parseInt, constraints.width, constraints.height); } else if (id.equals("width")) { constraints = new Rectangle(constraints.x, constraints.y, parseInt, constraints.height); } else if (id.equals("height")) { constraints = new Rectangle(constraints.x, constraints.y, constraints.width, parseInt); } model.setConstraints(constraints); } }
图一
二、增加大纲视图
@Override public Object getAdapter(Class type) { if(type.equals(IContentOutlinePage.class)){ return new DiagramEditorOutlinePage(getGraphicalViewer()); } return super.getAdapter(type); }
public class DiagramEditorOutlinePage extends ContentOutlinePage { private GraphicalViewer viewer; private Composite control; public DiagramEditorOutlinePage(GraphicalViewer graphicalViewer) { this.viewer = graphicalViewer; } @Override public void createControl(Composite parent) { control = new Composite(parent, SWT.NONE); control.setLayout(new GridLayout(1, false)); control.setLayoutData(new GridData(GridData.FILL_BOTH)); Canvas canvas = new Canvas(control, SWT.NONE); canvas.setLayoutData(new GridData(GridData.FILL_BOTH)); LightweightSystem liSystem = new LightweightSystem(canvas); ScalableFreeformRootEditPart rootEditPart = ((ScalableFreeformRootEditPart) viewer .getRootEditPart()); ScrollableThumbnail thumbnail = new ScrollableThumbnail( (Viewport) rootEditPart.getFigure()); thumbnail.setSource(rootEditPart .getLayer(LayerConstants.SCALABLE_LAYERS)); liSystem.setContents(thumbnail); } @Override public Control getControl() { return control; } @Override public void setFocus() { control.setFocus(); } }
protected void initializeOverview() { LightweightSystem lws = new LightweightSystem(overview); RootEditPart rep = getGraphicalViewer().getRootEditPart(); DiagramRootEditPart root = (DiagramRootEditPart) rep; thumbnail = new ScrollableThumbnail((Viewport) root.getFigure()); // thumbnail.setSource(root.getLayer(LayerConstants.PRINTABLE_LAYERS)); thumbnail.setSource(root.getLayer(LayerConstants.SCALABLE_LAYERS)); lws.setContents(thumbnail); disposeListener = new DisposeListener() { public void widgetDisposed(DisposeEvent e) { if (thumbnail != null) { thumbnail.deactivate(); thumbnail = null; } } }; getEditor().addDisposeListener(disposeListener); this.overviewInitialized = true; }
图二
三、dirty标记的增加
一般来说,在Eclipse里,当Editor的内容发生改变时,会有个dirty标记,例如:。但是目前我们的Editor上有编辑时并不会出现dirty标记。所以我们也应该给我们的Editor提供一个。
其实目前也不是对编辑完全无知。当我们做了一些修改,然后关闭时,会得到一个提示:
说明我们的编辑器已经知道了有改动。之所没有显示dirty标记,是因为我们没有通知它。在Eclipse里,要想显示dirty标记是需要发出通知的。下面我们就来完成我们的dirty标记。
我们先理解几点:
1.我们都知道(假设)Eclipse里的Editor是通过方法:isDirty()的返回值来判断是否为脏。
2.Eclipse里的Editor并不是一直轮询isDirty()方法的,它是需要一个事件触发的。
3.我们都知道,所有的GEF里的操作都是通过command来完成的,而所有的command都是放在一个command堆栈中的。这个堆栈可以由editor直接得到。
有这三条,我觉得就够了:isDirty()方法的返回值就由命令栈是否为空决定了。所以就只剩下一个问题了:怎么发出通知机制?简单的想应该是在每个command执行和撤消时都需要发出这个通知。那如果真要这么实现的话,我想大家都会觉得很不好了。幸好,在GEF的Editor里就有一个方法可以完成这件事:commandStackChanged(EventObject event)。 在这个方法在每次命令栈有变化的时候都被会调用。
不知道大家有没有注意到:虽然我们的脏标记没有出来。但是我们的Actions是否可用的状态总是正确。说明这个action的状态总是被更新了。其实看看源码就知道是怎么回事了。commandStackChanged(EventObject event)的默认实现如下:
public void commandStackChanged(EventObject event) { updateActions(stackActions); }
所以action的状态总是会被更新的。
刚才上面我也说到了,如果我们要自己完成发出事件机制,那么我们需要在每个command有执行或撤消的地方都发出一个事件。事实上GEF本身也是这样做的,我们看一下commandStackChanged(EventObject event)方法被调用的地方就知道了:
图三
那现在知道怎么做了没?好了,不说了,直接给出代码:
@Override public boolean isDirty() { return getCommandStack().isDirty(); } @Override public void commandStackChanged(EventObject event) { super.commandStackChanged(event); firePropertyChange(PROP_DIRTY); }
最后再编辑的时候:
图四
评论
谢谢你,刘刚,找到错误了,是因为在非UI线程里访问了UI造成的!
呵呵!
public class ThalesCtrl extends Thread
{
private final int n_sleep = 3000;
private int n = 0;
private Job job;
public ThalesCtrl()
{
job = new Job("My First Job")
{
protected IStatus run(IProgressMonitor moinitor)
{
System.out.println("Hello World (from a background job).");
HelloModel hello1 = (HelloModel) Session.htHelloModel.get("1");
if (n < 1000)
{
n = n + 1;
if (hello1 != null)
{
if ((n % 3) == 0)
{
System.out.println("red");
hello1.setColor(hello1.P_COLOR_RED);
}
else
{
System.out.println("blue");
hello1.setColor(hello1.P_COLOR_BLUE);
}
}
else
{
System.out.println("hello1 is null");
}
}
else
{
n = 0;
}
return Status.OK_STATUS;
}
};
this.start();
}
public void run()
{
while (true)
{
try
{
Thread.sleep(n_sleep);
job.schedule(2000);
}
catch (Exception e)
{
e.printStackTrace();
}
}
}
}
HelloModel 文件:
public class HelloModel extends AbstractModel
{
public static final String P_COLOR = "color";
public static final String P_COLOR_RED = "red";
public static final String P_COLOR_BLUE = "blue";
public static final String P_COLOR_ORANGE = "orange";
public static final String P_COLOR_GRAY = "gray";
public void setColor(String color)
{
this.color = color;
System.out.println("set Color!");
firePropertyChange(P_COLOR, null, color);
}
。。。。。
}
AbstractModel文件:
public class AbstractModel implements IPropertySource
{
private PropertyChangeSupport listeners = new PropertyChangeSupport(this);
public void addPropertyChangeListener(PropertyChangeListener listener)
{
listeners.addPropertyChangeListener(listener);
}
public void firePropertyChange(String propName,Object oldValue,Object newValue)
{
listeners.firePropertyChange(propName,oldValue,newValue);
}
public void removePropertyChangeListener(PropertyChangeListener listener)
{
listeners.removePropertyChangeListener(listener);
}
public Object getEditableValue()
{
return this;//返回模型自身作为可编辑的属性值
}
public IPropertyDescriptor[] getPropertyDescriptors()
{ //如果在抽象模型中返回null会出现异常,因此这里返回一个长度为0的数组
return new IPropertyDescriptor[0];
}
public Object getPropertyValue(Object id)
{
return null;
}
public boolean isPropertySet(Object id)
{
return false;
}
public void resetPropertyValue(Object id)
{
}
public void setPropertyValue(Object id,Object value)
{
}
}
public class HelloEditorPart extends EditPartWithListener implements NodeEditPart,Runnable//AbstractGraphicalEditPart { private CustomDirectEditManager directManager = null; private Thread timer = null; private boolean isNext = true; protected IFigure createFigure() { timer = new Thread(this); timer.start(); HelloModel model = (HelloModel)getModel(); System.out.println("id : " + model.getId()); Label label = new Label(); label.setText(model.getText()); label.setBorder(new CompoundBorder(new LineBorder(),new MarginBorder(3))); //背景色 label.setBackgroundColor(ColorConstants.green); //背景色不透明 label.setOpaque(true); return label; } public void setColor(Color color) { if(color != null && getFigure()!= null) ((Label)getFigure()).setBackgroundColor(color); } protected void createEditPolicies() { ... } protected void refreshVisuals() { ... } public void performRequest(Request req) { ... } private void performDirectEdit() { ... } public void run() { while(true) { try { if(isNext) { setColor(ColorConstants.green); isNext = false; } else { setColor(ColorConstants.red); isNext = true; } Thread.sleep(1000); } catch(Exception e) { e.printStackTrace(); } } } } 然后报错:java.lang.NullPointerException at org.eclipse.draw2d.DeferredUpdateManager.sendUpdateRequest(DeferredUpdateManager.java:225) at org.eclipse.draw2d.DeferredUpdateManager.queueWork(DeferredUpdateManager.java:215) at org.eclipse.draw2d.DeferredUpdateManager.addDirtyRegion(DeferredUpdateManager.java:111) at org.eclipse.draw2d.Figure.repaint(Figure.java:1319) at org.eclipse.draw2d.Figure.repaint(Figure.java:1311) at org.eclipse.draw2d.Figure.repaint(Figure.java:1326) at org.eclipse.draw2d.Figure.setBackgroundColor(Figure.java:1357) at gef.tutorial.step.parts.HelloEditorPart.setColor(HelloEditorPart.java:77) at gef.tutorial.step.parts.HelloEditorPart.run(HelloEditorPart.java:224) at java.lang.Thread.run(Thread.java:595) 希望指教!
应该是因为你在非UI线程中访问了UI。看出错地方的源码:
protected void sendUpdateRequest() {
Display.getCurrent().asyncExec(new UpdateRequest());
}
虽然不知道你的代码实际运行情况,但我猜想这个空指的是:Display.getCurrent()返回值为空。所以,如果要想能正确运行,你需要使用UI线程。
{
private CustomDirectEditManager directManager = null;
private Thread timer = null;
private boolean isNext = true;
protected IFigure createFigure()
{
timer = new Thread(this);
timer.start();
HelloModel model = (HelloModel)getModel();
System.out.println("id : " + model.getId());
Label label = new Label();
label.setText(model.getText());
label.setBorder(new CompoundBorder(new LineBorder(),new MarginBorder(3)));
//背景色
label.setBackgroundColor(ColorConstants.green);
//背景色不透明
label.setOpaque(true);
return label;
}
public void setColor(Color color)
{
if(color != null && getFigure()!= null)
((Label)getFigure()).setBackgroundColor(color);
}
protected void createEditPolicies()
{
...
}
protected void refreshVisuals()
{
...
}
public void performRequest(Request req)
{ ...
}
private void performDirectEdit()
{
...
}
public void run()
{
while(true)
{
try
{
if(isNext)
{
setColor(ColorConstants.green);
isNext = false;
}
else
{
setColor(ColorConstants.red);
isNext = true;
}
Thread.sleep(1000);
}
catch(Exception e)
{
e.printStackTrace();
}
}
}
}
然后报错:java.lang.NullPointerException
at org.eclipse.draw2d.DeferredUpdateManager.sendUpdateRequest(DeferredUpdateManager.java:225)
at org.eclipse.draw2d.DeferredUpdateManager.queueWork(DeferredUpdateManager.java:215)
at org.eclipse.draw2d.DeferredUpdateManager.addDirtyRegion(DeferredUpdateManager.java:111)
at org.eclipse.draw2d.Figure.repaint(Figure.java:1319)
at org.eclipse.draw2d.Figure.repaint(Figure.java:1311)
at org.eclipse.draw2d.Figure.repaint(Figure.java:1326)
at org.eclipse.draw2d.Figure.setBackgroundColor(Figure.java:1357)
at gef.tutorial.step.parts.HelloEditorPart.setColor(HelloEditorPart.java:77)
at gef.tutorial.step.parts.HelloEditorPart.run(HelloEditorPart.java:224)
at java.lang.Thread.run(Thread.java:595)
希望指教!
对ArrayList里的内容进行编辑的窗口。对内容进行编辑后editor
不会显示dirty(),应该怎样处理???
在 线 等!!!!
发表评论
-
GEF中用鼠标移动画布
2011-12-27 13:37 1357第一步 增加Palette项: moveTool = n ... -
Draw2d的ScrollPane的使用
2011-04-19 15:05 1602ScrollPane scrollpane = ne ... -
GEF的动态变化二
2011-04-13 10:47 1333之前有一篇文件介绍怎么实现GEF Editor中的图元的渐近、 ... -
(译)Eclipse Zest二
2011-01-07 15:41 19545. Zest和JFace的例子 5.1 创建工程 创建一 ... -
(译)Eclipse Zest一
2011-01-07 15:14 28831. Eclipse Zest 1.1 概述 Eclips ... -
增加GEF的动态性
2011-01-06 10:25 1780在一个GEF应用中,最常的操作是移位和缩放。移位和缩放实现本身 ... -
GEF中Palette项的属性页显示
2010-11-04 14:25 2002一般来说我们只需要在GraphicalViewer部分显示在P ... -
定制GEF的Palette
2009-11-23 16:35 2533用GEF框架实现一个Editor时,会有一个默认的palett ... -
GEF增加之连接助手二
2009-10-29 16:01 1027上一篇说过怎么实现悬浮连接助手。一直想要怎么实现悬浮连接助手。 ... -
GEF功能增强之创建助手
2009-09-28 09:09 1704用过GMF就知道,GMF默认生成的editor有一个悬浮的创建 ... -
GEF功能增强之连接助手
2009-09-10 14:45 1802GEF图形编辑器中,通常 ... -
GEF中实现“拷贝为图片”
2009-09-06 09:13 1356在一个GEF的编辑器中,编辑器上是一个个的Figure,从外观 ... -
GEF中扩大、缩小时处理编辑行为
2008-12-30 10:54 1523我们为GEF应用提供了ZoomIn和ZoomOut功能之后,在 ... -
改变GEF的一些默认行为
2008-12-29 14:12 1421一、改变Layer GEF中会根据editpart的类 ... -
GEF中一个模型的多层图的问题
2008-12-26 16:00 1642一般来说,我们在做GEF的时候,通常是一个模型对应一个图,这个 ... -
GEF中增加ContextMenu的支持
2008-12-19 22:32 2635GEF中,增加对EditPart的右键菜单的支持是很普遍的一 ... -
增加Palette的拖放支持
2008-12-19 14:08 1962默认情况下,GEF中要创建一个新的结点都是通点在Palette ... -
给GEF拖放功能
2008-07-17 10:26 1889我们知道SWT支持Native的拖放。GEF使用SWT的拖放来 ... -
修改GEF中Connection的端点
2008-07-14 16:09 1817GEF中,选中一条连接线,默认的端点是两个小黑框,如下: ... -
GEF中导视图的使用
2008-07-10 17:01 2183有时增加一个导视图能给用户很大的方便性,例如在outline视 ...
相关推荐
在GEF(Graphical Editing Framework)中,理解其工作流程对于开发图形编辑工具至关重要。GEF主要用于构建基于SWT和JFace的图形用户界面,它提供了丰富的功能来处理图形元素的绘制、操作和交互。本篇文章将深入探讨...
【GEF理解系列二】是深入学习GEF框架的第二部分,主要讲解如何配置和初始化Editor,以及如何创建多层结构以支持添加多个图形。GEF(Graphical Editing Framework)是一个用于构建图形编辑器的开源框架,常用于开发...
在"GEF入门系列宝典"中,我们将深入探讨如何使用GEF进行Eclipse插件开发,以创建自定义的图形编辑器。以下是一些关键知识点: 1. **Eclipse插件体系结构**: - 插件是Eclipse的核心组成部分,它们通过OSGi模块系统...
本资料集旨在为初学者提供一个全面的入门指南,帮助理解GEF的基础概念和实现方法。 GEF的核心功能是提供了一套强大的组件和API,用于创建可交互的、图形式的用户界面。通过使用GEF,开发者可以轻松地创建出具有拖放...
**GEF入门系列 PDF 格式资料** GEF(Graphical Editing Framework)是Eclipse开源组织推出的一个图形编辑框架,主要用于构建可视化的图形编辑...在阅读过程中,建议结合实际编程实践,以便更好地理解和掌握GEF的精髓。
- 示例代码:Eclipse项目中包含多个GEF示例,是学习和理解GEF的好资料。 - 在线教程:互联网上有许多博客和教程,针对不同水平的学习者提供了丰富的教学内容。 通过这个GEF入门系列,你可以逐步掌握如何利用GEF...
本入门系列旨在帮助初学者快速理解并掌握这两个强大的工具。 EMF是Eclipse项目的一部分,它提供了一种模型驱动的开发方式。EMF允许开发者创建、存储和操作数据模型,这些模型可以用来表示复杂的数据结构或业务逻辑...
"GEF入门系列宝典.doc"可能更侧重于实践,提供逐步的教程和实例,帮助初学者快速上手。它可能包含一些实际的代码示例,教你如何构建一个简单的图形编辑器,例如绘制流程图或网络拓扑图。 通过学习这两份资料,你将...
2. "GEF入门系列(一、Draw2D).doc" 可能是一个逐步的教学系列,从基础的Draw2D开始,逐步引入GEF的概念和应用。 3. "如何在Eclipse3.3.1.1中安装VE,emf,GEF插件.doc" 提供了在特定版本的Eclipse中安装相关插件的步骤...
为了帮助读者更好地理解GEF框架的实际应用,作者提供了由简至繁的一系列示例项目。这些项目按序排列,从最简单的pt1开始,逐步添加新功能,最终形成一个具备DirectEdit、Palette等功能的图形编辑器。这种逐步递进的...
这个入门学习例子旨在帮助初学者理解GEF的基本用法和核心概念,通过实例展示如何利用GEF实现工具栏、菜单栏、属性栏以及图形的交互功能,如移动、删除、撤销、连线等,并涵盖了大纲视图和鹰眼功能的实现。...
4. **流程设计基础**:在gef框架下进行流程设计,首先要明确流程的目标和步骤,这可能涉及到对程序逻辑的理解和拆解,将复杂的任务分解为一系列可执行的子任务。这通常需要扎实的编程基础和问题解决能力。 5. **gef...
**3gef**可能是这个系列教程的一个特定版本或者阶段,强调了对GEF的三次迭代改进或深化理解。这可能涉及到更高级的功能,如图形的动态更新、自定义手势识别或者与其他Eclipse插件的集成。 **gef_eclipse**标签表明...
这个"eclipse_gef_example.rar"压缩包提供了一系列的例子,帮助开发者更好地理解和掌握GEF框架。以下是对每个部分的详细解释: 1. **org.eclipse.gef.examples.text** 这个部分主要展示了如何在GEF环境中处理文本...
总结来说,gef工程代码是一个强大的学习资源,对于想要提升调试技能和深入理解代码运行机制的开发者来说,是不可多得的宝藏。通过深入研究和实践,你将能够掌握gef的精髓,从而在日常开发和调试工作中更加游刃有余。
### GEF(Graphical Editing Framework)入门教程知识点详解 #### 一、简介 GEF(Graphical Editing Framework),即图形编辑框架,是一种基于...希望您能够通过实践加深对GEF的理解,并成功地应用于自己的项目中。
GEF包含了一系列的类和接口,如Command、Model、View、EditPart、Figure等,它们共同构成了图形编辑的基础架构。Command代表可撤销/重做的操作,Model表示数据模型,View负责显示图形,EditPart作为模型和视图之间...
10. **示例和教程**:GEF通常会提供一系列的示例项目和教程,帮助开发者快速上手,理解和使用框架。 总的来说,"GEF.rar"压缩包可能是为开发者提供的一个完整的开发环境,包括了源代码、必要的库文件以及示例,使得...