爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 6698|回复: 4

[求助] 求助地图白化,不能去掉区域外的等值线标签

[复制链接]

新浪微博达人勋

发表于 2021-12-1 21:11:58 | 显示全部楼层 |阅读模式

登录后查看更多精彩内容~

您需要 登录 才可以下载或查看,没有帐号?立即注册 新浪微博登陆

x
本帖最后由 qwe91100 于 2021-12-1 21:14 编辑

用的是萝卜大佬的maskout方法,也综合了晋陵小生大佬的去标签,加上了clabel条件,但是没有去除区域外等值线标签,问问各位大佬我该怎么改才能去掉区域外等值线,用的cartopy库
  1. def shp2clip(originfig,ax,shpfile,region,clabel = False):
  2.     sf = shapefile.Reader(shpfile)
  3.     for shape_rec in sf.shapeRecords():
  4. #         print(shape_rec.record)
  5.         if shape_rec.record[1] == region:  ####这里需要找到和region匹配的唯一标识符,record[]中必有一项是对应的。
  6.             vertices = []
  7.             codes = []
  8.             pts = shape_rec.shape.points
  9.             prt = list(shape_rec.shape.parts) + [len(pts)]
  10.             for i in range(len(prt) - 1):
  11.                 for j in range(prt[i], prt[i+1]):
  12.                     vertices.append((pts[j][0], pts[j][1]))
  13.                 codes += [Path.MOVETO]
  14.                 codes += [Path.LINETO] * (prt[i+1] - prt[i] -2)
  15.                 codes += [Path.CLOSEPOLY]
  16.             clip = Path(vertices, codes)
  17.             clip = PathPatch(clip, transform=ax.transData)
  18.         if  clabel:
  19.             clip_map_shapely = ShapelyPolygon(vertices)
  20.             for text_object in clabel:
  21.                 if not clip_map_shapely.contains(ShapelyPoint(text_object.get_position())):
  22.                     text_object.set_visible(False)
  23.     for contour in originfig.collections:
  24.         contour.set_clip_path(clip)
复制代码


Snipaste_2021-12-01_20-43-46.png
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2021-12-2 22:53:46 | 显示全部楼层
自己给自己顶一下,有没有大佬解惑啊
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

新浪微博达人勋

发表于 2021-12-3 00:12:28 | 显示全部楼层
cartopy降级到0.17
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

新浪微博达人勋

 楼主| 发表于 2021-12-3 22:36:03 | 显示全部楼层

老师我问下,降级该怎么做
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

新浪微博达人勋

发表于 2022-1-8 17:14:13 | 显示全部楼层
conda install cartopy==0.17.0
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

Copyright ©2011-2014 bbs.06climate.com All Rights Reserved.  Powered by Discuz! (京ICP-10201084)

本站信息均由会员发表,不代表气象家园立场,禁止在本站发表与国家法律相抵触言论

快速回复 返回顶部 返回列表