tkinter使用js的canvas实现渐变色

作者:布小禅 时间:2024-02-24 20:46:47 

之前呢,我一直对GUI不是很感兴趣,但是呢,最近由于某些特殊原因,导致不得不用tkinter,需要实现一个渐变色,但是当我翻阅文档的时候,却发现并没有内置的函数可以实现这个功能,只能自己实现,所以就搜索了一下渐变色得原理,实现了出来

1. 使用rgb表示颜色

tkinter是没有提供使用rgb作为参数的函数的,所以就需要将十六进制的值转为grb的值,当然方法也很简单,就是对十六进制进行运算

代码:


def use_rgb(rgb):
   """
   将rgb转十六进制
   Args:
       rgb: rgb颜色
   Returns: 十六进制
   """
   rgb = str(rgb)
   RGB = rgb.replace('(', '').replace(")", '').split(',')  # 将RGB格式划分开来
   color = '#'
   for i in RGB:
       num = int(i)
       # 将R、G、B分别转化为16进制拼接转换并大写  hex() 函数用于将10进制整数转换成16进制,以字符串形式表示
       color += str(hex(num))[-2:].replace('x', '0')
   return color

因为传入得到rgb是元组形式,所以转为字符串,然后再转为十六进制的字符串,记得前面需要加上#

2. tkinter canvas组件

canvas组件是tkinter库里面作为画东西的,可以画线段,矩形,多边形,圆弧等

使用canvas组件需要先创建一个窗口对象来作为canvas的父物体


import tkinter as tk
# 先初始化tkinter组件,创建窗口对象
window = tk.Tk()
# 设置窗口的标题,长宽
window.title("title")
window.geometry("800x600")

运行后什么都不会发生,因为还需要将窗口显示


window.mainloop()

然后就是夜光什么都没有的小框框

canvas的创建也是创建类的实例化,可以是无参的,后面再调整,也可以在创建的同时就实例化


# 使用canvas
canvas = window.Canvas()

也可以:


# window是canvas的父物体,width和height一看就是canvas的宽和高了
canvas = tk.Canvas(window, width=800, height=600)
# 这个方法可以设置布局方式,当然也是显示画布的方法
canvas.pack()

当然此时运行后也是什么都没有的,我们需要在画布上面画东西

然后我们通过canvas画一个矩形


canvas.create_rectangle(100, 100, 300, 300, fill="red")
# 这行代码也可以这么写
canvas.create_rectangle((100, 100, 300, 300), fill="red")

这样就是画了一个红色的矩形

3. 设置渐变

这里面的渐变也不是直接在矩形上面做文章的,而是需要使用线段,每条线段显示一种颜色,然后形成渐变的效果

画线段的方法是:


canvas.create_line()

里面的参数形式和上面线段的差不多,只不过画线段只需要两个坐标

3.1 渐变的原理

简便的的原理就是设置一种颜色从深变浅,然后再变为另一种颜色的浅,再深

说起来是不是很简单,但是要实现还是有点困难的

我们的思路是:

循环画线段

计算每个线段的颜色

而我们画线段的时候,只需要计算这三个参数:

矩形的长度线段起点x坐标线段起点y坐标

这里的起点,并不是最开始的点,而是线段的上面的点

我们还需要知道我们需要渐变的两种颜色的rgb值

而渐变,我们只需要知道某条线段对于开始的增值,然后再将其与rgb结合,就是某条线段的颜色

3.2 实例1

将这个红色的矩形变成从左到右的红蓝渐变

红色grb值(255, 0, 0)

蓝色rgb值(0, 0, 255)


#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Author: Smly
# @datetime: 2021/12/4 19:44
# @Version: 1.0
import tkinter as tk
RED = (255, 0, 0)
BLUE = (0, 0, 255)
def use_rgb(rgb):
   """
   将rgb转十六进制
   Args:
       rgb: rgb颜色
   Returns: 十六进制
   """
   rgb = str(rgb)
   RGB = rgb.replace('(', '').replace(")", '').split(',')  # 将RGB格式划分开来
   color = '#'
   for i in RGB:
       num = int(i)
       # 将R、G、B分别转化为16进制拼接转换并大写  hex() 函数用于将10进制整数转换成16进制,以字符串形式表示
       color += str(hex(num))[-2:].replace('x', '0')
   return color
# 先初始化tkinter组件,创建窗口对象
window = tk.Tk()
# 设置窗口的标题,长宽
window.title("title")
window.geometry("800x600")
# 使用canvas
canvas = tk.Canvas(window, width=800, height=600)
canvas.pack()
a1, a2, a3, b1, b2, b3 = RED[0], RED[1], RED[2], BLUE[0], BLUE[1], BLUE[2]
# 相差的rgb
r, g, b = (b1 - a1), (b2 - a2), (b3 - a3)
print(r, g, b)
h = 200
for i in range(200):
   x1 = 100 + i
   y1 = 100
   t = (x1 - 100) / (300 - 100)
   rgb = (int(a1 + r * t), int(a2 + g * t), int(a3 + b * t))
   print(rgb)
   canvas.create_line((x1, y1), (x1, y1 + h), fill=use_rgb(rgb))
window.mainloop()

效果:

tkinter使用js的canvas实现渐变色

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

来源:https://blog.csdn.net/m0_52883898/article/details/121721642

标签:tkinter,canvas,渐变
0
投稿

猜你喜欢

  • Golang学习笔记(一):简介

    2024-02-22 18:59:28
  • 使用python画出逻辑斯蒂映射(logistic map)中的分叉图案例

    2023-05-19 13:05:18
  • Python常用的内置序列结构(列表、元组、字典)学习笔记

    2021-02-18 21:25:45
  • js加密页面代码生成器

    2007-10-12 13:40:00
  • Java数据库操作库DButils类的使用方法与实例详解

    2024-01-20 13:32:45
  • mysql 将列值转变为列的方法

    2024-01-18 21:27:38
  • 使用python处理一万份word表格简历操作

    2021-09-15 17:36:36
  • Pytorch使用MNIST数据集实现CGAN和生成指定的数字方式

    2022-01-14 07:38:10
  • 基于JavaScript实现单选框下拉菜单添加文件效果

    2023-07-15 08:46:33
  • Python中Yield的基本用法

    2021-08-30 15:34:55
  • MySql数据库备份的几种方式

    2024-01-17 03:15:05
  • Java连接Oracle数据库实例解析

    2024-01-17 06:31:04
  • Python机器学习应用之决策树分类实例详解

    2021-12-19 16:57:53
  • 在Python中等距取出一个数组其中n个数的实现方式

    2023-10-18 10:03:10
  • jupyter notebook运行代码没反应且in[ ]没有*

    2022-03-06 17:37:39
  • vue实现验证码倒计时按钮

    2024-04-09 10:49:05
  • 清空所有表中的数据的存储过程

    2024-01-16 11:00:08
  • Python yield生成器和return对比代码实例

    2022-07-17 21:54:57
  • MySql索引原理与操作

    2024-01-28 22:27:31
  • 关于matplotlib-legend 位置属性 loc 使用说明

    2021-12-19 06:48:25
  • asp之家 网络编程 m.aspxhome.com