Interactivegraphics

Graphical User Interface, GUI Tkinter-Python标准GUI Graphics-基于Tkinter扩展 Turtle-python内置的图形库

graphics库

原点在左上角,x轴从坐到右是递增,y轴从上到下是递增

from graphics import *
circ = Circle(Point(100, 100), 30)
# 在(100,100)坐标处建立圆
win = GraphWin()
circ.draw(win)

两个不同的变量可能表示同一个对象

编写卡通脸的程序,两个眼睛间隔40像素长度

win = GraphWin()
leftEye = Circle(Point(80, 80), 5)
leftEye.setFill("yellow")
leftEye.setOutline("red")
rightEye = leftEye
rightEye.move(40, 0)
leftEye.draw(win)
rightEye.draw(win)

解决方法 为左右眼分别创建两个不同的圆对象

交互式图形用户接口

连续点击10次鼠标,返回其坐标值

在窗口中点击5个点来画一个五边形

Text对象:setText()和getText() Entry对象:setText()和getText() 内容可以被用户修改

在窗口中点击5个点来画一个五边形

GraphWin对象

一个程序可以定义任意数量的窗体 GraphWin() 默认标题是"Graphics Window" 默认大小为200*200

GraphWin对象常用方法

  • plot(x, y, color) 在窗口中(x,y)位置绘制像素。颜色参数可选,默认值为黑色。

  • plotPixel(x, y, Color) 在“原始”位置(x,y)处绘制像素,忽略* setCoords()方法设置的坐标变换。

  • setBackground(color) 将窗口背景颜色设为指定颜色,默认值为灰色。

  • close() 关闭屏幕上的窗口。

  • getMouse() 程序等待用户在窗口内点击鼠标,返回值为点击处的位置,并以Point对象返回。

  • setCoords(xll, yll, xur, yur) 设置窗口的坐标系。左下角是(xll,yll),右上角是(xur,yur)。所有后面的绘制都以这个坐标系做参照(plotPexil除外)

  • 图形对象:点、线段、圆、椭圆、矩形、多边形以及文本

  • 默认初始化:黑色边框;没有被填充;

图形对象通用方法

  • setFill(color) 设置对象内部填充颜色。

  • setOutline(color) 设置对象边框颜色。

  • setWidth(pixels) 设置对象的宽度(对Point类不起作用)。

  • draw(aGraphWin) 在指定的窗口中绘制对象。

  • undraw() 从窗口中删除该对象。如该对象没有在窗口中画出将会报错。

  • move(dx,dy) 将对象沿x轴和y轴分别移动dx和dy单位长度。

  • clone()返回该对象的副本。

Point对象方法

  • Point(x,y) 以指定坐标的值(x, y)构造一点

  • getX() 返回该点的x坐标值

  • getY() 返回该点的y坐标值

Line对象方法

  • Line(point1, point2) 构造一个从点point1到点point2的线段

  • setArrow(string) 设置线段的箭头样式。箭头可以绘制在左端,右端,或者两端都有。string参数值为’first’, ’last’, ’both’,或 ’none’,默认值为’none’。

  • getCenter() 返回线段中点的坐标值。

  • getP1(), getP2() 返回线段相应端点的坐标值。

Circle对象方法

  • Circle(centerPoint, radius) 根据给定圆心和半径构建圆

  • getCenter() 返回圆心的值

  • getRadius() 返回圆的半径长度

  • getP1(), getP2() 返回值为该圆边框对应点,对应点指的是该圆外接正方形的对角点。

Rectangle对象方法

  • Rectangle(point1, point2) 以point1和point2为对角点创建一个矩形。

  • getCenter() 返回矩形的中心点的克隆值。

  • getP1(), getP2() 返回构造矩形的对角点的克隆值

Oval对象方法

  • Oval(point1, point2) 在点point1和point2指定的边界框中创建一个椭圆。

  • getCenter() 返回椭圆的中心点的坐标值

  • getP1(), getP2() 返回构造椭圆的对角点的坐标值

Polygon 对象方法

  • Polygon (point1, point2, point3, ...) 根据给定的顶点构造一个多边形。也可以只用一个顶点列表作为参数

  • getPoints() 返回构造多边形的顶点值的列表

Text 对象方法

  • Text(anchorPoint, string) 以anchorPoint点的位置为中心,构建了一个内容为string的文本对象。

  • setText(string) 设置文本对象的内容

  • getText() 返回当前文本内容。

  • getAnchor() 返回文本显示中间位置点anchor的坐标值。

  • setFace(family) 设置文本字体。family可选值为:’helvetica’,’courier’, ’times roman’, 以及 ’arial’.

  • setSize(point) 设置字体大小为给定点point的大小。合法数值为5-36。

  • setStyle(style) 设置字体的风格。可选值为’normal’, ’bold’, ’italic’,以及 ’bold italic’。

  • setTextColor(color) 设置文本颜色。与setFill效果相同。

图形颜色

  • Python中颜色由字符串指定

  • 很多颜色具有不同深浅

    • 红色逐渐加深

    • ‘red1’‘red2’‘red3’ ‘red4’

color_rgb(red,green,blue)函数

  • 设定颜色数值获得颜色

  • 三个参数为0-255范围内的整数

  • 返回一个字符串

    • color_rgb(255,0,0) 亮红色,

    • color_rgb(130,0,130) 中度洋红色。

温度转换程度示例

计算温度值设定窗口颜色: 温度越高,颜色越偏红 温度越低,颜色越偏蓝 setBackground(Newcolor)设置窗口背景颜色。 假定输入温度范围为0-100, 颜色权重weight=输入温度/100 newcolor的rgb计算: 红色分量=255weight 绿色分量=66+150(1-weight) 蓝色分量=255(1-weight)

Tkinter库

创建GUI程序的基本步骤为: 导入Tk模块. 创建GUI应用程序的主窗口. 添加控件或GUI应用程序. 进入主事件循环,等待响应用户触发事件.

15中常见的Tk控件 Button, Canvas, Checkbutton, Entry, Frame, Label, Listbox, Menubutton, Menu, Message, Radiobutton, Scale Scrollbar, Text, Toplevel, Spinbox PanedWindow, LabelFrame, tkMessageBox

共同属性

  • Dimensions :尺寸

  • Colors:颜色

  • Fonts:字体

  • Anchors:锚

  • Relief styles:浮雕式

  • Bitmaps:显示位图

  • Cursors:光标的外形 特有属性

界面布局 Tkinter三种几何管理方法 pack() grid() place() 简单GUI示例

响应用户事件示例

显示文字、图片、绘制图形

控制图形移动的示例

基于tkinter库完成聊天窗口GUI 见ChatWin.py

Last updated

Was this helpful?