当前位置: 首页 > news >正文

学东西的网站phpcms网站源码

学东西的网站,phpcms网站源码,郑州建筑工程有限公司,wordpress最受欢迎的主题概述 本篇论述#xff0c;如何用加速度在Godot中控制粒子运动。 匀速和匀变速直线运动的统一 以下是匀变速运动的速度和位移公式#xff1a; v t v 0 a t x t v 0 t 1 2 a t 2 v_tv_0 at \\ x_tv_0t \frac{1}{2}at^2 vt​v0​atxt​v0​t21​at2 当a 0 时#xf…概述 本篇论述如何用加速度在Godot中控制粒子运动。 匀速和匀变速直线运动的统一 以下是匀变速运动的速度和位移公式 v t v 0 a t x t v 0 t 1 2 a t 2 v_tv_0 at \\ x_tv_0t \frac{1}{2}at^2 vt​v0​atxt​v0​t21​at2 当a 0 时 v t v 0 x t v 0 t v_tv_0 \\ x_tv_0t vt​v0​xt​v0​t 所以匀速直线运动可以看成是a 0 的特殊匀变速直线运动两者可以共用一套公式。 Godot中的匀变速直线运动实现 另外我们在Godot的_process()或者_physics_process()中得到的delta其实就是 Δ t \Delta t Δt,而不是一个连续累计的时间 t t t。 我们需要计算的当前帧基于前一帧的速度和位移也就是 v f r a m e v f r a m e − 1 a Δ t x f r a m e v f r a m e − 1 Δ t 1 2 a Δ t 2 v_{frame} v_{frame-1} a \Delta t \\ x_{frame} v_{frame-1}\Delta t \frac{1}{2} a {\Delta t}^2 vframe​vframe−1​aΔtxframe​vframe−1​Δt21​aΔt2 其中 v f r a m e v_{frame} vframe​表示当前帧的速度 v f r a m e − 1 v_{frame-1} vframe−1​表示上一帧的速度 x f r a m e x_{frame} xframe​表示当前帧的位置 x f r a m e − 1 x_{frame-1} xframe−1​表示上一帧的位置 其实也就是 Δ v v f r a m e − v f r a m e − 1 a Δ t Δ x x f r a m e − x f r a m e − 1 v f r a m e − 1 Δ t 1 2 a Δ t 2 \Delta v v_{frame} - v_{frame-1} a \Delta t \\ \Delta x x_{frame} - x_{frame-1} v_{frame-1}\Delta t \frac{1}{2} a {\Delta t}^2 Δvvframe​−vframe−1​aΔtΔxxframe​−xframe−1​vframe−1​Δt21​aΔt2 所以当前帧 v f r a m e v f r a m e − 1 Δ v x f r a m e x f r a m e − 1 Δ x v_{frame} v_{frame-1} \Delta v \\ x_{frame} x_{frame-1} \Delta x vframe​vframe−1​Δvxframe​xframe−1​Δx 速度和位移都变成了基于前一帧的累计值而与初始的速度 v 0 v_0 v0​无关同样加速度a 0时 Δ v \Delta v Δv0,当前帧速度保持不变 Δ x v f r a m e − 1 Δ t \Delta x v_{frame-1}\Delta t Δxvframe−1​Δt当前帧的位置 上一帧位置 Δ x \Delta x Δx。 实现粒子类 基于上面的认识我们可以编写一个粒子类。它的代码如下其中update()用于粒子基于_process()或者_physics_process()中得到的delta更新粒子速度和位置是完全按照上面的思路实现的。 # 粒子 class Particle:var position:Vector2var velocity:Vector2var acceleration:Vector2func _init(position:Vector2,velocity:Vector2,acceleration:Vector2) - void:self.position positionself.velocity velocityself.acceleration acceleration# 更新速度和位置func update(d_t: float)- void:var d_v acceleration * d_tvelocity d_vposition velocity * d_t (d_v * d_t)/2# 绘制粒子func draw_particle(canvas_item:CanvasItem,color:Color.AQUAMARINE,r:3.0,fill:true,border_width:1):canvas_item.draw_circle(position,r,color,fill,border_width)# 绘制粒子的速度矢量func draw_velocity(canvas_item:CanvasItem,color:Color.GREEN_YELLOW,border_width:1):canvas_item.draw_line(position,positionvelocity,color,border_width)# 绘制粒子的加速度矢量func draw_acceleration(canvas_item:CanvasItem,color:Color.ORANGE_RED,border_width:1):canvas_item.draw_line(position,positionacceleration,color,border_width)测试代码 extends Node2Dvar pos:Vector2 Vector2(100,100) # 位置 var v : Vector2() # 速度 var a : Vector2.RIGHT * 20 # 加速度# 创建粒子实例 var p Particle.new(pos,v,a)func _process(delta: float) - void:p.update(delta) # 更新粒子的速度和位置queue_redraw() # 请求重绘# 绘制 func _draw() - void:p.draw_particle(self) # 绘制粒子p.draw_velocity(self) # 绘制速度向量p.draw_acceleration(self) # 绘制加速度向量可以看到 我们在创建粒子实例时只需要设定起始位置、初始速度以及加速度就可以了。程序便会自动随时间更新粒子的速度和位置并且绘制出粒子、粒子当前的速度以及加速度 通过设定不同的起始位置、初始速度以及加速度我们就可以模拟出匀速直线运动、匀加速直线运动和匀减速直线运动。 # 匀减速直线运动 var pos:Vector2 Vector2(100,100) # 起始位置 var v : Vector2.RIGHT * 100 # 初始速度 var a : Vector2.LEFT * 20 # 加速度# 初速度为0的匀加速直线运动 var pos:Vector2 Vector2(100,100) # 起始位置 var v : Vector2() # 初始速度 var a : Vector2.RIGHT * 20 # 加速度# 初速度不为0的匀速直线运动 var pos:Vector2 Vector2(100,100) # 起始位置 var v : Vector2.RIGHT * 100 # 初始速度 var a : Vector2() # 加速度用曲线控制速度和加速度变化 extends Node2D# 匀减速直线运动 var pos:Vector2 Vector2(300,300) # 起始位置 var v : Vector2.RIGHT * 100 # 初始速度 var a : Vector2.LEFT * 0 # 加速度export var velocity_curve:Curve# 创建粒子实例 var p Particle.new(pos,v,a)var offset: 0.0 var step:0.005func _process(delta: float) - void:p.velocity v * velocity_curve.sample(offset)offset stepif not(offset 1.0 and offset 0.0):step * -1p.update(delta) # 更新粒子的速度和位置queue_redraw()# 绘制 func _draw() - void:p.draw_particle(self,Color.AQUAMARINE,20.0) # 绘制粒子p.draw_velocity(self) # 绘制速度向量p.draw_acceleration(self) # 绘制加速度向量效果
http://www.hkea.cn/news/14502461/

