HT for Web integration openlayers GIS map application

Source: Internet
Author: User

The HT for Web, as the logical topology graphics component itself, does not have GIS capabilities, but can be fused with a variety of GIS engines, namely its client components, to achieve seamless integration of logical and physical topologies, and this chapter will specifically describe the HT for Web and development free Openlayers map combined with the application of key technology points, the introduction of the principle of combining, in fact, can also be extended to ArcGIS, Baidu Map and GoogleMap and many other GIS map engine fusion solution.

above screenshot for the example described in the final running effect, next we step by step to achieve, the preferred display map information needs to have city latitude and longitude data, search the next thanks to the data provided by this blog. With such a large amount of data, I use the Getrawtext function described in "the Way (iv) of HT graphics component Design", with the data remaining the problem of presentation, and we need to overlay the HT Graphview component with the Openlayers map component. That is openlayers tile map picture below, Graphview component is above, because Graphview is transparent by default, so non-entity part user can penetrate see map content. Finding the right component insertion location is a headache, ArcGIS, Baidu maps including GoogleMap almost every different GIS component needs to be tried to find the right insertion location, and the integration of other GIS engine components will be introduced later in the chapter. The openlayers we focus on in this article is Map.viewPortDiv.appendChild (Graphview.getview ()).

After the HT and openlayers components are stacked together, the rest is the problem of the placement of elements in the topology and the latitude and longitude, which is stored in the general network topology diagram in HT. Node position is a logical location, and latitude and longitude does not have any relationship, so in the GIS application we need to use the latitude and longitude information of the entity to convert the position screen logical coordinate information, if you know the projection algorithm can also provide their own function processing, But all GIS components provide similar API functions for invocation, and of course this part is not standardized, and different GIS components need to call the API to differ, but the rationale is consistent, for openlayers we pass Map.getpixelfromlonlat ( Data.lonlat) can convert latitude and longitude information into screen pixel logical coordinates, which is HT. node needs the position coordinate information.

The careful classmate will think that the conversion is bidirectional, it is possible that the user needs to drag the element node to change its latitude and longitude information, this time we need another direction function, that is, according to the screen logical coordinates converted to the current coordinates corresponding latitude and longitude, In Openlayers we pass Map.getlonlatfrompixel (new Openlayers.pixel (x, y));

Show done after the rest is the problem of interaction, HT own set of interactive system, Openlayers also need map roaming and scaling interaction, how to combine them? If you can keep the function of both the best, the answer is certain, we only need to add MouseDown or Touchstart event monitoring, if Graphview.getdataat (e) Selected elements we pass the e.stoppropagation (); Stop the propagation of the event so that the map does not respond, when HT takes over the interaction, and if no entities are selected, the map takes over the interaction of the maps operation.

The above interaction design seems to be perfect, and the results run to find a few places that have been frustrating me for a long time to find a solution to the pit:

    1. Set Map.events.fallThrough = true; otherwise the map will not pass events to the Graphview component of HT

    2. Graphview.getview (). Style.zindex = 999; Need to specify a certain zindex otherwise it will be obscured

    3. Graphview.getview (). ClassName = ' olscrollable '; Otherwise the wheel does not respond to map scaling

    4. Set HT. default.basezindex:1000 otherwise the tooltip will be obscured

In order to make this example user experience more friendly, I also toss some technical points for reference:

    1. Open source free http://llllll.li/randomColor/random color class library, the library has a lot of very good color get function, I just simply display a different color for each province

    2. IsVisible, isnotevisible, and islabelvisible are overloaded to show more detail only when scaled to a certain level, otherwise all city information is displayed at full visibility when zoomed out, and how much can improve display performance

The following is the final effect of the capture, video and source code: http://v.youku.com/v_show/id_XODM5Njk0NTU2.html

