Python实战之画哆啦A梦(超详细步骤)

一、写在前面

本文基于64位windows系统(鼠标右键点击桌面“此电脑”图标——属性可查看电脑系统版本)、python3.x(pycharm自动安装的版本, 3.0以上)。文中代码内容所使用的工具是pycharm-community-2020.1,实践中如有碰到问题,可留言提问。

前阵子有看到zh上有大神画了这个哆啦A梦的大头贴,自己也来试了一下,很简单,但长篇整段的代码对刚刚学会海龟绘图语法的初学者来说还是有一定难度,所以来做一个拆解版详细步骤讲解实现。

二、效果图

言归正传,先上效果图。

三、详细步骤拆分讲解

第一步:猫脸蓝色外圈

调整画笔粗细到8

隐藏画笔

画一个半径为120的圆

填充成蓝色(颜色值由取色吸管吸色测量得出)

import turtle as t
t.pensize(8)
t.hideturtle()
# 猫脸外圈蓝色
t.fillcolor('#00A1E8')
t.begin_fill()
t.circle(120)
t.end_fill()

第二步:猫脸白色内圈

调整画笔粗细到3

画一个半径为100的圆

填充成白色(颜色值由取色吸管吸色测量得出)

# 猫脸内圈白色
t.pensize(3)
t.fillcolor('white')
t.begin_fill()
t.circle(100)
t.end_fill()

第三步:鼻子

抬起画笔

移动至坐标(0,134)准备画鼻子

调整画笔粗细到4

落下画笔

画一个半径为18的圆

填充成红色(颜色值由取色吸管吸色测量得出)

# 鼻子
t.penup()
t.home()
t.goto(0, 134)
t.pendown()
t.pensize(4)
t.fillcolor("#EA0014")
t.begin_fill()
t.circle(18)
t.end_fill()

第四步:鼻尖白色圆点

抬起画笔

移动至坐标(7,155)准备画鼻尖的白色圆点

调整画笔粗细到2

落下画笔

画一个半径为4的圆

画笔白色,填充白色(颜色值由取色吸管吸色测量得出)

# 鼻尖
t.penup()
t.goto(7, 155)
t.pensize(2)
t.color('white', 'white')
t.pendown()
t.begin_fill()
t.circle(4)
t.end_fill()

第五步:左眼

抬起画笔

移动至坐标(-30,160)准备画左眼

调整画笔粗细到4

落下画笔

画笔黑色,填充白色(颜色值由取色吸管吸色测量得出)

定义绘制步长变量a,设置初始值为0.4

循环控制总角度120:

当角度等于0-30度或角度等于60-90度时:

每循环一次步长a增加0.08

每循环一次画笔左转3度

每循环一次向前绘制步长变量a

否则:

每循环一次步长a减少0.08

每循环一次画笔左转3度

每循环一次向前绘制步长变量a

# 左眼
t.penup()
t.goto(-30, 160)
t.pensize(4)
t.pendown()
t.color('black', 'white')
t.begin_fill()
a = 0.4
for i in range(120):
    if 0 <= i < 30 or 60 <= i < 90:
        a = a + 0.08
        t.left(3)  # 向左转3度
        t.forward(a)  # 向前走a的步长
    else:
        a = a - 0.08
        t.left(3)
        t.forward(a)
t.end_fill()

第六步:右眼

抬起画笔

移动至坐标(30,160)准备画右眼

调整画笔粗细到4

落下画笔

画笔黑色,填充白色(颜色值由取色吸管吸色测量得出)

循环控制总角度120:

当角度等于0-30度或角度等于60-90度时:

每循环一次步长a增加0.08

每循环一次画笔左转3度

每循环一次向前绘制步长变量a

否则:

每循环一次步长a减少0.08

每循环一次画笔左转3度

每循环一次向前绘制步长变量a

# 右眼
t.penup()
t.goto(30, 160)
t.pensize(4)
t.pendown()
t.color('black', 'white')
t.begin_fill()
for i in range(120):
    if 0 <= i < 30 or 60 <= i < 90:
        a = a + 0.08
        t.left(3)  # 向左转3度
        t.forward(a)  # 向前走a的步长
    else:
        a = a - 0.08
        t.left(3)
        t.forward(a)
