武汉的樱花开了!出不了门别担心,线上带你开樱花![Python画樱花]

news/2024/12/2 22:53:00/

GitHub 微信公众号 知乎 B站 CSDN

武汉的樱花开了!出不了门别担心,线上带你"开"樱花![Python画樱花]

Python实现部分转载自Soul fragments:https://blog.csdn.net/weixin_43943977/article/details/102691392?utm_source=app

阳春三月,草长莺飞。今天下午,百年珞珈、纯美樱花,我们线上赏樱花!

在家用python写了三种樱花树,希望你们能够喜欢。

1 樱花树
动态生成樱花
效果图(这个是动态的):
在这里插入图片描述
实现代码(Python):

import turtle as T
import random
import time# 画樱花的躯干(60,t)
def Tree(branch, t):time.sleep(0.0005)if branch > 3:if 8 <= branch <= 12:if random.randint(0, 2) == 0:t.color('snow')  # 白else:t.color('lightcoral')  # 淡珊瑚色t.pensize(branch / 3)elif branch < 8:if random.randint(0, 1) == 0:t.color('snow')else:t.color('lightcoral')  # 淡珊瑚色t.pensize(branch / 2)else:t.color('sienna')  # 赭(zhě)色t.pensize(branch / 10)  # 6t.forward(branch)a = 1.5 * random.random()t.right(20 * a)b = 1.5 * random.random()Tree(branch - 10 * b, t)t.left(40 * a)Tree(branch - 10 * b, t)t.right(20 * a)t.up()t.backward(branch)t.down()# 掉落的花瓣
def Petal(m, t):for i in range(m):a = 200 - 400 * random.random()b = 10 - 20 * random.random()t.up()t.forward(b)t.left(90)t.forward(a)t.down()t.color('lightcoral')  # 淡珊瑚色t.circle(1)t.up()t.backward(a)t.right(90)t.backward(b)# 绘图区域
t = T.Turtle()
# 画布大小
w = T.Screen()
t.hideturtle()  # 隐藏画笔
t.getscreen().tracer(5, 0)
w.screensize(bg='wheat')  # wheat小麦
t.left(90)
t.up()
t.backward(150)
t.down()
t.color('sienna')# 画樱花的躯干
Tree(60, t)
# 掉落的花瓣
Petal(200, t)
w.exitonclick()

2 飘落效果樱花树

效果图:
在这里插入图片描述
实现代码:

from turtle import *
from random import *
from math import *def tree(n,l):pd()#下笔#阴影效果t = cos(radians(heading()+45))/8+0.25pencolor(t,t,t)pensize(n/3)forward(l)#画树枝if n>0:b = random()*15+10 #右分支偏转角度c = random()*15+10 #左分支偏转角度d = l*(random()*0.25+0.7) #下一个分支的长度#右转一定角度,画右分支right(b)tree(n-1,d)#左转一定角度,画左分支left(b+c)tree(n-1,d)#转回来right(c)else:#画叶子right(90)n=cos(radians(heading()-45))/4+0.5pencolor(n,n*0.8,n*0.8)circle(3)left(90)#添加0.3倍的飘落叶子if(random()>0.7):pu()#飘落t = heading()an = -40 +random()*40setheading(an)dis = int(800*random()*0.5 + 400*random()*0.3 + 200*random()*0.2)forward(dis)setheading(t)#画叶子pd()right(90)n = cos(radians(heading()-45))/4+0.5pencolor(n*0.5+0.5,0.4+n*0.4,0.4+n*0.4)circle(2)left(90)pu()#返回t=heading()setheading(an)backward(dis)setheading(t)pu()backward(l)#退回bgcolor(0.5,0.5,0.5)#背景色
ht()#隐藏turtle
speed(0)#速度 1-10渐进,0 最快
tracer(0,0)
pu()#抬笔
backward(100)
left(90)#左转90度
pu()#抬笔
backward(300)#后退300
tree(12,100)#递归7层
done()

3 暗色效果樱花树
效果图:
在这里插入图片描述
实现代码:

from turtle import *
from random import *
from math import *def tree(n, l):pd()t = cos(radians(heading() + 45)) / 8 + 0.25pencolor(t, t, t)pensize(n / 4)forward(l)if n > 0:b = random() * 15 + 10c = random() * 15 + 10d = l * (random() * 0.35 + 0.6)right(b)tree(n - 1, d)left(b + c)tree(n - 1, d)right(c)else:right(90)n = cos(radians(heading() - 45)) / 4 + 0.5pencolor(n, n, n)circle(2)left(90)pu()backward(l)
bgcolor(0.5, 0.5, 0.5)
ht()
speed(0)
tracer(0, 0)
left(90)
pu()
backward(300)
tree(13, 100)
done()

