当前位置:   article > 正文

python编程画爱心代码,python画爱心代码大全

python画爱心代码大全

大家好,小编来为大家解答以下问题,python编程画爱心代码,python画爱心代码大全,今天让我们一起来看看吧!

前端时间电视剧《点燃我,温暖你》正在热播中,里面的天才程序员李峋制作的爱心跳动代码是不是震撼了你的心,今天我们用Python来尝试一下制作爱心跳动代码吧!

怎么说呢,用这个表白也可以的,万一她也看这个剧呢,万一就成了呢 哈哈

冲啊,兄弟们
在这里插入图片描述

okok 话不多说,现在开始代码部分

代码

模块导入

  1. import random
  2. from math import sin, cos, pi, log
  3. from tkinter import *

画布的高和宽

有些数值咱自己也是可以调改的哈,这里我设置的高和宽是 480:640

  1. CANVAS_WIDTH = 640 # 画布的宽
  2. CANVAS_HEIGHT = 480 # 画布的高

x,y轴坐标

  1. CANVAS_CENTER_X = CANVAS_WIDTH / 2 # 画布中心的X轴坐标
  2. CANVAS_CENTER_Y = CANVAS_HEIGHT / 2 # 画布中心的Y轴坐标

放大比例

IMAGE_ENLARGE = 11  # 放大比例

心的颜色

这个自己看着改啊,想改啥色就改啥色

HEART_COLOR = "#ff8181"  # 心的颜色,芜湖我喜欢的粉色

函数生成器

  1. def heart_function(t, shrink_ratio: float = IMAGE_ENLARGE):
  2. """
  3. “爱心函数生成器”
  4. :param shrink_ratio: 放大比例
  5. :param t: 参数
  6. :return: 坐标
  7. """
  8. # 基础函数
  9. x = 16 * (sin(t) ** 3)
  10. y = -(13 * cos(t) - 5 * cos(2 * t) - 2 * cos(3 * t) - cos(4 * t))

放大

  1. # 放大
  2. x *= shrink_ratio
  3. y *= shrink_ratio

移到画布中央

基本操作,我要多发点文字哈哈,不然说我质量不行

  1. # 移到画布中央
  2. x += CANVAS_CENTER_X
  3. y += CANVAS_CENTER_Y
  4. return int(x), int(y)

随机内部扩散

  1. def scatter_inside(x, y, beta=0.15):
  2. """
  3. 随机内部扩散
  4. :param x: 原x
  5. :param y: 原y
  6. :param beta: 强度
  7. :return: 新坐标
  8. """
  9. ratio_x = - beta * log(random.random())
  10. ratio_y = - beta * log(random.random())
  11. dx = ratio_x * (x - CANVAS_CENTER_X)
  12. dy = ratio_y * (y - CANVAS_CENTER_Y)
  13. return x - dx, y - dy

抖动

这一步可关键了,咱做的就是跳动的爱心代码,so这一步重中之重

  1. def shrink(x, y, ratio):
  2. """
  3. 抖动
  4. :param x: 原x
  5. :param y: 原y
  6. :param ratio: 比例
  7. :return: 新坐标
  8. """
  9. force = -1 / (((x - CANVAS_CENTER_X) ** 2 + (y - CANVAS_CENTER_Y) ** 2) ** 0.6) # 这个参数...
  10. dx = ratio * force * (x - CANVAS_CENTER_X)
  11. dy = ratio * force * (y - CANVAS_CENTER_Y)
  12. return x - dx, y - dy

调整缩放比例

基本上都可以自己调改到自己喜欢的样子

  1. @staticmethod
  2. def calc_position(x, y, ratio):
  3. # 调整缩放比例
  4. force = 1 / (((x - CANVAS_CENTER_X) ** 2 + (y - CANVAS_CENTER_Y) ** 2) ** 0.520) # 魔法参数
  5. dx = ratio * force * (x - CANVAS_CENTER_X) + random.randint(-1, 1)
  6. dy = ratio * force * (y - CANVAS_CENTER_Y) + random.randint(-1, 1)
  7. return x - dx, y - dy

圆滑的周期缩放比例

  1. def calc(self, generate_frame):
  2. ratio = 10 * curve(generate_frame / 10 * pi) # 圆滑的周期的缩放比例
  3. halo_radius = int(4 + 6 * (1 + curve(generate_frame / 10 * pi)))
  4. halo_number = int(3000 + 4000 * abs(curve(generate_frame / 10 * pi) ** 2))
  5. all_points = []

