當前位置: 首頁>>代碼示例>>Python>>正文


Python s2sphere.RegionCoverer方法代碼示例

本文整理匯總了Python中s2sphere.RegionCoverer方法的典型用法代碼示例。如果您正苦於以下問題:Python s2sphere.RegionCoverer方法的具體用法?Python s2sphere.RegionCoverer怎麽用?Python s2sphere.RegionCoverer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在s2sphere的用法示例。


在下文中一共展示了s2sphere.RegionCoverer方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_covering

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def test_covering(self):
        r = s2sphere.RegionCoverer()
        p1 = s2sphere.LatLng.from_degrees(33, -122)
        p2 = s2sphere.LatLng.from_degrees(33.1, -122.1)
        cell_ids = r.get_covering(s2sphere.LatLngRect.from_point_pair(p1, p2))
        ids = sorted([c.id() for c in cell_ids])
        target = [9291041754864156672,
                  9291043953887412224,
                  9291044503643226112,
                  9291045878032760832,
                  9291047252422295552,
                  9291047802178109440,
                  9291051650468806656,
                  9291052200224620544]
        self.assertEqual(ids, target) 
開發者ID:sidewalklabs,項目名稱:s2sphere,代碼行數:17,代碼來源:covering_test.py

示例2: break_down_area_to_cell

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def break_down_area_to_cell(north, south, west, east):
    """ Return a list of s2 cell id"""
    result = []

    region = s2sphere.RegionCoverer()
    region.min_level = 15
    region.max_level = 15
    p1 = s2sphere.LatLng.from_degrees(north, west)
    p2 = s2sphere.LatLng.from_degrees(south, east)
    rect = s2sphere.LatLngRect.from_point_pair(p1, p2)

    print rect.area()
    if rect.area() * 1000 * 1000 * 100 > 5:
        return []

    cell_ids = region.get_covering(rect)
    result += [cell_id.id() for cell_id in cell_ids]
    print result

    return result 
開發者ID:chenditc-bittiger,項目名稱:pokemon_R2_week4_coding_class,代碼行數:22,代碼來源:scan_area.py

示例3: break_down_area_to_cell

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def break_down_area_to_cell(north, south, west, east):  
    print DBG + "Inside break_down_area_to_cell"
    result = []
    
    region = s2sphere.RegionCoverer()
    region.min_level = 15
    region.max_level = 15
    p1 = s2sphere.LatLng.from_degrees(north, west)
    p2 = s2sphere.LatLng.from_degrees(south, east)

    rect = s2sphere.LatLngRect.from_point_pair(p1, p2)
    area = rect.area()
    if (area * 1000 * 1000 * 100 > 7):
        print DBG + "The area is too big, return..."
        logger.info(DBG + "The area is too big, return...")
        return
    
    cell_ids = region.get_covering(s2sphere.LatLngRect.from_point_pair(p1, p2))
    result += [cell_id.id() for cell_id in cell_ids]
    print cell_ids

    return result 
開發者ID:hackjutsu,項目名稱:pokemongo-map-poc,代碼行數:24,代碼來源:views.py

示例4: cover_region_s2

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def cover_region_s2(location1,location2):
    rc = RegionCoverer()
    rc.max_level = lvl_big
    rc.min_level = lvl_big
    rc.max_cells = 1000
    locations = []

    if location1[0] > location2[0]:
        lat1,lat2 = location2[0],location1[0]
    else:
        lat1, lat2 = location1[0], location2[0]


    if location1[1] > location2[1]:
        lng1, lng2 = location2[1], location1[1]
    else:
        lng1, lng2 = location1[1], location2[1]

    lng1 = (lng1 + 180) % 360 - 180
    lng2 = (lng2 + 180) % 360 - 180

    lngs = []
    if lng2 > lng1:
        lngs.append((lng1,lng2))
    elif lng2 < lng1:
        lngs.append((-180.0,lng2))
        lngs.append((lng1,180.0))

    for lng1,lng2 in lngs:
        cids = rc.get_covering(LatLngRect(LatLng.from_degrees(lat1,lng1),LatLng.from_degrees(lat2,lng2)))

        for cid in cids:
            ll_cid = cid.to_lat_lng()
            locations.append((ll_cid.lat().degrees,ll_cid.lng().degrees))
    return locations 
開發者ID:seikur0,項目名稱:PGO-mapscan-opt,代碼行數:37,代碼來源:maplib.py

示例5: get_cell_ids

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def get_cell_ids(lat, long, radius=500):
    if radius > 500:
        radius = 500
    region = Cap.from_axis_angle(LatLng.from_degrees(lat, long).to_point(), Angle.from_degrees(360*radius/(2*math.pi*EARTH_RADIUS)))
    coverer = RegionCoverer()
    coverer.min_level = 15
    coverer.max_level = 15
    cells = coverer.get_covering(region)
    cells = cells[:21]
    return sorted([x.id() for x in cells]) 
