《阿里云产品四月刊》—Ganos H3 地理网格能力解析与最佳实践(3)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: 阿里云瑶池数据库云原生化和一体化产品能力升级,多款产品更新迭代

本文来源于阿里云社区电子书《阿里云产品四月刊》


《阿里云产品四月刊》—Ganos H3 地理网格能力解析与最佳实践(2)https://developer.aliyun.com/article/1554159

附录

可视化前端 Python 脚本如下:

from quart import Quart, send file, render template
import asyncpg
import io
import re
# 数据库连接参数
CONNECTION = {"host": "YOUR HOST NAME OR IP", "port": PORT NO,
"database": "DATABASE NAME",
"user": "USER NAME", "password": "PASSWORD"}
# 目标表名/字段/ID
TABLE = "h3 count lev13"
H3 COL = "h3 lev13"
H3 GEOM COL = "geometry"
AGG VAL COL = "count"
COL SRID = 4326
app = Quart( name , template folder='./')
@app.before serving
async def create db pool():
app.db pool = await asyncpg.create pool(**CONNECTION)
@app.after serving
async def close db pool():
await app.db pool.close()
@app.route("/")
async def home():
sql = f'''
SELECT ST Extent(ST Transform(ST Envelope({H3 GEOM COL}), 4326))
FROM {TABLE};
'''
async with app.db pool.acquire() as connection:
box = await connection.fetchval(sql)
box = re.findall('BOX\((.*?) (.*?),(.*?) (.*?)\)', box)[0]
min x, min y, max x, max y = list(map(float, box))
bounds = [[min x, min y], [max x, max y]]
center = [(min x + max x) / 2, (min y + max y) / 2]
return await render template('./index.html', center=str(center),
bounds=str(bounds))
@app.route("/h3 mvt/<int:z>/<int:x>/<int:y>")
async def h3 mvt(z, x, y):
sql = f'''
SELECT ST AsMVT(tile.*)
FROM
(SELECT
ST AsMVTGeom({H3 COL},
ST Transform(ST TileEnvelope($1,$2,$3),{COL SRID}), 4096, 512, true)
geometry,
{AGG VAL COL} count
FROM {TABLE}
WHERE
({H3 COL}
&&
ST Transform(ST TileEnvelope($1,$2,$3),{COL SRID}))) tile'''
async with app.db pool.acquire() as connection:
tile = await connection.fetchval(sql, z, x, y)
return await send file(io.BytesIO(tile),
mimetype='application/vnd.mapbox vector tile')
if name == " main ":
app.run(port=5100)


index.html 文件内容如下:

 

