【问题标题】:Show Google Maps markers based on user's current map view根据用户当前的地图视图显示 Google 地图标记
【发布时间】:2018-01-03 16:22:53
【问题描述】:

在我的网络应用程序中,我使用 psycopg2 来查询包含数千个位置点的 postgreSQL 数据库。假设它们可以分为办公室学校

大约有 5500 个办公室和 550 所学校。一次获取所有结果会使其过载并导致我的查询被取消。因此,我只想根据用户当前正在查看的地图部分显示大约 100 个结果。

我的地图的默认视图是美国。我希望数据库在任何给定时间都只能获得 100 个结果(100 个办公室和 100 所学校)。如果用户放大,它会更详细——会出现不同的标记。

这是我目前所拥有的:

@app.route('/_ajax', methods= ['GET'])
def points():
    myConnection = psycopg2.connect(host=hostname, user=username,
    password=password, dbname=database)
    cur = myConnection.cursor()

    bounds = request.args.get('bounds')

    officeID = []
    office_info = []
    cur.execute("""SELECT DISTINCT(o.office_id) from db_office o
                   WHERE o.location && ST_MakeEnvelope(left, bottom, right, top, 4326)
                   GROUP BY o.office_id LIMIT 100""")
    for row in cur:
        officeID.append(row[0])
    for o in officeID:
    cur.execute("""SELECT ST_Y(o.location::geometry), 
                   ST_X(o.location::geometry),
                   o.owner, o.office_name from db_office o""".format(o))
    for row in cur:
        office_info.append([row[0], row[1], row[2], row[3]])
    offices = dict(zip(officeID, office_info))

    schoolID = []
    school_info = []
    cur.execute("""SELECT DISTINCT(s.school_id) from db_school s
                    WHERE s.location && ST_MakeEnvelope(left, bottom, right, top, 4326)
                   GROUP BY s.school_id LIMIT 100""")
    for row in cur:
        schoolID.append(row[0])
    for s in schoolID:
        cur.execute("""SELECT ST_Y(s.location::geometry), 
                       ST_X(s.location::geometry),
                       s.owner, s.school_name from db_school s""".format(s))
    for row in cur:
        school_info.append([row[0], row[1], row[2], row[3]])
    schools = dict(zip(schoolID, school_info))

return jsonify(offices=offices, schools=schools)

绘制标记的 AJAX 调用如下所示:

 $SCRIPT_ROOT = {{ request.script_root|tojson|safe }};
 $(function() {
    $.getJSON($SCRIPT_ROOT + '/_ajax?bounds=' + map.getBounds().toUrlValue(),
    function(data) {

    var places = [];
    var marker;

    Object.keys(data.offices).forEach(function(key) {
        var offices = data.offices[key];
        places.push(new google.maps.LatLng(offices[0], offices[1]))
        marker = new google.maps.Marker({
            position: {lat: offices[0], lng: offices[1]},
            map: map
        });
    });

    Object.keys(data.schools).forEach(function(key) {
       var schools = data.schools[key];
       places.push(new google.maps.LatLng(schools[0], schools[1]))
       marker = new google.maps.Marker({
           position: {lat: schools[0], lng: schools[1]},
           map: map,
       });
    });
});

总而言之,这段代码获取了 100 个办公室和 100 个学校,并将其放入字典中,其中 id 是键,值是纬度和经度等信息。

这有效,每个结果显示 100 个,但不依赖于用户位置。如何根据用户的地图视图更改数据库获取的结果?

【问题讨论】:

  • 我想我需要在我的查询中添加一个WHERE 参数,并做一些涉及ST_Within 的事情可能吗?但我不知道具体是什么

标签: javascript ajax google-maps postgis psycopg2


【解决方案1】:

您需要首先按照here 的说明获取 Google 地图的边界。

然后使用边界在 Postgres 中执行相交查询,如 here 所述。

SELECT DISTINCT(o.office_id) from db_office o
WHERE o.location && ST_MakeEnvelope(left, bottom, right, top, 4326);
GROUP BY o.office_id LIMIT 100

来自 javascript 的 Ajax 调用:

$.getJSON($SCRIPT_ROOT + '/_ajax?bounds=' + map.getBounds().toUrlValue(), function (response) { 
    //do something with response here
});

【讨论】:

  • 所以根据第一篇文章,我可以访问我的 Javascript 中的边界(使用 map.getBounds),但是如何在我的查询中引用它?
  • 我仍然不确定如何获得界限。 map.getBounds 方法在 JavaScript 中使用,那么如何访问代码中引用的“左、下、右、上”值?
  • 你是如何调用你的 ajax 脚本的?只需将边界作为查询字符串参数发送。我已经更新了答案。
  • 我更新了问题以显示我如何使用我的 ajax 调用
  • 我更新了答案。在 python 方面,您将必须读取查询字符串并解析边界并更新您的查询。您可以按照here 的说明进行操作
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2012-04-16
  • 2016-11-03
  • 2019-01-05
  • 1970-01-01
  • 1970-01-01
  • 2013-02-27
  • 1970-01-01
相关资源
最近更新 更多