python实现动态爱心

最近很火的李峋的爱心代码火遍全网,至此很多语言的爱心都蜂拥而至,那么下面来实现一下李峋的动态跳动爱心,下面是代码

# -*- coding: utf-8 -*-
# @Author  :yanghao
# @Time    : 2022/11/9 12:07
# @Function:
import random
from math import sin, cos, pi, log
from tkinter import *

CANVAS_WIDTH = 640  # 画布的宽
CANVAS_HEIGHT = 480  # 画布的高
CANVAS_CENTER_X = CANVAS_WIDTH / 2  # 画布中心的X轴坐标
CANVAS_CENTER_Y = CANVAS_HEIGHT / 2  # 画布中心的Y轴坐标
IMAGE_ENLARGE = 11  # 放大比例
HEART_COLOR = "pink"  # 心的颜色


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

    # 放大
    x *= shrink_ratio
    y *= shrink_ratio

    # 移到画布中央
    x += CANVAS_CENTER_X
    y += CANVAS_CENTER_Y

    return int(x), int(y)


def scatter_inside(x, y, beta=0.15):
    """
    随机内部扩散
    :param x: 原x
    :param y: 原y
    :param beta: 强度
    :return: 新坐标
    """
    ratio_x = - beta * log(random.random())
    ratio_y = - beta * log(random.random())

    dx = ratio_x * (x - CANVAS_CENTER_X)
    dy = ratio_y * (y - CANVAS_CENTER_Y)

    return x - dx, y - dy


def shrink(x, y, ratio):
    """
    抖动
    :param x: 原x
    :param y: 原y
    :param ratio: 比例
    :return: 新坐标
    """
    force = -1 / (((x - CANVAS_CENTER_X) ** 2 + (y - CANVAS_CENTER_Y) ** 2) ** 0.6)  # 这个参数...
    dx = ratio * force * (x - CANVAS_CENTER_X)
    dy = ratio * force * (y - CANVAS_CENTER_Y)
    return x - dx, y - dy


def curve(p):
    """
    自定义曲线函数,调整跳动周期
    :param p: 参数
    :return: 正弦
    """
    return 4 * (2 * sin(4 * p)) / (2 * pi)


class Heart:
    """
    爱心类
    """

    def __init__(self, generate_frame=20):
        self._points = set()  # 原始爱心坐标集合
        self._edge_diffusion_points = set()  # 边缘扩散效果点坐标集合
        self._center_diffusion_points = set()  # 中心扩散效果点坐标集合
        self.all_points = {}  # 每帧动态点坐标
        self.build(2000)

        self.random_halo = 1000

        self.generate_frame = generate_frame
        for frame in range(generate_frame):
            self.calc(frame)

    def build(self, number):
        # 爱心
        for _ in range(number):
            t = random.uniform(0, 2 * pi)  # 随机不到的地方造成爱心有缺口
            x, y = heart_function(t)
            self._points.add((x, y))

        # 爱心内扩散
        for _x, _y in list(self._points):
            for _ in range(3):
                x, y = scatter_inside(_x, _y, 0.05)
                self._edge_diffusion_points.add((x, y))

        # 爱心内再次扩散
        point_list = list(self._points)
        for _ in range(4000):
            x, y = random.choice(point_list)
            x, y = scatter_inside(x, y, 0.17)
            self._center_diffusion_points.add((x, y))

    @staticmethod
    def calc_position(x, y, ratio):
        # 调整缩放比例
        force = 1 / (((x - CANVAS_CENTER_X) ** 2 + (y - CANVAS_CENTER_Y) ** 2) ** 0.520)

        dx = ratio * force * (x - CANVAS_CENTER_X) + random.randint(-1, 1)
        dy = ratio * force * (y - CANVAS_CENTER_Y) + random.randint(-1, 1)

        return x - dx, y - dy

    def calc(self, generate_frame):
        ratio = 10 * curve(generate_frame / 10 * pi)  # 圆滑的周期的缩放比例

        halo_radius = int(4 + 6 * (1 + curve(generate_frame / 10 * pi)))
        halo_number = int(3000 + 4000 * abs(curve(generate_frame / 10 * pi) ** 2))

        all_points = []

        # 光环
        heart_halo_point = set()  # 光环的点坐标集合
        for _ in range(halo_number):
            t = random.uniform(0, 2 * pi)  # 随机不到的地方造成爱心有缺口
            x, y = heart_function(t, shrink_ratio=11)
            x, y = shrink(x, y, halo_radius)
            if (x, y) not in heart_halo_point:
                # 处理新的点
                heart_halo_point.add((x, y))
                x += random.randint(-11, 11)
                y += random.randint(-11, 11)
                size = random.choice((1, 2, 2))#控制外围粒子的大小
                all_points.append((x, y, size))

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

        # 内容
        for x, y in self._center_diffusion_points:
            x, y = self.calc_position(x, y, ratio)
            size = random.randint(1, 2)
            all_points.append((x, y, size))

        self.all_points[generate_frame] = all_points

    def render(self, render_canvas, render_frame):
        for x, y, size in self.all_points[render_frame % self.generate_frame]:
            render_canvas.create_rectangle(x, y, x + size, y + size, width=0, fill=HEART_COLOR)