相关文章:

  • 村志网站建设成都seo学徒
  • 西安建设集团网站网站设计制作策划
  • 网站建设运营公司大全wordpress文章rss
  • 暗网网站有那些潍坊网站排名
  • 北京个人网站公司网页设计作品论文
  • 网站是用什么软件做的自己搭建app
  • 做er图的网站商城网站设计与实现
  • 网站推广方式百度云做一个卖车的网站该怎么做
  • 哈尔滨自助建站模板电商营销推广有哪些?
  • 网站的界面设计怎么做郑州酒店网站建设
  • 网站长图怎么做竣工验收报告查询网
  • 海口seo整站设计学校
  • 建设个人网站赚钱设计公司网站首页显示
  • 最好的建站平台如何做网络推广赚钱
  • 必应网站提交入口帝国cms做电影网站
  • 做网站的顶部图片品牌营销与推广
  • 深圳招聘网站推荐提高工作效率图片
  • 网站转微信小程序云南建设局网站首页
  • 主题wordpress吉它多肉点击seo软件
  • 关于文化建设网站WordPress mip 评论框
  • 代码网站推荐专业的免费网站建设哪家
  • 高端网站改版锦州网站建设预订
  • wordpress网站导出porto 4wordpress下载
  • 可以进不良网站的浏览器服务类网站模板
  • 网站开发的公司排名推荐晚上用的网站
  • 网站模板代理电话云南省昆明市做网站的公司
  • 编程c++网课哪家好哈尔滨seo优化运营
  • 网络公司网站开发平面设计平台有哪些
  • 国家建设网站小制作怎么做
  • 网站开发岗位分析赞友商城电商平台排名第几