tkinter改进了随机显示图片
随机显示,还加了圆圈,这样感觉更好点。
from django.test import TestCase
# Create your tests here.
import random
import json
import time
import tkinter as tk
from tkinter import filedialog
from tkinter import LabelFrame
from tkinter import StringVar
from PIL import Image, ImageTk
# 方块大小
card_size = 120
# 间隙大小
gap_size = 2
# 绘图起点坐标
start_x = 400
start_y = 100
# 7 * 5 方格
x_grid = 7
y_grid = 5
# 打开文件,载入json文件
def open_file():
xxx_name = filedialog.askopenfilename(title='打开文件',
filetypes=[('json', '*.json'),
('All Files', '*')])
# 更新Label text变量
var.set(xxx_name)
with open(xxx_name, 'r') as load_f:
global card_dict
card_dict = json.load(load_f)
# 画圆
def draw_circle(cvs, x, y, r, **kwargs):
return cvs.create_oval(x-r, y-r, x+r, y+r, **kwargs)
# 绘图
def draw_card():
# 这个打开文件,用的是回调函数,我暂时也不知道如何不用这个全局变量
global card_dict
imgs_list = []
for i in range(y_grid):
y1 = start_y + i * card_size
for j in range(x_grid):
x1 = start_x + j * card_size
# 解析json里对应的文件名
image_num = card_dict[str(i+1)][str(j+1)]
image_path = "images/{}.png".format(image_num[0].upper())
# 载入图片
img = Image.open(image_path)
# 重定义大小
img = img.resize((card_size-gap_size, card_size-gap_size), Image.BILINEAR)
# 重定义旋转
img = img.rotate(image_num[1])
imgs = ImageTk.PhotoImage(img)
# 先形成一个大列表,便于后面打乱了显示或成行成列显示
card_pos = [x1 + gap_size, y1 + gap_size, imgs]
imgs_list.append(card_pos)
# 为了效果好,随机显示
random.shuffle(imgs_list)
for item in imgs_list:
# 以nw左上角为基准点, 先大图出现,提示一下重点,加点透明GIF,就完美了
# img_big = ImageTk.PhotoImage(item[3])
# cv.create_image((item[0], item[1]), anchor='nw', image=img_big, tag='tmp_resize')
cv.create_image((item[0], item[1]), anchor='nw', image=item[2])
draw_circle(cv, item[0] + card_size / 2, item[1] + card_size / 2, 20, width=', outline="green",
tag='tmp_circle')
cv.update()
# 停一下
time.sleep(0.5)
# 删除圆圈,只作动画
cv.delete('tmp_circle')
# 不调用update,不会更新画布
cv.update()
time.sleep(10)
win = tk.Tk()
win.title('tkinter')
w = win.winfo_screenwidth()
h = win.winfo_screenheight()
win.geometry("%dx%d" % (w, h))
cv = tk.Canvas(win, bg='silver', width=w, height=h)
# 要更新label的text,要用var.set方法才行
var = StringVar()
var.set("...")
lab_fra = LabelFrame(win, height=200, width=300, text='选择文件')
lab_fra.pack(side='top', fill='both', expand=True)
btn_open = tk.Button(lab_fra, text='打开文件', command=open_file)
btn_open.grid(row=0, column=0)
btn_render = tk.Button(lab_fra, text='开始渲染', command=draw_card)
btn_render.grid(row=0, column=1)
text_label = tk.Label(lab_fra, textvariable=var)
text_label.grid(row=0, column=2)
# 画格子, 要算好横纵坐标
for i in range(y_grid):
y1 = start_y + i * card_size
for j in range(x_grid):
x1 = start_x + j * card_size
cv.create_rectangle(x1, y1, x1 + card_size, y1 + card_size)
cv.pack()
win.mainloop()
tkinter改进了随机显示图片的更多相关文章
- php 随机显示图片的函数(实例分享)
转自:http://www.jbxue.com/article/12695.html 发布:thatboy 来源:Net [大 中 小] 本文分享一个php实现的随机显示图片的函数,可以将 ...
- php 随机显示图片的函数(实例)
转自:http://www.jbxue.com/article/12695.html 发布:thatboy 来源:Net [大 中 小] 本文分享一个php实现的随机显示图片的函数,可 ...
- JS实现的随机显示图片
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xht ...
- Python3 tkinter基础 Label imag显示图片
Python : 3.7.0 OS : Ubuntu 18.04.1 LTS IDE : PyCharm 2018.2.4 Conda ...
- js随机显示图片
定义一个图片数组,生成一个随机数对应数据索引. window.onload = choosePic; function choosePic() { var myPix = new Array(&quo ...
- jq实现随机显示部分图片在页面上(兼容IE5)
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- PHP生成随机水印图片
基于PHP的GD图形库,自己生成一张图片.仅限初识GD库,实例学习. 一.需求 网站的布局用到了类似慕课网课程列表的风格,每一个课程是一个banner图,图下面是标题加简介.因为课程的数量较大没有为所 ...
- Tensorflow显示图片
Tensorflow在处理数据时,经常加载图像数据,有的时候是直接读取文件,有的则是读取二进制文件,为了更好的理解Tensorflow数据处理模式,先简单讲解显示图片机制,就能更好掌握是否读取正确了. ...
- 随机漂浮图片、右侧上下浮动快捷栏JS
随机漂浮图片JS: //公共脚本文件 main.js function addEvent(obj,evtType,func,cap){ cap=cap||false; if(obj.addEventL ...
随机推荐
- massif 图例
19.63^ ### | # | # :: | # : ::: | :::::::::# : : :: | : # : : : :: | : # : : : : ::: | : # : : : : : ...
- [转载]schtasks命令使用实例介绍
Schtasks /Query /s "XXX" /V /FO /CSV > XXX.csv 原文出处:http://www.dzwebs.net/2969.html sch ...
- 手写MVC框架(一)-再出发
背景 前段时间把之前写的DAO框架(手写DAO框架(一)-从“1”开始)整理了一下,重构了一版.整理过程中看以前写的代码,只是为了了解实现,只是为了实现,代码写的有点粗糙.既然已经整理了DAO框架,索 ...
- MATLAB 安装 cvx 工具箱
步骤: matlab本身是没有cvx的工具箱,需要到[cvx主页],「http://cvxr.com/cvx/」上下载,菜单上有个「download」,进入后选择适合你的版本下载: 将cvx压缩包解压 ...
- Codeforces Round #603 (Div. 2) (题解)
A. Sweet Problem (找规律) 题目链接 大致思路: 有一点瞎猜的,首先排一个序, \(a_1>a_2>a_3\) ,发现如果 \(a_1>=a_2+a_3\) ,那么 ...
- 用Scratch制作一个Hello World程序
网上出现了很多Hello World程序,看的小编心里也痒痒的,为此这次作为南京小码王Scratch培训机构的小编,就为大家来详细的了解下Scratch制作Hello World程序的过程,现在就和小 ...
- python 职责链模式
模式定义 责任链模式(Chain of Responsibility Pattern)为请求创建了一个接收者对象的链. 这种模式给予请求的类型,对请求的发送者和接收者进行解耦. 这种类型的设计模式属于 ...
- Navicat Premium 12 安装与破解,Navicat Premium通用的数据库管理工具
本文转自:https://blog.csdn.net/WYpersist/article/details/86530973 Navicat Premium 是一套数据库开发工具,让你从单一应用程序中同 ...
- 介绍一款好用的命令行工具Cmder
一.Cmder的介绍: 在大多数情况下,我们都想复制命令行窗口中的命令行,但是cmd复制粘贴大家都懂得:有没有更好的工具替代呢? 答案是肯定的,今天我将为大家介绍一款工具--Cmder. Cmder可 ...
- Spark之RDD弹性特性
RDD作为弹性分布式数据集,它的弹性具体体现在以下七个方面. 1.自动进行内存和磁盘数据存储的切换 Spark会优先把数据放到内存中,如果内存实在放不下,会放到磁盘里面,不但能计算内存放下的数据,也能 ...