<!DOCTYPE html>
<html>
<head>
<meta charset="utf 8">
<title>map viewer</title>
<meta
name="viewport"
content="initial scale=1,maximum scale=1,user scalable=no">
<link
href="https://api.mapbox.com/mapbox gl js/v2.14.1/mapbox gl.css"
rel="stylesheet">
<script
src="https://api.mapbox.com/mapbox gl js/v2.14.1/mapbox gl.js"></scr
ipt>
<script
src="https://cdnjs.cloudflare.com/ajax/libs/chroma js/2.4.2/chroma.m
in.js"></script>
</head>
<body>
<div id="map" style="position: absolute;left:0; top: 0; bottom: 0;
width: 100%;cursor:pointer;"></div>
<div class="counter"
style="position:
absolute;left:2%;font size:
20px;padding: .1em .1em;text shadow: 3px 3px 3px black;">
<span>当前网格计数:</span><span id="count">0</span>
</div>
<script>
let YOUR TOKEN = "input your mapbox token"
mapboxgl.accessToken = YOUR TOKEN;
const map = new mapboxgl.Map({
container: "map",
style: "mapbox://styles/mapbox/navigation night v1",
center: {{ center }},
zoom: 1
})
map.on("load", () => {
map.fitBounds({{ bounds }})
map.on('mousemove', 'h3', (e) => {
map.getCanvas().style.cursor = "default";
if (e.features.length > 0)
document.getElementById('count').innerText =
e.features[0].properties.count
})
map.on('mouseleave', 'h3', () => {
map.getCanvas().style.cursor = "grab";
document.getElementById('count').innerText = 0
})
map.addSource("h3 source", {
type: "vector",
tiles: [`${window.location.href}h3 mvt/{z}/{x}/{y}`],
tileSize: 512
});
// make color map
const MIN = 1
const MAX = 600
const STEP = 10
color map = chroma.scale(["#536edb", "#5d96a5", "#68be70",
"#91d54d", "#cddf37", "#fede28", "#fda938", "#fb7447", "#f75a40",
"#f24734", "#e9352a", "#da2723", "#cb181d"])
.domain([MIN, MAX]);
let colors = []
for (let i = MIN; i < MAX; i += STEP)
colors.push(color map(i).hex(), i)
colors.push(color map(MAX).hex())
map.addLayer({
id: "h3",
type: "fill",
source: "h3 source",
"source layer": "default",
paint: {
"fill color": [
"step", ["get", "count"],
...colors
],
"fill opacity": 0.8
}
});
});
</script>
</body>
</html>
相关文章
|
5天前
|
机器学习/深度学习 人工智能 弹性计算
阿里云GPU服务器全解析_GPU价格收费标准_GPU优势和使用说明
阿里云GPU云服务器提供强大的GPU算力,适用于深度学习、科学计算、图形可视化和视频处理等场景。作为亚太领先的云服务商,阿里云GPU云服务器具备高灵活性、易用性、容灾备份、安全性和成本效益,支持多种实例规格,满足不同业务需求。
|
19天前
|
存储 弹性计算 NoSQL
"从入门到实践,全方位解析云服务器ECS的秘密——手把手教你轻松驾驭阿里云的强大计算力!"
【10月更文挑战第23天】云服务器ECS(Elastic Compute Service)是阿里云提供的基础云计算服务,允许用户在云端租用和管理虚拟服务器。ECS具有弹性伸缩、按需付费、简单易用等特点,适用于网站托管、数据库部署、大数据分析等多种场景。本文介绍ECS的基本概念、使用场景及快速上手指南。
60 3
|
30天前
|
域名解析 网络协议
非阿里云注册域名如何在云解析DNS设置解析?
非阿里云注册域名如何在云解析DNS设置解析?
|
23天前
|
运维 Cloud Native 持续交付
云原生技术解析:从IO出发,以阿里云原生为例
【10月更文挑战第24天】随着互联网技术的不断发展,传统的单体应用架构逐渐暴露出扩展性差、迭代速度慢等问题。为了应对这些挑战,云原生技术应运而生。云原生是一种利用云计算的优势,以更灵活、可扩展和可靠的方式构建和部署应用程序的方法。它强调以容器、微服务、自动化和持续交付为核心,旨在提高开发效率、增强系统的灵活性和可维护性。阿里云作为国内领先的云服务商,在云原生领域有着深厚的积累和实践。
51 0
|
30天前
|
监控 网络协议 数据挖掘
阿里云国际云解析DNS如何开启/关闭流量分析?
阿里云国际云解析DNS如何开启/关闭流量分析?
|
1月前
|
人工智能 分布式计算 数据处理
阿里云与传智教育联合直播:深度解析MaxFrame,探索量化交易新纪元
2024年10月15日,阿里云与传智教育联合举办了一场主题为“解密新一代AI+Python分布式计算框架MaxFrame”的直播,对阿里云最新推出的分布式计算框架MaxFrame进行了详细的介绍。
199 0
|
1月前
|
弹性计算 网络协议 数据库
在阿里云国际站上解析域名到服务器详细教程
在阿里云国际站上解析域名到服务器详细教程
|
3天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
14 2
|
1月前
|
缓存 Java 程序员
Map - LinkedHashSet&Map源码解析
Map - LinkedHashSet&Map源码解析
66 0
|
1月前
|
算法 Java 容器
Map - HashSet & HashMap 源码解析
Map - HashSet & HashMap 源码解析
52 0

推荐镜像

更多