python+matplotlib绘制简单的海豚(顶点和节点的操作)


Posted in Python onJanuary 02, 2018

海豚

本文例子主要展示了如何使用补丁、路径和转换类绘制和操作给定的顶点和节点的形状。

测试可用。

import matplotlib.cm as cm
import matplotlib.pyplot as plt
from matplotlib.patches import Circle, PathPatch
from matplotlib.path import Path
from matplotlib.transforms import Affine2D
import numpy as np

# Fixing random state for reproducibility
np.random.seed(19680801)


r = np.random.rand(50)
t = np.random.rand(50) * np.pi * 2.0
x = r * np.cos(t)
y = r * np.sin(t)

fig, ax = plt.subplots(figsize=(6, 6))
circle = Circle((0, 0), 1, facecolor='none',
        edgecolor=(0, 0.8, 0.8), linewidth=3, alpha=0.5)
ax.add_patch(circle)

im = plt.imshow(np.random.random((100, 100)),
        origin='lower', cmap=cm.winter,
        interpolation='spline36',
        extent=([-1, 1, -1, 1]))
im.set_clip_path(circle)

plt.plot(x, y, 'o', color=(0.9, 0.9, 1.0), alpha=0.8)

# Dolphin from OpenClipart library by Andy Fitzsimon
#    <cc:License rdf:about="http://web.resource.org/cc/PublicDomain">
#     <cc:permits rdf:resource="http://web.resource.org/cc/Reproduction"/>
#     <cc:permits rdf:resource="http://web.resource.org/cc/Distribution"/>
#     <cc:permits rdf:resource="http://web.resource.org/cc/DerivativeWorks"/>
#    </cc:License>

dolphin = """
M -0.59739425,160.18173 C -0.62740401,160.18885 -0.57867129,160.11183
-0.57867129,160.11183 C -0.57867129,160.11183 -0.5438361,159.89315
-0.39514638,159.81496 C -0.24645668,159.73678 -0.18316813,159.71981
-0.18316813,159.71981 C -0.18316813,159.71981 -0.10322971,159.58124
-0.057804323,159.58725 C -0.029723983,159.58913 -0.061841603,159.60356
-0.071265813,159.62815 C -0.080250183,159.65325 -0.082918513,159.70554
-0.061841203,159.71248 C -0.040763903,159.7194 -0.0066711426,159.71091
0.077336307,159.73612 C 0.16879567,159.76377 0.28380306,159.86448
0.31516668,159.91533 C 0.3465303,159.96618 0.5011127,160.1771
0.5011127,160.1771 C 0.63668998,160.19238 0.67763022,160.31259
0.66556395,160.32668 C 0.65339985,160.34212 0.66350443,160.33642
0.64907098,160.33088 C 0.63463742,160.32533 0.61309688,160.297
0.5789627,160.29339 C 0.54348657,160.28968 0.52329693,160.27674
0.50728856,160.27737 C 0.49060916,160.27795 0.48965803,160.31565
0.46114204,160.33673 C 0.43329696,160.35786 0.4570711,160.39871
0.43309565,160.40685 C 0.4105108,160.41442 0.39416631,160.33027
0.3954995,160.2935 C 0.39683269,160.25672 0.43807996,160.21522
0.44567915,160.19734 C 0.45327833,160.17946 0.27946869,159.9424
-0.061852613,159.99845 C -0.083965233,160.0427 -0.26176109,160.06683
-0.26176109,160.06683 C -0.30127962,160.07028 -0.21167141,160.09731
-0.24649368,160.1011 C -0.32642366,160.11569 -0.34521187,160.06895
-0.40622293,160.0819 C -0.467234,160.09485 -0.56738444,160.17461
-0.59739425,160.18173
"""

vertices = []
codes = []
parts = dolphin.split()
i = 0
code_map = {
  'M': (Path.MOVETO, 1),
  'C': (Path.CURVE4, 3),
  'L': (Path.LINETO, 1)}

while i < len(parts):
  code = parts[i]
  path_code, npoints = code_map[code]
  codes.extend([path_code] * npoints)
  vertices.extend([[float(x) for x in y.split(',')] for y in
           parts[i + 1:i + npoints + 1]])
  i += npoints + 1
vertices = np.array(vertices, float)
vertices[:, 1] -= 160

dolphin_path = Path(vertices, codes)
dolphin_patch = PathPatch(dolphin_path, facecolor=(0.6, 0.6, 0.6),
             edgecolor=(0.0, 0.0, 0.0))
ax.add_patch(dolphin_patch)