光环

  1. # 光环
  2. heart_halo_point = set() # 光环的点坐标集合
  3. for _ in range(halo_number):
  4. t = random.uniform(0, 2 * pi) # 随机不到的地方造成爱心有缺口
  5. x, y = heart_function(t, shrink_ratio=11.6) # 魔法参数
  6. x, y = shrink(x, y, halo_radius)
  7. if (x, y) not in heart_halo_point:
  8. # 处理新的点
  9. heart_halo_point.add((x, y))
  10. x += random.randint(-14, 14)
  11. y += random.randint(-14, 14)
  12. size = random.choice((1, 2, 2))
  13. all_points.append((x, y, size))

轮廓

  1. # 轮廓
  2. for x, y in self._points:
  3. x, y = self.calc_position(x, y, ratio)
  4. size = random.randint(1, 3)
  5. all_points.append((x, y, size))

内容

  1. # 内容
  2. for x, y in self._edge_diffusion_points:
  3. x, y = self.calc_position(x, y, ratio)
  4. size = random.randint(1, 2)
  5. all_points.append((x, y, size))
  6. for x, y in self._center_diffusion_points:
  7. x, y = self.calc_position(x, y, ratio)
  8. size = random.randint(1, 2)
  9. all_points.append((x, y, size))
  10. self.all_points[generate_frame] = all_points

最后一步

马上就完成了,坚持就是胜利

  1. def draw(main: Tk, render_canvas: Canvas, render_heart: Heart, render_frame=0):
  2. render_canvas.delete('all')
  3. render_heart.render(render_canvas, render_frame)
  4. main.after(160, draw, main, render_canvas, render_heart, render_frame + 1)
  5. if __name__ == '__main__':
  6. root = Tk() # 一个Tk
  7. canvas = Canvas(root, bg='black', height=CANVAS_HEIGHT, width=CANVAS_WIDTH)
  8. canvas.pack()
  9. heart = Heart() # 心
  10. draw(root, canvas, heart) # 开始画画~
  11. root.mainloop()