t.end_fill()

第七步:左眼内部

抬起画笔

移动至坐标(-38,190)准备画左眼内部

调整画笔粗细到8

落下画笔

右转-30度,绘制步长15的线条

右转70度,绘制步长15的线条

# 左眼内部
t.penup()
t.goto(-38, 190)
t.pensize(8)
t.pendown()
t.right(-30)
t.forward(15)
t.right(70)
t.forward(15)

第八步:右眼内部

抬起画笔

移动至坐标(15,185)准备画右眼内部黑色眼球

调整画笔粗细到4

落下画笔

画笔黑色,填充黑色(颜色值由取色吸管吸色测量得出)

画一个半径为13的圆

# 右眼内部
t.penup()
t.goto(15, 185)
t.pensize(4)
t.pendown()
t.color('black', 'black')
t.begin_fill()
t.circle(13)
t.end_fill()

第九步:右眼内部白色圆点

抬起画笔

移动至坐标(13,190)准备画右眼黑色眼球内部的白色圆点

调整画笔粗细到2

落下画笔

画笔白色,填充白色(颜色值由取色吸管吸色测量得出)

画一个半径为5的圆

# 右眼内部白色圆点
t.penup()
t.goto(13, 190)
t.pensize(2)
t.pendown()
t.color('white', 'white')
t.begin_fill()
t.circle(5)
t.end_fill()

第十步:鼻子下面黑色竖线

抬起画笔

移动至坐标(0,134)并恢复初始状态,准备画鼻子下面的黑色竖线

调整画笔粗细到4

落下画笔

画笔黑色(颜色值由取色吸管吸色测量得出)

右转90度

绘制步长40的线条

# 鼻子下面的黑色竖线
t.penup()
t.home()
t.goto(0, 134)
t.pensize(4)
t.pencolor('black')
t.pendown()
t.right(90)
t.forward(40)

第十一步:右边胡子

抬起画笔

移动至坐标(0,124)并恢复初始状态,准备画右边从上往下数的第1根胡子

调整画笔粗细到3

落下画笔

画笔黑色(颜色值由取色吸管吸色测量得出)

左转10度

绘制步长80的线条

————————————————————————————————

抬起画笔

移动至坐标(0,114)并恢复初始状态,准备画右边从上往下数的第2根胡子

调整画笔粗细到3

落下画笔

画笔黑色(颜色值由取色吸管吸色测量得出)

左转6度

绘制步长80的线条

————————————————————————————————

抬起画笔

移动至坐标(0,104)并恢复初始状态,准备画右边从上往下数的第3根胡子

调整画笔粗细到3

落下画笔

画笔黑色(颜色值由取色吸管吸色测量得出)

左转0度

绘制步长80的线条

# 右边的胡子(第1根)
t.penup()
t.home()
t.goto(0, 124)
t.pensize(3)
t.pencolor('black')
t.pendown()
t.left(10)
t.forward(80)
# 右边的胡子(第2根)
t.penup()
t.home()
t.goto(0, 114)
t.pensize(3)
t.pencolor('black')
t.pendown()
t.left(6)
t.forward(80)
# 右边的胡子(第3根)
t.penup()
t.home()
t.goto(0, 104)
t.pensize(3)
t.pencolor('black')
t.pendown()
t.left(0)
t.forward(80)

第十二步:左边胡子

抬起画笔

移动至坐标(0,124)并恢复初始状态,准备画左边从上往下数的第1根胡子

调整画笔粗细到3

落下画笔

画笔黑色(颜色值由取色吸管吸色测量得出)

左转170度

绘制步长80的线条

————————————————————————————————

抬起画笔

移动至坐标(0,114)并恢复初始状态,准备画左边从上往下数的第2根胡子

调整画笔粗细到3

落下画笔

画笔黑色(颜色值由取色吸管吸色测量得出)

左转174度

绘制步长80的线条

————————————————————————————————

抬起画笔

移动至坐标(0,104)并恢复初始状态,准备画左边从上往下数的第3根胡子

