I've been working on an architecture that combines the simplicity of MVVM for UI interactions with the scalability, pluggability, and distributedness of SOA for processing data for visualization. The first prototype I've implemented is in the form of the PheonixRt.Mvvm application (on github at https://github.com/dg1an3/PheonixRt.Mvvm)
PheonixRt.Mvvm is split in to two exe's:
can be exposed as bindable properties on the ViewModel, and then any additional rendering can be done by the View (for instance to add adornments, or other rendering styles). So the services are necessary to turn the data in to these kinds of primitives, and WPF will take it from there.
This prototype also looks at the use of the standy pool as a means of caching large amounts of data to be ready for loading. This is similar to what the Windows SuperFetch feature does for DLLs, but in this case it is large volumetric data being pre-cached.
PheonixRt.Mvvm is split in to two exe's:
- Front-end
- UI containing the MVVM
- Interaction with back-end services is via service helpers (using standard .NET events)
- Back-end
- hosts the services responsible for pre-processing data
- hosts services that visualize the data, such as calculating an MPR, a mesh intersection, or an isosurface
- Bitmap (including alpha values)
- 2D vector geometry, such as a line, polyline, or polygon
- 2D transformation
can be exposed as bindable properties on the ViewModel, and then any additional rendering can be done by the View (for instance to add adornments, or other rendering styles). So the services are necessary to turn the data in to these kinds of primitives, and WPF will take it from there.
This prototype also looks at the use of the standy pool as a means of caching large amounts of data to be ready for loading. This is similar to what the Windows SuperFetch feature does for DLLs, but in this case it is large volumetric data being pre-cached.