def draw(main: Tk, render_canvas: Canvas, render_heart: Heart, render_frame=0):
    render_canvas.delete('all')
    render_heart.render(render_canvas, render_frame)
    main.after(160, draw, main, render_canvas, render_heart, render_frame + 1)


if __name__ == '__main__':
    root = Tk()  # 一个Tk
    canvas = Canvas(root, bg='black', height=CANVAS_HEIGHT, width=CANVAS_WIDTH)
    canvas.pack()
    heart = Heart()  # 心
    draw(root, canvas, heart)  # 开始画画~
    root.mainloop()

运行结果:

 

快拿去发给喜欢的人哦!

好好踢球啦
关注 关注
  • 10
    点赞
  • 62
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
python爱心代码简单教程
计算机毕业论文源码,学生个人网页制作html源码。贴近用户做网络推广和互联网优化。
11-16 2万+
python爱心代码简单教程操作方法:1 将以上代码保存为.py文件,假设保存的文件名为 love.py (不会保存?先保存为txt文本,然后将后缀改为.py) 2 在终端(cmd命令窗口)输入python 空格 love.py的路径 回车 (如果是python3就这样写 python3 love.py路径,py文件的路径:直接将文件拖进来命令窗口就是路径) 3 根据提示 输入要展示的内容(如果输入中文要用英文引号引起来) **注意**: 01 如果要换行加上\n,比如Lily 后面换行,就这样写lily
李峋爱心代码
weixin_49796643的博客
11-08 9万+
李峋爱心代码
一篇文章教会你如何用Python制作爱心代码(跳动版)
最新发布
Python_HUHU的博客
08-06 1474
Hello大家好,今天来给大家分享一波用Python制作的表白代码——Python爱心代码,接下来会给大家详细讲解,代码实现的详细步骤,以及代码运行所需要的环境。
python】点燃我,温暖你 ,快来Get同款爱心代码
Python单行客的博客
11-11 1万+
python】点燃我,温暖你 ,快来Get同款爱心代码
python实现 跳动爱心代码 ,表白神器又+1+1+1......
m0_67575344的博客
11-09 1万+
关于表白神器什么的,我是豪不吝啬给的,别说小熊猫我没发嗷~
[Python]《点燃我,温暖你》李峋同款爱心代码
ZXW_NUDT的博客
11-16 1万+
《点燃我,温暖你》李峋同款爱心代码。 注意:代码原作者是【抖音:无所不能的法学生小黑】
Python实现动态爱心教程及源码
01-09
Python是一种高级、通用的编程语言,由Guido van Rossum于1991年创建。它被设计为易读、简洁和可扩展的语言,并且在如软件开发、数据分析、人工智能等多个领域中广泛应用。 Python具有以下特点: 1. 简单易学:...
python实现动态爱心源码.doc
03-23
这个程序通过一系列精心设计的函数来实现爱心的动画效果,包括放大、随机内部扩散、抖动等效果,使得爱心看起来更生动有趣。 首先,程序定义了一些常量,如画布的宽(CANVAS_WIDTH)、高(CANVAS_HEIGHT)以及中心...
基于Python实现动态爱心.py
07-03
python
Python李峋同款跳动的爱心代码(可写字版)
xxue345678的博客
12-07 3620
一年前小编曾用python编写过跳动的爱心代码,不知道有多少小伙伴们已经学会了呢,最近小编在用c语言和java编写跳动的爱心的时候,发现之前用python编写跳动的爱心时没有添加文字,这不,小编立马翻出之前的代码一顿操作,给大家带来了更新后的爱心,快来看看趴~(附详细分析哦)
爱心代码python
热门推荐
新手小白
10-08 11万+
爱心代码 抖音来的看这里
python 爱心代码
sunsiyuan12的博客
12-30 8063
python爱心代码
m0_60735903的博客
03-31 6539
代码python爱心代码
python爱心代码
2201_75893919的博客
09-02 5589
你可以将这段代码复制到 Python 编辑器中运行,然后就可以在控制台中看到一个会动的爱心了。如果你想让爱心的大小或速度发生变化,可以尝试修改代码中的一些参数,例如。的二维列表,其中包含了爱心的形状。然后,代码使用一。函数的参数、列表中爱心的位置等等。这段代码定义了一个名为。个无限循环来不断地输出爱心形状
写文章