调整画笔粗细到3

落下画笔

画笔黑色(颜色值由取色吸管吸色测量得出)

左转180度

绘制步长80的线条

# 左边的胡子(第1根)
t.penup()
t.home()
t.goto(0, 124)
t.pensize(3)
t.pencolor('black')
t.pendown()
t.left(170)
t.forward(80)
# 左边的胡子(第2根)
t.penup()
t.home()
t.goto(0, 114)
t.pensize(3)
t.pencolor('black')
t.pendown()
t.left(174)
t.forward(80)
# 左边的胡子(第3根)
t.penup()
t.home()
t.goto(0, 104)
t.pensize(3)
t.pencolor('black')
t.pendown()
t.left(180)
t.forward(80)

第十三步:嘴巴

抬起画笔

移动至坐标(-70,70),准备画下边沿圆弧

调整画笔粗细到6

落下画笔

画笔黑色,填充红色(颜色值由取色吸管吸色测量得出)

恢复画笔初始方向并右转60度

绘制半径80,角度40的圆弧

绘制半径80,角度80的圆弧

————————————————————————————————

抬起画笔

恢复初始

移动至坐标(-80,70),准备画上边沿横线

落下画笔

绘制步长160的线条

# 嘴巴(下边沿圆弧和颜色填充)
t.penup()
t.goto(-70, 70)
t.pendown()
t.color('black', 'red')
t.pensize(6)
t.setheading(-60)
t.begin_fill()
t.circle(80, 40)
t.circle(80, 80)
t.end_fill()
# 嘴巴(上边沿的横线)
t.penup()
t.home()
t.goto(-80, 70)
t.pendown()
t.forward(160)

第十四步:舌头

抬起画笔

恢复初始

移动至坐标(-50,50),准备画舌头

调整画笔粗细到1

落下画笔

画笔黑色,填充土黄色(颜色值由取色吸管吸色测量得出)

恢复画笔初始方向并左转40度

绘制半径-40,角度40的圆弧

绘制半径-40,角度40的圆弧

恢复画笔初始方向并左转40度

绘制半径-40,角度40的圆弧

绘制半径-40,角度40的圆弧

恢复画笔初始方向并左转220度

绘制半径-80,角度40的圆弧

绘制半径-80,角度40的圆弧

# 舌头
t.penup()
t.home()
t.goto(-50, 50)
t.pendown()
t.pensize(1)
t.fillcolor("#eb6e1a")
t.setheading(40)
t.begin_fill()
t.circle(-40, 40)
t.circle(-40, 40)
t.setheading(40)
t.circle(-40, 40)
t.circle(-40, 40)
t.setheading(220)
t.circle(-80, 40)
t.circle(-80, 40)
t.end_fill()

第十五步:领带/红色围巾

抬起画笔

移动至坐标(-70,12),准备画红色围巾

调整画笔粗细到14

落下画笔

画笔红色(颜色值由取色吸管吸色测量得出)

恢复画笔初始方向并右转20度

绘制半径200,角度30的圆弧

绘制半径200,角度10的圆弧

# 领带
t.penup()
t.goto(-70, 12)
t.pensize(14)
t.pencolor('red')
t.pendown()
t.setheading(-20)
t.circle(200, 30)
t.circle(200, 10)

第十六步:铃铛

抬起画笔

移动至坐标(0,-46),准备画铃铛

调整画笔粗细到3

落下画笔

画笔黑色,填充黄色(颜色值由取色吸管吸色测量得出)

绘制一个半径25的圆

————————————————————————————————

抬起画笔

移动至坐标(-5,-40),准备画铃铛细节部分

调整画笔粗细到2

画笔黑色,填充黄绿色(颜色值由取色吸管吸色测量得出)

绘制一个半径5的圆

调整画笔粗细到3

右转115度

绘制步长7的线条

# 铃铛
t.penup()
t.goto(0, -46)
t.pendown()
t.pensize(3)
t.color("black", '#f8d102')
t.begin_fill()
t.circle(25)
t.end_fill()
# 铃铛细节
t.penup()
t.goto(-5, -40)
t.pendown()
t.pensize(2)
t.color("black", '#79675d')
t.begin_fill()
t.circle(5)
t.end_fill()
t.pensize(3)
t.right(115)
t.forward(7)

