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 -
data:image/s3,"s3://crabby-images/80d0b/80d0b528685815515c4939e2e249658cc4e6bef0" alt=""
--曲线公式绘画
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)
data:image/s3,"s3://crabby-images/325a9/325a955f8123e2de862c8e4999adccc7a826a9ce" alt=""
蝴蝶曲线公式
local r =a * (math.cos(b * theta)*math.cos( theta))
data:image/s3,"s3://crabby-images/e51a9/e51a9e27ce887b70c45851bb02b3d275ac7c8ef2" alt=""
水平双球曲线公式
local r =a * math.cos(b * theta)*math.cos( theta)
data:image/s3,"s3://crabby-images/811c8/811c86f2df038f66f07993d14c5be4f2cc85251c" alt=""
反向双球曲线
local r =a * math.cos(b * theta)*math.sin( theta)
data:image/s3,"s3://crabby-images/fd94c/fd94c774f0eea60cc9de8d1dfe05baa97d110e16" alt=""
data:image/s3,"s3://crabby-images/9f137/9f13745ad3377a46906f1e364dd6bda68785133f" alt=""
data:image/s3,"s3://crabby-images/9a7e7/9a7e7d87153d0c2ddebcf9bf137057d13c2fd931" alt=""
data:image/s3,"s3://crabby-images/e36fd/e36fd9522347f10808799d7a601a8597ad08b4db" alt=""
data:image/s3,"s3://crabby-images/b85df/b85df4e02c793f508f50a1451cb4ccbf5d9a4e1e" alt=""
data:image/s3,"s3://crabby-images/30d2e/30d2e75c0884f8304785f6514b7caca7db850b0c" alt=""
data:image/s3,"s3://crabby-images/e7583/e758373f1d204bd45a8c39972e795e7837cefd0d" alt=""
data:image/s3,"s3://crabby-images/b8cb4/b8cb4ee891aeb7cef813ea2c2055e447756caeb4" alt=""
data:image/s3,"s3://crabby-images/3ee00/3ee00ecdde0db08d5011776de186f530b6ee7d0b" alt=""
data:image/s3,"s3://crabby-images/dce0c/dce0c076d1f1e1d9c4faa862155669661570a5d4" alt=""
data:image/s3,"s3://crabby-images/d3073/d307380b77f3616df751119c73766af051feda3c" alt=""
data:image/s3,"s3://crabby-images/6cca8/6cca82a357099dec4b77cad6689875391f66b266" alt=""
data:image/s3,"s3://crabby-images/ad1af/ad1af7c5c176d42e8cccb00592ab1e7978ac317f" alt=""
data:image/s3,"s3://crabby-images/3bc37/3bc3750bb69f813ab5c70a71550ff6feb85ae645" alt=""
data:image/s3,"s3://crabby-images/d0617/d0617b8791bbb70a37adf6b72b4fde969efb749c" alt=""
data:image/s3,"s3://crabby-images/4d902/4d9025105714d27eb835522500741a8d44558c54" alt=""
data:image/s3,"s3://crabby-images/56062/560620e7bd05325b150bd8409b0cac74bd10efa2" alt=""
data:image/s3,"s3://crabby-images/249d8/249d8b2b3a79c6e2f02105c758c3a12be11a023c" alt=""
data:image/s3,"s3://crabby-images/c29e4/c29e458a5cbb2c5e456750e1669059ec83612251" alt=""