vertices = Affine2D().rotate_deg(60).transform(vertices)
dolphin_path2 = Path(vertices, codes)
dolphin_patch2 = PathPatch(dolphin_path2, facecolor=(0.5, 0.5, 0.5),
              edgecolor=(0.0, 0.0, 0.0))
ax.add_patch(dolphin_patch2)

plt.show()

效果如下:

python+matplotlib绘制简单的海豚(顶点和节点的操作)

总结

以上就是本文关于python+matplotlib绘制简单的海豚(顶点和节点的操作)的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

Python 相关文章推荐
web.py中调用文件夹内模板的方法
Aug 26 Python
python判断一个集合是否包含了另外一个集合中所有项的方法
Jun 30 Python
Python基于checksum计算文件是否相同的方法
Jul 09 Python
Python 基础教程之包和类的用法
Feb 23 Python
python使用socket创建tcp服务器和客户端
Apr 12 Python
Pyinstaller打包.py生成.exe的方法和报错总结
Apr 02 Python
pip install python 快速安装模块的教程图解
Oct 08 Python
Tensorflow不支持AVX2指令集的解决方法
Feb 03 Python
Python使用pyyaml模块处理yaml数据
Apr 14 Python
使用Python3 poplib模块删除服务器多天前的邮件实现代码
Apr 24 Python
python爬虫之利用selenium模块自动登录CSDN
Apr 22 Python
图文详解matlab原始处理图像几何变换
Jul 09 Python
Python实现进程同步和通信的方法
Jan 02 #Python
mac系统安装Python3初体验
Jan 02 #Python
Python中static相关知识小结
Jan 02 #Python
python tensorflow基于cnn实现手写数字识别
Jan 01 #Python
python+selenium实现163邮箱自动登陆的方法
Dec 31 #Python
python 类对象和实例对象动态添加方法(分享)
Dec 31 #Python
利用python将图片转换成excel文档格式
Dec 30 #Python
You might like
php侧拉菜单 漂亮,可以向右或者向左展开,支持FF,IE
2009/10/15 PHP
php生成RSS订阅的方法
2015/02/13 PHP
PHP ADODB生成HTML表格函数rs2html功能【附错误处理函数用法】
2018/05/29 PHP
浅析PHP中的 inet_pton 网络函数
2019/12/16 PHP
JS实现浏览器菜单命令
2006/09/05 Javascript
20个最新的jQuery插件
2012/01/13 Javascript
JavaScript中变量提升 Hoisting
2012/07/03 Javascript
轻松创建nodejs服务器(8):非阻塞是如何实现的
2014/12/18 NodeJs
Node.js读写文件之批量替换图片的实现方法
2016/09/07 Javascript
js实现下一页页码效果
2017/03/07 Javascript
微信小程序 下拉列表的实现实例代码
2017/03/08 Javascript
javascript遍历json对象的key和任意js对象属性实例
2017/03/09 Javascript
详解Angular.js中$http拦截器的介绍及使用
2017/07/04 Javascript
vue通过style或者class改变样式的实例代码
2018/10/30 Javascript
基于javascript实现贪吃蛇经典小游戏
2020/04/10 Javascript
javascript中的相等操作符(==与===区别)
2019/12/21 Javascript
vue实例的选项总结
2020/06/09 Javascript
python获取文件后缀名及批量更新目录下文件后缀名的方法
2014/11/11 Python
在Python下使用Txt2Html实现网页过滤代理的教程
2015/04/11 Python
Python语言的变量认识及操作方法
2018/02/11 Python
Python使用Selenium模块模拟浏览器抓取斗鱼直播间信息示例
2018/07/18 Python
python 实现数字字符串左侧补零的方法
2018/12/04 Python
python json.loads兼容单引号数据的方法
2018/12/19 Python
python实现的登录与提交表单数据功能示例
2019/09/25 Python
Python使用selenium + headless chrome获取网页内容的方法示例
2019/10/16 Python
TensorFlow2.0:张量的合并与分割实例
2020/01/19 Python
tensorflow使用CNN分析mnist手写体数字数据集
2020/06/17 Python
python中setuptools的作用是什么
2020/06/19 Python
英国领先的大码时装品牌之一:Elvi
2018/08/26 全球购物
民生工程实施方案
2014/03/22 职场文书
意外伤害赔偿协议书范文
2014/09/23 职场文书
高中生期中考试失利检讨书
2014/10/23 职场文书
2014年项目经理工作总结
2014/11/24 职场文书
2014年加油站站长工作总结
2014/12/23 职场文书
高中生物教学反思
2016/02/20 职场文书
导游词之重庆渣滓洞
2020/01/08 职场文书