本文实例为大家分享了python实现画圆功能的具体代码,供大家参考,具体内容如下

import numpy as np

import matplotlib.pyplot as plt

from matplotlib.patches import Polygon

import matplotlib.patches as mpatches

fig = plt.figure(figsize = (16,8))

ax = fig.gca()

ax.set_xlim(-5,18)

ax.set_ylim(-5,8)

alpha = np.linspace(-np.pi,np.pi,30)

t = np.linspace(-np.pi,np.pi,100)

def ppp(nc , na , c , sx , sy):

beta = alpha[na]

gam = alpha[na+1]

x = [] ; y = [] ;

r = 0.5*nc

x.append(r*np.cos(beta)) ; y.append(r*np.sin(beta)) ;

tt = np.linspace(beta,gam,10)

for i in range(len(tt)):

x.append(r*np.cos(tt[i]))

y.append(r*np.sin(tt[i]))

r-=0.5

x.append(r*np.cos(gam)) ; y.append(r*np.sin(gam))

tt = np.linspace(gam,beta,10)

for i in range(len(tt)):

x.append(r*np.cos(tt[i])) ; y.append(r*np.sin(tt[i]))

x = np.array(x) ; y = np.array(y)

verts = list(zip(x+sx,y+sy))

poly = Polygon(verts , facecolor=c , edgecolor=c)

ax.add_patch(poly)

#ppp(2,0,'r',0,0)

def get_coordiate(x , y):

beta = (alpha[y]+alpha[y+1])/2

pr = 0.5*(x+x-1)/2

sx = pr*np.cos(beta) ; sy = pr*np.sin(beta)

return sx,sy

def pp_arrow(x,y):

print x , y

sx , sy = get_coordiate(x, y)

for i in range(-1,2):

for j in range(-1,2):

if i == 0 and j == 0:

continue

ex , ey = get_coordiate(x+i, y+j)

ax.arrow(sx,sy,ex-sx,ey-sy,head_width=0.05,head_length=0.1,fc='r',ec='r')

def pxy(cx,cy):

for i in range(10):

plt.plot(0.5*i*np.cos(t)+cx,0.5*i*np.sin(t)+cy)

for i in range(len(alpha)):

plt.plot((0.5*np.cos(alpha)+cx,4.5*np.cos(alpha)+cx),(0.5*np.sin(alpha)+cy,4.5*np.sin(alpha)+cy))

cx = 13 ; cy =0

pxy(0,0)

pxy(13,0)

mr = np.zeros((10,30))

mb = np.zeros((10,30))

for i in range(3,9):

for j in range(1,27):

ttt = np.random.random()

if ttt >= 0.98 and ttt <= 1:

ppp(i,j,'r',0,0)

mr[i][j] = 1

continue

if ttt < 0.8:

continue

else:

ppp(i,j,'b',0,0)

mb[i][j] = 1

for i in range(10):

for j in range(30):

if mr[i][j] == 0:

continue

pp_arrow(i, j)

ma = 0 ;posx = 1 ; posy = 1

for k in range(-1,2):

for s in range(-1,2):

mb[i+k][j+s]=0

ttt = np.random.random()

if ttt > ma:

ma = ttt

posx = k ; posy = s

ppp(i+posx , j+posy , 'r' , 13 , 0)

ppp(i,j,'g',13,0)

for i in range(10):

for j in range(30):

if mb[i][j] == 0:

continue

ppp(i , j , 'b' , 13 , 0)

arrow = mpatches.Arrow(5, 0

,3,0,width = 1,color = 'r')

ax.add_patch(arrow)

ax.text(6.2,0.5,'after one\nunit time',ha='center',va='center',color='y')

xx = [4,4,4]

yy = [7.5,6.5,5.5]

c = ['b' , 'r' , 'g']

s = ['debris','satellite' , 'the location of satellite one unit time ago']

for i in range(3):

print xx[i] , yy[i]

rect = mpatches.Rectangle((xx[i],yy[i]),0.5,0.3,ec = c[i],fc=c[i] )

ax.text(xx[i]+0.7,yy[i],s[i])

ax.add_patch(rect)

plt.axis('off')

plt.show()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

本文标题: 简单实现python画圆功能

本文地址: http://www.cppcns.com/jiaoben/python/218576.html

