python thinker canvas create_arc 使用详解

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/A757291228/article/details/106739556
———————————————— 版权声明:本文为CSDN博主「1_bit」的原创文章,遵循CC 4.0
BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/A757291228/article/details/106739556

注:以下文章皆基于以下代码所创建的对tk对象进行编程
python 版本为3.x

from tkinter import *
root = Tk()
canvas = Canvas(root,background='#D4D4D4',width=1000,height=1000)#初始化 canvas
canvas.pack(fill=BOTH,expand=YES)

create_arc 的基本使用

Python Thinker canvas 使用 create_arc 创建一个扇形。
create_arc 的函数的一般使用方法如下:

canvas.create_arc(coord, start, extent, fill)

类型说明:

  • coord :元组 int
  • start :整形 int
  • extent:整形 int
  • fill :字符串 str

coord元组配置矩形所形成的椭圆的左上角坐标及右下角坐标:
coord=x1,y1,x2,y2
首先尝试 create_arc 的简单使用方法:

canvas.create_arc(coord)

完整代码如下:

from tkinter import *

root = Tk()
root.title('作者CSDN :1bit 帐号:A757291228')

canvas = Canvas(root,background='#D4D4D4',width=830,height=830)#初始化 canvas
canvas.pack(fill=BOTH,expand=YES)

coord = 200, 200, 400, 400 #坐标起始点
canvas.create_rectangle(coord)#这一行只是为了方便查看该坐标绘制的矩形,进行对照,不必要了解
arc = canvas.create_arc(coord)

以上代码绘制了一个矩形与扇形进行对照,结果如下:
python thinker canvas create_arc 使用详解_第1张图片
以上结果得到了一个扇形,该扇形与矩形进行对比,得出扇形所在的区域为矩形的右上部分,扇形所在的区域为矩形的右上角区域,想要扇形绘制出一个半圆,占整个矩形的上半部分所需要另外两个参数:extentstart(start并不是一定需要) 。

参数类型说明:

  • start:从x轴正方向(起始方向)开始,单位为度进行绘制,start为起始绘制角度的设置
  • extent:以start参数作为参考,以start参数给定的角度开始,逆时针延伸角度,这个角度为extent设置的值

尝试使用start参数:

from tkinter import *

root = Tk()
root.title('作者CSDN :1bit 帐号:A757291228')

canvas = Canvas(root,background='#D4D4D4',width=830,height=830)#初始化 canvas
canvas.pack(fill=BOTH,expand=YES)

coord = 200, 200, 400, 400
canvas.create_rectangle(coord)
arc = canvas.create_arc(coord,start=10)

以上代码在 create_arc 添加了 start参数,设置start参数为10,绘制时,将以x正方向作为参照,形成的角度为10度作为起始绘制角度,所形成的扇形如下:
python thinker canvas create_arc 使用详解_第2张图片
现在使用 extent 参数进行延伸绘制,并把 start 参数设置为 0:

from tkinter import *

root = Tk()
root.title('作者CSDN :1bit 帐号:A757291228')

canvas = Canvas(root,background='#D4D4D4',width=830,height=830)#初始化 canvas
canvas.pack(fill=BOTH,expand=YES)

coord = 200, 200, 400, 400
canvas.create_rectangle(coord)
arc = canvas.create_arc(coord,start=0,extent=180)

结果如下,绘制成一个半圆扇形:
python thinker canvas create_arc 使用详解_第3张图片
以上代码,start 参数省略也可以完成半圆绘制,start默认为0。使用start可更灵活的控制起始绘制角度。
使用fill 可以使绘制区域填充设置的颜色代码,代码如下:

arc = canvas.create_arc(coord,extent=180,fill="red")

结果如下:
python thinker canvas create_arc 使用详解_第4张图片

create_arc 的扩展使用

create_arc 可以接收更多的参数进行扩展绘制,参数为 (并不是所有参数,之后有时间将陆续补上):style、dash、outline、width等。

style 参数

style 参数设置值有 ARCCHORD 以及 PIESLICE;默认情况下 style的值为 PIESLICE,以下设置 style 的值为 ARC 查看效果:

arc = canvas.create_arc(coord,extent=180,style=ARC)

结果如下:
python thinker canvas create_arc 使用详解_第5张图片
CHORD

arc = canvas.create_arc(coord,extent=180,style=CHORD)

结果如下:
python thinker canvas create_arc 使用详解_第6张图片
PIESLICE

arc = canvas.create_arc(coord,extent=180,style=PIESLICE)

结果如下:
python thinker canvas create_arc 使用详解_第7张图片

dash 参数

dash 参数类型为元组,用于设定虚线线段。例如 dash=(3,4) 中,值3为指定绘制多少个像素的线段,值4为下一条线段绘制需要间隔多少个像素。
查看代码:

arc = canvas.create_arc(coord,dash=(10,2),style=PIESLICE)

以上代码绘制一个扇形,是虚线绘制,其中dash的值设置为10与2,其中10为设置每条线段长度为10,下次绘制间隔2个像素。结果如下:
python thinker canvas create_arc 使用详解_第8张图片
dash设置的值并不只能设置两个,可以设置多个,例如:dash=(15,2,13,2,10,2,7,2);该代码为绘制15像素线段后间隔2像素再次绘制,下一次绘制13像素,再间隔2次以此类推。结果为:
python thinker canvas create_arc 使用详解_第9张图片

outline 参数

outline 用于设置绘制的线段颜色,默认为黑色,参数类型为字符串,例如:outline='red',代码如下:

arc = canvas.create_arc(coord,outline='red',style=PIESLICE)

结果如下:
python thinker canvas create_arc 使用详解_第10张图片

width 参数

设置绘制成的图形边框的粗细,默认单位为像素。
代码示例:

arc = canvas.create_arc(coord,width=10,style=PIESLICE)

设置边框粗细为10,结果如下:
python thinker canvas create_arc 使用详解_第11张图片

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/A757291228/article/details/106739556
———————————————— 版权声明:本文为CSDN博主「1_bit」的原创文章,遵循CC 4.0
BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/A757291228/article/details/106739556

你可能感兴趣的:(python,Tkinter,Canvas,python,canvas,Thinker)