四、收尾

绘制结束后停留在绘制页面

t.done()

到此这篇关于Python实战之画哆啦A梦(超详细步骤)的文章就介绍到这了,更多相关Python画哆啦A梦内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python下使用Trackbar实现绘图板

    本次实验利用到了cv2中的createTrackbar和getTrackbarPos函数实现一个绘图板的功能,用户可以选择矩形或是画笔模式,并设置调色板中的值来选择颜色,再选择画笔大小,进行绘图.除此之外,还可以用橡皮擦进行擦除,模式同样也分为矩形和画笔. 下面是具体的代码: import cv2 import numpy as np drawing = False mode = True ix, iy = -1, -1 def nothing(x): pass def draw_circle(

  • 用Python的绘图库(matplotlib)绘制小波能量谱

    时间小波能量谱 反映信号的小波能量沿时间轴的分布. 由于小波变换具有等距效应,所以有: 式中 表示信号强度,对于式①在平移因子b方向上进行加权积分 式中 代表时间-小能量谱 尺度小波能量谱 反映信号的小波能量随尺度的变化情况. 同理,对式①在尺度方向上进行加权积分: 式中 连续小波变换 连续小波变换的结果是一个小波系数矩阵,随着尺度因子和位移因子变化.然后将系数平方后得到小波能量,把每个尺度因子对应的所有小波能量进行叠加,那么就可以得到随尺度因子变换的小波能量谱曲线.把尺度换算成频率后,这条曲线

  • 使用Python对Syslog信息进行分析并绘图的实现

    实验目的: 对设备Syslong信息进行分析记录,并写入sqlite数据库中:后续读取数据库的信息,对Syslog的严重级别分布.来源进行分析进行分析. 同时监控OSPF的状态信息,状态一旦改变,进行告警. 实验结果: 监控Syslog的严重级别分布,和日志源分布,并绘图: 监控OSPF状态信息: 实验环境: 两台CSR1000v,完成Syslog(其中一台)和OSPF的配置: logging hosy x.x.x.x /将Syslong日志信息发送给目的主机(运行python)进行处理. lo

  • Python三维绘图之Matplotlib库的使用方法

    前言 在遇到三维数据时,三维图像能给我们对数据带来更加深入地理解.python的matplotlib库就包含了丰富的三维绘图工具. 1.创建三维坐标轴对象Axes3D 创建Axes3D主要有两种方式,一种是利用关键字projection='3d'l来实现,另一种则是通过从mpl_toolkits.mplot3d导入对象Axes3D来实现,目的都是生成具有三维格式的对象Axes3D. #方法一,利用关键字 from matplotlib import pyplot as plt from mpl_

  • python绘图模块之利用turtle画图

    模块之turtle 小故事 前两天朋友说:"常文啊!听说你会python,那能不能用python画一些好看的图呢?"然后我特意去学了一下turtle模块,现在给大家分享一下. 一.什么是turtle Turtle是python内嵌的绘制线.圆以及其他形状(包括文本)的图形模块. 二.turtle函数的使用 import turtle turtle.pendown() # 放下画笔 turtle.penup() # 抬起画笔 turtle.pensize(int) # 设置画笔宽度,值为

  • python 绘图模块matplotlib的使用简介

    上周对线上某几个磁盘进行了fio硬盘性能测试,测试完成之后的结果需要绘制成图像展示出来.我在官网上查找了一下fio自带的命令fio_generate_plot和fio2gnuplot工具的用法,找到了图像的绘制方法,在某一个单一的场景下,确实可以使用这两个工具来进行硬盘性能图像绘制,但是问题是,如果要对比多个场景下绘制出来的图像的差异,fio自带的绘图工具实现起来就有些困难了,但是确实也能实现.例如下图: 如图所示为磁盘iodepth不变,numjobs在(1,8,16)三种不同的场景下绘制出来

  • Python绘图之柱形图绘制详解

    前言 用python编程绘图,其实非常简单.中学生.大学生.研究生都能通过这10篇教程从入门到精通!快速绘制几种简单的柱状图. 1垂直柱图(普通柱图) 绘制普通柱图的python代码如下: (左右滑动可以查看全部代码) # -*- coding:utf-8 -*- # 申明编码格式为utf-8 import matplotlib as mpl import matplotlib.pyplot as plt mpl.rcParams["font.sans-serif"]=["S

  • python之 matplotlib和pandas绘图教程

    不得不说使用python库matplotlib绘图确实比较丑,但使用起来还算是比较方便,做自己的小小研究可以使用.这里记录一些统计作图方法,包括pandas作图和plt作图. 前提是先导入第三方库吧 import pandas as pd import matplotlib.pyplot as plt import numpy as np 然后以下这两句用于正常显示中文标签什么的. plt.rcParams['font.sans-serif'] = ['SimHei'] # 用来正常显示中文标签

  • Python绘图之二维图与三维图详解

    各位工程师累了吗? 推荐一篇可以让你技术能力达到出神入化的网站"持久男" 1.二维绘图 a. 一维数据集 用 Numpy ndarray 作为数据传入 ply 1. import numpy as np import matplotlib as mpl import matplotlib.pyplot as plt np.random.seed(1000) y = np.random.standard_normal(10) print "y = %s"% y x =

  • python matplotlib绘图实现删除重复冗余图例的操作

    问题: 由于自己做项目的时候,需要循环的绘制数据,假设有100个样本,每个样本包含两个坐标点(A, B),我需要对这两个点标上不同的颜色,同时还要画出两点间的连线. 显然这个问题中图例我只需要3个(A点,B点,AB的连线),而不是300个,因为每个样本的A点都是同样的颜色,B点也都是一样的颜色,AB的连线也是. 但是单纯的在画完图之后用plt.legend(), 它会给你画出所有300个图例来,这肯定不是我想要的. 探索过程: 如何解决呢? 当然有一种很强制的方法,就是只在画第一个样本,或最后一

  • python绘图pyecharts+pandas的使用详解

    pyecharts介绍 pyecharts 是一个用于生成 Echarts 图表的类库.Echarts 是百度开源的一个数据可视化 JS 库.用 Echarts 生成的图可视化效果非常棒 为避免绘制缺漏,建议全部安装 为了避免下载缓慢,作者全部使用镜像源下载过了 pip install -i https://pypi.tuna.tsinghua.edu.cn/simple/ echarts-countries-pypkg pip install -i https://pypi.tuna.tsin

  • Python数据可视化常用4大绘图库原理详解

    今天我们就用一篇文章,带大家梳理matplotlib.seaborn.plotly.pyecharts的绘图原理,让大家学起来不再那么费劲! 1. matplotlib绘图原理 关于matplotlib更详细的绘图说明,大家可以参考下面这篇文章,相信你看了以后一定学得会. matplotlib绘图原理:http://suo.im/678FCo 1)绘图原理说明 通过我自己的学习和理解,我将matplotlib绘图原理高度总结为如下几步: 导库;创建figure画布对象;获取对应位置的axes坐标

  • Python实现手绘图效果实例分享

    首先我们来看看原图: 接着我们来看看效果图: 通过分析我们不难发现以下特征: 主要颜色为黑白灰 边界线条较重 相同或相近色趋于白色 略有光源效果 需要用到的库有: numpy PIL 代码实现: import numpy as np from PIL import Image baseImg = Image.open("./img/myimg2.jpg").convert("L")  # 这里放置你要手绘的图片原图 a = np.array(baseImg).ast

  • Python Matplotlib绘图基础知识代码解析

    1.Figure和Subplot import numpy as np import matplotlib.pyplot as plt #创建一个Figure fig = plt.figure() #不能通过空figure绘图,必须使用add_subplot创建一个或多个subplot #图像为2x2,第三个参数为当前选中的第几个 ax1 = fig.add_subplot(2, 2, 1) ax2 = fig.add_subplot(2, 2, 2) ax3 = fig.add_subplot

随机推荐