開發者ID:PokeHunterProject,項目名稱:pogom-linux,代碼行數:12,代碼來源:utilities.py

示例6: break_down_area_to_cell

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def break_down_area_to_cell(north, south, west, east):
    """ Return a list of s2 cell id"""
    result = []

    region = s2sphere.RegionCoverer()
    region.min_level = 15
    region.max_level = 15
    p1 = s2sphere.LatLng.from_degrees(north, west)
    p2 = s2sphere.LatLng.from_degrees(south, east)

    cell_ids = region.get_covering(s2sphere.LatLngRect.from_point_pair(p1, p2))
    result += [cell_id.id() for cell_id in cell_ids]
    print result

    return result 
開發者ID:chenditc-bittiger,項目名稱:pokemon_R2_week4_coding_class,代碼行數:17,代碼來源:scan_area.py

示例7: cover_circle

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def cover_circle(lat, lng, radius, level=15):
    EARTH = 6371000
    region = Cap.from_axis_angle(\
             LatLng.from_degrees(lat, lng).to_point(), \
             Angle.from_degrees(360*radius/(2*math.pi*EARTH)))
    coverer = RegionCoverer()
    coverer.min_level = level
    coverer.max_level = level
    cells = coverer.get_covering(region)
    return cells 
開發者ID:tcmaps,項目名稱:fastmap,代碼行數:12,代碼來源:utils.py

示例8: cover_square

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def cover_square(lat, lng, width, level=15):
    offset = int(width / 2)
    g = Geodesic.WGS84  # @UndefinedVariable
    r = RegionCoverer()
    r.min_level, r.min_level = level, level
    g1 = g.Direct(lat, lng, 360, offset)
    g1 = g.Direct(g1['lat2'],g1['lon2'],270,offset)
    p1 = LatLng.from_degrees(g1['lat2'],g1['lon2'])
    g2 = g.Direct(lat, lng, 180, offset)
    g2 = g.Direct(g2['lat2'],g2['lon2'], 90,offset)
    p2 = LatLng.from_degrees(g2['lat2'],g2['lon2'])
    cells = r.get_covering(LatLngRect.from_point_pair(p1, p2))
    return cells 
開發者ID:tcmaps,項目名稱:fastmap,代碼行數:15,代碼來源:utils.py

示例9: break_down_area_to_cell

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def break_down_area_to_cell(north, south, west, east): 
    "return a list of s2 cell ids"
    result = []
    
    region = s2sphere.RegionCoverer()
    region.min_level = 15
    region.max_level = 15
    p1 = s2sphere.LatLng.from_degrees(north, west)
    p2 = s2sphere.LatLng.from_degrees(south, east)

    cell_ids = region.get_covering(s2sphere.LatLngRect.from_point_pair(p1, p2))
    result += [cell_id.id() for cell_id in cell_ids]
    #  print cell_ids

    return result 
開發者ID:hackjutsu,項目名稱:pokemongo-map-poc,代碼行數:17,代碼來源:my_pokemon_api.py

示例10: get_cell_ids

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def get_cell_ids(lat, long, radius=1000):
    # Max values allowed by server according to this comment:
    # https://github.com/AeonLucid/POGOProtos/issues/83#issuecomment-235612285
    if radius > 1500:
        radius = 1500  # radius = 1500 is max allowed by the server
    region = Cap.from_axis_angle(LatLng.from_degrees(lat, long).to_point(), Angle.from_degrees(360*radius/(2*math.pi*EARTH_RADIUS)))
    coverer = RegionCoverer()
    coverer.min_level = 15
    coverer.max_level = 15
    cells = coverer.get_covering(region)
    cells = cells[:100]  # len(cells) = 100 is max allowed by the server
    return sorted([x.id() for x in cells]) 
開發者ID:favll,項目名稱:pogom,代碼行數:14,代碼來源:utilities.py

示例11: cover_circle

# 需要導入模塊: import s2sphere [as 別名]
# 或者: from s2sphere import RegionCoverer [as 別名]
def cover_circle(lat, lng, radius, level=15):
    EARTH = 6371000
    region = Cap.from_axis_angle(
             LatLng.from_degrees(lat, lng).to_point(),
             Angle.from_degrees(360*radius/(2*math.pi*EARTH)))
    coverer = RegionCoverer()
    coverer.min_level = level
    coverer.max_level = level
    cells = coverer.get_covering(region)
    return cells 
開發者ID:tcmaps,項目名稱:pickymap,代碼行數:12,代碼來源:ext.py


注:本文中的s2sphere.RegionCoverer方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。