PHP+jQuery中國地圖熱點數據統計展示實例

来源:https://www.cnblogs.com/mrlime/archive/2019/12/18/12063763.html
-Advertisement-
Play Games

一款PHP+jQuery實現的中國地圖熱點數據統計展示實例,當滑鼠滑動到地圖指定省份區域,在彈出的提示框中顯示對應省份的數據信息。 ...


一款PHP+jQuery實現的中國地圖熱點數據統計展示實例,當滑鼠滑動到地圖指定省份區域,在彈出的提示框中顯示對應省份的數據信息。

首先在頁面中加一個div#tip,用來展示地圖信息的提示框和#map用來生成地圖。

1 <div id="map"></div>  
2 <div id="tip"></div>


接著我們引入jQuery庫、raphael.js及chinamapPath.js(中國地圖數據)

1 <script type="text/javascript" src="jquery.js"></script>  
2 <script type="text/javascript" src="raphael.js"></script> 
3 <script type="text/javascript" src="chinamapPath.js"></script>


通過調用raphael繪製出中國地圖,然後載入統計數據,由於地圖區塊小,我們不在地圖載入的時候就將數據顯示在地圖區塊上了,我們通過滑鼠交互實現將數據信息更好的展示給用戶。當滑鼠滑向省份區塊時,通過e.clientX和e.clientY定位滑鼠坐標,然後通過jquery的css()方法定位提示框div#tip,並且將對應省份的的名稱和活躍用戶數加到提示框里並展現出來,代碼如下:

 1 $(function() { 
 2     $.get("json.php", 
 3     function(json) { 
 4         var data = string2Array(json); 
 5         var flag; 
 6         var arr = new Array(); 
 7         for (var i = 0; i < data.length; i++) { 
 8             var d = data[i]; 
 9             if (d < 100) { 
10                 flag = 0; 
11             } else if (d >= 100 && d < 500) { 
12                 flag = 1; 
13             } else if (d >= 500 && d < 2000) { 
14                 flag = 2; 
15             } else if (d >= 2000 && d < 5000) { 
16                 flag = 3; 
17             } else if (d >= 5000 && d < 10000) { 
18                 flag = 4; 
19             } else { 
20                 flag = 5; 
21             } 
22             arr.push(flag); 
23         } 
24         var colors = ["#d7eef8", "#97d6f5", "#3fbeef", "#00a2e9", "#0084be", "#005c86"]; 
25         var R = Raphael("map", 600, 500); 
26  
27         //調用繪製地圖方法 
28         paintMap(R); 
29  
30         var i = 0; 
31         for (var state in china) { 
32             china[state]['path'].color = Raphael.getColor(0.9); (function(st, state) { 
33                 var prodata = data[i]; 
34                 var fillcolor = colors[arr[i]]; 
35                 st.attr({ 
36                     fill: fillcolor 
37                 }); //填充背景色 
38                 xOffset = 70; 
39                 yOffset = 180; 
40                 st.hover(function(e) { 
41                     st.animate({ 
42                         fill: "#fdd", 
43                         stroke: "#eee" 
44                     }, 
45                     500); 
46                     R.safari(); 
47                     $("#tip").css({ 
48                         "top": (e.clientY - xOffset) + "px", 
49                         "left": (e.clientX - yOffset) + "px" 
50                     }).fadeIn("fast").html("<h4>" + china[state]['name'] + "</h4><p>活躍用戶數:" + prodata + "</p>"); 
51                 }, 
52                 function() { 
53                     st.animate({ 
54                         fill: fillcolor, 
55                         stroke: "#eee" 
56                     }, 
57                     500); 
58                     R.safari(); 
59                     $("#tip").hide(); 
60                 }); 
61  
62                 st.mousemove(function(e) { 
63                     $("#tip").css({ 
64                         "top": (e.clientY - xOffset) + "px", 
65                         "left": (e.clientX - yOffset) + "px" 
66                     }); 
67                     R.safari(); 
68                 }); 
69  
70             })(china[state]['path'], state); 
71             i++; 
72         } 
73     }); 
74 }); 
75  
76 function string2Array(string) { 
77     eval("var result = " + decodeURI(string)); 
78     return result; 
79 }


本文轉自:https://www.sucaihuo.com/php/147.html 轉載請註明出處!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 0、前言 任何系統,我們不會傻傻的在每一個地方進行異常捕獲和處理,整個系統一般我們會在一個的地方統一進行異常處理,spring boot全局異常處理很簡單; 介紹前先說點題外話,我們現在開發系統,都是前後端完全分離的,後端只提供RESTfull API,禁止涉及任何界面,什麼thymeleaf、JS ...
  • 背景 一次無意的訪問,點擊到了一個專門做PHP性能測試的網站,看這裡 "PHP Benchmarks" 。 在裡面發現了框架性能測試的結果,發現Laravel的框架性能盡然是最低的。瞬間受到了一萬點的暴擊,誰讓最近一直用Laravel開發項目的呢。 說到底還是Laravel好用呀,方便不說,各方面支 ...
  • 在java類中使用super來調用父類中的指定操作: super可用於訪問父類中定義的屬性; super可用於調用父類中定義的成員方法; super可用於在子類構造方法中調用父類的構造方法; 註意: 尤其當父子類出現同名成員時,可以用super進行區分; super的追溯不僅限於直接父類,還可以調用 ...
  • 使用Spring Boot 本節將詳細介紹如何使用Spring Boot。它涵蓋了諸如構建系統,自動配置以及如何運行應用程式之類的主題。我們還將介紹一些Spring Boot最佳實踐。儘管Spring Boot並沒有什麼特別的地方(它只是另一個可以使用的庫),但是有一些建議可以使您的開發過程更輕鬆一 ...
  • 該參數主要是控制新生代需要經歷多少次GC晉升到老年代中的最大閾值。在JVM中用4個bit存儲(放在對象頭中),所以其最大值是15。如果該值=0則表示對象在Eden區gc後不經過Survivor區直接進入老年代。如果該值等於15,並非意味著,對象必須要經歷15次YGC才會晉升到老年代中。例如,當sur... ...
  • 一 Netty服務端NioEventLoop的啟動 Netty服務端創建、初始化完成後,再向Selector上註冊時,會將服務端Channel與NioEventLoop綁定,綁定之後,一方面會將服務端Channel的註冊工作當做Runnable任務提交到NioEventLoop的taskQueue, ...
  • 在一篇《初步瞭解JVM第一篇》中,我們已經瞭解了: 類載入器:負責載入*.class文件,將位元組碼內容載入到記憶體中。其中類載入器的類型有如下: 啟動類載入器(Bootstrap) 擴展類載入器(Extension) 應用程式類載入器(AppClassLoader) 用戶自定義載入器(User-Def ...
  • 微信公眾平臺後臺配置自定義菜單 一、首先進入微信公眾平臺, 訪問地址 https://mp.weixin.qq.com/ 二、用註冊的微信公眾號的賬號和密碼登錄,左側的功能選項中進入自定義菜單頁面 三、在自定義菜單頁面 點擊紅框的 + 號 就可以增加新的菜單 四、對新加的菜單可以根據自己的需要進行設 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...