Python+Turtle绘制航海王草帽路飞详解
作者:挣扎的蓝藻
turtle库是一个点线面的简单图像库,在Python2.6之后被引入进来,能够完成一些比较简单的几何图像可视化。本文将利用turtle绘制一个可爱的草帽路飞,感兴趣的可以试一试
一、程序运行
1.效果展示 - 轮廓描绘
看轮廓描绘效果:
2.效果展示 - 颜色填充
衣服和裤子颜色填充效果:
二、实现过程
1.绘图数据下载
内容预览:
2.海龟绘图配置项
降低刷新率可提升绘制速度,值越大刷新频率越低,速度越快
t.tracer(5000)
def set_trutle(): ''' 作用:海龟绘图配置项 参数:无 返回:无 ''' # 默认颜色区间是[0,1],切换为[0,255] t.Screen().colormode(255) # 设置起始大小 t.setup(width=x, height=y) # 调整坐标, t.setworldcoordinates(0,y,x,0) t.pen() # 设置绘制速度,0为最快 t.speed(0) # 禁用延迟提升速度 t.delay(0) # 提升速度,值越大越快 t.tracer(5000) # 设置默认画笔颜色为白色 t.pencolor((255,255,255)) # 抬起画笔 t.penup()
3.轮廓绘制
通过下落画笔 t.pendown()
和抬起画笔 t.penup()
来避免连线问题。
def draw_lufei_outline(): ''' 作用:绘制路飞轮廓 参数:无 返回:无 ''' # 数据文件读取 f=open("lufei.txt","r") bigmom_date = f.read().split(" ") for i in bigmom_date: try: # 数据分离与转化 j = i.split("_") x1 = round(float(j[0])) y1 = round(float(j[1])) color = j[2][1:-1].split(",") color[0]=int(color[0]) color[1]=int(color[1]) color[2]=int(color[2]) if((color[0]*0.299 + color[1]*0.587 + color[2]*0.114)>50): color = (255,255,255); # 下落画笔 t.pendown() # 解决图像只绘制一半的问题 t.sety(y1) # 轨迹追踪与绘制 t.goto(x1, y1) t.color(color) # 抬起画笔 t.penup() except Exception as e: print() f.close() print("轮廓绘制完成")
效果图演示:
4.颜色填充:衣服、裤子
绘制衣服、裤子的红色和蓝色。
def draw_lufei_tintage1(): ''' 作用:路飞颜色填充:衣服、帽子 参数:无 返回:无 ''' # 数据文件读取 f=open("lufei.txt","r") bigmom_date = f.read().split(" ") for i in bigmom_date: try: # 数据分离与转化 j = i.split("_") x1 = int(j[0]) y1 = int(j[1]) color = j[2][1:-1].split(",") color[0]=int(color[0]) color[1]=int(color[1]) color[2]=int(color[2]) if((color[0]*0.299 + color[1]*0.587 + color[2]*0.114)>150): color = (255,255,255); # 下落画笔 t.pendown() # 解决图像只绘制一半的问题 t.sety(y1) # 轨迹追踪与绘制 t.goto(x1, y1) t.color(color) # 抬起画笔 t.penup() except Exception as e: print() f.close() print("上色完成")
效果图演示:
5.颜色填充:草帽、腰带
绘制草帽、腰带的黄色。
def draw_lufei_tintage2(): ''' 作用:路飞颜色填充:草帽、腰带 参数:无 返回:无 ''' # 数据文件读取 f=open("lufei.txt","r") bigmom_date = f.read().split(" ") for i in bigmom_date: try: # 数据分离与转化 j = i.split("_") x1 = int(j[0]) y1 = int(j[1]) color = j[2][1:-1].split(",") color[0]=int(color[0]) color[1]=int(color[1]) color[2]=int(color[2]) if((color[0]*0.299 + color[1]*0.587 + color[2]*0.114)>215): color = (255,255,255); # 下落画笔 t.pendown() # 解决图像只绘制一半的问题 t.sety(y1) # 轨迹追踪与绘制 t.goto(x1, y1) t.color(color) # 抬起画笔 t.penup() except Exception as e: print() f.close() print("上色完成")
效果图演示:
6.完整源码
# -*- coding:utf-8 -*- # 2022-3-9 # 作者:小蓝枣 # 图像绘制:路飞 import turtle as t import time x = 224 y = 345 def set_trutle(): ''' 作用:海龟绘图配置项 参数:无 返回:无 ''' # 默认颜色区间是[0,1],切换为[0,255] t.Screen().colormode(255) # 设置起始大小 t.setup(width=x, height=y) # 调整坐标, t.setworldcoordinates(0,y,x,0) t.pen() # 设置绘制速度,0为最快 t.speed(0) # 禁用延迟提升速度 t.delay(0) # 提升速度,值越大越快 t.tracer(5000) # 设置默认画笔颜色为白色 t.pencolor((255,255,255)) # 抬起画笔 t.penup() def draw_lufei_outline(): ''' 作用:绘制路飞轮廓 参数:无 返回:无 ''' # 数据文件读取 f=open("lufei.txt","r") bigmom_date = f.read().split(" ") for i in bigmom_date: try: # 数据分离与转化 j = i.split("_") x1 = round(float(j[0])) y1 = round(float(j[1])) color = j[2][1:-1].split(",") color[0]=int(color[0]) color[1]=int(color[1]) color[2]=int(color[2]) if((color[0]*0.299 + color[1]*0.587 + color[2]*0.114)>50): color = (255,255,255); # 下落画笔 t.pendown() # 解决图像只绘制一半的问题 t.sety(y1) # 轨迹追踪与绘制 t.goto(x1, y1) t.color(color) # 抬起画笔 t.penup() except Exception as e: print() f.close() print("轮廓绘制完成") def draw_lufei_tintage1(): ''' 作用:路飞颜色填充:衣服、帽子 参数:无 返回:无 ''' # 数据文件读取 f=open("lufei.txt","r") bigmom_date = f.read().split(" ") for i in bigmom_date: try: # 数据分离与转化 j = i.split("_") x1 = int(j[0]) y1 = int(j[1]) color = j[2][1:-1].split(",") color[0]=int(color[0]) color[1]=int(color[1]) color[2]=int(color[2]) if((color[0]*0.299 + color[1]*0.587 + color[2]*0.114)>150): color = (255,255,255); # 下落画笔 t.pendown() # 解决图像只绘制一半的问题 t.sety(y1) # 轨迹追踪与绘制 t.goto(x1, y1) t.color(color) # 抬起画笔 t.penup() except Exception as e: print() f.close() print("上色完成") def draw_lufei_tintage2(): ''' 作用:路飞颜色填充:草帽、腰带 参数:无 返回:无 ''' # 数据文件读取 f=open("lufei.txt","r") bigmom_date = f.read().split(" ") for i in bigmom_date: try: # 数据分离与转化 j = i.split("_") x1 = int(j[0]) y1 = int(j[1]) color = j[2][1:-1].split(",") color[0]=int(color[0]) color[1]=int(color[1]) color[2]=int(color[2]) if((color[0]*0.299 + color[1]*0.587 + color[2]*0.114)>215): color = (255,255,255); # 下落画笔 t.pendown() # 解决图像只绘制一半的问题 t.sety(y1) # 轨迹追踪与绘制 t.goto(x1, y1) t.color(color) # 抬起画笔 t.penup() except Exception as e: print() f.close() print("上色完成") set_trutle() draw_lufei_outline() draw_lufei_tintage1() draw_lufei_tintage2() time.sleep(10000)
以上就是Python+Turtle绘制航海王草帽路飞详解的详细内容,更多关于Python Turtle路飞的资料请关注脚本之家其它相关文章!