C# designer flow chart app - how?
Hi I'm new to C# WPF. There's a flowchart WPF program in C#. The program can display objects and connecting arrows between them. ie eg
======== ========
| | | |
| obj1 | ------> | obj2 |
======== ========
1 - How do I add a visual function to each object when right clicking them ? ie when I right mouse click an object, I like to be able to change its properties belonging to an application.
2 - how do I create and generate 开发者_如何学Goa file containing the relationship information about the objects above. ie obj1 flows to obj2
Thanks for sharing your thoughts
1) You will need to write hit-testing code to be used in the mouse click event. You need to check the screen location of each of your objects to determine which (if any) of the objects was "under" the pointer when the mouse was clicked. From there you can display the appropriate context menu for the functionality you want to implement.
2) If you just want to save the information to re-open by the app later, simple serialization to XML or Binary will work fine. If the intent is to make user-readable content, you will need to write a simple csv export or if the output needs to be more complex, a custom serializer.
More Info:
Hit-testing is the general term for evaluating what object has been clicked on, for example, when you click in a DataGridView, hit testing logic can tell you which cell/row/column was clicked on. Many Widget classes, including DataGridView, have a HitTest method which will return an object which provides this information. If the flowcharting tool uses custom drawing for the connected objects, then you will have to do the work of using the click coordinates to determine what element in the flowchart has been clicked on.
http://msdn.microsoft.com/en-us/library/system.windows.forms.datagridview.hittest.aspx documents the HitTest method for the DataGridView.
http://www.codeproject.com/KB/list/CSharpHitTest.aspx is a sample program on CodeProject which does hit testing logic in a ListView.
1 - Handle the mouse click events for the objects, and do whatever you have to do. 2 - Serialize the object graph to XML or binary format.
I am not sure how your application works and what controls you have used but I would suggest you to look at following articles implementing designes with the features you mentioned -
http://flowpad.codeplex.com/
WPF Diagram Designer
http://simulo.codeplex.com/
Simple library from Git https://gridwizard.wordpress.com/2015/03/25/simple-c-library-to-render-graph-to-flowchart
It helps generates flow chart by first calculate Node.x/y and Canvas size (given object graph), then render to HTML5. You can adapt the code render to WPF (simply by adding another render - borrowing code from their HTML5 renderer).
精彩评论