爱心曲线公式大全

local r = a*((math.sin(angle) * math.sqrt(math.abs(math.cos(angle)))) / (math.sin(angle) + 1.4142) - 2 * math.sin(angle) + 2)

local x = r * math.cos(angle) -- 计算对应的x值

local z = r * math.sin(angle) +1.5*a -

--曲线公式绘画

local function generateParabola()

local a = 10 -- 控制振幅(增加这个值会使波形更大)

local b = 0.9 -- 控制频率(增加这个值会使波形更密集)

local id = math.random(668, 681) -- 随机选择一个方块ID

local y = 8 -- 固定y坐标为8

local date = 0 -- 方块的时间戳

local step = 0.005 -- θ的步长,减小步长以增加分辨率

local maxR = 200 -- 设置r的最大值,即波形的最大半径

local blocksPerWait = 30 -- 每次等待前生成的方块数

local waitTime = 0.05 -- 每次生成后的等待时间

local theta = 0

local count = 0 -- 计数器,用于跟踪每次生成的方块数

-- 根据需要调整θ的遍历范围和步长

while true do

theta = theta + step

-- local r = a * math.sin(b * theta) -- 计算对应的r值

--local r = a * math.asin(math.tan(b * theta))

-- local r =a * math.cos(b * theta)+a * math.sin(b * theta)

--local r =a * math.cos(b * theta)*math.cos( theta)

-- local r =a * (math.sin(b * theta)*math.sin( theta))

-- local r =a * (math.cos(b * theta)*math.cos( theta))

--local r = a * math.sin(b * theta)

--local r = a * math.sin(b*theta) +b*math.sin(b*theta)

local angle=theta

local r = a*((math.sin(angle) * math.sqrt(math.abs(math.cos(angle)))) / (math.sin(angle) + 1.4142) - 2 * math.sin(angle) + 2)

if r > maxR then

break -- 如果r超过最大半径,则停止生成

end

local x = r * math.cos(theta) -- 计算对应的x值

local z = r * math.sin(theta) +1.5*a -- 计算对应的z值

-- 在计算出的位置放置方块

Block:setBlockAll(math.floor(x), y, math.floor(z), id, date)

count = count + 1 -- 增加计数器

-- 每生成10个方块后等待0.1秒

if count % blocksPerWait == 0 then

threadpool:wait(waitTime)

end

if math.floor(1000*angle) % 1256 == 0 then

id = math.random(668, 681) -- 随机选择一个方块ID

a=a+1

print(angle)

end

end

end

ScriptSupportEvent:registerEvent("Player.ClickBlock", generateParabola)

local r = a*((math.sin(angle) * math.sqrt(math.abs(math.cos(angle)))) / (math.sin(angle) + 1.4142) - 2 * math.sin(angle) + 2)

蝴蝶曲线公式

local r =a * (math.cos(b * theta)*math.cos( theta))

水平双球曲线公式

local r =a * math.cos(b * theta)*math.cos( theta)

反向双球曲线

local r =a * math.cos(b * theta)*math.sin( theta)

相关推荐
Aloys_Code12 小时前
逆向一个被遗忘的DVD游戏格式:从DES加密到Rust模拟器
游戏·模拟器·retroarch·复古游戏·native32·sunplus·赤刃·钢铁风暴
金銀銅鐵16 小时前
用 Python 实现 Take-Away 游戏
python·游戏
金銀銅鐵1 天前
用 Pygame 实现 15 puzzle
python·数学·游戏
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠3 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾3 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
xingpanvip3 天前
星盘接口开发文档:本命盘接口指南
android·开发语言·css·php·lua
Qres8213 天前
算法复键——树状数组
数据结构·算法
两水先木示3 天前
【Unity3D】小游戏启动优化、发热优化、蒙皮网格优化
游戏
资源分享助手4 天前
杀戮尖塔2下载、Slay the Spire 2中文版、卡牌肉鸽游戏、杀戮尖塔2联机、杀戮尖塔2攻略
游戏