zoukankan      html  css  js  c++  java
  • 几何图形相交计算

    #!/usr/bin/env python
    # -*- coding: utf-8 -*-
    
    import os
    import json
    from shapely.geometry import asShape
    
    # define output GeoJSON file
    res_line_intersect = os.path.realpath("../geodata/ch05-01-geojson.js")
    
    # input GeoJSON features
    simple_line = {"type":"FeatureCollection","features":[{"type":"Feature","properties":{"name":"line to clip"},"geometry":{"type":"LineString","coordinates":[[5.767822265625,50.14874640066278],[11.901806640625,50.13466432216696],[4.493408203125,48.821332549646634]]}}]}
    clip_boundary = {"type":"FeatureCollection","features":[{"type":"Feature","properties":{"name":"Clipping boundary circle"},"geometry":{"type":"Polygon","coordinates":[[[6.943359374999999,50.45750402042058],[7.734374999999999,51.12421275782688],[8.96484375,51.316880504045876],[10.1513671875,51.34433866059924],[10.8544921875,51.04139389812637],[11.25,50.56928286558243],[11.25,49.89463439573421],[10.810546875,49.296471602658094],[9.6240234375,49.03786794532644],[8.1298828125,49.06666839558117],[7.5146484375,49.38237278700955],[6.8994140625,49.95121990866206],[6.943359374999999,50.45750402042058]]]}}]}
    
    # create shapely geometry from FeatureCollection
    # access only the geomety part of GeoJSON
    shape_line = asShape(simple_line['features'][0]['geometry'])
    shape_circle = asShape(clip_boundary['features'][0]['geometry'])
    
    # run the intersection
    shape_intersect = shape_line.intersection(shape_circle)
    
    # define output GeoJSON dictionary
    out_geojson = dict(type='FeatureCollection', features=[])
    
    # generate GeoJSON features
    for (index_num, line) in enumerate(shape_intersect):
        feature = dict(type='Feature', properties=dict(id=index_num))
        feature['geometry'] = line.__geo_interface__
        out_geojson['features'].append(feature)
    
    # write out GeoJSON to javascript file
    # this file is read in our html and
    # displayed as GeoJSON on the leaflet map
    # called /html/ch05-01-clipping.html
    with open(res_line_intersect, 'w') as js_file:
        js_file.write('var big_circle = {0}'.format(json.dumps(clip_boundary)))
        js_file.write("
    ")
        js_file.write('var big_linestring = {0}'.format(json.dumps(simple_line)))
        js_file.write("
    ")
        js_file.write('var simple_intersect = {0}'.format(json.dumps(out_geojson)))
  • 相关阅读:
    时间随手记
    laravel简书(2)
    laravel简书(1)
    <<Design Patterns>> Gang of Four
    计算机网络你还懵逼吗?持续更新!!!
    poj3126 搜索
    POJ 1426 搜索进阶
    CodeForces 660D
    poj3279搜索详解
    bfs简单题-poj2251
  • 原文地址:https://www.cnblogs.com/gispathfinder/p/5745997.html
Copyright © 2011-2022 走看看