热门文章

  • python实现动态爱心 11421
  • error Component name “Login“ should always be multi-word vue/multi-word-component-names 7177
  • Spark 案例实操(Spark Streaming之WordCount) 2787
  • 客户端404The origin server did not find a current representation for the target resource or is not... 1459
  • MapReduce案例实操---对电话号码进行分区 1175

最新评论

  • python实现动态爱心

    H8305_: 这是python还是js啊

  • python实现动态爱心

    2301_77511340: 真的很好

  • python实现动态爱心

    2301_77153785: from tkinter import * 这句就错了

  • python实现动态爱心

    ꧁༺易寒༻꧂: 为什么我的是黑屏

  • python实现动态爱心

    小凝young: 作者大大表情包表情包表情包

最新文章

  • 客户端404The origin server did not find a current representation for the target resource or is not...
  • error Component name “Login“ should always be multi-word vue/multi-word-component-names
  • Spark 案例实操(Spark Streaming之WordCount)
2022年3篇
2021年4篇

目录

目录

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43元 前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

玻璃钢生产厂家兴化玻璃钢雕塑电话户外商场美陈市场价阜阳欧式玻璃钢雕塑定制中山市玻璃钢雕塑厂家江苏商场节庆美陈草莓玻璃钢卡通雕塑订做六安春季商场美陈上海大型商场美陈费用玻璃钢恐龙雕塑厂家银川玻璃钢景观雕塑材料济南玻璃钢花盆市场报价沈阳步行街玻璃钢雕塑联系方式句容商场春节美陈河南铸铜玻璃钢仿铜雕塑定制南昌大型玻璃钢雕塑多少钱商场美陈包括什么玻璃钢 铜皮怎么制作雕塑武汉玻璃钢雕塑模具价格昆明市玻璃钢雕塑加工玻璃钢模型雕塑广东玻璃钢花盆组合青岛玻璃钢花盆怎么样云浮玻璃钢名人雕塑江西景观玻璃钢雕塑定做价格玻璃钢球雕塑属于装饰材料吗雕塑玻璃钢翻制方法豆子玻璃钢雕塑邳州商场入口美陈焦作玻璃钢雕塑雕刻信阳卡通玻璃钢雕塑哪家好香港通过《维护国家安全条例》两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”19岁小伙救下5人后溺亡 多方发声单亲妈妈陷入热恋 14岁儿子报警汪小菲曝离婚始末遭遇山火的松茸之乡雅江山火三名扑火人员牺牲系谣言何赛飞追着代拍打萧美琴窜访捷克 外交部回应卫健委通报少年有偿捐血浆16次猝死手机成瘾是影响睡眠质量重要因素高校汽车撞人致3死16伤 司机系学生315晚会后胖东来又人满为患了小米汽车超级工厂正式揭幕中国拥有亿元资产的家庭达13.3万户周杰伦一审败诉网易男孩8年未见母亲被告知被遗忘许家印被限制高消费饲养员用铁锨驱打大熊猫被辞退男子被猫抓伤后确诊“猫抓病”特朗普无法缴纳4.54亿美元罚金倪萍分享减重40斤方法联合利华开始重组张家界的山上“长”满了韩国人?张立群任西安交通大学校长杨倩无缘巴黎奥运“重生之我在北大当嫡校长”黑马情侣提车了专访95后高颜值猪保姆考生莫言也上北大硕士复试名单了网友洛杉矶偶遇贾玲专家建议不必谈骨泥色变沉迷短剧的人就像掉进了杀猪盘奥巴马现身唐宁街 黑色着装引猜测七年后宇文玥被薅头发捞上岸事业单位女子向同事水杯投不明物质凯特王妃现身!外出购物视频曝光河南驻马店通报西平中学跳楼事件王树国卸任西安交大校长 师生送别恒大被罚41.75亿到底怎么缴男子被流浪猫绊倒 投喂者赔24万房客欠租失踪 房东直发愁西双版纳热带植物园回应蜉蝣大爆发钱人豪晒法院裁定实锤抄袭外国人感慨凌晨的中国很安全胖东来员工每周单休无小长假白宫:哈马斯三号人物被杀测试车高速逃费 小米:已补缴老人退休金被冒领16年 金额超20万

玻璃钢生产厂家 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化