Function init () {                 graphview = new ht.graph.graphview (); Var view = graphview.getview ();                  map  = new openlayers.map ("Map"); Var ol_wms = new openlayers.layer.wms (" Openlayers wms "," Http://vmap0.tiles.osgeo.org/wms/vmap0 ",{layers: " Basic "}); Map.addlayers ([ol_wms]); Map.addcontrol (New openlayers.control.layerswitcher ()); Map.zoomtomaxextent ();                 map.events.fallThrough =  true;map.zoomtoproxy = map.zoomto;map.zoomto =  function  (ZOOM,XY) { View.style.opacity = 0;map.zoomtoproxy (ZOOM,&NBSP;XY);     console.log (zoom);};         &Nbsp;       map.events.register ("MoveStart",  this, function ()  {}); Map.events.register ("Move",  this, function ()  {                    }); Map.events.register ("MoveEnd" ,  this, function ()  {view.style.opacity = 1;reset ();});                  Graphview.getview () .classname =  ' olscrollable '; graphview.setscrollbarvisible (false); Graphview.setautoscrollzone ( -1); Graphview.handlescroll = function () {};graphview.handlepinch =  function () {};&NBSP;&NBSP;&NBSP;&NBSP;&NBSP;GRAPHVIEW.MI (function (e) {if (e.kind ===  ' EndMove ') { Graphview.sm (). each (function (data) {if (DATA&NBSP;INSTANCEOF&NBSP;HT). Node) {   var position = data.getposition (),   x =  Position.x +&nBsp;graphview.tx (),    y = position.y + graphview.ty ();      data.lonlat = map.getlonlatfrompixel (New openlayers.pixel (x, y));                                                                         }                              });}); Graphview.enabletooltip (); Graphview.gettooltip = function (event) {var data =  This.getdataat (event), if (data) {return  ' City: '  + data.s (' note ')  +  ' Longitude: '  + d ata.lonlat.lon +  ' dimension: '  + data.lonlat.lat;} return null;}; Graphview.isvisible = function (data) {return map.zoom > 1 | |  this.isselected (data);}; Graphview.isnotevisible = function (data) {return map.zoom > 6 | |  this.isselected (data);};  graphview.getlabel = function (data) {return  ' Longitude: '  + data.lonLat.lon +  ' \ n Dimension: '  + data.lonLat.lat;}; Graphview.islabelvisible = function (data) {return map.zoom > 7 | |  this.isselected (data);};                   View.addeventlistener ("Ontouchend"  in document ?  ' Touchstart '  :  ' MouseDown ',  function (e) {Var data = graphview.getdataat (e); if (data | |  e.metakey | |  e.ctrlkey) {e.stoppropagation ();}        &Nbsp;              }, false);  view.style.position =  ' absolute ';view.style.top =  ' 0 ';view.style.left =  ' 0 '; view.style.right =  ' 0 ';view.style.bottom =  ' 0 ';                 view.style.zIndex = 999; Map.viewPortDiv.appendChild (view); Var color = randomcolor (); Lines = china.split (' \ n ') ; for (var i=0; i<lines.length; i++)  {line = lines[i].trim (); if (Line.indexOf (' " ') ( === 0) {//province = line.substring (1, line.length-1);                 color = randomcolor ();} Else{var ss = line.split ('   '), if (ss.length === 3) {CreateNode (parsefloat (ss[1]). SUBSTR (3)),  parsefloat (SS[2].SUBSTR (3)), &nbsP;SS[0].SUBSTR (3),  color);                                                         }}}                                  }function reset () {graphview.tx (0); graphview.ty (0); graphview.dm (). each (function data) {                      if (Data.lonlat) {                             data.setposition ( Map.getpixelfromlonlat (Data.lonlat)); &Nbsp;                           }); Graphview.validate ();} Function createnode (Lon, lat, name, color) {var node = new ht. Node (); Node.s ({' Shape ':  ' circle ', ' shape.background ':  color, ' note ': name,                      ' Label.background ':  ' Rgba (255, 255, 0, 0.5) ',                      ' select.type ':  ' Circle '}); Node.setsize (10, 10); Var lonlat = new openlayers.lonlat (Lon, lat); Lonlat.transform (' epsg:4326 ',  map.getprojectionobject ()); Node.setposition (Map.getpixelfromlonlat (LonLat)) ; node.lonlat = lonlat;graphview.dm (). Add (node); return node;}


HT for Web integration openlayers GIS map application

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.