当前位置: 首页 > news >正文

网站建设与管理知识点深圳关键词自动排名

网站建设与管理知识点,深圳关键词自动排名,线上平台推广是做什么的,张家口网站建设在Google Earth Engine的python版API更新后,之前使用folium动态加载地图的代码就不能在正常运行,因为整个Google Earth Engine的地图加载服务的URL发生了更新,所以我们也需要更新相关绘制方法。下面我会讲解一种新的绘制方法,大家…

在Google Earth Engine的python版API更新后,之前使用folium动态加载地图的代码就不能在正常运行,因为整个Google Earth Engine的地图加载服务的URL发生了更新,所以我们也需要更新相关绘制方法。下面我会讲解一种新的绘制方法,大家可以根据自己的需求来扩充相关绘制方法,直接上相关具体代码。

     需要说明一下,我所有的代码都是在Jupyter Lab中运行,这些代码无法在pycharm中直接运行。

第一步、注册GEE。

第二步、导入外部库folium。

第三步、编写添加GEE图层的方法,并且将其作为自定义方法加入到folium的Map中。

具体代码:

  1. # 定义加载GEE影像数或者矢量数据方法

  2. def add_ee_layer(self, ee_object, vis_params, name):

  3.     try:    

  4.         if isinstance(ee_object, ee.Image):    

  5.             map_id_dict = ee.Image(ee_object).getMapId(vis_params)

  6.             folium.raster_layers.TileLayer(

  7.                 tiles = map_id_dict['tile_fetcher'].url_format,

  8.                 attr = 'Google Earth Engine',

  9.                 name = name,

  10.                 overlay = True,

  11.                 control = True

  12.             ).add_to(self)

  13.         elif isinstance(ee_object, ee.FeatureCollection):  

  14.             ee_object_new = ee.Image().paint(ee_object, 0, 2)

  15.             map_id_dict = ee.Image(ee_object_new).getMapId(vis_params)

  16.             folium.raster_layers.TileLayer(

  17.                 tiles = map_id_dict['tile_fetcher'].url_format,

  18.                 attr = 'Google Earth Engine',

  19.                 name = name,

  20.                 overlay = True,

  21.                 control = True

  22.             ).add_to(self)

  23.     except:

  24.         print("Could not display {}".format(name))

  25.     

  26. folium.Map.add_ee_layer = add_ee_layer

代码解析:

加载图层方法为add_ee_layer,这个方法的具体参数参数有三个分别为:

  • ee_object,显示对象可以为image或者featureCollection

  • vis_params,显示规则,其中image和JavaScript版配置一致,featureCollection配置使用palette配置颜色即可

  • name,图层的名称

第四步、调用上面定义的方法绘制影像Image和矢量数据FeatureCollection。

具体代码:

  1. dem = ee.Image('USGS/SRTMGL1_003')

  2. vis = {

  3.   'min': 0,

  4.   'max': 4000,

  5.   'palette': ['006633', 'E5FFCC', '662A00', 'D8D8D8', 'F5F5F5']

  6. }

  7. roi = ee.FeatureCollection("users/wangweihappy0/training03/bj_shp")

  8. center = roi.geometry().centroid().getInfo()['coordinates']

  9. center.reverse()

  10. print("center is: {}".format(center))

  11. my_map = folium.Map(location=center, zoom_start=8, height=500)

  12. my_map.add_ee_layer(dem.updateMask(dem.gt(0)), vis, 'DEM')

  13. my_map.add_ee_layer(roi, {"palette": "FF0000"}, "roi")

  14. my_map.add_child(folium.LayerControl())

代码解析:

  • vis配置的是DEM显示规则

  • center是地图要居中显示的位置

  • my_map是通过folium.Map配置显示的地图

  • my_map通过add_ee_layer添加定义的图层dem和roi

运行结果:

第五步、总结第四步调用方法可以将其写为一个具体的方法,然后直接调用这个方法。

