Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ptv-logistics/sharpmap.widgets
About Build responsive map applications for web and desktop
https://github.com/ptv-logistics/sharpmap.widgets
aspnet csharp gis javascript leaflet leaflet-plugin mapping sharpmap spatial winforms wpf
Last synced: 21 days ago
JSON representation
About Build responsive map applications for web and desktop
- Host: GitHub
- URL: https://github.com/ptv-logistics/sharpmap.widgets
- Owner: ptv-logistics
- Created: 2016-06-02T06:15:26.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-04-22T22:26:52.000Z (9 months ago)
- Last Synced: 2024-04-23T21:08:30.374Z (9 months ago)
- Topics: aspnet, csharp, gis, javascript, leaflet, leaflet-plugin, mapping, sharpmap, spatial, winforms, wpf
- Language: C#
- Homepage: https://sharpmapwidgets.azurewebsites.net
- Size: 4.54 MB
- Stars: 12
- Watchers: 6
- Forks: 3
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# SharpMap.Widgets
Build responsive map applications for web and desktop[SharpMap](https://github.com/SharpMap) is a powerful mapping library that supports a large variety of standards and formats.
But the interactive Web- and Windows-Widgets of the SharpMap project are somehow neglected. On the other hand, "slippy map" Widgets like [Leaflet](http://leafletjs.com/) or [Ptv xServer.NET](https://github.com/ptv-logistics/xserver.net) cannot handle mass data very well. SharpMap.Widgets shows how to combine the SharpMap renderer with these widgets, so it combines the power of SharpMap with the Look&Feel of modern widgets.[Web-Sample](https://sharpmapwidgets.azurewebsites.net/)
**Windows-Sample:**
![Windows-Sample](/Doc/SharpMap.Win.png)### What the project shows
* Efficiently render large data sets on "slippy" map widgets with SharpMap
* Add interaction to pick an item
* Implementing SharpMap interfaces to render your custom data source
* Sharing your map business-code between web and desktop applications### The projects
* SharpMap.Win - Windows (Forms) sample
* SharpMap.Web - Browser sample
* SharpMap.WinThin - Windows sample that uses the middle ware from the web project
* SharpMap.Print - Sample for creating static images
* SharpMap.Common - Shared code### The basic technique
The basic idea is to compose (or "mesh-up") imagery and vector data on the client-side. "First-class" map widgets like Leaflet and OpenLayers (for browser applications) or PTV xServer.NET (for Microsoft Windows applications) support this. The partitioning is done both between "base-map" and "application-data", which is delivered from different services, as well as between different rendering-techniques, depending on the type of data and required responsiveness. There are three main categories of render-data:
* Persistent data than can be rendered independent from the viewport. This is typically the case for polygons and lines (areas or road segments).
* Persistent data that cannot be rendered in tiles. This is the case for objects that "bleed" outside tiles or are using a heuristic layout algorithm. Symbols and labels need this strategy.
* Transient data, for example the currently selected item.So the layering-stack when using PTV xMapServer as base-map looks as follows:
### Architecture considerations
A crucial part for UI applications is the decision about the basic architecture. There are two categories of UI-applications:
* 2-tier, where the client directly accesses the data inside the database using SQL. It could even be possible that the database is not hosted on an external server, but an embedded (MS Access, SQLite) database, or just a plain .csv file. In this case we speak of a 1-tier applicatin.
* 3-tier, where the client is only a thin application that consumes web services. A middleware supplies the client with the data via HTTP (SOAP, REST) interfaces. Web-clients usually use this architecture, but it's also possible to build a thin Windows (Forms, WPF) client that doesn't access the database directly, but only via a web interface.The difference is very important with aspect on rendering performance. The renderer reads the geometry and attribute data from the database. This requires a high bandwidth between renderer and database server. If the client doesn't have this high-bandwidth connection to the database it's recommended to use a middleware, so only the rendered images have to be transferred to the client.
### ToDos
* Add interaction to thin Windows-Client
* Some dynamic filtering and styling
* Better sample data sources
* More docs