完整代码

  1. import random
  2. from math import sin, cos, pi, log
  3. from tkinter import *
  4. CANVAS_WIDTH = 640 # 画布的宽
  5. CANVAS_HEIGHT = 480 # 画布的高
  6. CANVAS_CENTER_X = CANVAS_WIDTH / 2 # 画布中心的X轴坐标
  7. CANVAS_CENTER_Y = CANVAS_HEIGHT / 2 # 画布中心的Y轴坐标
  8. IMAGE_ENLARGE = 11 # 放大比例
  9. HEART_COLOR = "#ff2121" # 心的颜色,这个是中国红
  10. def heart_function(t, shrink_ratio: float = IMAGE_ENLARGE):
  11. """
  12. “爱心函数生成器”
  13. :param shrink_ratio: 放大比例
  14. :param t: 参数
  15. :return: 坐标
  16. """
  17. # 基础函数
  18. x = 16 * (sin(t) ** 3)
  19. y = -(13 * cos(t) - 5 * cos(2 * t) - 2 * cos(3 * t) - cos(4 * t))
  20. # 放大
  21. x *= shrink_ratio
  22. y *= shrink_ratio
  23. # 移到画布中央
  24. x += CANVAS_CENTER_X
  25. y += CANVAS_CENTER_Y
  26. return int(x), int(y)
  27. def scatter_inside(x, y, beta=0.15):
  28. """
  29. 随机内部扩散
  30. :param x: 原x
  31. :param y: 原y
  32. :param beta: 强度
  33. :return: 新坐标
  34. """
  35. ratio_x = - beta * log(random.random())
  36. ratio_y = - beta * log(random.random())
  37. dx = ratio_x * (x - CANVAS_CENTER_X)
  38. dy = ratio_y * (y - CANVAS_CENTER_Y)
  39. return x - dx, y - dy
  40. def shrink(x, y, ratio):
  41. """
  42. 抖动
  43. :param x: 原x
  44. :param y: 原y
  45. :param ratio: 比例
  46. :return: 新坐标
  47. """
  48. force = -1 / (((x - CANVAS_CENTER_X) ** 2 + (y - CANVAS_CENTER_Y) ** 2) ** 0.6) # 这个参数...
  49. dx = ratio * force * (x - CANVAS_CENTER_X)
  50. dy = ratio * force * (y - CANVAS_CENTER_Y)
  51. return x - dx, y - dy
  52. def curve(p):
  53. """
  54. 自定义曲线函数,调整跳动周期
  55. :param p: 参数
  56. :return: 正弦
  57. """
  58. # 可以尝试换其他的动态函数,达到更有力量的效果(贝塞尔?)
  59. return 2 * (2 * sin(4 * p)) / (2 * pi)
  60. class Heart:
  61. """
  62. 爱心类
  63. """
  64. def __init__(self, generate_frame=20):
  65. self._points = set() # 原始爱心坐标集合
  66. self._edge_diffusion_points = set() # 边缘扩散效果点坐标集合
  67. self._center_diffusion_points = set() # 中心扩散效果点坐标集合
  68. self.all_points = {} # 每帧动态点坐标
  69. self.build(2000)
  70. self.random_halo = 1000
  71. self.generate_frame = generate_frame
  72. for frame in range(generate_frame):
  73. self.calc(frame)
  74. def build(self, number):
  75. # 爱心
  76. for _ in range(number):
  77. t = random.uniform(0, 2 * pi) # 随机不到的地方造成爱心有缺口
  78. x, y = heart_function(t)
  79. self._points.add((x, y))
  80. # 爱心内扩散
  81. for _x, _y in list(self._points):
  82. for _ in range(3):
  83. x, y = scatter_inside(_x, _y, 0.05)
  84. self._edge_diffusion_points.add((x, y))
  85. # 爱心内再次扩散
  86. point_list = list(self._points)
  87. for _ in range(4000):
  88. x, y = random.choice(point_list)
  89. x, y = scatter_inside(x, y, 0.17)
  90. self._center_diffusion_points.add((x, y))
  91. @staticmethod
  92. def calc_position(x, y, ratio):
  93. # 调整缩放比例
  94. force = 1 / (((x - CANVAS_CENTER_X) ** 2 + (y - CANVAS_CENTER_Y) ** 2) ** 0.520) # 魔法参数
  95. dx = ratio * force * (x - CANVAS_CENTER_X) + random.randint(-1, 1)
  96. dy = ratio * force * (y - CANVAS_CENTER_Y) + random.randint(-1, 1)
  97. return x - dx, y - dy
  98. def calc(self, generate_frame):
  99. ratio = 10 * curve(generate_frame / 10 * pi) # 圆滑的周期的缩放比例
  100. halo_radius = int(4 + 6 * (1 + curve(generate_frame / 10 * pi)))
  101. halo_number = int(3000 + 4000 * abs(curve(generate_frame / 10 * pi) ** 2))
  102. all_points = []
  103. # 光环
  104. heart_halo_point = set() # 光环的点坐标集合
  105. for _ in range(halo_number):
  106. t = random.uniform(0, 2 * pi) # 随机不到的地方造成爱心有缺口
  107. x, y = heart_function(t, shrink_ratio=11.6) # 魔法参数
  108. x, y = shrink(x, y, halo_radius)
  109. if (x, y) not in heart_halo_point:
  110. # 处理新的点
  111. heart_halo_point.add((x, y))
  112. x += random.randint(-14, 14)
  113. y += random.randint(-14, 14)
  114. size = random.choice((1, 2, 2))
  115. all_points.append((x, y, size))
  116. # 轮廓
  117. for x, y in self._points:
  118. x, y = self.calc_position(x, y, ratio)
  119. size = random.randint(1, 3)
  120. all_points.append((x, y, size))
  121. # 内容
  122. for x, y in self._edge_diffusion_points:
  123. x, y = self.calc_position(x, y, ratio)
  124. size = random.randint(1, 2)
  125. all_points.append((x, y, size))
  126. for x, y in self._center_diffusion_points:
  127. x, y = self.calc_position(x, y, ratio)
  128. size = random.randint(1, 2)
  129. all_points.append((x, y, size))
  130. self.all_points[generate_frame] = all_points
  131. def render(self, render_canvas, render_frame):
  132. for x, y, size in self.all_points[render_frame % self.generate_frame]:
  133. render_canvas.create_rectangle(x, y, x + size, y + size, width=0, fill=HEART_COLOR)
  134. def draw(main: Tk, render_canvas: Canvas, render_heart: Heart, render_frame=0):
  135. render_canvas.delete('all')
  136. render_heart.render(render_canvas, render_frame)
  137. main.after(160, draw, main, render_canvas, render_heart, render_frame + 1)
  138. if __name__ == '__main__':
  139. root = Tk() # 一个Tk
  140. canvas = Canvas(root, bg='black', height=CANVAS_HEIGHT, width=CANVAS_WIDTH)
  141. canvas.pack()
  142. heart = Heart() # 心
  143. draw(root, canvas, heart) # 开始画画~
  144. root.mainloop()

最后

给大家分享一波Python全套学习资料,免费!免费!免费!都是我自己学习时整理的,整理不易,请多多点赞分享哦~

微信扫描下方CSDN官方认证二维码即可领取啦!

一、Python所有方向的学习路线

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述

二、Python学习软件

工欲善其事,必先利其器火车头标题伪原创【php源码】。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
在这里插入图片描述

三、Python入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
在这里插入图片描述

四、Python练习题

检验学习成果
在这里插入图片描述

五、Python实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
在这里插入图片描述

六、Python面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
在这里插入图片描述
在这里插入图片描述
需要的小伙伴可自行微信扫描下方CSDN官方认证二维码免费领取!!

文章知识点与官方知识档案匹配,可进一步学习相关知识
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/192123
推荐阅读
相关标签
  

闽ICP备14008679号