具体代码:

  1. # 使用Folium展示地图  

  2. def Mapdisplay(center, layers, Tiles="OpensTreetMap",zoom_start=10):  

  3.     mapViz = folium.Map(location=center,tiles=Tiles, zoom_start=zoom_start)  

  4.     for data in layers:  

  5.         mapViz.add_ee_layer(data.get("layer"), data.get("vis"), data.get("name"))

  6.     mapViz.add_child(folium.LayerControl())  

  7.     return mapViz

使用这个方法示例如下

具体代码:

  1. dem = ee.Image('USGS/SRTMGL1_003')

  2. vis = {

  3.   'min': 0,

  4.   'max': 4000,

  5.   'palette': ['006633', 'E5FFCC', '662A00', 'D8D8D8', 'F5F5F5']

  6. }

  7. roi = ee.FeatureCollection("users/wangweihappy0/training03/bj_shp")

  8. center = roi.geometry().centroid().getInfo()['coordinates']

  9. center.reverse()

  10. print("center is: {}".format(center))

  11. layers = [

  12.     {

  13.         "layer": dem,

  14.         "vis": vis,

  15.         "name": "DEM"

  16.     },

  17.     {

  18.         "layer": roi,

  19.         "vis": {"palette": "FF0000"},

  20.         "name": "roi"

  21.     }

  22. ]

  23. Mapdisplay(center, layers, zoom_start=8)

代码解析:

    这个程序运行结果和前面例子运行结果一样,区别就是在这里使用的我们自定义的方法Mapdisplay()方法,这个方法的参数分别为:

  • center,中心点坐标

  • layers,要加载的所有图层信息列表,配置规则是

    [

    {

            "layer": xxx, //图层的数据可以是image或者featureCollection

            "vis": xxx, //显示规则,image配置和在JavaScript中配置一致

                        //featureCoolection配置用{"palette": 颜色}就可以

            "name": xxx, //显示的图层名称

    }

    ]

  • Tiles,这个使用默认就可以,不用修改

  • zoom_start,最初缩放比例,比如这里使用的是8

  • 来源请引用:地理遥感生态网科学数据注册与出版系统。

http://www.tj-hxxt.cn/news/98363.html

相关文章:

  • 做网站简单还是写程序seo手机端优化
  • 支付宝手机网站支付前端怎么做百度搜索入口官网
  • 网站开发人员介绍佛山网站建设维护
  • 三只松鼠品牌案例分析上海优质网站seo有哪些
  • 网站建设与制作教程北华大学bt磁力
  • 想要找个网站做环评公示百度竞价推广方案
  • 上海网站建设哪家便宜宁波seo推广
  • 网站建设和维护待遇网络推广合作协议
  • 做网站客户不给钱怎么办google adwords关键词工具
  • 移动端网站建设费用谷歌google下载
  • 做的网站速度慢怎样在百度上做广告推广
  • 做农村电子商务的网站有哪些成都百度提升优化
  • 邯郸做网站的公司哪家好站长工具seo综合查询工具
  • 网站怎么公安备案号安卓优化大师历史版本
  • b2c网站前台系统主要包括哪几个部分河南网站优化排名
  • 做平面设计的网站怎么做市场推广
  • 东莞 网站设计全能优化大师
  • 我们是谁 网站运营一个产品营销策划方案
  • 如何在自己的网站上做直播网站管理与维护
  • 高邮市建设网站国内企业网站模板
  • 婚庆企业网站建设软文广告有哪些
  • 网络销售怎么做网站免费的发帖收录网站
  • 兖州网站建设多少钱网上营销培训课程
  • 铆钉机 东莞网站建设自己怎么开网站
  • 网站建设中 源码网页seo优化
  • 做模具的都有什么网站游戏推广赚佣金
  • 震旦集团网站建设互联网广告推广公司
  • 公司网站可以分两个域名做吗福州百度关键词优化
  • 网站开发与推广就业凡科网免费建站官网
  • 官方网站建设计划书google关键词seo