Skip to main content



      Home
Home » Archived » Visual Editor (VE) » Browsing the VE Source
Browsing the VE Source [message #51273] Thu, 22 July 2004 09:13 Go to next message
Eclipse UserFriend
After getting the VE SDK I imported the plugins and created projects from
them.
Wanted to look at the EditParts and associated Figures that VE uses for
Swing components.

I assumed that these would be in org.eclipse.ve.internal.jfc.core. But
don't see any thing that looks like EditParts or Figures in there.
Is there any documentation that explains how the VE SDK is put together?
Seems to have a bewildering array of different PlugIns that are way beyond
anything I've seen in my brief experience.

I'm investigating using GEF for a Visual Builder for our own non-Java 4GL
environment which uses Swing at run time. We store all the meta-data that
we generate the Swing components from in a DataBase. So I'm not sure how
useful EMF would be to us (we don't ever generate Java Source, we just
read the meta data and create Swing components at run time). But really
would like to see how VE renders components at design time.
Re: Browsing the VE Source [message #51300 is a reply to message #51273] Thu, 22 July 2004 09:37 Go to previous messageGo to next message
Eclipse UserFriend
Originally posted by: myersj.nospam.us.ibm.com

Steve,

Glad to have you looking at the VE source. Someone else will talk about
the documentation (or lack thereof) and what would be necessary to
achieve what you're looking to do, but I can quickly point out which
EditParts you might want to start looking at. On the JFC side, check
out ComponentGraphicalEditPart and ContainerGraphicalEditPart in
org.eclipse.ve.internal.jfc.core.

I'll see about getting you a more indepth response to your other
questions. I'd also encourage you to join the VE development mailing
list at http://dev.eclipse.org/mailman/listinfo/ve-dev

- Jeff

Steve Harper wrote:

> After getting the VE SDK I imported the plugins and created projects from
> them.
> Wanted to look at the EditParts and associated Figures that VE uses for
> Swing components.
>
> I assumed that these would be in org.eclipse.ve.internal.jfc.core. But
> don't see any thing that looks like EditParts or Figures in there.
> Is there any documentation that explains how the VE SDK is put together?
> Seems to have a bewildering array of different PlugIns that are way beyond
> anything I've seen in my brief experience.
>
> I'm investigating using GEF for a Visual Builder for our own non-Java 4GL
> environment which uses Swing at run time. We store all the meta-data that
> we generate the Swing components from in a DataBase. So I'm not sure how
> useful EMF would be to us (we don't ever generate Java Source, we just
> read the meta data and create Swing components at run time). But really
> would like to see how VE renders components at design time.
>
Re: Browsing the VE Source [message #51327 is a reply to message #51273] Thu, 22 July 2004 09:59 Go to previous messageGo to next message
Eclipse UserFriend
Originally posted by: richkulp.NO.SPAM.us.ibm.com

If you have a fixed, small, non-extensible model, using GEF is probably
the best way to go. VE adds a fair amount of extras, but those extras
are for allowing anybody through plugins to extend your editor. We have
that condition with the VE for Java because anyone can add their own
editparts and code generators.

As for documentation, we are in the development phase and I really don't
expect things to settle down and become true documented API until the
next release.

We can answer questions until then.

--
Thanks, Rich Kulp

Re: Browsing the VE Source [message #51439 is a reply to message #51273] Thu, 22 July 2004 12:16 Go to previous messageGo to next message
Eclipse UserFriend
Steve Harper wrote:
> I'm investigating using GEF for a Visual Builder for our own non-Java 4GL
> environment which uses Swing at run time. We store all the meta-data that
> we generate the Swing components from in a DataBase. So I'm not sure how
> useful EMF would be to us (we don't ever generate Java Source, we just
> read the meta data and create Swing components at run time). But really
> would like to see how VE renders components at design time.

In addition to the other posts, I'll add a brief architectural description:

VE uses the model-view-controller pattern, so the model is king and
everything else is just a view of that model.

Since VE needs to be able to model any kind of UI for any platform or
language, a platform and widget-set independent model was needed. EMF
fits this pretty well because it has methods that are analogous to what
you find in java.lang.reflect, but is not Java specific. These methods
can be used to discover the property names and read/write the contents
of your GUI objects dynamically at runtime, just like you would do using
java.lang.reflect or java.beans, but without directly relying on either.

So if you wanted to hook into VE, your persistence model (in your case,
your database) would be hooked up as a "view" listening to the EMF model
in order to support your back-end.

I hope this helps provide some conceptual understanding of how VE works.
As the others said, please ask more specific questions as you need to
and we'll try to help.


Regards,

Dave

--
Dave Orme
Eclipse Visual Editor Project Lead
Advanced Systems Concepts' Chief Architect
http://www.swtworkbench.com
Re: Browsing the VE Source [message #52569 is a reply to message #51300] Fri, 30 July 2004 09:47 Go to previous messageGo to next message
Eclipse UserFriend
I don't think it would make sense for the editor I'm working on to extend
VE. We have platform independant meta data stored in a database. At run
time we have a "Swing Player" that reads the meta data and instatiates
Swing components on the fly. There are currently over 1000 such panels
stored in the database together with 4GL code that handles the business
logic on the panels. We have never generated Java code that represents
these panels. Instead we render them at run time using Java. So the whole
approach of VE using EMF to generate Java code from the beans doesn't seem
to apply to this editor.

I am very interested in how VE renders the Swing components at design time.
Looked at ComponentGraphicalEditPart and started looking at ImageFigure,
ImageFigureController, IVisualComponent, et al. Have to admit I quickly
became lost. Was trying to see if you used draw2d to actually render the
components. Assume that when I run VE that I'm not actually manipulating
real Swing components but rather the proxies that are somehow rendered
with draw2d.

I've got a prototype of my editor where the various Swing Components are
rendered via draw2d components (ie. been using Label, TextFlow, Checkbox
from draw2d to simulate Swing components). Having a lot of problem
(obviously) doing WYSIWYG with the approach.

When someone drops a Swing JCheckBox on the editor in VE where does the
ImageFigure come from? I did a search on all calls to
ImageFigure.setImage() and was even more confused about what was going on.
Can you point at the classes I should look at to understand all this?

Thanks, it looks like there are some really powerful patterns in VE that
are generally applicable, but it's hard to get the big picture diving into
the source. Think a big part of my difficulty is that I've never written a
Visual Editor of any kind.


Jeff Myers wrote:

> Steve,

> Glad to have you looking at the VE source. Someone else will talk about
> the documentation (or lack thereof) and what would be necessary to
> achieve what you're looking to do, but I can quickly point out which
> EditParts you might want to start looking at. On the JFC side, check
> out ComponentGraphicalEditPart and ContainerGraphicalEditPart in
> org.eclipse.ve.internal.jfc.core. ....
Re: Browsing the VE Source [message #52596 is a reply to message #52569] Fri, 30 July 2004 10:42 Go to previous message
Eclipse UserFriend
Originally posted by: myersj.nospam.us.ibm.com

Steve,

Please check out the overview of the Visual Editor's architecture here:
http://dev.eclipse.org/viewcvs/indextools.cgi/%7Echeckout%7E /vep-home/WebContent/docs/architecture/architecture.html

To render the Swing, AWT and SWT components, the Visual Editor launches
a target VM off screen that instantiates and renders a live version of
the file you're editing. The image is captured from this live window,
and sent via the proxy classes you found back to the editor. The editor
takes these screen capture images and creates GEF figures out of them.
This is the way we ensure an accurate WYSIWYG representation of the
Visual Class.

The VE project is designed to be able to extend or replace any of the
main architecture components (the blue ovals in the diagram) with
alternate implementations. This means you could rip out the Java code
generation aspect of the VE completely and replace it with something
that generates whatever representation you are storing in your database.
You can provide an adaptor from your model to the VE's Java component
EMF model, or replace the core model with another EMF model that will
work with the other parts of the system.

The point is, you can replace codegen and the rest of the framework will
do the rest for you (all the GEF edit parts, the rendering on the target
vm, etc)

Hope this helps,

- Jeff

Steve Harper wrote:
> I don't think it would make sense for the editor I'm working on to extend
> VE. We have platform independant meta data stored in a database. At run
> time we have a "Swing Player" that reads the meta data and instatiates
> Swing components on the fly. There are currently over 1000 such panels
> stored in the database together with 4GL code that handles the business
> logic on the panels. We have never generated Java code that represents
> these panels. Instead we render them at run time using Java. So the whole
> approach of VE using EMF to generate Java code from the beans doesn't seem
> to apply to this editor.
>
> I am very interested in how VE renders the Swing components at design time.
> Looked at ComponentGraphicalEditPart and started looking at ImageFigure,
> ImageFigureController, IVisualComponent, et al. Have to admit I quickly
> became lost. Was trying to see if you used draw2d to actually render the
> components. Assume that when I run VE that I'm not actually manipulating
> real Swing components but rather the proxies that are somehow rendered
> with draw2d.
>
> I've got a prototype of my editor where the various Swing Components are
> rendered via draw2d components (ie. been using Label, TextFlow, Checkbox
> from draw2d to simulate Swing components). Having a lot of problem
> (obviously) doing WYSIWYG with the approach.
>
> When someone drops a Swing JCheckBox on the editor in VE where does the
> ImageFigure come from? I did a search on all calls to
> ImageFigure.setImage() and was even more confused about what was going on.
> Can you point at the classes I should look at to understand all this?
>
> Thanks, it looks like there are some really powerful patterns in VE that
> are generally applicable, but it's hard to get the big picture diving into
> the source. Think a big part of my difficulty is that I've never written a
> Visual Editor of any kind.
Re: Browsing the VE Source [message #595618 is a reply to message #51273] Thu, 22 July 2004 09:37 Go to previous message
Eclipse UserFriend
Steve,

Glad to have you looking at the VE source. Someone else will talk about
the documentation (or lack thereof) and what would be necessary to
achieve what you're looking to do, but I can quickly point out which
EditParts you might want to start looking at. On the JFC side, check
out ComponentGraphicalEditPart and ContainerGraphicalEditPart in
org.eclipse.ve.internal.jfc.core.

I'll see about getting you a more indepth response to your other
questions. I'd also encourage you to join the VE development mailing
list at http://dev.eclipse.org/mailman/listinfo/ve-dev

- Jeff

Steve Harper wrote:

> After getting the VE SDK I imported the plugins and created projects from
> them.
> Wanted to look at the EditParts and associated Figures that VE uses for
> Swing components.
>
> I assumed that these would be in org.eclipse.ve.internal.jfc.core. But
> don't see any thing that looks like EditParts or Figures in there.
> Is there any documentation that explains how the VE SDK is put together?
> Seems to have a bewildering array of different PlugIns that are way beyond
> anything I've seen in my brief experience.
>
> I'm investigating using GEF for a Visual Builder for our own non-Java 4GL
> environment which uses Swing at run time. We store all the meta-data that
> we generate the Swing components from in a DataBase. So I'm not sure how
> useful EMF would be to us (we don't ever generate Java Source, we just
> read the meta data and create Swing components at run time). But really
> would like to see how VE renders components at design time.
>
Re: Browsing the VE Source [message #595628 is a reply to message #51273] Thu, 22 July 2004 09:59 Go to previous message
Eclipse UserFriend
Originally posted by: richkulp.NO.SPAM.us.ibm.com

If you have a fixed, small, non-extensible model, using GEF is probably
the best way to go. VE adds a fair amount of extras, but those extras
are for allowing anybody through plugins to extend your editor. We have
that condition with the VE for Java because anyone can add their own
editparts and code generators.

As for documentation, we are in the development phase and I really don't
expect things to settle down and become true documented API until the
next release.

We can answer questions until then.

--
Thanks, Rich Kulp

Re: Browsing the VE Source [message #595656 is a reply to message #51273] Thu, 22 July 2004 12:16 Go to previous message
Eclipse UserFriend
Steve Harper wrote:
> I'm investigating using GEF for a Visual Builder for our own non-Java 4GL
> environment which uses Swing at run time. We store all the meta-data that
> we generate the Swing components from in a DataBase. So I'm not sure how
> useful EMF would be to us (we don't ever generate Java Source, we just
> read the meta data and create Swing components at run time). But really
> would like to see how VE renders components at design time.

In addition to the other posts, I'll add a brief architectural description:

VE uses the model-view-controller pattern, so the model is king and
everything else is just a view of that model.

Since VE needs to be able to model any kind of UI for any platform or
language, a platform and widget-set independent model was needed. EMF
fits this pretty well because it has methods that are analogous to what
you find in java.lang.reflect, but is not Java specific. These methods
can be used to discover the property names and read/write the contents
of your GUI objects dynamically at runtime, just like you would do using
java.lang.reflect or java.beans, but without directly relying on either.

So if you wanted to hook into VE, your persistence model (in your case,
your database) would be hooked up as a "view" listening to the EMF model
in order to support your back-end.

I hope this helps provide some conceptual understanding of how VE works.
As the others said, please ask more specific questions as you need to
and we'll try to help.


Regards,

Dave

--
Dave Orme
Eclipse Visual Editor Project Lead
Advanced Systems Concepts' Chief Architect
http://www.swtworkbench.com
Re: Browsing the VE Source [message #596054 is a reply to message #51300] Fri, 30 July 2004 09:47 Go to previous message
Eclipse UserFriend
I don't think it would make sense for the editor I'm working on to extend
VE. We have platform independant meta data stored in a database. At run
time we have a "Swing Player" that reads the meta data and instatiates
Swing components on the fly. There are currently over 1000 such panels
stored in the database together with 4GL code that handles the business
logic on the panels. We have never generated Java code that represents
these panels. Instead we render them at run time using Java. So the whole
approach of VE using EMF to generate Java code from the beans doesn't seem
to apply to this editor.

I am very interested in how VE renders the Swing components at design time.
Looked at ComponentGraphicalEditPart and started looking at ImageFigure,
ImageFigureController, IVisualComponent, et al. Have to admit I quickly
became lost. Was trying to see if you used draw2d to actually render the
components. Assume that when I run VE that I'm not actually manipulating
real Swing components but rather the proxies that are somehow rendered
with draw2d.

I've got a prototype of my editor where the various Swing Components are
rendered via draw2d components (ie. been using Label, TextFlow, Checkbox
from draw2d to simulate Swing components). Having a lot of problem
(obviously) doing WYSIWYG with the approach.

When someone drops a Swing JCheckBox on the editor in VE where does the
ImageFigure come from? I did a search on all calls to
ImageFigure.setImage() and was even more confused about what was going on.
Can you point at the classes I should look at to understand all this?

Thanks, it looks like there are some really powerful patterns in VE that
are generally applicable, but it's hard to get the big picture diving into
the source. Think a big part of my difficulty is that I've never written a
Visual Editor of any kind.


Jeff Myers wrote:

> Steve,

> Glad to have you looking at the VE source. Someone else will talk about
> the documentation (or lack thereof) and what would be necessary to
> achieve what you're looking to do, but I can quickly point out which
> EditParts you might want to start looking at. On the JFC side, check
> out ComponentGraphicalEditPart and ContainerGraphicalEditPart in
> org.eclipse.ve.internal.jfc.core. ....
Re: Browsing the VE Source [message #596065 is a reply to message #52569] Fri, 30 July 2004 10:42 Go to previous message
Eclipse UserFriend
Steve,

Please check out the overview of the Visual Editor's architecture here:
http://dev.eclipse.org/viewcvs/indextools.cgi/%7Echeckout%7E /vep-home/WebContent/docs/architecture/architecture.html

To render the Swing, AWT and SWT components, the Visual Editor launches
a target VM off screen that instantiates and renders a live version of
the file you're editing. The image is captured from this live window,
and sent via the proxy classes you found back to the editor. The editor
takes these screen capture images and creates GEF figures out of them.
This is the way we ensure an accurate WYSIWYG representation of the
Visual Class.

The VE project is designed to be able to extend or replace any of the
main architecture components (the blue ovals in the diagram) with
alternate implementations. This means you could rip out the Java code
generation aspect of the VE completely and replace it with something
that generates whatever representation you are storing in your database.
You can provide an adaptor from your model to the VE's Java component
EMF model, or replace the core model with another EMF model that will
work with the other parts of the system.

The point is, you can replace codegen and the rest of the framework will
do the rest for you (all the GEF edit parts, the rendering on the target
vm, etc)

Hope this helps,

- Jeff

Steve Harper wrote:
> I don't think it would make sense for the editor I'm working on to extend
> VE. We have platform independant meta data stored in a database. At run
> time we have a "Swing Player" that reads the meta data and instatiates
> Swing components on the fly. There are currently over 1000 such panels
> stored in the database together with 4GL code that handles the business
> logic on the panels. We have never generated Java code that represents
> these panels. Instead we render them at run time using Java. So the whole
> approach of VE using EMF to generate Java code from the beans doesn't seem
> to apply to this editor.
>
> I am very interested in how VE renders the Swing components at design time.
> Looked at ComponentGraphicalEditPart and started looking at ImageFigure,
> ImageFigureController, IVisualComponent, et al. Have to admit I quickly
> became lost. Was trying to see if you used draw2d to actually render the
> components. Assume that when I run VE that I'm not actually manipulating
> real Swing components but rather the proxies that are somehow rendered
> with draw2d.
>
> I've got a prototype of my editor where the various Swing Components are
> rendered via draw2d components (ie. been using Label, TextFlow, Checkbox
> from draw2d to simulate Swing components). Having a lot of problem
> (obviously) doing WYSIWYG with the approach.
>
> When someone drops a Swing JCheckBox on the editor in VE where does the
> ImageFigure come from? I did a search on all calls to
> ImageFigure.setImage() and was even more confused about what was going on.
> Can you point at the classes I should look at to understand all this?
>
> Thanks, it looks like there are some really powerful patterns in VE that
> are generally applicable, but it's hard to get the big picture diving into
> the source. Think a big part of my difficulty is that I've never written a
> Visual Editor of any kind.
Previous Topic:Custom Controls in VE & Other questions
Next Topic:Milestone 2 is now available
Goto Forum:
  


Current Time: Sun Oct 26 07:09:44 EDT 2025

Powered by FUDForum. Page generated in 0.04299 seconds
.:: Contact :: Home ::.

Powered by: FUDforum 3.0.2.
Copyright ©2001-2010 FUDforum Bulletin Board Software

Back to the top