Python绘制的爱⼼树与表⽩代码(完整代码)
⽬录
Python给⼥朋友带来的快乐
1、爱⼼树
2、画桃⼼
3、⼀箭穿⼼
Python给⼥朋友带来的快乐
⽤的的开发⼯具为pycham,pycham也是⼴泛⽤于做Python开发的⼯具。运⽤的turtle库,当然了如果是安装了anaconda3这个库那更好,以为这⾥⾯有我们会做Python程序设计时⽤到的⼤部分的库,turtle它是python中⼀个绘制图像的函数库,可以⽤它来绘制很多的东西,⽐如简单的⼩黄⼈、玫瑰花等,这个库也可以⽣说是⼀只马良的神笔的吧。⽐如以下是为⼥朋友准备的⼩⼩的惊喜吧。
1、爱⼼树
import turtle
import random
def love(x,y):#在(x,y)处画爱⼼lalala
lv=turtle.Turtle()
lv.hideturtle()
lv.up()
<(x,y)#定位到(x,y)
def curvemove():#画圆弧
for i in range(20):
lv.right(10)
lv.forward(2)
lv.speed(100)
lv.pensize(1)
#开始画爱⼼lalala
lv.down()
lv.begin_fill()
lv.left(140)
lv.forward(22)
curvemove()
lv.left(120)
curvemove()
lv.forward(22)
lv.write("杨幂",font=("Arial",12,"normal"),align="center")#写上表⽩的⼈的名字
lv.left(140)#画完复位
def tree(branchLen,t):
if branchLen > 5:#剩余树枝太少要结束递归
if branchLen<20:
t.pensize(random.uniform((branchLen + 5) / 4 - 2, (branchLen + 6) / 4 + 5)) t.down()
t.forward(branchLen)
(),t.ycor())#传输现在turtle的坐标
t.up()
t.backward(branchLen)
return
t.pensize(random.uniform((branchLen+5)/4-2,(branchLen+6)/4+5))
t.down()
t.forward(branchLen)
# 以下递归
ang=random.uniform(15,45)
t.right(ang)
tree(branchLen-random.uniform(12,16),t)#随机决定减⼩长度
t.left(2*ang)
怎么使用replace函数进行插入数字tree(branchLen-random.uniform(12,16),t)#随机决定减⼩长度
t.right(ang)
t.up()
t.backward(branchLen)
myWin = turtle.Screen()
t = turtle.Turtle()
t.hideturtle()
t.speed(1000)
t.left(90)
t.up()
t.backward(200)
t.down()
t.pensize(32)
t.forward(60)
tree(100,t)
2、画桃⼼
# -*- coding:utf-8 -*-
import turtle
import time
# 画爱⼼的顶部
def LittleHeart():
for i in range(200):
turtle.right(1)
turtle.forward(2)
# 输⼊表⽩的语句,默认I Love you
love = input('请输⼊表⽩语句,默认为输⼊为"I Love you": ')
# 输⼊署名或者赠谁,没有不执⾏
me = input('请输⼊您⼼上⼈的姓名或者昵称: ')
if love == '':
love = 'I Love you'
# 窗⼝⼤⼩
turtle.setup(width=800, height=500)
# 颜⾊
# 笔粗细
turtle.pensize(5)
# 速度
turtle.speed(1)
# 提笔
turtle.up()
# 隐藏笔
python代码画图案turtle.hideturtle()
# 去到的坐标,窗⼝中⼼为0,0
<(0, -180)
turtle.showturtle()
# 画上线
turtle.down()
turtle.speed(1)
turtle.begin_fill()
turtle.left(140)
turtle.forward(224)
# 调⽤画爱⼼左边的顶部
LittleHeart()
# 调⽤画爱右边的顶部
turtle.left(120)
LittleHeart()
# 画下线
turtle.forward(224)
turtle.pensize(5)
turtle.up()
turtle.hideturtle()
# 在⼼中写字⼀次
<(0, 0)
turtle.showturtle()
# 在⼼中写字 font可以设置字体⾃⼰电脑有的都可以设 align开始写字的位置turtle.write(love, font=('gungsuh', 30,), align="center")
turtle.up()
turtle.hideturtle()
time.sleep(2)
# 在⼼中写字⼆次
<(0, 0)
turtle.showturtle()
turtle.write(love, font=('gungsuh', 30,), align="center")
turtle.up()
turtle.hideturtle()
# 写署名
if me != '':
time.sleep(2)
<(180, -180)
turtle.showturtle()
turtle.write(me, font=(20,), align="center", move=True)
# 点击窗⼝关闭
window = turtle.Screen()
3、⼀箭穿⼼
import turtle
def getPosition(x, y):
turtle.setx(x)
turtle.sety(y)
print(x, y)
class Pikachu:
def __init__(self):
self.t = turtle.Turtle()
t = self.t
def noTrace_goto(self, x, y):
<(x, y)
def leftEye(self, x, y):
t = self.t
t.seth(0)
t.fillcolor('#333333')
t.begin_fill()
t.circle(22)
t.fillcolor('#000000')
t.begin_fill()
t.circle(10)
t.begin_fill()
t.circle(10)
def rightEye(self, x, y):
t = self.t
t.seth(0)
t.fillcolor('#333333')
t.begin_fill()
t.circle(22)
t.fillcolor('#000000')
t.begin_fill()
t.circle(10)
t.begin_fill()
t.circle(10)
def mouth(self, x, y):
t = self.t
t.fillcolor('#88141D')
t.begin_fill()
# 下嘴唇
l1 = []
l2 = []
t.seth(190)
a = 0.7
for i in range(28):
a += 0.1
t.right(3)
t.fd(a)
l1.append(t.position())
t.seth(10)
a = 0.7
for i in range(28):
a += 0.1
t.left(3)
t.fd(a)
l2.append(t.position())
# 上嘴唇
t.seth(10)
t.circle(50, 15)
t.left(180)
t.circle(-50, 15)
t.circle(-50, 40)
t.seth(233)
t.circle(-50, 55)
t.left(180)
如何启用activex控件筛选t.circle(50, 12.1)
# ⾆头
t.fillcolor('#DD716F')
t.begin_fill()
t.seth(145)
t.circle(40, 86)
t.penup()
for pos in reversed(l1[:20]):
<(pos[0], pos[1] + 1.5)
for pos in l2[:20]:
<(pos[0], pos[1] + 1.5)
t.pendown()
# ⿐⼦
t.seth(8)
t.fd(4)
t.back(8)
# 红脸颊
def leftCheek(self, x, y):
t = self.t
t.seth(300)
t.fillcolor('#DD4D28')
t.begin_fill()
a = 2.3
for i in range(120):
java认证考试if 0 <= i < 30 or 60 <= i < 90:
t.fd(a)
else:
a += 0.05
t.lt(3)
t.fd(a)
def rightCheek(self, x, y):
t = self.t
t.seth(60)
t.fillcolor('#DD4D28')
t.begin_fill()
a = 2.3
for i in range(120):
if 0 <= i < 30 or 60 <= i < 90: a -= 0.05
t.lt(3)
t.fd(a)
else:
a += 0.05
t.lt(3)
t.fd(a)
def colorLeftEar(self, x, y): t = self.t
t.fillcolor('#000000')
t.begin_fill()
t.seth(330)
t.circle(100, 35)
t.seth(219)listened
t.circle(-300, 19)
t.seth(110)
t.circle(-30, 50)
t.circle(-300, 10)
def colorRightEar(self, x, y): t = self.t
t.fillcolor('#000000')
t.begin_fill()
t.seth(300)
t.circle(-100, 30)
t.seth(35)
t.circle(300, 15)
t.circle(30, 50)
t.seth(190)
t.circle(300, 17)
def body(self):
t = self.t
t.fillcolor('#F6D02F')
t.begin_fill()
# 右脸轮廓
t.penup()
t.circle(130, 40)
t.pendown()
t.circle(100, 105)
t.left(180)
t.circle(-100, 5)
# 右⽿朵
t.seth(20)
t.circle(300, 30)
t.circle(30, 50)
t.seth(190)
t.circle(300, 36)
# 上轮廓
t.seth(150)
t.circle(150, 70)
# 左⽿朵
t.seth(200)
t.circle(300, 40)
t.circle(30, 50)
t.seth(20)
t.circle(300, 35)
律师事务所法律咨询# print(t.pos())
# 左脸轮廓
t.seth(240)
t.circle(105, 95)
t.left(180)
t.circle(-105, 5)
# 左⼿
t.seth(210)
t.circle(500, 18)
t.seth(200)
t.fd(10)
t.seth(280)
t.fd(7)
t.seth(210)
t.fd(10)
t.seth(300)
t.circle(10, 80)
t.seth(220)
t.fd(10)
t.seth(300)
t.circle(10, 80)
t.seth(240)
t.fd(12)
t.seth(0)
t.fd(13)
t.seth(240)
t.circle(10, 70)
t.seth(10)
t.circle(10, 70)
t.seth(10)
t.circle(300, 18)
t.seth(75)
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论