python画圆花_简单实现python画圆功能相关推荐

  1. python中输入字符串_简单讲解Python中的字符串与字符串的输入输出

    简单讲解Python中的字符串与字符串的输入输出 发布于 2016-03-26 14:35:42 | 110 次阅读 | 评论: 0 | 来源: 网友投递 Python编程语言Python 是一种面向 ...

  2. 怎么用python画一朵花_怎么用python画花朵

    怎么用python画花朵?下面给大家讲解一下具体步骤: 第一步,打开菜单栏,输入idle,打开shell. 第二步,新建一个文件,并命名. 第三步,导入turtle模块,创建一个新窗口用于绘图,再创建 ...

  3. python中len用法_简单介绍Python中的len()函数的使用

    简单介绍Python中的len()函数的使用 函数:len() 1:作用:返回字符串.列表.字典.元组等长度 2:语法:len(str) 3:参数:str:要计算的字符串.列表.字典.元组等 4:返回 ...

  4. python打开excel窗口_简单介绍python在CMD界面读取excel所有数据

    这篇文章主要介绍了python在CMD界面读取excel所有数据,帮助大家更好的利用python办公,感兴趣的朋友可以了解下 代码 import xlrd import os from prettyt ...

  5. python携程使用_简单了解python gevent 协程使用及作用

    简介 没有切换开销.因为子程序切换不是线程切换,而是由程序自身控制,没有线程切换的开销,因此执行效率高, 不需要锁机制.因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁,只需要判断 ...

  6. python变量作用域图解_简单了解Python变量作用域正确使用方法

    在写代码的时候,免不了要使用变量.但程序中的一个变量并不一定是在哪里都可以被使用,根据情况不同,会有不同的"有效范围". 看这样一段代码: def func(x): print ( ...

  7. python 表格格式输出_简单介绍python输出列表元素的所有排列形式

    今天小编就为大家分享一篇浅谈python输出列表元素的所有排列形式,具有很好的参考价值,希望对大家有所帮助.一起跟随小编过来看看吧 例如: ['a', 'b', 'c'] 输出 ['a', 'b', ...

  8. python数据分析实战五_简单的python数据分析实战——黑五销售数据分析

    黑色星期五(通过消费者行为进行销售研究) 背景描述:关于零售商店中黑色星期五的55万个观测数据集.它包含不同类型的数字或分类变量,包含缺失值. 1.理解数据 数据包含538K行,12列.各列含义如下: ...

  9. len函数python返回值类型_简单介绍Python中的len()函数的使用

    01状态机介绍 游戏中的状态机一般都是有限状态机,简写为FSM(有限状态机),简称状态机,是表示有限个状态以及在这些状态之间的转移和动作等行为的数学模型. 状态机的每一个状态至少需要有以下三个操作: ...

最新文章

  1. 利用OnAnimatorove函数控制人物的移动
  2. Oracle Profile 使用详解
  3. 不同的PCB混装方式及加工工艺
  4. r语言 去除双引号_tidyfst vs pandas(12):去除重复条目
  5. JavaSE学习之IO流使用技巧
  6. 2019.6.16完成classstack任务
  7. 蓝桥杯第四届初赛-买不到的数目-数论
  8. jdk1.8新特性的应用-Stream 的终止操作
  9. JavaScript:继承详解
  10. C# lock 学习
  11. 关于bayes错误率计算公式P[error] = P[error | x]P(x)dx
  12. AMTEmu v0.9.2
  13. 软件评测师32小时-第一小时 软件测试概论
  14. cada0图纸框_CAD怎么画图纸框?cad图纸框的绘制方法
  15. Parallels Toolbox for mac(万能工具箱)中文版
  16. Canvas-lms 开源在线学习管理系统源码部署(生产版)
  17. 【Android取证篇】华为手机OTG备份密码重置教程
  18. 特征图注意力_深入理解图注意力机制
  19. HEVC 参考帧管理(RPS)
  20. 香农编码C程序及演示结果

热门文章

  1. 广东省交通运输厅关于新建深惠城际前海保税区至坪地段项目初步设计的批复
  2. 编程匕首Editplus
  3. 为气候问题捐出整个公司,Patagonia接下来归谁管?钱去哪?
  4. Array VPN 设备常用配置维护
  5. python 使用opencv 切割图片的白边(横切和竖切)
  6. Java实现下载文件到本地
  7. ubuntu安装dbus
  8. 【Latex系列】表格绘制
  9. 带领百姓修致富路,村民纷纷称赞
  10. shiro mgt包下的AbstractRememberMeManager类