4 网页樱花树
效果图(动态效果):
在这里插入图片描述
在这里插入图片描述

实现程序:

<!doctype html>
<html>
<head>
<meta http-equiv="Pragma" content="no-cache" />
<meta http-equiv="Cache-Control" content="no-cache" />
<meta http-equiv="Expires" content="0" />
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no" />
<style type="text/css">
canvas{position: absolute;left: 0;top: 0;
}
</style>
</head>
<body bgcolor="#000000">
<canvas id="tree"></canvas>
<canvas id="flower"></canvas>
<script>
//两个canvas
var tree = document.getElementById("tree");
tree.width = window.innerWidth;
tree.height = window.innerHeight ;
var tCxt = tree.getContext("2d");
var flower = document.getElementById("flower");
flower.width = window.innerWidth;
flower.height = window.innerHeight ;
var cxt = flower.getContext("2d");var flowerList = [];//樱花列表
var rootTop = 450 ;//树起点
var flowerColor = "rgba(255,192,203,.3)" ;//花色
var flowerColorDeep = "rgba(241,158,194,.5)" ;//花色深
var treeColor2 = "rgba(255,192,203,.5)" ;//树枝颜色
var treeColor = "#FFF" ;//树干颜色
var fallList = [];//飘落樱花列表
var g = 0.01 ;//重力加速度
var gWind = 0.005;//风力加速度
var limitSpeedY = 1;//速度上限
var limitSpeedX = 1 ;//速度上限cxt.shadowColor= "#FFF" ;
cxt.shadowBlur = 10 ;function drawTree(x,y,deg,step,type){var deg1 = step%2 == 0 ? 0.1 : -0.1 ;var x1 = x + Math.cos(deg+deg1) * (step+4) * 0.8 ;//以步长来判断枝干长度 x轴偏移大一些var y1 = y + Math.sin(deg+deg1) * (step-1) * 0.8 ;//以步长来判断枝干长度 Y轴压缩一些tCxt.beginPath();tCxt.lineWidth = step/3;tCxt.moveTo(x,y);tCxt.lineTo(x1,y1);tCxt.strokeStyle = (step > 5 ) ? treeColor : treeColor2 ;//细纸条都换成花的颜色tCxt.stroke();if(step > 20){//树干相交的位置有间隙,以一个圆填充tCxt.fillStyle = treeColor ;tCxt.arc(x,y,step/6,0,Math.PI*2);tCxt.fill();}if(step < 3 || (step < 23 && Math.random() > 0.1)){//末梢位置 画花瓣var color = [flowerColorDeep,flowerColor,flowerColor][Math.round(Math.random()+0.2)] ;var r = 2+Math.random()*2tCxt.fillStyle = color ;tCxt.arc(x1+Math.random()*3,y1+Math.random()*3,r,0,Math.PI)tCxt.fill();flowerList.push({x:x,y:y,sx:(Math.random()-0.5),sy:0,color:color,r:r,deg:deg});//保存下画樱花的位置}step -- ;if(step > 0){drawTree(x1,y1,deg,step,type);if(step%3 == 1 && step > 0 && step < 30)drawTree(x1,y1,deg+0.2 + 0.3 * Math.random(),Math.round(step/1.13));//右分叉if(step%3 == 0 && step > 0 && step < 30)drawTree(x1,y1,deg-0.2 - 0.3 * Math.random(),Math.round(step/1.13));//左分叉}
}drawTree(tree.width/2,rootTop,-Math.PI/2,30,1);//执行var len = flowerList.length ;
function step(){if(Math.random() > 0.3)    fallList.push(flowerList[Math.floor(Math.random()*len)]);//随机取出一个,花瓣复制到飘落花瓣的列表中cxt.clearRect(0,0,tree.width,tree.height);for(var i = 0 ;i < fallList.length ; i ++){if(fallList[i].sy < limitSpeedY) fallList[i].sy += g ;fallList[i].sx += gWind ;fallList[i].x += fallList[i].sx ;fallList[i].y += fallList[i].sy ;if(fallList[i].y > rootTop+30){//飘到树根+30的花瓣移除fallList.splice(i,1);i -- ;continue ;}cxt.beginPath();cxt.fillStyle = fallList[i].color ;fallList[i].deg += fallList[i].sx*0.05 ;//跟速度相关的旋转花瓣cxt.arc(fallList[i].x,fallList[i].y,fallList[i].r,fallList[i].deg,fallList[i].deg+Math.PI*1.3);cxt.fill();}requestAnimationFrame(step);
}
requestAnimationFrame(step);
</script>
</body>
</html>

最后一种用HTML语言写的,直接复制用浏览器打开就能查看,是动态的哦!

