简单实现python画圆功能


Posted in Python onJanuary 25, 2018

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

简单实现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 相关文章推荐
在Python中处理时间之clock()方法的使用
May 22 Python
Python中列表和元组的相关语句和方法讲解
Aug 20 Python
python在文本开头插入一行的实例
May 02 Python
python主线程捕获子线程的方法
Jun 17 Python
在Python中实现shuffle给列表洗牌
Nov 08 Python
selenium+python自动化测试之使用webdriver操作浏览器的方法
Jan 23 Python
使用python爬取微博数据打造一颗“心”
Jun 28 Python
python读取Excel表格文件的方法
Sep 02 Python
Python 线程池用法简单示例
Oct 02 Python
关于初始种子自动选取的区域生长实例(python+opencv)
Jan 16 Python
QML实现钟表效果
Jun 02 Python
python实现学生信息管理系统(面向对象)
Jun 05 Python
Python中sort和sorted函数代码解析
Jan 25 #Python
django在接受post请求时显示403forbidden实例解析
Jan 25 #Python
Python微信公众号开发平台
Jan 25 #Python
Python实现PS图像调整黑白效果示例
Jan 25 #Python
1 行 Python 代码快速实现 FTP 服务器
Jan 25 #Python
http请求 request失败自动重新尝试代码示例
Jan 25 #Python
Python实现PS图像调整颜色梯度效果示例
Jan 25 #Python
You might like
日本十大科幻动漫 宇宙骑士垫底,第一已成经典
2020/03/04 日漫
PHP将DateTime对象转化为友好时间显示的实现代码
2011/09/20 PHP
几个有用的php字符串过滤,转换函数代码
2012/05/01 PHP
深入phpMyAdmin的安装与配置的详细步骤
2013/05/07 PHP
解析php多线程下载远程多个文件
2013/06/25 PHP
PHP进制转换实例分析(2,8,16,36,64进制至10进制相互转换)
2017/02/04 PHP
浅析PHP数据导出知识点
2018/02/17 PHP
PHP笛卡尔积实现原理及代码实例
2020/12/09 PHP
动感效果的TAB选项卡jquery 插件
2011/07/09 Javascript
利用jquery的获取JS文件中的字符串内容
2012/02/14 Javascript
jquery中的过滤操作详细解析
2013/12/02 Javascript
js事件绑定快捷键以ctrl+k为例
2014/09/30 Javascript
QQ登录背景闪动效果附效果演示源码下载
2015/09/22 Javascript
详解Angular2中的编程对象Observable
2016/09/17 Javascript
jQuery autoComplete插件两种使用方式及动态改变参数值的方法详解
2016/10/24 Javascript
JavaScript基于Dom操作实现查找、修改HTML元素的内容及属性的方法
2017/01/20 Javascript
thinkphp标签实现bootsrtap轮播carousel实例代码
2017/02/19 Javascript
jQuery上传多张图片带进度条样式(DEMO)
2017/03/02 Javascript
JavaScript 过滤关键字
2017/03/20 Javascript
JavaScrpt的面向对象全面解析
2017/05/09 Javascript
对于js垃圾回收机制的理解
2017/09/14 Javascript
Vue实现数字输入框中分割手机号码的示例
2017/10/10 Javascript
浅谈FastClick 填坑及源码解析
2018/03/02 Javascript
分享5个顶级的JavaScript Ajax组件库
2018/09/16 Javascript
vue实现类似淘宝商品评价页面星级评价及上传多张图片功能
2018/10/29 Javascript
uni-app 支持多端第三方地图定位的方法
2020/01/03 Javascript
Python中异常重试的解决方案详解
2017/05/05 Python
关于Python核心框架tornado的异步协程的2种方法详解
2019/08/28 Python
pygame实现俄罗斯方块游戏(基础篇2)
2019/10/29 Python
基于python实现文件加密功能
2020/01/06 Python
Python gevent协程切换实现详解
2020/09/14 Python
AmazeUI 点击元素显示全屏的实现
2020/08/25 HTML / CSS
会计电算化专业毕业生自荐信
2013/12/20 职场文书
国庆节慰问信
2015/02/15 职场文书
上学路上观后感
2015/06/16 职场文书
2015国庆节66周年标语
2015/07/30 职场文书