python带你体验唯美雪景,愿这个冬天的你,不缺暖阳

news2025/1/11 15:01:30

前言

嗨喽,大家好呀~这里是爱看美女的茜茜呐

又到了学Python时刻~

大雪已至,冬天无恙,愿这个冬天的你,不缺暖阳,好日常在

一、画一朵小雪花

import turtle
import time
from turtle import *
# coding=utf-8

def snowflake(l, d):
    screen = turtle.Screen()
    # screen.bgpic("my_q.jpg")
    screen.bgcolor("white")# 背景颜色可调
    turtle.tracer(0, 0)
    if d > 0:
        for i in range(6):
            speed("fastest")
            color("#97CBFF")  # silver
            width(5)
            forward(l)
            snowflake(l // 3, d - 1)
            backward(l)
            left(60)

if __name__ == "__main__":
    snowflake(180, 5)#形状参数可调
    time.sleep(100)  #
import turtle as t              #用于图像
import random                   #产生随机数

# 递归函数,具体过程,上面有介绍
def koch(size, n):
    if n == 0:
        t.pencolor(random.randint(0, 255), random.randint(0, 255), random.randint(0, 255))
        t.fd(size)
    else:
        for i in [0, 60, -120, 60]:
            t.left(i)
            koch(size / 3, n - 1)

#稍微封装了下,颜色有点Hua
def per(n):
    t.color((random.randint(0, 255), random.randint(0, 255), random.randint(0, 255)))
    # t.begin_fill()
    koch(400, n)
    # t.end_fill()

    t.color((random.randint(0, 255), random.randint(0, 255), random.randint(0, 255)))
    t.begin_fill()
    t.left(120)
    t.fd(lenth)
    t.left(120)
    t.fd(lenth)
    t.left(120)
    koch(400, n)
    t.end_fill()
    t.left(60)


lenth = 0


def main():
    n = eval(input())
    t.colormode(255)    #颜色模式设置为255,其它模式有1,string,python文档有详细说明
    t.speed(0)          #速度快
    t.setup(1600, 700)  #设置开始时窗体,但没什么必要,直接最大化就好
    t.pu()
    t.goto(-300, -350)
    t.pd()
    t.pensize(5)

    koch(400, n)
    t.left(60)
    global lenth
    lenth = t.position()[0] - (-300)
    # 下面六个部分就为剩下部分绘制
    per(n)
    per(n)
    per(n)
    per(n)
    per(n)
    per(n)

    t.hideturtle()


main()
t.done()
## 完整源码加Q君羊:261823976

PS:本篇完整源码如有需要的小伙伴可以加下方的群去找管理员免费领取

二、实现素描雪景

from PIL import Image
import numpy as np
import tkinter.filedialog
root = tkinter.Tk().withdraw()
filename = tkinter.filedialog.askopenfilename()  # 打开选择文件对话框
try:
    depth = 30  # 0-100,越高,颜色越深
    picture_grad = np.gradient(np.asarray(Image.open(filename).convert('L')).astype('int'))  # 取图像灰度的梯度值
    grad_x, grad_y = picture_grad[0] * depth / 100., picture_grad[1] * depth / 100.  # 将获取的维度梯度值进行深度处理
    base = np.sqrt(grad_x ** 2 + grad_y ** 2 + 1.)  # 降噪基
    _x, _y, _z = grad_x / base, grad_y / base, 1. / base
    sce_z, sce_x = np.pi / 2.1, np.pi / 3  # 光源的俯视角度值和方位角度值
    # 光源对x,y,z 轴的影响
    dx, dy, dz = np.cos(sce_z) * np.cos(sce_x), np.cos(sce_z) * np.sin(sce_x), np.sin(sce_z)
    Normalized = 255 * (dx * _x + dy * _y + dz * _z).clip(0, 255)  # 光源归一化
    im = Image.fromarray(Normalized.astype('uint8'))  # 重构图像
    im.save('转换后的素描图.jpg')  # 保存转换后的图片
    im.show()  # 展示转换后的图片
except Exception:
    print('转换失败!')

三、故宫下雪拉

# -*- coding: utf-8 -*-
import pygame
import random

初始化pygame

pygame.init()

根据背景图片的大小,设置屏幕长宽

SIZE = (670, 690)
 
screen = pygame.display.set_mode(SIZE)
pygame.display.set_caption("故宫下雪了——更多源码可加q群:261823976")
bg = pygame.image.load('1.jpg')

雪花列表

snow_list = []

初始化雪花:[x坐标, y坐标, x轴速度, y轴速度]

for i in range(200):
    x = random.randrange(0, SIZE[0])
    y = random.randrange(0, SIZE[1])
    sx = random.randint(-1, 1)
    sy = random.randint(3, 6)
    snow_list.append([x, y, sx, sy])
 
clock = pygame.time.Clock()

游戏主循环

done = False
while not done:
    # 消息事件循环,判断退出
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            done = True
 
    # 黑背景/图片背景
    # screen.fill((0, 0, 0))
    screen.blit(bg, (0, 0))
 
    # 雪花列表循环
    for i in range(len(snow_list)):
        # 绘制雪花,颜色、位置、大小
        pygame.draw.circle(screen, (255, 255, 255), snow_list[i][:2], snow_list[i][3]-3)
 
        # 移动雪花位置(下一次循环起效)
        snow_list[i][0] += snow_list[i][2]
        snow_list[i][1] += snow_list[i][3]
 
        # 如果雪花落出屏幕,重设位置
        if snow_list[i][1] > SIZE[1]:
            snow_list[i][1] = random.randrange(-50, -10)
            snow_list[i][0] = random.randrange(0, SIZE[0])
 
    # 刷新屏幕
    pygame.display.flip()
    clock.tick(20)

退出

pygame.quit()

雪花飘落轨迹是运动的(自然飘落),不过我懒,就不给你们做动图拉~自己复制代码去看吧

四、圆圆雪花落

导入模块

import pygame
import random
#pygame初始化
pygame.init()

声明屏幕/窗口size大小,与背景图片的大小一样才能完美显示

SIZE = (1025, 640)

给屏幕设置大小,参数为上面设置的大小

screen = pygame.display.set_mode(SIZE)

设置标题

pygame.display.set_caption("霸道与雪")

加载背景图

background = pygame.image.load('1.png')

定义一个雪花列表

snow = []
# 初始化雪花
for i in range(300):
    #randrange()方法返回指定递增基数集合中的一个随机数
    #randrange()是不能直接访问的,需要导入random模块,然后通过ranom静态对象调用
    x = random.randrange(0, SIZE[0])
    y = random.randrange(0, SIZE[1])
    #ranint用于生成指定范围内的随机整数
    speedx = random.randint(-1, 1)
    speedy = random.randint(3,6)
    snow.append([x, y, speedx, speedy])
#创建时钟对象,用来控制游戏循环频率
clock = pygame.time.Clock()

done = False
while not done:
    # 消息事件循环,判断退出
    for event in pygame.event.get():
        if event.type == pygame.QUIT:
            done = True
    #绘制位图
    screen.blit(background, (0,0))

雪花列表循环

    for i in range(len(snow)):
        # 绘制雪花,颜色、位置、大小
        pygame.draw.circle(screen, (255, 255, 255), snow[i][:2], snow[i][3]-3)
        # 移动雪花位置(下一次循环起效)
        snow[i][0] += snow[i][2]
        snow[i][1] += snow[i][3]
        # 如果雪花落出屏幕,重设位置
        if snow[i][1] > SIZE[1]:
            snow[i][1] = random.randrange(-50, -10)
            snow[i][0] = random.randrange(0, SIZE[0])
    #更新显示到屏幕表面
    pygame.display.flip()
    #每秒循环20次
    clock.tick(20)
## 完整源码加Q君羊:261823976        
pygame.quit()

PS:本篇完整源码如有需要的小伙伴可以加下方的群去找管理员免费领取

雪花飘落轨迹一样是运动的(自然飘落)

五、唯美雪花飘落

导入模块

## 完整源码加Q君羊:261823976
#PerpetualSmile 
import pygame
import random
import os
from PIL import Image
from pygame.sprite import Sprite
from pygame.sprite import Group
from PIL import ImageGrab
import shutil

表示单个雪花的类

class Snow(Sprite):
    def __init__(self, image, pos, speed, size, screen):
        super().__init__()
        self.screen = screen
        self.speed= speed
        self.pos = pos
        self.image = pygame.transform.scale(image, size)
        self.rect = self.image.get_rect()
        self.rect.x = pos[0]
        self.rect.y = pos[1]

    def blitme(self):
        self.screen.blit(self.image, self.rect)

    def update(self):
        self.rect.x += self.speed[0]
        self.rect.y += self.speed[1]

        # 雪花旋转
        self.image = pygame.transform.rotate(self.image, 90)
        if self.check_edges():
            self.rect.x = self.pos[0]
            self.rect.y = self.pos[1]

    def check_edges(self):
        screen_rect = self.screen.get_rect()
        if self.rect.top >= screen_rect.bottom:
            return True
        return False



def add_snow(path):
    pygame.init()
    size = Image.open(path).size
    screen = pygame.display.set_mode(size, pygame.NOFRAME)
    s = pygame.display.get_surface()

    bg = pygame.image.load_extended(path).convert()
    screen.blit(bg, (0, 0))

    # 加载雪花图片
    snow_image = pygame.image.load_extended('snow.png')
    snow_group = Group()


    for i in range(500):
        # 雪花起始位置
        pos = (random.randint(-size[0], size[0]), random.randint(-size[1], 0))

        # 控制雪花大小
        n = random.randint(4, 12)
        snow_size = (n, n)

        # 雪花下落速度
        speed = (2, random.randint(2, 7))
        snow_group.add(Snow(snow_image, pos, speed, snow_size, screen))

    clock = pygame.time.Clock()

    # 创建文件夹用于保存每一帧图片
    if not os.path.exists("frames"):
        os.makedirs("frames")

    flag = True
    num = 1;
    while flag:
        for event in pygame.event.get():
            # 退出窗口
            if event.type == pygame.QUIT:
                flag = False

        screen.blit(bg, (0, 0))
        for snow in snow_group.copy():
            snow.blitme()
        snow_group.update()

        # 保存当前画面
        pygame.image.save(screen, "frames\\"+str(num)+".jpg")


        # 刷新屏幕
        pygame.display.update()

        # 设置fps
        clock.tick(30)
        if num >= 250:
            break
        num += 1

制作GIF图

    im = Image.open("frames\\1.jpg")
    images = []
    size = (int(im.size[0]/2), int(im.size[1]/2))
    for file in range(2, num + 1):
        filepath = "frames\\" + str(file) + ".jpg"
        temp = Image.open(filepath)
        temp = temp.resize(size, Image.ANTIALIAS)
        images.append(temp)

    im = im.resize(size, Image.ANTIALIAS)
    im.save('snow.gif', save_all=True, append_images=images, loop=2, duration=5)

    # 删除保存中间图片文件的文件夹
    shutil.rmtree("frames")
if __name__ == '__main__':
    add_snow('5.jpg')

好啦~今天的代码分享就到这里拉

尾语

感谢你观看我的文章呐~本次航班到这里就结束啦 🛬

希望本篇文章有对你带来帮助 🎉,有学习到一点知识~

躲起来的星星🍥也在努力发光,你也要努力加油(让我们一起努力叭)。

最后,博主要一下你们的三连呀(点赞、评论、收藏),不要钱的还是可以搞一搞的嘛~

不知道评论啥的,即使扣个6666也是对博主的鼓舞吖 💞 感谢 💐

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/79904.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

%00截断

%00截断 CVE-2013-4547 影响版本:Nginx 0.8.41 ~ 1.4.3 / 1.5.0 ~ 1.5.7 影响说明:绕过服务器策略,上传webshell 环境说明:Nginx 1.4.2 /test.jpg%00.php该漏洞利用了Nginx错误的解析了URL地址,导致可以绕过服务端限…

Armadillo与OpenCV矩阵数据mat、vec与Mat的相互转换

本文介绍在C 语言中,矩阵库Armadillo的mat、vec格式数据与计算机视觉库OpenCV的Mat格式数据相互转换的方法。 在C 语言的矩阵库Armadillo与计算机视觉库OpenCV中,都有矩阵格式的数据类型;而这两个库在运行能力方面各有千秋,因此实…

shiro-spring-boot-starter

第2.1.7章 WEB系统最佳实践Spring文件配置之spring-shiro.xml 2016年还在使用shiro,后来使用应用springboot之后,因为有了网关,感觉网关就可以做一些拦截,就没必要一定要使用shiro,如果你使用平台还需要每个系统自己做…

小白学编程(Java)20:判断一个数是否是质数

解题思路: 第一步:弄明白质数是什么? 质数的定义:质数又称素数。一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数(规定1既不是质数也不是合数&am…

微信公众号开发——获取AccessToken接口调用凭据

😊 作者: 一恍过去💖 主页: https://blog.csdn.net/zhuocailing3390🎊 社区: Java技术栈交流🎉 主题: 微信公众号开发——获取AccessToken接口调用凭据⏱️ 创作时间&#xff1…

Typora的使用

一.标题:六级标题 1 .一级标题 2. 二级标题 二级标题 : ## 加一个空格 现在加 ## 空格 然后我们把光标放在其他地方 点击一下 3 层级列表 层级列表: > 空格 回车 在这一部分,我们先来讲解三个概念&#xff1a…

基于java+springboot+mybatis+vue+mysql的篮球竞赛预约平台

项目介绍 随着人们生活质量提高,越来越多的年轻人喜欢足球。尤其是在高校之中,每年都会举办一些足球和篮球比赛。甚至在国际上每年也都会有一足球和篮球联赛。很多高校为了提高学生的身体素质每年也都会举办一些篮球竞赛,为了让这些篮球爱好…

计算机毕业设计ssm+vue基本微信小程序的奶茶点单系统

随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受客户的喜爱,随便点奶茶点单小程序被客户普遍使用,为方便客户能够…

《发现心流》

关于作者 米哈里•契克森米哈赖,任教于美国加州克 菜蒙特大学,提出并发展了心流理论。他 一直在关注人类的积极心理体验,完成了 大量经典的研究工作,是该领域最权威的 学者之一,被誉为积极心理学的世界级领 军人物。 …

日期与时间

目录 一、基本概念 1.1、日期和时间 1.2、本地时间 1.3、时区 1.4、夏令时 1.5、本地化 二、Date 和 Calendar 2.1、Date 2.2、Calendar 三、TimeZone 四、LocalDateTime 4.1、LocalDateTime 4.2、Duration和Period 五、ZoneDateTime 5.1、创建实例 5.2、时区转…

电子学会2020年12月青少年软件编程(图形化)等级考试试卷(一级)答案解析

目录 一、单选题(共25题,每题2分,共50分) 二、判断题(共10题,每题2分,共20分) 三、编程题【该题由测评师线下评分】(共2题,共30分) 青少年软件…

【MySQL数据库】索引到底是什么,怎么创建索引的效率最高

面试官:我看你简历上写了MySQL,对MySQL InnoDB引擎的索引了解吗? 候选者:嗯啊,使用索引可以加快查询速度,其实上就是将无序的数据变成有序(有序就能加快检索速度) 候选者&#xff…

微服务守护神-Sentinel-其他

引言 书接上篇 微服务守护神-Sentinel-热点-授权-系统规则 ,上面介绍了Sentinel热点、授权、系统规则,本篇继续来Sentinel 剩下其他操作 自定义异常返回 当触发sentinel流控规则之后, sentinel就干巴巴返回异常信息,单纯的文字…

JVM监控及诊断工具

本文目录命令行jps 查看正在运行的Java进程jstat:查看JVM统计信息jinfo:实时查看和修改JVM配置参数jmap:导出内存映像文件&内存使用情况jhat:JDK自带堆分析工具jstack:打印JVM中线程快照jcmd:多功能命令…

docker、LXC、LXD的区别及传统的虚拟机与操作系统虚拟化的区别

1. 概念解释 1.1. Docker Docker是一个用于在集中式平台上创建、部署和运行应用程序的开源工具。这使得主机的操作系统通过容器运行具有相同Linux内核的应用程序,而不是创建一个完整的虚拟机。使用docker容器不需要考虑Ram和磁盘空间的分配。它能够自己处理这些需…

CopyOnWriteArrayList源码解析

CopyOnWriteArrayList源码解析 简介 我们知道 ArrayList 是线程不安全的,其存在一个古老的线程安全的 Vector,但是由于 Vector 效率太低 (方法都加了synchronzed),在 JDK1.5 时 Doug Lea 提供了一个效率较高的线程安全的 CopyOnWriteArrayL…

虚拟内存(深入理解计算机系统原书第3版9节)

深入理解计算机系统(原书第3版)读书笔记,其实就是嚼碎了原文然后把一部分挑了出来摘要,免得读着读着忘了 文章目录前言一、物理和虚拟寻址二、地址空间三、虚拟内存作为缓存的工具1、DRAM缓存的组织结构2、页表3、页命中4、缺页5、…

[附源码]Python计算机毕业设计SSM基于的小区物业管理系统(程序+LW)

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

微服务框架 SpringCloud微服务架构 微服务保护 33 授权规则 33.1 授权规则

微服务框架 【SpringCloudRabbitMQDockerRedis搜索分布式,系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 微服务保护 文章目录微服务框架微服务保护33 授权规则33.1 授权规则33.1.1 授权规则33 授权规则 33.1 授权规则 33.1.1 授权规则 看看sen…

康鹏科技将于12月16日上会:曾在纽交所上市,由杨建华家族控股

近日,上海康鹏科技股份有限公司(下称“康鹏科技”)在上海证券交易所递交招股书(上会稿),准备在科创板上市。据贝多财经了解,康鹏科技将于2022年12月16日接受科创板上市委的现场审议。 根据公开信…