如果觉得画的不行,也给大家找了不错的樱花视频,供大家欣赏,祝大家健康快乐,一切安好!

无锡鼋头渚樱花节


转载自新片场,作者朱力,原话是:总之就是美了…如果有时间3月份可以来无锡赏樱。清明时节,樱花烂漫,无需去看日本樱花,赏樱的话,鼋头渚也是很不错的地方。

@林夕啊ʚ🐷ྀིɞ
#无锡鼋头渚樱花 正好拍到起风的瞬间 #抖音约你去赏花 #绿水青山我的家 #人民记忆70年70城

来自无锡鼋头渚的漫天樱飞雪

去年在无锡鼋头渚的大风天里,无意间拍摄到的漫天樱吹雪。
新增了快板配乐和慢板配乐,希望大家喜欢~

@航拍vlogger
樱花它本来的颜色好看吗?#航拍 #樱花 #带你看樱花 # 抖音群樱会


关注微信公众号:迈微电子研发社,回复获取更多精彩内容。
在这里插入图片描述

△微信扫一扫关注「迈微电子研发社」公众号

在这里插入图片描述


http://www.ppmy.cn/news/399763.html

相关文章

【一】win10 下 ElasticSearch8.1.0、Head插件、Kibana下载与安装(图文详解)

以 win10 下安装 8.1.0 版本为例 jdk版本&#xff1a;openjdk 17 D:\> java -version openjdk version "17" 2021-09-14 OpenJDK Runtime Environment (build 1735-2724) OpenJDK 64-Bit Server VM (build 1735-2724, mixed mode, sharing)1、ElasticSearch8.1.0 …

Acwing1294.樱花

文章目录 题意思路代码 题意 给定一个整数n&#xff0c;求有多少正整数对(x, y)满足 1 x 1 y 1 n ! \frac{1}{x} \frac{1}{y} \frac{1}{n!} x1​y1​n!1​ 思路 推公式 ∵ 1 x 1 y 1 n ! . ∴ x ≥ n ! y ≥ n ! . ∴ y k n ! ( k ≥ 1 ) . 1 x 1 y 1 n ! − >…

Luogu P1445[Violet]樱花/P4167 [Violet]樱花

Luogu P1445[Violet]樱花/P4167 [Violet]樱花 真双倍经验 化简原式&#xff1a;\[\frac{1}{x}\frac{1}{y}\frac{1}{n!}\]\[\frac{xy}{xy}n!\]\[xyn!(xy)\]\[-n!(xy)xy0\]\[(n!xn!y)-xy0\]\[(n!)^2(n!xn!y)-xy(n!)^2\]\[(x-n!)(y-n!)(n!)^2\] 所以\((x-n!)\)就是\((n!)^2\)的一个…

断点续传下载引出的http header的range和content-range参数

背景 最近同事在做安卓的断点续传下载&#xff0c;然后遇到了在请求头添加RANGE参数设置时&#xff1a; .addHeader("RANGE", "bytes" downloadLength "-" (contentLength-1))网络上找的资料都是设置contentLength,同时测试后&#xff0c;发…

DAY24:二叉树(十四)二叉搜索树中的插入操作+删除二叉搜索树中的节点(二叉树结构修改难点)

文章目录 701.二叉搜索树中的插入操作思路递归法如何保证连接的节点就是空节点的父节点&#xff1f; 迭代法迭代法注意debug测试 450.删除二叉搜索树中的节点&#xff08;坑较多&#xff0c;注意复盘&#xff09;思路最开始的写法debug测试1.使用了释放后的空间ERROR: AddressS…

7 个Python 类的最佳实践栗子

描述一个过程&#xff1a;”门铃响了&#xff0c;快递小哥tiger敲门&#xff0c;狗叫&#xff0c;jimmy开门“ 这里面的 3 个对象&#xff1a;敲门的人&#xff0c;动物和开门的人&#xff0c;需要我们灵活设置。对应于每次敲门、动物叫声和开门的人的不同变化。 输入&#xff…

JavaScript 页面可见性-监听用户离开页面-visibilitychange 事件

JavaScript监听用户离开页面-visibilitychange &#x1f4d2;博客首页&#xff1a;蔚说的博客&#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐️留言&#x1f4dd;&#x1f64f;作者水平很有限&#xff0c;如果发现错误&#xff0c;求告知&#xff0c;多谢&#x…

十字军之王3 mac中文版

喜欢策略类角色扮演游戏的玩家注意&#xff1a;十字军之王3中文破解版上市&#xff01;最新版采用了3地形图、3D头像&#xff0c;新UI的启用也给游戏带来了很多新意&#xff0c;十字军之王3游戏中将策略玩法延伸到极致&#xff0c;玩家将会成为某个国家国王的直系继承人&#x…