PHP不直接绘图,热力图需借助前端(Canvas/SVG)或GD/Imagick等库;GD适合生成静态PNG报表,需启用gd扩展、预定义色表并线性插值;主流做法是PHP输出JSON供ECharts/Leaflet渲染,注意归一化、坐标系匹配(如WGS-84转BD-09)及数据验证。
PHP 本身不直接绘图,热力图必须借助前端(如 Canvas / SVG)或外部图形库(如 GD、Imagick),PHP 只负责生成坐标+强度数据或生成图像二进制流;所谓“数据映射法”,本质是把地理/网格坐标转为颜色值(通常是 RGB 或十六进制),再渲染成图。

适合后台定时生成 PNG 热力图用于报表或邮件附件,不支持交互缩放或动态更新。
gd 扩展(php -m | grep gd 验证)imagesetpixel() 填充单像素,或用 imagefilledrectangle() 填充区块$colors = [0 => [0,0,255], 50 => [0,255,255], 100 => [255,255,0], 150 => [255,0,0]],再线性插值得到中间色imagealphablending()
这是当前主流做法,PHP 只做数据准备,前端负责可视化和交互,更灵活也更符合现代架构。
series.type: 'heatmap' 要求每项为 [x, y, value] 三元组(坐标可为经纬度或自定义索引)min()/max() + 线性映射map.setOption({ series: [{ type: 'map', data: [...] }] })
header('Content-Type: application/json; charset=utf-8');,中文地名不乱码直接用 GPS 坐标(WGS-84)在百度或高德底图上绘制会整体偏移数百米——这不是 PHP 绘图错误,而是坐标系不匹配。
http://api.map.baidu.com/geoconv/v1/?coords=116.48,39.99&from=1&to=5(WGS-84 → BD-09)真正卡住人的往往不是“怎么画”,而是“坐标对不对”“色阶是否掩盖了真实分布差异”“聚合粒度是否让热点淹没在均值里”。先用小样本导出 CSV,在 Excel 里散点图验证分布形态,再动代码。