| 12345678910111213141516171819202122232425262728293031323334 | 
Current for 6.x-2.0-alpha3The OpenLayers module aims to add minimal abstraction in Javascript to what isalready provided by the [OpenLayers](http://openlayers.org/) Javascript library.However, it does create certain structures that may not be immediately obvious.# Data StorageThe module stores all settings initially under Drupal.settings.openlayers. Itdoes this in a slightly modified way if your server supports native JSON writing- this basically means that, instead of using Drupal to encode the settingsarray, it uses a PHP extension (written in C). This greatly increasesperformance for displaying many points on maps.# Keeping Track of MapsThe OpenLayers map object, which contains pointers to all layers, etc., isstored with the [jQuery data() method](http://api.jquery.com/jQuery.data/),which provides the phenomenal convenience of storing arbitrary data within theDOM itself. This means that the map object is attached to the openlayers-map-0,or so on, div element in your page. So, to access it, one could use a line like    $('#openlayers-map-0').data('openlayers')In FireBug, Safari, or Chrome.Note that the 2.x branch strives to not duplicate map information: it exists inthe Drupal settings array and then is transformed into a map object, but afterthat point, the canonical location for data about maps is in the map object.This is for purposes of both flexibility, since the map object lets developersaccess objects by better getter methods, and for the purpose of keepingOpenLayers behaviors and layer initialization code less tied to Drupal thanbefore.
 |