Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to draw a map from images?

I want to write a navigator application which draws maps from images. Maps need to be drawn dynamically, based on the user's navigation. My idea is loading 9 images into memory, and then creating a view to show the needed map:

alt text http://img526.imageshack.us/img526/2574/screento.png

When user navigates, the view is moved. When needed, images which no longer seen will be destroyed, and new ones will be loaded.

My first problem is that I can't get it to work. :(. My second problem is that it seems to be too complex and resource-wasting. It's also hard to scale in case screen size is changed.

Can you please show me an effective algorithm to draw maps? Demo code in C# will help a lot. An open source library will be much appreciated. :)

Thank you.

like image 900
Quan Mai Avatar asked Oct 20 '25 14:10

Quan Mai


2 Answers

depending on what you want to do this could be a pretty hard problem. e.g. georeferencing, projection, GCS, you don't want to roll your own

there are a number of gis tools available that already do this sort of thing, for c# and open source there is SharpMap or possibly google maps/earth

there are various commerical libs available as well e.g. ESRI or Luciad

like image 151
jk. Avatar answered Oct 23 '25 09:10

jk.


We actually use this as an interview question. I agree with jk, you should use a third party library, but I'll give you an idea

First storing this data as an image is the wrong approach. We actually word our question to immediately direct people away from this approach. You really want to store individual roads or features as a series of points (preferably using splines so you can efficiently represent curves) and then render the correct roads. Now because you're using vector (rather than raster) data your scaling and rotation issues are solved.

You were going down the right path when you discussed breaking it into smaller squares. Each square should contain data about all of the roads that pass through it. If a road crosses an edge, break it into two road pieces, one in each square. That way each square has enough data to render itself completely.

Looking up the squares you need to draw can be a bit of a pain, but no worse than you had to solve with images. Personally I'd store a bunch of data structures in a binary file with an index at the beginning, listing where each square begins in the file and how long it is. That way you can read the data for the square pretty efficiently (jump to correct position in TOC, read TOC data, jump to start of square, read square data). You could even optimize for empty squares sharing space.

Last, you'll probably want to do different levels of zoom. Personally I'd store a completely separate set of blocks at a few different zoom levels. That way you can vary the size of the block as appropriate.

Again, to reiterate, use a product off the shelf, but there's no problem using this as a thought experiment.

like image 36
Hounshell Avatar answered Oct 23 '25 07:10

Hounshell