php和jquery實現地圖地區資料統計展示資料樣本

來源:互聯網
上載者:User

 我們要在地圖上有限的區塊內展示更多的資訊,更好的辦法是通過地圖互動來實現。本文將給大家講解通過滑鼠滑動到地圖指定省份地區,在彈出的提示框中顯示對應省份的資料資訊。適用於資料統計和地圖區塊展示等情境

  HTML 首先在head部分載入raphael.js庫檔案和chinamapPath.js路徑資訊檔,本文不重複寫下,唯一不同的地方是需要在body中加一個div#tip,用來展示地圖資訊的提示框。 代碼如下:<div id="map"></div> <div id="tip"></div>   jQuery 通過調用raphael繪製出中國地圖,然後載入統計資料,由於地圖區塊小,我們不在地圖載入的時候就將資料顯示在地圖區塊上了,我們通過滑鼠互動實現將資料資訊更好的展示給使用者。當滑鼠滑向省份區塊時,通過e.pageX和e.pageY定位滑鼠座標,然後通過jquery的css()方法定位提示框div#tip,並且將對應省份的的名稱和活躍使用者數加到提示框裡並展現出來,請看代碼: 代碼如下:$(function(){     $.get("json.php",function(json){      ......//這裡省略代碼若干      var i=0;     for (var state in china) {         china[state]['path'].color = Raphael.getColor(0.9);         (function (st, state) {             var prodata = data[i];             var fillcolor = colors[arr[i]];             st.attr({fill:fillcolor});//填充背景色             xOffset = 70;             yOffset = 180;             st.hover(function(e){//滑鼠滑向                 st.animate({fill: "#fdd", stroke: "#eee"}, 500);                 R.safari();                                 $("#tip").css({"top":(e.pageY-xOffset)+"px","left":(e.pageX-yOffset)+"px"}).fadeIn("fast")                 .html("<h4>"+china[state]['name']+"</h4><p>活躍使用者數:"+prodata+"</p>");             },function(){//滑鼠離開                 st.animate({fill: fillcolor, stroke: "#eee"}, 500);                 R.safari();                 $("#tip").hide();             });              st.mousemove(function(e){//滑鼠移動                 $("#tip").css({"top":(e.pageY-xOffset)+"px","left":(e.pageX-yOffset)+"px"});                 R.safari();             });           })(china[state]['path'], state);          i++;     }     }); });   以上代碼可以看出,通過jQuery的hover()滑鼠滑向省份區塊時,調用彈出提示框,並將資料載入顯示在提示框中,而值得關注的是,我們還需要加一個效果,就是滑鼠在省份區塊上移動mousemove()的時候,也應該調用提示框跟隨滑鼠一起移動,否則的話當滑鼠在一個省份區塊內滑動的話提示框位置不會變化,這樣會影響體驗效果,小小的改動可以提升使用者體驗。最後,如果您需要定製提示框的效果的話,可以設定提示框的CSS樣式,本例簡單的CSS代碼如下:  代碼如下:#tip{position:absolute; width:180px; border:1px solid #d3d3d3; background:#fff;display:none; -moz-border-radius:5px; -webkit-border-radius:5px; overflow:hidden; border-radius:5px; -moz-box-shadow:1px 1px 2px rgba(0,0,0,.2); -webkit-box-shadow:1px 1px 2px rgba(0,0,0,.2);  box-shadow:1px 1px 2px rgba(0,0,0,.2);} #tip h4{height:28px; line-height:28px; padding-left:6px; background:#f0f0f0} #tip p{line-height:24px; padding:2px 4px}  
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

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.