Compare commits
116 Commits
v0.17.0
...
test-new-m
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
707bcca368 | ||
|
|
f8f115de10 | ||
|
|
b07c4dc53a | ||
|
|
6eeddba773 | ||
|
|
0cfe4df468 | ||
|
|
eb5c3c3be5 | ||
|
|
a5b9206694 | ||
|
|
375e67bdc4 | ||
|
|
724a576aa3 | ||
|
|
ed47dcb90c | ||
|
|
64b08a5a4d | ||
|
|
baed0153a2 | ||
|
|
46d95b33e4 | ||
|
|
200d270fee | ||
|
|
a8628275a0 | ||
|
|
20a1d2bcc1 | ||
|
|
b887a1f096 | ||
|
|
9bf0e9f28d | ||
|
|
dfc724767b | ||
|
|
f0e66e9dc5 | ||
|
|
0932335f0b | ||
|
|
a9b39e396a | ||
|
|
2e0ceaae72 | ||
|
|
04f38d2eb6 | ||
|
|
fc1ed4dff6 | ||
|
|
f8935d3dd7 | ||
|
|
a86228677f | ||
|
|
79df9f7876 | ||
|
|
12ea2d76be | ||
|
|
485bd72241 | ||
|
|
7240275075 | ||
|
|
29ef9b8d15 | ||
|
|
97f4795d4e | ||
|
|
226e45b24d | ||
|
|
d6ab7e72b2 | ||
|
|
168f44b8b3 | ||
|
|
b73f646a4c | ||
|
|
36cefcc000 | ||
|
|
f901c25c87 | ||
|
|
6d8478b029 | ||
|
|
9bcb040019 | ||
|
|
d977087fc0 | ||
|
|
1a330771d7 | ||
|
|
9c8c9f2106 | ||
|
|
0498beecdf | ||
|
|
8e075adf8f | ||
|
|
60f2a0e647 | ||
|
|
b642f2b5c4 | ||
|
|
2b80f72c6b | ||
|
|
462720881a | ||
|
|
3dda0254a8 | ||
|
|
054a52a445 | ||
|
|
85242d808b | ||
|
|
57241677a9 | ||
|
|
6ccdee2a53 | ||
|
|
a3d2b7b7f3 | ||
|
|
b7b28b4ae3 | ||
|
|
30748200dd | ||
|
|
c9f8240234 | ||
|
|
5c7082e886 | ||
|
|
9a3c889a9d | ||
|
|
f41f58e13f | ||
|
|
e81f25c216 | ||
|
|
36fc681fbf | ||
|
|
87e5e29129 | ||
|
|
b432fdf90a | ||
|
|
6e78a3fedd | ||
|
|
24760801af | ||
|
|
f5e8e0f7a5 | ||
|
|
df089a2f04 | ||
|
|
6600713f4b | ||
|
|
96dad762b2 | ||
|
|
5470387685 | ||
|
|
fa64c868b9 | ||
|
|
2f4a416353 | ||
|
|
3dbafb042c | ||
|
|
97e7b019dd | ||
|
|
28103ad952 | ||
|
|
1826ca6f2f | ||
|
|
db490a6c6c | ||
|
|
421fdef4f9 | ||
|
|
d717ce842d | ||
|
|
f13c9792af | ||
|
|
41e7b8e0f4 | ||
|
|
4bd723a7ee | ||
|
|
66d5bd5490 | ||
|
|
351d0258b2 | ||
|
|
26fb9a7052 | ||
|
|
307fd637fa | ||
|
|
93fb716f89 | ||
|
|
7b41551e2d | ||
|
|
4806af5f7d | ||
|
|
85cb55cdd0 | ||
|
|
27a9697e47 | ||
|
|
7d230cc3b0 | ||
|
|
0db2fffad1 | ||
|
|
2a3296a0e8 | ||
|
|
941b875afa | ||
|
|
99155bb9cf | ||
|
|
0701dd2ad3 | ||
|
|
5570c19e1f | ||
|
|
a728c91476 | ||
|
|
6a43481067 | ||
|
|
29a049fe4e | ||
|
|
b5a9c8e1bb | ||
|
|
bb9a35c161 | ||
|
|
b25a345b42 | ||
|
|
b22b0e0194 | ||
|
|
55cf95f218 | ||
|
|
225ddbcfac | ||
|
|
9377090c7c | ||
|
|
ed002ec2e1 | ||
|
|
e33036d9ec | ||
|
|
ef03e7c009 | ||
|
|
aef4220ac0 | ||
|
|
46223e38cd |
BIN
.github/build/macOS/backgroundImage.tiff
vendored
@@ -1,44 +1,37 @@
|
|||||||
local lastLoaded={}
|
local lastLoaded={}
|
||||||
local maxLoadedCount=3
|
local maxLoadedCount=3
|
||||||
|
local nameList={}
|
||||||
local SourceObjList={}
|
local SourceObjList={}
|
||||||
local volume=1
|
local volume=1
|
||||||
|
|
||||||
local BGM={
|
local BGM={
|
||||||
default=false,
|
default=false,
|
||||||
getList=function()error("Cannot getList before initialize!")end,
|
|
||||||
getCount=function()return 0 end,
|
|
||||||
play=NULL,
|
|
||||||
stop=NULL,
|
|
||||||
onChange=NULL,
|
onChange=NULL,
|
||||||
--nowPlay=[str:playing ID]
|
--nowPlay=[str:playing ID]
|
||||||
--playing=[src:playing SRC]
|
--playing=[src:playing SRC]
|
||||||
--lastPlayed=[str:lastPlayed ID]
|
--lastPlayed=[str:lastPlayed ID]
|
||||||
}
|
}
|
||||||
local function task_fadeOut(src)
|
|
||||||
while true do
|
function BGM.getList()return nameList end
|
||||||
coroutine.yield()
|
function BGM.getCount()return #nameList end
|
||||||
local v=src:getVolume()-.025*volume
|
local function _addFile(name,path)
|
||||||
src:setVolume(v>0 and v or 0)
|
if not SourceObjList[name]then
|
||||||
if v<=0 then
|
table.insert(nameList,name)
|
||||||
src:pause()
|
SourceObjList[name]={path=path,source=false}
|
||||||
return true
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
local function task_fadeIn(src)
|
function BGM.load(name,path)
|
||||||
while true do
|
if type(name)=='table'then
|
||||||
coroutine.yield()
|
for k,v in next,name do
|
||||||
local v=volume
|
_addFile(k,v)
|
||||||
v=math.min(v,src:getVolume()+.025*v)
|
|
||||||
src:setVolume(v)
|
|
||||||
if v>=volume then
|
|
||||||
return true
|
|
||||||
end
|
end
|
||||||
|
else
|
||||||
|
_addFile(name,path)
|
||||||
end
|
end
|
||||||
|
table.sort(nameList)
|
||||||
|
LOG(BGM.getCount().." BGM files added")
|
||||||
end
|
end
|
||||||
local function check_curFadeOut(task,code,src)
|
|
||||||
return task.code==code and task.args[1]==src
|
|
||||||
end
|
|
||||||
local function _tryReleaseSources()
|
local function _tryReleaseSources()
|
||||||
local n=#lastLoaded
|
local n=#lastLoaded
|
||||||
while #lastLoaded>maxLoadedCount do
|
while #lastLoaded>maxLoadedCount do
|
||||||
@@ -75,85 +68,115 @@ function BGM.setVol(v)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function BGM.init(list)
|
|
||||||
BGM.init=nil
|
|
||||||
|
|
||||||
local simpList={}
|
local function task_fadeOut(src)
|
||||||
for _,v in next,list do
|
while true do
|
||||||
table.insert(simpList,v.name)
|
coroutine.yield()
|
||||||
SourceObjList[v.name]={path=v.path,source=false}
|
local v=src:getVolume()-.025*volume
|
||||||
end
|
src:setVolume(v>0 and v or 0)
|
||||||
table.sort(simpList)
|
if v<=0 then
|
||||||
function BGM.getList()return simpList end
|
src:pause()
|
||||||
local count=#simpList
|
return true
|
||||||
LOG(count.." BGM files added")
|
|
||||||
function BGM.getCount()return count end
|
|
||||||
|
|
||||||
local function _tryLoad(name)
|
|
||||||
if SourceObjList[name]then
|
|
||||||
if SourceObjList[name].source then
|
|
||||||
return true
|
|
||||||
elseif love.filesystem.getInfo(SourceObjList[name].path)then
|
|
||||||
SourceObjList[name].source=love.audio.newSource(SourceObjList[name].path,'stream')
|
|
||||||
SourceObjList[name].source:setLooping(true)
|
|
||||||
SourceObjList[name].source:setVolume(0)
|
|
||||||
table.insert(lastLoaded,1,name)
|
|
||||||
_tryReleaseSources()
|
|
||||||
return true
|
|
||||||
else
|
|
||||||
LOG("No BGM: "..SourceObjList[name],5)
|
|
||||||
end
|
|
||||||
elseif name then
|
|
||||||
LOG("No BGM: "..name,5)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function BGM.play(name)
|
end
|
||||||
name=name or BGM.default
|
local function task_fadeIn(src)
|
||||||
if not _tryLoad(name)then return end
|
while true do
|
||||||
if volume==0 then
|
coroutine.yield()
|
||||||
|
local v=volume
|
||||||
|
v=math.min(v,src:getVolume()+.025*v)
|
||||||
|
src:setVolume(v)
|
||||||
|
if v>=volume then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local function check_curFadeOut(task,code,src)
|
||||||
|
return task.code==code and task.args[1]==src
|
||||||
|
end
|
||||||
|
local function _tryLoad(name)
|
||||||
|
if SourceObjList[name]then
|
||||||
|
if SourceObjList[name].source then
|
||||||
|
return true
|
||||||
|
elseif love.filesystem.getInfo(SourceObjList[name].path)then
|
||||||
|
SourceObjList[name].source=love.audio.newSource(SourceObjList[name].path,'stream')
|
||||||
|
SourceObjList[name].source:setVolume(0)
|
||||||
|
table.insert(lastLoaded,1,name)
|
||||||
|
_tryReleaseSources()
|
||||||
|
return true
|
||||||
|
else
|
||||||
|
LOG("No BGM: "..SourceObjList[name],5)
|
||||||
|
end
|
||||||
|
elseif name then
|
||||||
|
LOG("No BGM: "..name,5)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function BGM.play(name,args)
|
||||||
|
name=name or BGM.default
|
||||||
|
args=args or""
|
||||||
|
if not _tryLoad(name)or args:sArg('-preLoad')then return end
|
||||||
|
if volume==0 then
|
||||||
|
BGM.nowPlay=name
|
||||||
|
BGM.playing=SourceObjList[name].source
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
if name and SourceObjList[name].source then
|
||||||
|
if BGM.nowPlay~=name then
|
||||||
|
if BGM.nowPlay then
|
||||||
|
if not args:sArg('-sdout')then
|
||||||
|
TASK.new(task_fadeOut,BGM.playing)
|
||||||
|
else
|
||||||
|
BGM.playing:pause()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
TASK.removeTask_iterate(check_curFadeOut,task_fadeOut,SourceObjList[name].source)
|
||||||
|
TASK.removeTask_code(task_fadeIn)
|
||||||
|
|
||||||
BGM.nowPlay=name
|
BGM.nowPlay=name
|
||||||
BGM.playing=SourceObjList[name].source
|
BGM.playing=SourceObjList[name].source
|
||||||
return true
|
if not args:sArg('-sdin')then
|
||||||
end
|
BGM.playing:setVolume(0)
|
||||||
if name and SourceObjList[name].source then
|
TASK.new(task_fadeIn,BGM.playing)
|
||||||
if BGM.nowPlay~=name then
|
else
|
||||||
if BGM.nowPlay then
|
BGM.playing:setVolume(volume)
|
||||||
TASK.new(task_fadeOut,BGM.playing)
|
|
||||||
end
|
|
||||||
TASK.removeTask_iterate(check_curFadeOut,task_fadeOut,SourceObjList[name].source)
|
|
||||||
TASK.removeTask_code(task_fadeIn)
|
|
||||||
|
|
||||||
TASK.new(task_fadeIn,SourceObjList[name].source)
|
|
||||||
BGM.nowPlay=name
|
|
||||||
BGM.playing=SourceObjList[name].source
|
|
||||||
BGM.lastPlayed=BGM.nowPlay
|
|
||||||
BGM.playing:seek(0)
|
|
||||||
BGM.playing:play()
|
BGM.playing:play()
|
||||||
BGM.onChange(name)
|
|
||||||
end
|
end
|
||||||
return true
|
SourceObjList[name].source:setLooping(not args:sArg('-noloop'))
|
||||||
end
|
BGM.lastPlayed=BGM.nowPlay
|
||||||
end
|
BGM.playing:seek(0)
|
||||||
function BGM.seek(t)
|
|
||||||
if BGM.playing then
|
|
||||||
BGM.playing:seek(t)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
function BGM.continue()
|
|
||||||
if BGM.lastPlayed then
|
|
||||||
BGM.nowPlay,BGM.playing=BGM.lastPlayed,SourceObjList[BGM.lastPlayed].source
|
|
||||||
TASK.removeTask_iterate(check_curFadeOut,task_fadeOut,SourceObjList[BGM.nowPlay].source)
|
|
||||||
TASK.removeTask_code(task_fadeIn)
|
|
||||||
TASK.new(task_fadeIn,BGM.playing)
|
|
||||||
BGM.playing:play()
|
BGM.playing:play()
|
||||||
|
BGM.onChange(name)
|
||||||
end
|
end
|
||||||
|
return true
|
||||||
end
|
end
|
||||||
function BGM.stop()
|
end
|
||||||
|
function BGM.seek(t)
|
||||||
|
if BGM.playing then
|
||||||
|
BGM.playing:seek(t)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function BGM.isPlaying()
|
||||||
|
return BGM.playing and BGM.playing:isPlaying()
|
||||||
|
end
|
||||||
|
function BGM.continue()
|
||||||
|
if BGM.lastPlayed then
|
||||||
|
BGM.nowPlay,BGM.playing=BGM.lastPlayed,SourceObjList[BGM.lastPlayed].source
|
||||||
|
TASK.removeTask_iterate(check_curFadeOut,task_fadeOut,SourceObjList[BGM.nowPlay].source)
|
||||||
TASK.removeTask_code(task_fadeIn)
|
TASK.removeTask_code(task_fadeIn)
|
||||||
|
TASK.new(task_fadeIn,BGM.playing)
|
||||||
|
BGM.playing:play()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function BGM.stop(args)
|
||||||
|
args=args or""
|
||||||
|
TASK.removeTask_code(task_fadeIn)
|
||||||
|
if not args:sArg('-s')then
|
||||||
if BGM.nowPlay then
|
if BGM.nowPlay then
|
||||||
TASK.new(task_fadeOut,BGM.playing)
|
TASK.new(task_fadeOut,BGM.playing)
|
||||||
end
|
end
|
||||||
BGM.nowPlay,BGM.playing=nil
|
elseif BGM.playing then
|
||||||
|
BGM.playing:pause()
|
||||||
end
|
end
|
||||||
|
BGM.nowPlay,BGM.playing=nil
|
||||||
end
|
end
|
||||||
return BGM
|
return BGM
|
||||||
|
|||||||
@@ -19,11 +19,11 @@ local COLOR={
|
|||||||
red= {hsv(0.00, 0.89, 0.91)},
|
red= {hsv(0.00, 0.89, 0.91)},
|
||||||
fire= {hsv(0.04, 0.93, 0.94)},
|
fire= {hsv(0.04, 0.93, 0.94)},
|
||||||
orange= {hsv(0.09, 0.99, 0.96)},
|
orange= {hsv(0.09, 0.99, 0.96)},
|
||||||
yellow= {hsv(0.16, 0.82, 0.90)},
|
yellow= {hsv(0.15, 0.82, 0.90)},
|
||||||
lime= {hsv(0.18, 0.89, 0.88)},
|
lime= {hsv(0.20, 0.89, 0.88)},
|
||||||
jade= {hsv(0.23, 1.00, 0.82)},
|
jade= {hsv(0.25, 1.00, 0.82)},
|
||||||
green= {hsv(0.33, 1.00, 0.81)},
|
green= {hsv(0.33, 1.00, 0.81)},
|
||||||
aqua= {hsv(0.48, 1.00, 0.74)},
|
aqua= {hsv(0.47, 1.00, 0.76)},
|
||||||
cyan= {hsv(0.53, 1.00, 0.88)},
|
cyan= {hsv(0.53, 1.00, 0.88)},
|
||||||
navy= {hsv(0.56, 1.00, 1.00)},
|
navy= {hsv(0.56, 1.00, 1.00)},
|
||||||
sea= {hsv(0.61, 1.00, 1.00)},
|
sea= {hsv(0.61, 1.00, 1.00)},
|
||||||
@@ -36,14 +36,14 @@ local COLOR={
|
|||||||
lRed= {hsv(0.00, 0.38, 0.93)},
|
lRed= {hsv(0.00, 0.38, 0.93)},
|
||||||
lFire= {hsv(0.04, 0.45, 0.91)},
|
lFire= {hsv(0.04, 0.45, 0.91)},
|
||||||
lOrange= {hsv(0.10, 0.53, 0.92)},
|
lOrange= {hsv(0.10, 0.53, 0.92)},
|
||||||
lYellow= {hsv(0.15, 0.61, 0.95)},
|
lYellow= {hsv(0.14, 0.61, 0.95)},
|
||||||
lLime= {hsv(0.19, 0.66, 0.92)},
|
lLime= {hsv(0.20, 0.66, 0.92)},
|
||||||
lJade= {hsv(0.24, 0.56, 0.90)},
|
lJade= {hsv(0.26, 0.56, 0.90)},
|
||||||
lGreen= {hsv(0.34, 0.49, 0.89)},
|
lGreen= {hsv(0.34, 0.49, 0.89)},
|
||||||
lAqua= {hsv(0.49, 0.59, 0.85)},
|
lAqua= {hsv(0.47, 0.59, 0.86)},
|
||||||
lCyan= {hsv(0.51, 0.77, 0.88)},
|
lCyan= {hsv(0.51, 0.77, 0.88)},
|
||||||
lNavy= {hsv(0.54, 0.80, 0.95)},
|
lNavy= {hsv(0.54, 0.80, 0.95)},
|
||||||
lSea= {hsv(0.56, 0.72, 0.97)},
|
lSea= {hsv(0.57, 0.72, 0.97)},
|
||||||
lBlue= {hsv(0.64, 0.44, 0.96)},
|
lBlue= {hsv(0.64, 0.44, 0.96)},
|
||||||
lViolet= {hsv(0.72, 0.47, 0.95)},
|
lViolet= {hsv(0.72, 0.47, 0.95)},
|
||||||
lPurple= {hsv(0.80, 0.62, 0.89)},
|
lPurple= {hsv(0.80, 0.62, 0.89)},
|
||||||
@@ -53,13 +53,13 @@ local COLOR={
|
|||||||
dRed= {hsv(0.00, 0.80, 0.48)},
|
dRed= {hsv(0.00, 0.80, 0.48)},
|
||||||
dFire= {hsv(0.04, 0.80, 0.34)},
|
dFire= {hsv(0.04, 0.80, 0.34)},
|
||||||
dOrange= {hsv(0.07, 0.80, 0.39)},
|
dOrange= {hsv(0.07, 0.80, 0.39)},
|
||||||
dYellow= {hsv(0.11, 0.80, 0.37)},
|
dYellow= {hsv(0.12, 0.80, 0.37)},
|
||||||
dLime= {hsv(0.17, 0.80, 0.26)},
|
dLime= {hsv(0.20, 0.80, 0.26)},
|
||||||
dJade= {hsv(0.31, 0.80, 0.27)},
|
dJade= {hsv(0.29, 0.80, 0.27)},
|
||||||
dGreen= {hsv(0.33, 0.80, 0.26)},
|
dGreen= {hsv(0.33, 0.80, 0.26)},
|
||||||
dAqua= {hsv(0.47, 0.80, 0.23)},
|
dAqua= {hsv(0.46, 0.80, 0.24)},
|
||||||
dCyan= {hsv(0.50, 0.80, 0.30)},
|
dCyan= {hsv(0.50, 0.80, 0.30)},
|
||||||
dNavy= {hsv(0.59, 0.80, 0.42)},
|
dNavy= {hsv(0.58, 0.80, 0.42)},
|
||||||
dSea= {hsv(0.64, 0.80, 0.40)},
|
dSea= {hsv(0.64, 0.80, 0.40)},
|
||||||
dBlue= {hsv(0.67, 0.80, 0.34)},
|
dBlue= {hsv(0.67, 0.80, 0.34)},
|
||||||
dViolet= {hsv(0.71, 0.80, 0.35)},
|
dViolet= {hsv(0.71, 0.80, 0.35)},
|
||||||
|
|||||||
@@ -6,22 +6,38 @@ function FILE.load(name,args)
|
|||||||
local F=fs.newFile(name)
|
local F=fs.newFile(name)
|
||||||
assert(F:open'r','open error')
|
assert(F:open'r','open error')
|
||||||
local s=F:read()F:close()
|
local s=F:read()F:close()
|
||||||
if args:sArg'-luaon'or args==''and s:sub(1,6)=='return{'then
|
local mode=
|
||||||
local func=loadstring(s)
|
STRING.sArg(args,'-luaon')and'luaon'or
|
||||||
|
STRING.sArg(args,'-lua')and'lua'or
|
||||||
|
STRING.sArg(args,'-json')and'json'or
|
||||||
|
STRING.sArg(args,'-string')and'string'or
|
||||||
|
s:sub(1,6)=='return{'and'luaon'or
|
||||||
|
(s:sub(1,1)=='['and s:sub(-1)==']'or s:sub(1,1)=='{'and s:sub(-1)=='}')and'json'or
|
||||||
|
'string'
|
||||||
|
if mode=='luaon'then
|
||||||
|
local func,err_mes=loadstring(s)
|
||||||
if func then
|
if func then
|
||||||
setfenv(func,{})
|
setfenv(func,{})
|
||||||
local res=func()
|
local res=func()
|
||||||
return assert(res,'decode error')
|
return assert(res,'decode error')
|
||||||
else
|
else
|
||||||
error('decode error')
|
error('decode error: '..err_mes)
|
||||||
end
|
end
|
||||||
elseif args:sArg'-json'or args==''and s:sub(1,1)=='['and s:sub(-1)==']'or s:sub(1,1)=='{'and s:sub(-1)=='}'then
|
elseif mode=='lua'then
|
||||||
|
local func,err_mes=loadstring(s)
|
||||||
|
if func then
|
||||||
|
local res=func()
|
||||||
|
return assert(res,'run error')
|
||||||
|
else
|
||||||
|
error('compile error: '..err_mes)
|
||||||
|
end
|
||||||
|
elseif mode=='json'then
|
||||||
local res=JSON.decode(s)
|
local res=JSON.decode(s)
|
||||||
if res then
|
if res then
|
||||||
return res
|
return res
|
||||||
end
|
end
|
||||||
error('decode error')
|
error('decode error')
|
||||||
elseif args:sArg'-string'or args==''then
|
elseif mode=='string'then
|
||||||
return s
|
return s
|
||||||
else
|
else
|
||||||
error('unknown mode')
|
error('unknown mode')
|
||||||
@@ -32,12 +48,12 @@ function FILE.load(name,args)
|
|||||||
end
|
end
|
||||||
function FILE.save(data,name,args)
|
function FILE.save(data,name,args)
|
||||||
if not args then args=''end
|
if not args then args=''end
|
||||||
if args:sArg'-d'and fs.getInfo(name)then
|
if STRING.sArg(args,'-d')and fs.getInfo(name)then
|
||||||
error('duplicate')
|
error('duplicate')
|
||||||
end
|
end
|
||||||
|
|
||||||
if type(data)=='table'then
|
if type(data)=='table'then
|
||||||
if args:sArg'-luaon'then
|
if STRING.sArg(args,'-luaon')then
|
||||||
data=TABLE.dump(data)
|
data=TABLE.dump(data)
|
||||||
if not data then
|
if not data then
|
||||||
error('encode error')
|
error('encode error')
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ function FONT.rawset(s)
|
|||||||
end
|
end
|
||||||
function FONT.load(fonts)
|
function FONT.load(fonts)
|
||||||
for name,path in next,fonts do
|
for name,path in next,fonts do
|
||||||
assert(love.filesystem.getInfo(path),("Font file $1($2) not exist!"):repD(name,path))
|
assert(love.filesystem.getInfo(path),STRING.repD("Font file $1($2) not exist!",name,path))
|
||||||
fontFiles[name]=love.filesystem.newFile(path)
|
fontFiles[name]=love.filesystem.newFile(path)
|
||||||
fontCache[name]={}
|
fontCache[name]={}
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ local IMG={}
|
|||||||
function IMG.init(list)
|
function IMG.init(list)
|
||||||
IMG.init=nil
|
IMG.init=nil
|
||||||
|
|
||||||
local null=love.graphics.newCanvas(1,1)
|
|
||||||
setmetatable(IMG,{__index=function(self,name)
|
setmetatable(IMG,{__index=function(self,name)
|
||||||
if type(list[name])=='table'then
|
if type(list[name])=='table'then
|
||||||
self[name]={}
|
self[name]={}
|
||||||
@@ -13,7 +12,7 @@ function IMG.init(list)
|
|||||||
self[name]=love.graphics.newImage(list[name])
|
self[name]=love.graphics.newImage(list[name])
|
||||||
else
|
else
|
||||||
LOG("No IMG: "..name)
|
LOG("No IMG: "..name)
|
||||||
self[name]=null
|
self[name]=PAPER
|
||||||
end
|
end
|
||||||
return self[name]
|
return self[name]
|
||||||
end})
|
end})
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
NONE={}function NULL()end
|
NONE={}function NULL()end PAPER=love.graphics.newCanvas(1,1)
|
||||||
EDITING=""
|
EDITING=""
|
||||||
LOADED=false
|
LOADED=false
|
||||||
|
|
||||||
@@ -70,15 +70,26 @@ local gc_draw,gc_line,gc_circle,gc_print=gc.draw,gc.line,gc.circle,gc.print
|
|||||||
|
|
||||||
local WIDGET,SCR,SCN=WIDGET,SCR,SCN
|
local WIDGET,SCR,SCN=WIDGET,SCR,SCN
|
||||||
local xOy=SCR.xOy
|
local xOy=SCR.xOy
|
||||||
|
|
||||||
local ITP=xOy.inverseTransformPoint
|
local ITP=xOy.inverseTransformPoint
|
||||||
|
|
||||||
local max,min=math.max,math.min
|
local max,min=math.max,math.min
|
||||||
|
|
||||||
|
local devMode
|
||||||
local mx,my,mouseShow,cursorSpd=640,360,false,0
|
local mx,my,mouseShow,cursorSpd=640,360,false,0
|
||||||
local jsState={}--map, joystickID->axisStates: {axisName->axisVal}
|
local jsState={}--map, joystickID->axisStates: {axisName->axisVal}
|
||||||
local errData={}--list, each error create {mes={errMes strings},scene=sceneNameStr}
|
local errData={}--list, each error create {mes={errMes strings},scene=sceneNameStr}
|
||||||
|
|
||||||
local devMode
|
local function drawCursor(_,x,y)
|
||||||
|
gc_setColor(1,1,1)
|
||||||
|
gc_setLineWidth(2)
|
||||||
|
gc_circle(ms.isDown(1)and'fill'or'line',x,y,6)
|
||||||
|
end
|
||||||
|
local showPowerInfo=true
|
||||||
|
local showClickFX=true
|
||||||
|
local discardCanvas=false
|
||||||
|
local frameMul=100
|
||||||
|
local sleepInterval=1/60
|
||||||
|
local onQuit=NULL
|
||||||
|
|
||||||
local batteryImg=GC.DO{31,20,
|
local batteryImg=GC.DO{31,20,
|
||||||
{'fRect',1,0,26,2},
|
{'fRect',1,0,26,2},
|
||||||
@@ -96,17 +107,16 @@ local function updatePowerInfo()
|
|||||||
gc_clear(0,0,0,.25)
|
gc_clear(0,0,0,.25)
|
||||||
if state~='unknown'then
|
if state~='unknown'then
|
||||||
gc_setLineWidth(4)
|
gc_setLineWidth(4)
|
||||||
local charging=state=='charging'
|
|
||||||
if state=='nobattery'then
|
if state=='nobattery'then
|
||||||
gc_setColor(1,1,1)
|
gc_setColor(1,1,1)
|
||||||
gc_setLineWidth(2)
|
gc_setLineWidth(2)
|
||||||
gc_line(74,SCR.safeX+5,100,22)
|
gc_line(74,5,100,22)
|
||||||
elseif pow then
|
elseif pow then
|
||||||
if charging then gc_setColor(0,1,0)
|
if state=='charging'then gc_setColor(0,1,0)
|
||||||
elseif pow>50 then gc_setColor(1,1,1)
|
elseif pow>50 then gc_setColor(1,1,1)
|
||||||
elseif pow>26 then gc_setColor(1,1,0)
|
elseif pow>26 then gc_setColor(1,1,0)
|
||||||
elseif pow==26 then gc_setColor(.5,0,1)
|
elseif pow==26 then gc_setColor(.5,0,1)
|
||||||
else gc_setColor(1,0,0)
|
else gc_setColor(1,0,0)
|
||||||
end
|
end
|
||||||
gc.rectangle('fill',76,6,pow*.22,14)
|
gc.rectangle('fill',76,6,pow*.22,14)
|
||||||
if pow<100 then
|
if pow<100 then
|
||||||
@@ -152,7 +162,7 @@ local function _triggerMouseDown(x,y,k)
|
|||||||
if SCN.mouseDown then SCN.mouseDown(x,y,k)end
|
if SCN.mouseDown then SCN.mouseDown(x,y,k)end
|
||||||
WIDGET.press(x,y,k)
|
WIDGET.press(x,y,k)
|
||||||
lastX,lastY=x,y
|
lastX,lastY=x,y
|
||||||
if SETTING.clickFX then SYSFX.newTap(3,x,y)end
|
if showClickFX then SYSFX.newTap(3,x,y)end
|
||||||
end
|
end
|
||||||
local function mouse_update(dt)
|
local function mouse_update(dt)
|
||||||
if not KBisDown('lctrl','rctrl')and KBisDown('up','down','left','right')then
|
if not KBisDown('lctrl','rctrl')and KBisDown('up','down','left','right')then
|
||||||
@@ -238,13 +248,13 @@ function love.touchpressed(id,x,y)
|
|||||||
x,y=ITP(xOy,x,y)
|
x,y=ITP(xOy,x,y)
|
||||||
lastX,lastY=x,y
|
lastX,lastY=x,y
|
||||||
WIDGET.cursorMove(x,y)
|
WIDGET.cursorMove(x,y)
|
||||||
if SCN.touchDown then SCN.touchDown(x,y)end
|
if SCN.touchDown then SCN.touchDown(x,y,id)end
|
||||||
if kb.hasTextInput()then kb.setTextInput(false)end
|
if kb.hasTextInput()then kb.setTextInput(false)end
|
||||||
end
|
end
|
||||||
function love.touchmoved(_,x,y,dx,dy)
|
function love.touchmoved(id,x,y,dx,dy)
|
||||||
if SCN.swapping then return end
|
if SCN.swapping then return end
|
||||||
x,y=ITP(xOy,x,y)
|
x,y=ITP(xOy,x,y)
|
||||||
if SCN.touchMove then SCN.touchMove(x,y,dx/SCR.k,dy/SCR.k)end
|
if SCN.touchMove then SCN.touchMove(x,y,dx/SCR.k,dy/SCR.k,id)end
|
||||||
WIDGET.drag(x,y,dx/SCR.k,dy/SCR.k)
|
WIDGET.drag(x,y,dx/SCR.k,dy/SCR.k)
|
||||||
end
|
end
|
||||||
function love.touchreleased(id,x,y)
|
function love.touchreleased(id,x,y)
|
||||||
@@ -257,10 +267,10 @@ function love.touchreleased(id,x,y)
|
|||||||
WIDGET.unFocus()
|
WIDGET.unFocus()
|
||||||
SCN.mainTouchID=false
|
SCN.mainTouchID=false
|
||||||
end
|
end
|
||||||
if SCN.touchUp then SCN.touchUp(x,y)end
|
if SCN.touchUp then SCN.touchUp(x,y,id)end
|
||||||
if(x-lastX)^2+(y-lastY)^2<62 then
|
if(x-lastX)^2+(y-lastY)^2<62 then
|
||||||
if SCN.touchClick then SCN.touchClick(x,y)end
|
if SCN.touchClick then SCN.touchClick(x,y)end
|
||||||
if SETTING.clickFX then SYSFX.newTap(3,x,y)end
|
if showClickFX then SYSFX.newTap(3,x,y)end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -309,7 +319,7 @@ function love.keypressed(key,_,isRep)
|
|||||||
MES.new('info',"DEBUG ON",.2)
|
MES.new('info',"DEBUG ON",.2)
|
||||||
elseif key=='f11'then
|
elseif key=='f11'then
|
||||||
SETTING.fullscreen=not SETTING.fullscreen
|
SETTING.fullscreen=not SETTING.fullscreen
|
||||||
applyFullscreen()
|
applySettings()
|
||||||
saveSettings()
|
saveSettings()
|
||||||
elseif not SCN.swapping then
|
elseif not SCN.swapping then
|
||||||
if EDITING==""and(not SCN.keyDown or SCN.keyDown(key,isRep))then
|
if EDITING==""and(not SCN.keyDown or SCN.keyDown(key,isRep))then
|
||||||
@@ -324,7 +334,7 @@ function love.keypressed(key,_,isRep)
|
|||||||
elseif key=='space'or key=='return'then
|
elseif key=='space'or key=='return'then
|
||||||
mouseShow=true
|
mouseShow=true
|
||||||
if not isRep then
|
if not isRep then
|
||||||
if SETTING.clickFX then SYSFX.newTap(3,mx,my)end
|
if showClickFX then SYSFX.newTap(3,mx,my)end
|
||||||
_triggerMouseDown(mx,my,1)
|
_triggerMouseDown(mx,my,1)
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
@@ -397,7 +407,7 @@ function love.joystickremoved(JS)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
function love.gamepadaxis(JS,axis,val)
|
function love.gamepadaxis(JS,axis,val)
|
||||||
if JS==jsState[1]._jsObj then
|
if jsState[1]and JS==jsState[1]._jsObj then
|
||||||
local js=jsState[1]
|
local js=jsState[1]
|
||||||
if axis=='leftx'or axis=='lefty'or axis=='rightx'or axis=='righty'then
|
if axis=='leftx'or axis=='lefty'or axis=='rightx'or axis=='righty'then
|
||||||
local newVal=--range: [0,1]
|
local newVal=--range: [0,1]
|
||||||
@@ -452,7 +462,7 @@ function love.gamepadpressed(_,key)
|
|||||||
if W and W.arrowKey then W:arrowKey(key)end
|
if W and W.arrowKey then W:arrowKey(key)end
|
||||||
elseif key=='return'then
|
elseif key=='return'then
|
||||||
mouseShow=true
|
mouseShow=true
|
||||||
if SETTING.clickFX then SYSFX.newTap(3,mx,my)end
|
if showClickFX then SYSFX.newTap(3,mx,my)end
|
||||||
_triggerMouseDown(mx,my,1)
|
_triggerMouseDown(mx,my,1)
|
||||||
else
|
else
|
||||||
if W and W.keypress then
|
if W and W.keypress then
|
||||||
@@ -481,14 +491,16 @@ function love.lowmemory()
|
|||||||
MES.new('check',"[auto GC] low MEM 设备内存过低")
|
MES.new('check',"[auto GC] low MEM 设备内存过低")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local onResize=NULL
|
||||||
function love.resize(w,h)
|
function love.resize(w,h)
|
||||||
|
if SCR.w==w and SCR.h==h then return end
|
||||||
SCR.resize(w,h)
|
SCR.resize(w,h)
|
||||||
if BG.resize then BG.resize(w,h)end
|
if BG.resize then BG.resize(w,h)end
|
||||||
if SCN.resize then SCN.resize(w,h)end
|
if SCN.resize then SCN.resize(w,h)end
|
||||||
WIDGET.resize(w,h)
|
WIDGET.resize(w,h)
|
||||||
FONT.reset()
|
FONT.reset()
|
||||||
|
onResize(w,h)
|
||||||
SHADER.warning:send('w',w*SCR.dpi)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local onFocus=NULL
|
local onFocus=NULL
|
||||||
@@ -627,14 +639,6 @@ local wsImg={}do
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
local function drawCursor(_,x,y)
|
|
||||||
gc_setColor(1,1,1)
|
|
||||||
gc_setLineWidth(2)
|
|
||||||
gc_circle(ms.isDown(1)and'fill'or'line',x,y,6)
|
|
||||||
end
|
|
||||||
local function showPowerInfo()return true end
|
|
||||||
local onQuit=NULL
|
|
||||||
|
|
||||||
function love.run()
|
function love.run()
|
||||||
local love=love
|
local love=love
|
||||||
|
|
||||||
@@ -649,7 +653,7 @@ function love.run()
|
|||||||
local FPS,MINI=love.timer.getFPS,love.window.isMinimized
|
local FPS,MINI=love.timer.getFPS,love.window.isMinimized
|
||||||
local PUMP,POLL=love.event.pump,love.event.poll
|
local PUMP,POLL=love.event.pump,love.event.poll
|
||||||
|
|
||||||
local timer,SETTING,VERSION=love.timer.getTime,SETTING,VERSION
|
local timer,VERSION=love.timer.getTime,VERSION
|
||||||
|
|
||||||
local frameTimeList={}
|
local frameTimeList={}
|
||||||
local lastFrame=timer()
|
local lastFrame=timer()
|
||||||
@@ -698,11 +702,10 @@ function love.run()
|
|||||||
|
|
||||||
--DRAW
|
--DRAW
|
||||||
if not MINI()then
|
if not MINI()then
|
||||||
FCT=FCT+SETTING.frameMul
|
FCT=FCT+frameMul
|
||||||
if FCT>=100 then
|
if FCT>=100 then
|
||||||
FCT=FCT-100
|
FCT=FCT-100
|
||||||
|
|
||||||
local safeX=SCR.safeX
|
|
||||||
gc_replaceTransform(SCR.origin)
|
gc_replaceTransform(SCR.origin)
|
||||||
gc_setColor(1,1,1)
|
gc_setColor(1,1,1)
|
||||||
BG.draw()
|
BG.draw()
|
||||||
@@ -713,16 +716,14 @@ function love.run()
|
|||||||
TEXT_draw()
|
TEXT_draw()
|
||||||
|
|
||||||
--Draw cursor
|
--Draw cursor
|
||||||
if mouseShow then
|
if mouseShow then drawCursor(time,mx,my)end
|
||||||
drawCursor(time,mx,my)
|
|
||||||
end
|
|
||||||
gc_replaceTransform(SCR.xOy_ul)
|
|
||||||
MES_draw()
|
|
||||||
gc_replaceTransform(SCR.origin)
|
gc_replaceTransform(SCR.origin)
|
||||||
|
MES_draw()
|
||||||
|
|
||||||
--Draw power info.
|
--Draw power info.
|
||||||
if showPowerInfo()then
|
if showPowerInfo then
|
||||||
gc_setColor(1,1,1)
|
gc_setColor(1,1,1)
|
||||||
gc_draw(infoCanvas,safeX,0,0,SCR.k)
|
gc_draw(infoCanvas,SCR.safeX,0,0,SCR.k)
|
||||||
end
|
end
|
||||||
|
|
||||||
--Draw scene swapping animation
|
--Draw scene swapping animation
|
||||||
@@ -737,6 +738,8 @@ function love.run()
|
|||||||
FONT.set(20)
|
FONT.set(20)
|
||||||
mStr(VERSION.string,0,-30)
|
mStr(VERSION.string,0,-30)
|
||||||
gc_replaceTransform(SCR.xOy_dl)
|
gc_replaceTransform(SCR.xOy_dl)
|
||||||
|
local safeX=SCR.safeX/SCR.k
|
||||||
|
|
||||||
--Draw FPS
|
--Draw FPS
|
||||||
FONT.set(15)
|
FONT.set(15)
|
||||||
gc_setColor(1,1,1)
|
gc_setColor(1,1,1)
|
||||||
@@ -794,13 +797,13 @@ function love.run()
|
|||||||
gc_present()
|
gc_present()
|
||||||
|
|
||||||
--SPEED UPUPUP!
|
--SPEED UPUPUP!
|
||||||
if SETTING.cleanCanvas then gc_discard()end
|
if discardCanvas then gc_discard()end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
--Fresh power info.
|
--Fresh power info.
|
||||||
if time-lastFreshPow>2.6 then
|
if time-lastFreshPow>2.6 then
|
||||||
if showPowerInfo()then
|
if showPowerInfo then
|
||||||
updatePowerInfo()
|
updatePowerInfo()
|
||||||
lastFreshPow=time
|
lastFreshPow=time
|
||||||
end
|
end
|
||||||
@@ -818,31 +821,44 @@ function love.run()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
--Keep 60fps
|
|
||||||
_=timer()-lastFrame
|
_=timer()-lastFrame
|
||||||
if _<.0162 then WAIT(.0162-_)end
|
if _<sleepInterval*.9626 then WAIT(sleepInterval*.9626-_)end
|
||||||
while timer()-lastFrame<1/60 do end
|
while timer()-lastFrame<sleepInterval do end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local Z={}
|
local Z={}
|
||||||
|
|
||||||
Z.js=jsState
|
function Z.getJsState()return jsState end
|
||||||
Z.errData=errData
|
function Z.getErr(i)
|
||||||
|
if i=='#'then
|
||||||
|
return errData[#errData]
|
||||||
|
elseif i then
|
||||||
|
return errData[i]
|
||||||
|
else
|
||||||
|
return errData
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
function Z.setIfPowerInfo(func)showPowerInfo=func end
|
function Z.setPowerInfo(bool)showPowerInfo=bool end
|
||||||
|
function Z.setCleanCanvas(bool)discardCanvas=bool end
|
||||||
|
function Z.setFrameMul(n)frameMul=n end
|
||||||
|
function Z.setMaxFPS(fps)sleepInterval=1/fps end
|
||||||
|
function Z.setClickFX(bool)showClickFX=bool end
|
||||||
|
|
||||||
--[Warning] Color and line width is uncertain value, set it in the function.
|
--[Warning] Color and line width is uncertain value, set it in the function.
|
||||||
function Z.setCursor(func)drawCursor=func end
|
function Z.setCursor(func)drawCursor=func end
|
||||||
|
|
||||||
--Change F1~F7 events of devmode (F8 mode)
|
--Change F1~F7 events of devmode (F8 mode)
|
||||||
function Z.setOnFnKeys(list)
|
function Z.setOnFnKeys(list)
|
||||||
assert(type(list)=='table')
|
assert(type(list)=='table',"Z.setOnFnKeys(list): list must be a table.")
|
||||||
for i=1,7 do fnKey[i]=type(list[i])=='function'and list[i]or NULL end
|
for i=1,7 do fnKey[i]=type(list[i])=='function'and list[i]or NULL end
|
||||||
end
|
end
|
||||||
|
|
||||||
function Z.setOnFocus(func)onFocus=type(func)=='function'and func or NULL end
|
function Z.setOnFocus(func)onFocus=assert(type(func)=='function'and func,"Z.setOnFocus(func): func must be a function")end
|
||||||
|
|
||||||
function Z.setOnQuit(func)onQuit=type(func)=='function'and func or NULL end
|
function Z.setOnResize(func)onResize=assert(type(func)=='function'and func,"Z.setOnResize(func): func must be a function")end
|
||||||
|
|
||||||
|
function Z.setOnQuit(func)onQuit=assert(type(func)=='function'and func,"Z.setOnQuit(func): func must be a function")end
|
||||||
|
|
||||||
return Z
|
return Z
|
||||||
|
|||||||
@@ -20,4 +20,18 @@ function MATH.coin(a,b)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function MATH.interval(v,low,high)
|
||||||
|
if v<=low then
|
||||||
|
return low
|
||||||
|
elseif v>=high then
|
||||||
|
return high
|
||||||
|
else
|
||||||
|
return v
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function MATH.expApproach(a,b,k)
|
||||||
|
return b+(a-b)*2.718281828459045^-k
|
||||||
|
end
|
||||||
|
|
||||||
return MATH
|
return MATH
|
||||||
@@ -140,11 +140,11 @@ function profile.switch()
|
|||||||
switch=not switch
|
switch=not switch
|
||||||
if not switch then
|
if not switch then
|
||||||
profile.stop()
|
profile.stop()
|
||||||
love.system.setClipboardText(PROFILE.report())
|
love.system.setClipboardText(profile.report())
|
||||||
PROFILE.reset()
|
profile.reset()
|
||||||
return false
|
return false
|
||||||
else
|
else
|
||||||
PROFILE.start()
|
profile.start()
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -15,6 +15,8 @@ local SCN={
|
|||||||
draw=false, --Swap draw func
|
draw=false, --Swap draw func
|
||||||
},
|
},
|
||||||
stack={},--Scene stack
|
stack={},--Scene stack
|
||||||
|
prev=false,
|
||||||
|
args={},--Arguments from previous scene
|
||||||
|
|
||||||
scenes=scenes,
|
scenes=scenes,
|
||||||
|
|
||||||
@@ -52,14 +54,15 @@ function SCN.swapUpdate(dt)
|
|||||||
S.time=S.time-dt
|
S.time=S.time-dt
|
||||||
if S.time<S.changeTime and S.time+dt>=S.changeTime then
|
if S.time<S.changeTime and S.time+dt>=S.changeTime then
|
||||||
--Scene swapped this frame
|
--Scene swapped this frame
|
||||||
SCN.init(S.tar,SCN.cur)
|
SCN.prev=SCN.cur
|
||||||
|
SCN.init(S.tar)
|
||||||
SCN.mainTouchID=nil
|
SCN.mainTouchID=nil
|
||||||
end
|
end
|
||||||
if S.time<0 then
|
if S.time<0 then
|
||||||
SCN.swapping=false
|
SCN.swapping=false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function SCN.init(s,org)
|
function SCN.init(s)
|
||||||
love.keyboard.setTextInput(false)
|
love.keyboard.setTextInput(false)
|
||||||
|
|
||||||
local S=scenes[s]
|
local S=scenes[s]
|
||||||
@@ -89,7 +92,7 @@ function SCN.init(s,org)
|
|||||||
SCN.update=S.update
|
SCN.update=S.update
|
||||||
SCN.draw=S.draw
|
SCN.draw=S.draw
|
||||||
if S.sceneInit then
|
if S.sceneInit then
|
||||||
S.sceneInit(org)
|
S.sceneInit()
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function SCN.push(tar,style)
|
function SCN.push(tar,style)
|
||||||
@@ -165,11 +168,12 @@ local swap={
|
|||||||
end
|
end
|
||||||
},
|
},
|
||||||
}--Scene swapping animations
|
}--Scene swapping animations
|
||||||
function SCN.swapTo(tar,style)--Parallel scene swapping, cannot back
|
function SCN.swapTo(tar,style,...)--Parallel scene swapping, cannot back
|
||||||
if scenes[tar]then
|
if scenes[tar]then
|
||||||
if not SCN.swapping and tar~=SCN.cur then
|
if not SCN.swapping and tar~=SCN.cur then
|
||||||
style=style or'fade'
|
style=style or'fade'
|
||||||
SCN.swapping=true
|
SCN.swapping=true
|
||||||
|
SCN.args={...}
|
||||||
local S=SCN.stat
|
local S=SCN.stat
|
||||||
S.tar,S.style=tar,style
|
S.tar,S.style=tar,style
|
||||||
S.time=swap[style].duration
|
S.time=swap[style].duration
|
||||||
@@ -180,15 +184,15 @@ function SCN.swapTo(tar,style)--Parallel scene swapping, cannot back
|
|||||||
MES.new('warn',"No Scene: "..tar)
|
MES.new('warn',"No Scene: "..tar)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function SCN.go(tar,style)--Normal scene swapping, can back
|
function SCN.go(tar,style,...)--Normal scene swapping, can back
|
||||||
if scenes[tar]then
|
if scenes[tar]then
|
||||||
SCN.push()
|
SCN.push()
|
||||||
SCN.swapTo(tar,style)
|
SCN.swapTo(tar,style,...)
|
||||||
else
|
else
|
||||||
MES.new('warn',"No Scene: "..tar)
|
MES.new('warn',"No Scene: "..tar)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function SCN.back()
|
function SCN.back(...)
|
||||||
if SCN.swapping then return end
|
if SCN.swapping then return end
|
||||||
|
|
||||||
--Leave scene
|
--Leave scene
|
||||||
@@ -199,7 +203,7 @@ function SCN.back()
|
|||||||
--Poll&Back to previous Scene
|
--Poll&Back to previous Scene
|
||||||
local m=#SCN.stack
|
local m=#SCN.stack
|
||||||
if m>0 then
|
if m>0 then
|
||||||
SCN.swapTo(SCN.stack[m-1],SCN.stack[m])
|
SCN.swapTo(SCN.stack[m-1],SCN.stack[m],...)
|
||||||
SCN.stack[m],SCN.stack[m-1]=nil
|
SCN.stack[m],SCN.stack[m-1]=nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
local type,rem=type,table.remove
|
local type,rem=type,table.remove
|
||||||
local int,rnd=math.floor,math.random
|
local int,rnd=math.floor,math.random
|
||||||
|
local interval=MATH.interval
|
||||||
|
|
||||||
local sfxList={}
|
local sfxList={}
|
||||||
local packSetting={}
|
local packSetting={}
|
||||||
@@ -140,7 +141,7 @@ local function _play(name,vol,pos,pitch)
|
|||||||
S=S[n]--AU_SRC
|
S=S[n]--AU_SRC
|
||||||
if S:getChannelCount()==1 then
|
if S:getChannelCount()==1 then
|
||||||
if pos then
|
if pos then
|
||||||
pos=pos*stereo
|
pos=interval(pos,-1,1)*stereo
|
||||||
S:setPosition(pos,1-pos^2,0)
|
S:setPosition(pos,1-pos^2,0)
|
||||||
else
|
else
|
||||||
S:setPosition(0,0,0)
|
S:setPosition(0,0,0)
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ local find,sub,gsub,upper=string.find,string.sub,string.gsub,string.upper
|
|||||||
local char,byte=string.char,string.byte
|
local char,byte=string.char,string.byte
|
||||||
|
|
||||||
--"Replace dollars", replace all $n with ...
|
--"Replace dollars", replace all $n with ...
|
||||||
function string.repD(str,...)
|
function STRING.repD(str,...)
|
||||||
local l={...}
|
local l={...}
|
||||||
for i=#l,1,-1 do
|
for i=#l,1,-1 do
|
||||||
str=gsub(str,'$'..i,l[i])
|
str=gsub(str,'$'..i,l[i])
|
||||||
@@ -15,7 +15,7 @@ function string.repD(str,...)
|
|||||||
end
|
end
|
||||||
|
|
||||||
--"Scan arg", scan if str has the arg (format of str is like "-json -q", arg is like "-q")
|
--"Scan arg", scan if str has the arg (format of str is like "-json -q", arg is like "-q")
|
||||||
function string.sArg(str,switch)
|
function STRING.sArg(str,switch)
|
||||||
if find(str.." ",switch.." ")then
|
if find(str.." ",switch.." ")then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
@@ -169,6 +169,25 @@ function STRING.vcsDecrypt(text,key)
|
|||||||
end
|
end
|
||||||
return result..buffer
|
return result..buffer
|
||||||
end
|
end
|
||||||
|
function STRING.digezt(text)--Not powerful hash, just protect the original text
|
||||||
|
local out={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}
|
||||||
|
local seed=26
|
||||||
|
for i=1,#text do
|
||||||
|
local c=byte(text,i)
|
||||||
|
seed=(seed+c)%26
|
||||||
|
c=c+seed
|
||||||
|
local pos=c*i%16
|
||||||
|
local step=(c+i)%4+1
|
||||||
|
local times=2+(c%6)
|
||||||
|
for _=1,times do
|
||||||
|
out[pos+1]=(out[pos+1]+c)%256
|
||||||
|
pos=(pos+step)%16
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local result=""
|
||||||
|
for i=1,16 do result=result..char(out[i])end
|
||||||
|
return result
|
||||||
|
end
|
||||||
|
|
||||||
function STRING.readLine(str)
|
function STRING.readLine(str)
|
||||||
local p=str:find("\n")
|
local p=str:find("\n")
|
||||||
@@ -178,6 +197,9 @@ function STRING.readLine(str)
|
|||||||
return str,""
|
return str,""
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
function STRING.readChars(str,n)
|
||||||
|
return sub(str,1,n),sub(str,n+1)
|
||||||
|
end
|
||||||
|
|
||||||
function STRING.packBin(s)
|
function STRING.packBin(s)
|
||||||
return data.encode('string','base64',data.compress('string','zlib',s))
|
return data.encode('string','base64',data.compress('string','zlib',s))
|
||||||
|
|||||||
@@ -19,6 +19,7 @@ local sub,ins,rem=string.sub,table.insert,table.remove
|
|||||||
local xOy=SCR.xOy
|
local xOy=SCR.xOy
|
||||||
local FONT=FONT
|
local FONT=FONT
|
||||||
local mStr=GC.mStr
|
local mStr=GC.mStr
|
||||||
|
local approach=MATH.expApproach
|
||||||
|
|
||||||
local downArrowIcon=GC.DO{40,25,{'fPoly',0,0,20,25,40,0}}
|
local downArrowIcon=GC.DO{40,25,{'fPoly',0,0,20,25,40,0}}
|
||||||
local upArrowIcon=GC.DO{40,25,{'fPoly',0,25,20,0,40,25}}
|
local upArrowIcon=GC.DO{40,25,{'fPoly',0,25,20,0,40,25}}
|
||||||
@@ -45,7 +46,12 @@ local function _rectangleStencil()
|
|||||||
gc.rectangle('fill',1,1,STW-2,STH-2)
|
gc.rectangle('fill',1,1,STW-2,STH-2)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local onChange=NULL
|
||||||
|
|
||||||
local WIDGET={}
|
local WIDGET={}
|
||||||
|
|
||||||
|
function WIDGET.setOnChange(func)onChange=assert(type(func)=='function'and func,"WIDGET.setOnChange(func): func must be a function")end
|
||||||
|
|
||||||
local widgetMetatable={
|
local widgetMetatable={
|
||||||
__tostring=function(self)
|
__tostring=function(self)
|
||||||
return self:getInfo()
|
return self:getInfo()
|
||||||
@@ -72,20 +78,23 @@ function text:draw()
|
|||||||
if self.alpha>0 then
|
if self.alpha>0 then
|
||||||
local c=self.color
|
local c=self.color
|
||||||
gc_setColor(c[1],c[2],c[3],self.alpha)
|
gc_setColor(c[1],c[2],c[3],self.alpha)
|
||||||
|
local w=self.obj:getWidth()
|
||||||
|
local k=min(self.lim/self.obj:getWidth(),1)
|
||||||
if self.align=='M'then
|
if self.align=='M'then
|
||||||
gc_draw(self.obj,self.x-self.obj:getWidth()*.5,self.y)
|
gc_draw(self.obj,self.x,self.y,nil,k,1,w*.5,0)
|
||||||
elseif self.align=='L'then
|
elseif self.align=='L'then
|
||||||
gc_draw(self.obj,self.x,self.y)
|
gc_draw(self.obj,self.x,self.y,nil,k,1)
|
||||||
elseif self.align=='R'then
|
elseif self.align=='R'then
|
||||||
gc_draw(self.obj,self.x-self.obj:getWidth(),self.y)
|
gc_draw(self.obj,self.x,self.y,nil,k,1,w,0)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function WIDGET.newText(D)--name,x,y[,fText][,color][,font=30][,fType][,align='M'][,hideF][,hide]
|
function WIDGET.newText(D)--name,x,y[,lim][,fText][,color][,font=30][,fType][,align='M'][,hideF][,hide]
|
||||||
local _={
|
local _={
|
||||||
name= D.name or"_",
|
name= D.name or"_",
|
||||||
x= D.x,
|
x= D.x,
|
||||||
y= D.y,
|
y= D.y,
|
||||||
|
lim= D.lim or 1e99,
|
||||||
|
|
||||||
fText=D.fText,
|
fText=D.fText,
|
||||||
color=D.color and(COLOR[D.color]or D.color)or COLOR.Z,
|
color=D.color and(COLOR[D.color]or D.color)or COLOR.Z,
|
||||||
@@ -520,7 +529,7 @@ function slider:isAbove(x,y)
|
|||||||
return x>self.x-10 and x<self.x+self.w+10 and y>self.y-25 and y<self.y+25
|
return x>self.x-10 and x<self.x+self.w+10 and y>self.y-25 and y<self.y+25
|
||||||
end
|
end
|
||||||
function slider:getCenter()
|
function slider:getCenter()
|
||||||
return self.x+self.w*(self.pos/self.unit),self.y
|
return self.x+self.w*((self.pos-self.rangeL)/(self.rangeR-self.rangeL)),self.y
|
||||||
end
|
end
|
||||||
function slider:update(dt)
|
function slider:update(dt)
|
||||||
local ATV=self.ATV
|
local ATV=self.ATV
|
||||||
@@ -534,7 +543,7 @@ function slider:update(dt)
|
|||||||
if ATV>0 then self.ATV=max(ATV-dt*30,0)end
|
if ATV>0 then self.ATV=max(ATV-dt*30,0)end
|
||||||
end
|
end
|
||||||
if not self.hide then
|
if not self.hide then
|
||||||
self.pos=self.pos*.7+self.disp()*.3
|
self.pos=approach(self.pos,self.disp(),dt*26)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function slider:draw()
|
function slider:draw()
|
||||||
@@ -547,8 +556,8 @@ function slider:draw()
|
|||||||
--Units
|
--Units
|
||||||
if not self.smooth then
|
if not self.smooth then
|
||||||
gc_setLineWidth(2)
|
gc_setLineWidth(2)
|
||||||
for p=0,self.unit do
|
for p=self.rangeL,self.rangeR,self.unit do
|
||||||
local X=x+(x2-x)*p/self.unit
|
local X=x+(x2-x)*(p-self.rangeL)/(self.rangeR-self.rangeL)
|
||||||
gc_line(X,y+7,X,y-7)
|
gc_line(X,y+7,X,y-7)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -558,7 +567,7 @@ function slider:draw()
|
|||||||
gc_line(x,y,x2,y)
|
gc_line(x,y,x2,y)
|
||||||
|
|
||||||
--Block
|
--Block
|
||||||
local cx=x+(x2-x)*self.pos/self.unit
|
local cx=x+(x2-x)*(self.pos-self.rangeL)/(self.rangeR-self.rangeL)
|
||||||
local bx,by,bw,bh=cx-10-ATV*.5,y-16-ATV,20+ATV,32+2*ATV
|
local bx,by,bw,bh=cx-10-ATV*.5,y-16-ATV,20+ATV,32+2*ATV
|
||||||
gc_setColor(.8,.8,.8)
|
gc_setColor(.8,.8,.8)
|
||||||
gc_rectangle('fill',bx,by,bw,bh,3)
|
gc_rectangle('fill',bx,by,bw,bh,3)
|
||||||
@@ -593,13 +602,16 @@ end
|
|||||||
function slider:drag(x)
|
function slider:drag(x)
|
||||||
if not x then return end
|
if not x then return end
|
||||||
x=x-self.x
|
x=x-self.x
|
||||||
local p=self.disp()
|
local newPos=MATH.interval(x/self.w,0,1)
|
||||||
local P=x<0 and 0 or x>self.w and self.unit or x/self.w*self.unit
|
local newVal
|
||||||
if not self.smooth then
|
if not self.unit then
|
||||||
P=int(P+.5)
|
newVal=(1-newPos)*self.rangeL+newPos*self.rangeR
|
||||||
|
else
|
||||||
|
newVal=newPos*(self.rangeR-self.rangeL)
|
||||||
|
newVal=self.rangeL+newVal-newVal%self.unit
|
||||||
end
|
end
|
||||||
if p~=P then
|
if newVal~=self.disp()then
|
||||||
self.code(P)
|
self.code(newVal)
|
||||||
end
|
end
|
||||||
if self.change and timer()-self.lastTime>.5 then
|
if self.change and timer()-self.lastTime>.5 then
|
||||||
self.lastTime=timer()
|
self.lastTime=timer()
|
||||||
@@ -612,8 +624,8 @@ function slider:release(x)
|
|||||||
end
|
end
|
||||||
function slider:scroll(n)
|
function slider:scroll(n)
|
||||||
local p=self.disp()
|
local p=self.disp()
|
||||||
local u=self.smooth and .01 or 1
|
local u=self.unit or .01
|
||||||
local P=n==-1 and max(p-u,0)or min(p+u,self.unit)
|
local P=MATH.interval(p+u*n,self.rangeL,self.rangeR)
|
||||||
if p==P or not P then return end
|
if p==P or not P then return end
|
||||||
self.code(P)
|
self.code(P)
|
||||||
if self.change and timer()-self.lastTime>.18 then
|
if self.change and timer()-self.lastTime>.18 then
|
||||||
@@ -624,7 +636,13 @@ end
|
|||||||
function slider:arrowKey(k)
|
function slider:arrowKey(k)
|
||||||
self:scroll((k=='left'or k=='up')and -1 or 1)
|
self:scroll((k=='left'or k=='up')and -1 or 1)
|
||||||
end
|
end
|
||||||
function WIDGET.newSlider(D)--name,x,y,w[,lim][,fText][,color][,unit][,smooth][,font=30][,fType][,change],disp[,show][,code],hide
|
function WIDGET.newSlider(D)--name,x,y,w[,lim][,fText][,color][,axis][,smooth][,font=30][,fType][,change],disp[,show][,code],hide
|
||||||
|
if not D.axis then
|
||||||
|
D.axis={0,1,false}
|
||||||
|
D.smooth=true
|
||||||
|
elseif not D.axis[3]then
|
||||||
|
D.smooth=true
|
||||||
|
end
|
||||||
local _={
|
local _={
|
||||||
name= D.name or"_",
|
name= D.name or"_",
|
||||||
|
|
||||||
@@ -643,8 +661,10 @@ function WIDGET.newSlider(D)--name,x,y,w[,lim][,fText][,color][,unit][,smooth][,
|
|||||||
|
|
||||||
fText= D.fText,
|
fText= D.fText,
|
||||||
color= D.color and(COLOR[D.color]or D.color)or COLOR.Z,
|
color= D.color and(COLOR[D.color]or D.color)or COLOR.Z,
|
||||||
unit= D.unit or 1,
|
rangeL=D.axis[1],
|
||||||
smooth=false,
|
rangeR=D.axis[2],
|
||||||
|
unit= D.axis[3],
|
||||||
|
smooth=D.smooth,
|
||||||
font= D.font or 30,
|
font= D.font or 30,
|
||||||
fType= D.fType,
|
fType= D.fType,
|
||||||
change=D.change,
|
change=D.change,
|
||||||
@@ -654,22 +674,17 @@ function WIDGET.newSlider(D)--name,x,y,w[,lim][,fText][,color][,unit][,smooth][,
|
|||||||
hide= D.hide,
|
hide= D.hide,
|
||||||
show= false,
|
show= false,
|
||||||
}
|
}
|
||||||
if D.smooth~=nil then
|
|
||||||
_.smooth=D.smooth
|
|
||||||
else
|
|
||||||
_.smooth=_.unit<=1
|
|
||||||
end
|
|
||||||
if D.show then
|
if D.show then
|
||||||
if type(D.show)=='function'then
|
if type(D.show)=='function'then
|
||||||
_.show=D.show
|
_.show=D.show
|
||||||
else
|
else
|
||||||
_.show=sliderShowFunc[D.show]
|
_.show=sliderShowFunc[D.show]
|
||||||
end
|
end
|
||||||
elseif D.show~=false then
|
elseif D.show~=false then--Use default if nil
|
||||||
if _.unit<=1 then
|
if _.unit and _.unit%1==0 then
|
||||||
_.show=sliderShowFunc.percent
|
|
||||||
else
|
|
||||||
_.show=sliderShowFunc.int
|
_.show=sliderShowFunc.int
|
||||||
|
else
|
||||||
|
_.show=sliderShowFunc.percent
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
for k,v in next,slider do _[k]=v end
|
for k,v in next,slider do _[k]=v end
|
||||||
@@ -1218,6 +1233,14 @@ function listBox:arrowKey(dir)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
function listBox:select(i)
|
||||||
|
self.selected=i
|
||||||
|
if self.selected<int(self.scrollPos/self.lineH)+2 then
|
||||||
|
self:drag(nil,nil,nil,1e99)
|
||||||
|
elseif self.selected>int(self.scrollPos/self.lineH)+self.capacity-1 then
|
||||||
|
self:drag(nil,nil,nil,-1e99)
|
||||||
|
end
|
||||||
|
end
|
||||||
function listBox:draw()
|
function listBox:draw()
|
||||||
local x,y,w,h=self.x,self.y,self.w,self.h
|
local x,y,w,h=self.x,self.y,self.w,self.h
|
||||||
local list=self.list
|
local list=self.list
|
||||||
@@ -1260,7 +1283,7 @@ end
|
|||||||
function listBox:getInfo()
|
function listBox:getInfo()
|
||||||
return("x=%d,y=%d,w=%d,h=%d"):format(self.x+self.w*.5,self.y+self.h*.5,self.w,self.h)
|
return("x=%d,y=%d,w=%d,h=%d"):format(self.x+self.w*.5,self.y+self.h*.5,self.w,self.h)
|
||||||
end
|
end
|
||||||
function WIDGET.newListBox(D)--name,x,y,w,h,lineH[,hideF][,hide][,drawF]
|
function WIDGET.newListBox(D)--name,x,y,w,h,lineH,drawF[,hideF][,hide]
|
||||||
local _={
|
local _={
|
||||||
name= D.name or"_",
|
name= D.name or"_",
|
||||||
|
|
||||||
@@ -1317,16 +1340,7 @@ function WIDGET.setWidgetList(list)
|
|||||||
for i=1,#list do
|
for i=1,#list do
|
||||||
list[i]:reset()
|
list[i]:reset()
|
||||||
end
|
end
|
||||||
if SCN.cur~='custom_field'then
|
onChange()
|
||||||
local colorList=THEME.getThemeColor()
|
|
||||||
if not colorList then return end
|
|
||||||
local rnd=math.random
|
|
||||||
for _,W in next,list do
|
|
||||||
if W.color and not W.fText then
|
|
||||||
W.color=colorList[rnd(#colorList)]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function WIDGET.setScrollHeight(height)
|
function WIDGET.setScrollHeight(height)
|
||||||
|
|||||||
98
main.lua
@@ -24,13 +24,13 @@ VERSION=require"version"
|
|||||||
TIME=love.timer.getTime
|
TIME=love.timer.getTime
|
||||||
YIELD=coroutine.yield
|
YIELD=coroutine.yield
|
||||||
SYSTEM=love.system.getOS()if SYSTEM=='OS X'then SYSTEM='macOS'end
|
SYSTEM=love.system.getOS()if SYSTEM=='OS X'then SYSTEM='macOS'end
|
||||||
FNSF=SYSTEM:find'\79\83'--What does FNSF stand for? IDK so don't ask me lol
|
FNNS=SYSTEM:find'\79\83'--What does FNSF stand for? IDK so don't ask me lol
|
||||||
MOBILE=SYSTEM=='Android'or SYSTEM=='iOS'
|
MOBILE=SYSTEM=='Android'or SYSTEM=='iOS'
|
||||||
SAVEDIR=fs.getSaveDirectory()
|
SAVEDIR=fs.getSaveDirectory()
|
||||||
|
|
||||||
--Global Vars & Settings
|
--Global Vars & Settings
|
||||||
SFXPACKS={'chiptune'}
|
SFXPACKS={'chiptune'}
|
||||||
VOCPACKS={'miya','mono','xiaoya','miku'}
|
VOCPACKS={'miya',--[['mono',]]'xiaoya','miku'}
|
||||||
FIRSTLAUNCH=false
|
FIRSTLAUNCH=false
|
||||||
DAILYLAUNCH=false
|
DAILYLAUNCH=false
|
||||||
|
|
||||||
@@ -62,6 +62,19 @@ BGM.setMaxSources(5)
|
|||||||
BGM.setChange(function(name)MES.new('music',text.nowPlaying..name,5)end)
|
BGM.setChange(function(name)MES.new('music',text.nowPlaying..name,5)end)
|
||||||
VOC.setDiversion(.62)
|
VOC.setDiversion(.62)
|
||||||
|
|
||||||
|
WIDGET.setOnChange(function()
|
||||||
|
if SCN.cur~='custom_field'then
|
||||||
|
local colorList=THEME.getThemeColor()
|
||||||
|
if not colorList then return end
|
||||||
|
local rnd=math.random
|
||||||
|
for _,W in next,SCN.scenes[SCN.cur].widgetList do
|
||||||
|
if W.color then
|
||||||
|
W.color=colorList[rnd(#colorList)]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
table.insert(_LOADTIMELIST_,("Load Zframework: %.3fs"):format(TIME()-_LOADTIME_))
|
table.insert(_LOADTIMELIST_,("Load Zframework: %.3fs"):format(TIME()-_LOADTIME_))
|
||||||
|
|
||||||
--Create shortcuts
|
--Create shortcuts
|
||||||
@@ -71,6 +84,9 @@ mStr=GC.mStr
|
|||||||
mText=GC.simpX
|
mText=GC.simpX
|
||||||
mDraw=GC.draw
|
mDraw=GC.draw
|
||||||
Snd=SFX.playSample
|
Snd=SFX.playSample
|
||||||
|
string.repD=STRING.repD
|
||||||
|
string.sArg=STRING.sArg
|
||||||
|
string.split=STRING.split
|
||||||
|
|
||||||
--Delete all naked files (from too old version)
|
--Delete all naked files (from too old version)
|
||||||
FILE.clear('')
|
FILE.clear('')
|
||||||
@@ -112,20 +128,17 @@ BOT= require'parts.bot'
|
|||||||
RSlist= require'parts.RSlist'DSCP=RSlist.TRS.centerPos
|
RSlist= require'parts.RSlist'DSCP=RSlist.TRS.centerPos
|
||||||
PLY= require'parts.player'
|
PLY= require'parts.player'
|
||||||
NETPLY= require'parts.netPlayer'
|
NETPLY= require'parts.netPlayer'
|
||||||
MODES= require'parts.modes'
|
MODETREE= require'parts.modeTree'
|
||||||
|
|
||||||
setmetatable(TEXTURE,{__index=function(self,k)
|
setmetatable(TEXTURE,{__index=function(self,k)
|
||||||
MES.new('warn',"No texture called: "..k)
|
MES.new('warn',"No texture called: "..k)
|
||||||
self[k]=love.graphics.newCanvas(1,1)
|
self[k]=PAPER
|
||||||
return self[k]
|
return self[k]
|
||||||
end})
|
end})
|
||||||
|
|
||||||
table.insert(_LOADTIMELIST_,("Load Parts: %.3fs"):format(TIME()-_LOADTIME_))
|
table.insert(_LOADTIMELIST_,("Load Parts: %.3fs"):format(TIME()-_LOADTIME_))
|
||||||
|
|
||||||
--Init Zframework
|
--Init Zframework
|
||||||
Z.setIfPowerInfo(function()
|
|
||||||
return SETTING.powerInfo and LOADED
|
|
||||||
end)
|
|
||||||
do--Z.setCursor
|
do--Z.setCursor
|
||||||
local normImg=GC.DO{16,16,
|
local normImg=GC.DO{16,16,
|
||||||
{'fCirc',8,8,4},
|
{'fCirc',8,8,4},
|
||||||
@@ -171,6 +184,9 @@ Z.setOnFnKeys({
|
|||||||
function()for k,v in next,_G do print(k,v)end end,
|
function()for k,v in next,_G do print(k,v)end end,
|
||||||
function()if love['_openConsole']then love['_openConsole']()end end,
|
function()if love['_openConsole']then love['_openConsole']()end end,
|
||||||
})
|
})
|
||||||
|
Z.setOnResize(function(w,_)
|
||||||
|
SHADER.warning:send('w',w*SCR.dpi)
|
||||||
|
end)
|
||||||
do--Z.setOnFocus
|
do--Z.setOnFocus
|
||||||
local function task_autoSoundOff()
|
local function task_autoSoundOff()
|
||||||
while true do
|
while true do
|
||||||
@@ -255,14 +271,17 @@ IMG.init{
|
|||||||
speedLimit='media/image/mess/speedLimit.png',--Not used, for future C2-mode
|
speedLimit='media/image/mess/speedLimit.png',--Not used, for future C2-mode
|
||||||
pay1='media/image/mess/pay1.png',
|
pay1='media/image/mess/pay1.png',
|
||||||
pay2='media/image/mess/pay2.png',
|
pay2='media/image/mess/pay2.png',
|
||||||
|
drought='media/image/mess/drought.png',
|
||||||
|
|
||||||
miyaCH='media/image/characters/miya.png',
|
miyaCH1='media/image/characters/miya1.png',
|
||||||
miyaF1='media/image/characters/miya_f1.png',
|
miyaCH2='media/image/characters/miya2.png',
|
||||||
miyaF2='media/image/characters/miya_f2.png',
|
miyaCH3='media/image/characters/miya3.png',
|
||||||
miyaF3='media/image/characters/miya_f3.png',
|
miyaCH4='media/image/characters/miya4.png',
|
||||||
miyaF4='media/image/characters/miya_f4.png',
|
miyaHeart='media/image/characters/miya_heart.png',
|
||||||
|
miyaGlow='media/image/characters/miya_glow.png',
|
||||||
monoCH='media/image/characters/mono.png',
|
monoCH='media/image/characters/mono.png',
|
||||||
xiaoyaCH='media/image/characters/xiaoya.png',
|
xiaoyaCH='media/image/characters/xiaoya.png',
|
||||||
|
xiaoyaOmino='media/image/characters/xiaoya_Omino.png',
|
||||||
mikuCH='media/image/characters/miku.png',
|
mikuCH='media/image/characters/miku.png',
|
||||||
electric='media/image/characters/electric.png',
|
electric='media/image/characters/electric.png',
|
||||||
hbm='media/image/characters/hbm.png',
|
hbm='media/image/characters/hbm.png',
|
||||||
@@ -279,7 +298,7 @@ IMG.init{
|
|||||||
SKIN.load{
|
SKIN.load{
|
||||||
{name="crystal_scf",path='media/image/skin/crystal_scf.png'},
|
{name="crystal_scf",path='media/image/skin/crystal_scf.png'},
|
||||||
{name="matte_mrz",path='media/image/skin/matte_mrz.png'},
|
{name="matte_mrz",path='media/image/skin/matte_mrz.png'},
|
||||||
{name="shiny_cho",path='media/image/skin/shiny_cho.png'},
|
{name="shiny_chno",path='media/image/skin/shiny_chno.png'},
|
||||||
{name="contrast_mrz",path='media/image/skin/contrast_mrz.png'},
|
{name="contrast_mrz",path='media/image/skin/contrast_mrz.png'},
|
||||||
{name="polkadots_scf",path='media/image/skin/polkadots_scf.png'},
|
{name="polkadots_scf",path='media/image/skin/polkadots_scf.png'},
|
||||||
{name="toy_scf",path='media/image/skin/toy_scf.png'},
|
{name="toy_scf",path='media/image/skin/toy_scf.png'},
|
||||||
@@ -302,6 +321,7 @@ SKIN.load{
|
|||||||
{name="classic",path='media/image/skin/classic_unknown.png'},
|
{name="classic",path='media/image/skin/classic_unknown.png'},
|
||||||
{name="ball_shaw",path='media/image/skin/ball_shaw.png'},
|
{name="ball_shaw",path='media/image/skin/ball_shaw.png'},
|
||||||
{name="retro_notypey",path='media/image/skin/retro_notypey.png'},
|
{name="retro_notypey",path='media/image/skin/retro_notypey.png'},
|
||||||
|
{name="pixel_chno",path='media/image/skin/pixel_chno.png'},
|
||||||
{name="textbone_mrz",path='media/image/skin/textbone_mrz.png'},
|
{name="textbone_mrz",path='media/image/skin/textbone_mrz.png'},
|
||||||
{name="coloredbone_mrz",path='media/image/skin/coloredbone_mrz.png'},
|
{name="coloredbone_mrz",path='media/image/skin/coloredbone_mrz.png'},
|
||||||
{name="wtf",path='media/image/skin/wtf_mrz.png'},
|
{name="wtf",path='media/image/skin/wtf_mrz.png'},
|
||||||
@@ -317,11 +337,11 @@ SFX.init((function()--[Warning] Not loading files here, just get the list of sou
|
|||||||
end
|
end
|
||||||
return L
|
return L
|
||||||
end)())
|
end)())
|
||||||
BGM.init((function()
|
BGM.load((function()
|
||||||
local L={}
|
local L={}
|
||||||
for _,v in next,fs.getDirectoryItems('media/music')do
|
for _,v in next,fs.getDirectoryItems('media/music')do
|
||||||
if isSafeFile('media/music/'..v,"Dangerous file : %SAVE%/media/music/"..v)then
|
if isSafeFile('media/music/'..v,"Dangerous file : %SAVE%/media/music/"..v)then
|
||||||
table.insert(L,{name=v:sub(1,-5),path='media/music/'..v})
|
L[v:sub(1,-5)]='media/music/'..v
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return L
|
return L
|
||||||
@@ -346,6 +366,7 @@ LANG.init('zh',
|
|||||||
fr=require'parts.language.lang_fr',
|
fr=require'parts.language.lang_fr',
|
||||||
es=require'parts.language.lang_es',
|
es=require'parts.language.lang_es',
|
||||||
pt=require'parts.language.lang_pt',
|
pt=require'parts.language.lang_pt',
|
||||||
|
id=require'parts.language.lang_id',
|
||||||
zh_grass=require'parts.language.lang_zh_grass',
|
zh_grass=require'parts.language.lang_zh_grass',
|
||||||
zh_yygq=require'parts.language.lang_yygq',
|
zh_yygq=require'parts.language.lang_yygq',
|
||||||
symbol=require'parts.language.lang_symbol',
|
symbol=require'parts.language.lang_symbol',
|
||||||
@@ -389,24 +410,6 @@ for _,v in next,fs.getDirectoryItems('parts/scenes')do
|
|||||||
LANG.addScene(sceneName)
|
LANG.addScene(sceneName)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
--Load mode files
|
|
||||||
for i=1,#MODES do
|
|
||||||
local m=MODES[i]--Mode template
|
|
||||||
if isSafeFile('parts/modes/'..m.name)then
|
|
||||||
TABLE.complete(require('parts.modes.'..m.name),MODES[i])
|
|
||||||
MODES[m.name],MODES[i]=MODES[i]
|
|
||||||
end
|
|
||||||
end
|
|
||||||
for _,v in next,fs.getDirectoryItems('parts/modes')do
|
|
||||||
if isSafeFile('parts/modes/'..v)and not MODES[v:sub(1,-5)]then
|
|
||||||
local M={name=v:sub(1,-5)}
|
|
||||||
local modeData=require('parts.modes.'..M.name)
|
|
||||||
if modeData.env then
|
|
||||||
TABLE.complete(modeData,M)
|
|
||||||
MODES[M.name]=M
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
table.insert(_LOADTIMELIST_,("Load Files: %.3fs"):format(TIME()-_LOADTIME_))
|
table.insert(_LOADTIMELIST_,("Load Files: %.3fs"):format(TIME()-_LOADTIME_))
|
||||||
|
|
||||||
@@ -463,6 +466,9 @@ do
|
|||||||
SETTING.dascut=SETTING.dascut+1
|
SETTING.dascut=SETTING.dascut+1
|
||||||
needSave=true
|
needSave=true
|
||||||
end
|
end
|
||||||
|
if SETTING.vocPack=='mono'then
|
||||||
|
SETTING.vocPack='miya'
|
||||||
|
end
|
||||||
if RANKS.stack_e then
|
if RANKS.stack_e then
|
||||||
RANKS.stack_e=nil
|
RANKS.stack_e=nil
|
||||||
RANKS.stack_h=nil
|
RANKS.stack_h=nil
|
||||||
@@ -519,6 +525,8 @@ do
|
|||||||
if not TABLE.find({8,10,13,17,22,29,37,47,62,80,100},SETTING.frameMul)then SETTING.frameMul=100 end
|
if not TABLE.find({8,10,13,17,22,29,37,47,62,80,100},SETTING.frameMul)then SETTING.frameMul=100 end
|
||||||
if SETTING.cv then SETTING.vocPack,SETTING.cv=SETTING.cv end
|
if SETTING.cv then SETTING.vocPack,SETTING.cv=SETTING.cv end
|
||||||
if type(SETTING.bg)~='string'then SETTING.bg='on'end
|
if type(SETTING.bg)~='string'then SETTING.bg='on'end
|
||||||
|
if SETTING.skin[18]==10 then SETTING.skin[18]=4 end
|
||||||
|
if SETTING.reTime>3 or SETTING.reTime<.5 then SETTING.reTime=2 end
|
||||||
if RANKS.infinite then RANKS.infinite=0 end
|
if RANKS.infinite then RANKS.infinite=0 end
|
||||||
if RANKS.infinite_dig then RANKS.infinite_dig=0 end
|
if RANKS.infinite_dig then RANKS.infinite_dig=0 end
|
||||||
if not RANKS.sprint_10l then RANKS.sprint_10l=0 end
|
if not RANKS.sprint_10l then RANKS.sprint_10l=0 end
|
||||||
@@ -529,26 +537,8 @@ do
|
|||||||
if type(name)=='number'or type(rank)~='number'then
|
if type(name)=='number'or type(rank)~='number'then
|
||||||
RANKS[name]=nil
|
RANKS[name]=nil
|
||||||
needSave=true
|
needSave=true
|
||||||
else
|
|
||||||
local M=MODES[name]
|
|
||||||
if M and M.unlock and rank>0 then
|
|
||||||
for _,unlockName in next,M.unlock do
|
|
||||||
if not RANKS[unlockName]then
|
|
||||||
RANKS[unlockName]=0
|
|
||||||
needSave=true
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if not(M and M.x)then
|
|
||||||
RANKS[name]=nil
|
|
||||||
needSave=true
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if not MODES[STAT.lastPlay]then
|
|
||||||
STAT.lastPlay='sprint_10l'
|
|
||||||
needSave=true
|
|
||||||
end
|
|
||||||
|
|
||||||
if needSave then
|
if needSave then
|
||||||
saveStats()
|
saveStats()
|
||||||
@@ -567,7 +557,7 @@ if FIRSTLAUNCH and MOBILE then
|
|||||||
end
|
end
|
||||||
|
|
||||||
--Apply system setting
|
--Apply system setting
|
||||||
applyAllSettings()
|
applySettings()
|
||||||
|
|
||||||
--Load replays
|
--Load replays
|
||||||
for _,fileName in next,fs.getDirectoryItems('replay')do
|
for _,fileName in next,fs.getDirectoryItems('replay')do
|
||||||
@@ -645,9 +635,9 @@ if TABLE.find(arg,'--test')then
|
|||||||
TASK.new(function()
|
TASK.new(function()
|
||||||
while true do
|
while true do
|
||||||
YIELD()
|
YIELD()
|
||||||
if Z.errData[1]then break end
|
if Z.getErr(1)then break end
|
||||||
end
|
end
|
||||||
LOG("\27[91m\27[1mAutomatic Test Failed :(\27[0m\nThe error message is:\n"..table.concat(Z.errData[1].mes,"\n").."\27[91m\nAborting\27[0m")
|
LOG("\27[91m\27[1mAutomatic Test Failed :(\27[0m\nThe error message is:\n"..table.concat(Z.getErr(1).mes,"\n").."\27[91m\nAborting\27[0m")
|
||||||
TEST.yieldN(60)
|
TEST.yieldN(60)
|
||||||
love.event.quit(1)
|
love.event.quit(1)
|
||||||
end)
|
end)
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 74 KiB |
BIN
media/image/characters/miya1.png
Normal file
|
After Width: | Height: | Size: 83 KiB |
BIN
media/image/characters/miya2.png
Normal file
|
After Width: | Height: | Size: 82 KiB |
BIN
media/image/characters/miya3.png
Normal file
|
After Width: | Height: | Size: 83 KiB |
BIN
media/image/characters/miya4.png
Normal file
|
After Width: | Height: | Size: 83 KiB |
|
Before Width: | Height: | Size: 2.1 KiB |
|
Before Width: | Height: | Size: 2.4 KiB |
|
Before Width: | Height: | Size: 1.3 KiB |
|
Before Width: | Height: | Size: 1.1 KiB |
BIN
media/image/characters/miya_glow.png
Normal file
|
After Width: | Height: | Size: 23 KiB |
BIN
media/image/characters/miya_heart.png
Normal file
|
After Width: | Height: | Size: 29 KiB |
|
Before Width: | Height: | Size: 62 KiB After Width: | Height: | Size: 62 KiB |
BIN
media/image/characters/xiaoya_Omino.png
Normal file
|
After Width: | Height: | Size: 5.9 KiB |
|
Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 1.2 KiB |
|
Before Width: | Height: | Size: 1.5 KiB |
|
Before Width: | Height: | Size: 3.5 KiB |
|
Before Width: | Height: | Size: 5.4 KiB |
|
Before Width: | Height: | Size: 552 B |
|
Before Width: | Height: | Size: 534 B |
|
Before Width: | Height: | Size: 603 B |
|
Before Width: | Height: | Size: 483 B |
|
Before Width: | Height: | Size: 207 B |
|
Before Width: | Height: | Size: 324 B |
|
Before Width: | Height: | Size: 275 B |
|
Before Width: | Height: | Size: 4.9 KiB |
|
Before Width: | Height: | Size: 283 B |
|
Before Width: | Height: | Size: 489 B |
|
Before Width: | Height: | Size: 272 B |
|
Before Width: | Height: | Size: 338 B |
|
Before Width: | Height: | Size: 403 B |
|
Before Width: | Height: | Size: 434 B |
|
Before Width: | Height: | Size: 464 B |
|
Before Width: | Height: | Size: 347 B |
|
Before Width: | Height: | Size: 395 B |
|
Before Width: | Height: | Size: 457 B |
|
Before Width: | Height: | Size: 1.2 KiB |
BIN
media/image/skin/pixel_chno.png
Normal file
|
After Width: | Height: | Size: 1.0 KiB |
|
Before Width: | Height: | Size: 32 KiB After Width: | Height: | Size: 32 KiB |
BIN
media/music/lounge.ogg
Normal file
@@ -376,8 +376,8 @@ do
|
|||||||
},--R
|
},--R
|
||||||
false,--Y
|
false,--Y
|
||||||
{
|
{
|
||||||
[01]={'+0+0','-1+0','-1+1','+0+1','+1+0','-1+2','-2+0','+0-2'},
|
[01]={'+0+0','-1+0','-1+1','+0+1','+1+0','+1+1','-1+2','-2+0','+0-2'},
|
||||||
[10]={'+0+0','+1+0','-1+0','+0-1','+1-1','+1-2','+2+0','+0+2'},
|
[10]={'+0+0','+1+0','-1+0','+0-1','-1-1','+1-1','+1-2','+2+0','+0+2'},
|
||||||
[03]={'+0+0','-1+0','+1-1','+0-2','+0-3','+1+0','+1-2','+1-3','+0+1','-1+1'},
|
[03]={'+0+0','-1+0','+1-1','+0-2','+0-3','+1+0','+1-2','+1-3','+0+1','-1+1'},
|
||||||
[30]={'+0+0','-1+0','+1-1','+1-2','+1+0','+0-2','+1-3','-1+2','+0+3','-1+3'},
|
[30]={'+0+0','-1+0','+1-1','+1-2','+1+0','+0-2','+1-3','-1+2','+0+3','-1+3'},
|
||||||
[12]={'+0+0','-1+0','+1-1','-1-1','+1-2','+1+0','+0-2','+1-3','-1+2','+0+3','-1+3'},
|
[12]={'+0+0','-1+0','+1-1','-1-1','+1-2','+1+0','+0-2','+1-3','-1+2','+0+3','-1+3'},
|
||||||
|
|||||||
@@ -22,12 +22,12 @@ function back.resize(w,h)
|
|||||||
S[i+4]=(rnd()-.5)*.01*s--Vy
|
S[i+4]=(rnd()-.5)*.01*s--Vy
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function back.update()
|
function back.update(dt)
|
||||||
local S=stars
|
local S=stars
|
||||||
--Star moving
|
--Star moving
|
||||||
for i=1,1260,5 do
|
for i=1,1260,5 do
|
||||||
S[i+1]=(S[i+1]+S[i+3])%W
|
S[i+1]=(S[i+1]+S[i+3]*dt*60)%W
|
||||||
S[i+2]=(S[i+2]+S[i+4])%H
|
S[i+2]=(S[i+2]+S[i+4]*dt*60)%H
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function back.draw()
|
function back.draw()
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ return
|
|||||||
PLY.draw.drawTargetLine(P,200-P.stat.row)
|
PLY.draw.drawTargetLine(P,200-P.stat.row)
|
||||||
end,
|
end,
|
||||||
task=function(P)
|
task=function(P)
|
||||||
local F=P.field
|
local F=P.field
|
||||||
for i=1,24 do
|
for i=1,24 do
|
||||||
F[i]=LINE.new(20)
|
F[i]=LINE.new(20)
|
||||||
P.visTime[i]=LINE.new(20)
|
P.visTime[i]=LINE.new(20)
|
||||||
@@ -31,7 +31,7 @@ return
|
|||||||
P:set20G(true)
|
P:set20G(true)
|
||||||
P.modeData.target=200
|
P.modeData.target=200
|
||||||
SFX.play('reach')
|
SFX.play('reach')
|
||||||
else
|
else
|
||||||
P:win('finish')
|
P:win('finish')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ return
|
|||||||
PLY.draw.drawTargetLine(P,200-P.stat.row)
|
PLY.draw.drawTargetLine(P,200-P.stat.row)
|
||||||
end,
|
end,
|
||||||
task=function(P)
|
task=function(P)
|
||||||
local F=P.field
|
local F=P.field
|
||||||
for i=1,24 do
|
for i=1,24 do
|
||||||
F[i]=LINE.new(20)
|
F[i]=LINE.new(20)
|
||||||
P.visTime[i]=LINE.new(20)
|
P.visTime[i]=LINE.new(20)
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ return{
|
|||||||
end
|
end
|
||||||
setFont(50)
|
setFont(50)
|
||||||
mStr(P.modeData.drought,63,130)
|
mStr(P.modeData.drought,63,130)
|
||||||
mDraw(MODES.drought_l.icon,63,200,nil,.5)
|
mDraw(IMG.drought,63,200,nil,.5)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
task=function(P)
|
task=function(P)
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ return{
|
|||||||
end
|
end
|
||||||
setFont(50)
|
setFont(50)
|
||||||
mStr(P.modeData.drought,63,130)
|
mStr(P.modeData.drought,63,130)
|
||||||
mDraw(MODES.drought_l.icon,63,200,nil,.5)
|
mDraw(IMG.drought,63,200,nil,.5)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
task=function(P)
|
task=function(P)
|
||||||
@@ -36,6 +36,7 @@ return{
|
|||||||
end,
|
end,
|
||||||
hook_drop=function(P)
|
hook_drop=function(P)
|
||||||
local D=P.modeData
|
local D=P.modeData
|
||||||
|
D.drought=P.lastPiece.id==7 and 0 or D.drought+1
|
||||||
if P.stat.row>=D.target then
|
if P.stat.row>=D.target then
|
||||||
if D.target==110 then
|
if D.target==110 then
|
||||||
P.gameEnv.drop,P.gameEnv.lock=2,2
|
P.gameEnv.drop,P.gameEnv.lock=2,2
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ return{
|
|||||||
end
|
end
|
||||||
setFont(50)
|
setFont(50)
|
||||||
mStr(P.modeData.drought,63,130)
|
mStr(P.modeData.drought,63,130)
|
||||||
mDraw(MODES.drought_l.icon,63,200,nil,.5)
|
mDraw(IMG.drought,63,200,nil,.5)
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
task=function(P)
|
task=function(P)
|
||||||
@@ -36,6 +36,7 @@ return{
|
|||||||
end,
|
end,
|
||||||
hook_drop=function(P)
|
hook_drop=function(P)
|
||||||
local D=P.modeData
|
local D=P.modeData
|
||||||
|
D.drought=P.lastPiece.id==7 and 0 or D.drought+1
|
||||||
if P.stat.row>=D.target then
|
if P.stat.row>=D.target then
|
||||||
if D.target==100 then
|
if D.target==100 then
|
||||||
P:win('finish')
|
P:win('finish')
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
local death_lock={12,11,10,9,8, 7,7,7,7,6}
|
local death_lock={12,11,10,9,8, 8,8,7,7,6}
|
||||||
local death_wait={10,9, 8, 7,6, 6,6,5,5,4}
|
local death_wait={10,9, 8, 7,6, 7,6,6,5,5}
|
||||||
local death_fall={10,9, 8, 7,6, 6,5,5,4,4}
|
local death_fall={10,9, 8, 7,6, 7,6,5,5,5}
|
||||||
|
|
||||||
return{
|
return{
|
||||||
drop=0,
|
drop=0,
|
||||||
|
|||||||
80
parts/eventsets/master_instinct.lua
Normal file
@@ -0,0 +1,80 @@
|
|||||||
|
local inv_lock={60,50,45,40,37, 34,32,30,28,26}
|
||||||
|
local inv_wait={12,11,11,10,10, 10,10, 9, 9, 9}
|
||||||
|
local inv_fall={18,16,14,13,12, 12,11,11,10,10}
|
||||||
|
local inv_hide={20,17,14,11, 8, 5, 3, 2, 1, 0}
|
||||||
|
local hidetimer=0
|
||||||
|
local held=false
|
||||||
|
|
||||||
|
return{
|
||||||
|
drop=0,
|
||||||
|
lock=inv_lock[1],
|
||||||
|
wait=inv_wait[1],
|
||||||
|
fall=inv_fall[1],
|
||||||
|
ghost=false,
|
||||||
|
noTele=true,
|
||||||
|
das=10,arr=1,
|
||||||
|
mesDisp=function(P)
|
||||||
|
PLY.draw.drawProgress(P.modeData.pt,P.modeData.target)
|
||||||
|
end,
|
||||||
|
hook_drop=function(P)
|
||||||
|
local D=P.modeData
|
||||||
|
|
||||||
|
local c=#P.clearedRow
|
||||||
|
if c==0 and D.pt%100==99 then return end
|
||||||
|
local s=c<3 and c+1 or c==3 and 5 or 7
|
||||||
|
if P.combo>7 then s=s+2
|
||||||
|
elseif P.combo>3 then s=s+1
|
||||||
|
end
|
||||||
|
D.pt=D.pt+s
|
||||||
|
held=false
|
||||||
|
if D.pt<1000 then
|
||||||
|
hidetimer=0-inv_wait[(P.modeData.pt/100-(P.modeData.pt%100)/100)+1]
|
||||||
|
if c>0 then hidetimer=hidetimer-inv_fall[(P.modeData.pt/100-(P.modeData.pt%100)/100)+1]end
|
||||||
|
end
|
||||||
|
|
||||||
|
if D.pt%100==99 then
|
||||||
|
SFX.play('warn_1')
|
||||||
|
elseif D.pt>=D.target then--Level up!
|
||||||
|
s=D.target/100
|
||||||
|
local E=P.gameEnv
|
||||||
|
E.lock=inv_lock[s]
|
||||||
|
E.wait=inv_wait[s]
|
||||||
|
E.fall=inv_fall[s]
|
||||||
|
|
||||||
|
if s==2 then
|
||||||
|
E.das=8
|
||||||
|
elseif s==4 then
|
||||||
|
BG.set('rgb')
|
||||||
|
elseif s==5 then
|
||||||
|
E.das=7
|
||||||
|
elseif s==7 then
|
||||||
|
E.das=6
|
||||||
|
BGM.play('far')
|
||||||
|
elseif s==10 then
|
||||||
|
D.pt=1000
|
||||||
|
P:win('finish')
|
||||||
|
return
|
||||||
|
end
|
||||||
|
D.target=D.target+100
|
||||||
|
P:stageComplete(s)
|
||||||
|
SFX.play('reach')
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
task=function(P)
|
||||||
|
P.modeData.pt=0
|
||||||
|
P.modeData.target=100
|
||||||
|
while true do
|
||||||
|
YIELD()
|
||||||
|
if P.holdTime==0 and P.waiting<=0 and not held then
|
||||||
|
hidetimer=0
|
||||||
|
held=true
|
||||||
|
end
|
||||||
|
hidetimer=hidetimer+1
|
||||||
|
if hidetimer>inv_hide[(P.modeData.pt/100-(P.modeData.pt%100)/100)+1]then
|
||||||
|
P.gameEnv.block=false
|
||||||
|
else
|
||||||
|
P.gameEnv.block=true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
}
|
||||||
@@ -5,15 +5,22 @@ local setFont=setFont
|
|||||||
local PLAYERS,PLY_ALIVE=PLAYERS,PLY_ALIVE
|
local PLAYERS,PLY_ALIVE=PLAYERS,PLY_ALIVE
|
||||||
|
|
||||||
return{
|
return{
|
||||||
|
layout='royale',
|
||||||
|
fkey1=function(P)
|
||||||
|
P:changeAtkMode(P.atkMode<3 and P.atkMode+2 or 5-P.atkMode)
|
||||||
|
P.swappingAtkMode=45
|
||||||
|
end,
|
||||||
mesDisp=function(P)
|
mesDisp=function(P)
|
||||||
setFont(35)
|
setFont(35)
|
||||||
mStr(#PLY_ALIVE.."/"..#PLAYERS,63,175)
|
mStr(#PLY_ALIVE.."/"..#PLAYERS,63,175)
|
||||||
mStr(P.modeData.ko,80,215)
|
mStr(P.modeData.ko,80,215)
|
||||||
gc_draw(TEXTOBJ.ko,60-TEXTOBJ.ko:getWidth(),222)
|
gc_draw(TEXTOBJ.ko,60-TEXTOBJ.ko:getWidth(),222)
|
||||||
|
|
||||||
setFont(20)
|
setFont(20)
|
||||||
gc_setColor(1,.5,0,.6)
|
gc_setColor(1,.5,0,.6)
|
||||||
gc_print(P.badge,103,227)
|
gc_print(P.badge,103,227)
|
||||||
gc_setColor(.97,.97,.97)
|
gc_setColor(.97,.97,.97)
|
||||||
|
|
||||||
setFont(25)
|
setFont(25)
|
||||||
mStr(text.powerUp[P.strength],63,290)
|
mStr(text.powerUp[P.strength],63,290)
|
||||||
gc_setColor(1,1,1)
|
gc_setColor(1,1,1)
|
||||||
|
|||||||
38
parts/eventsets/strategy_e_plus.lua
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
local waitSpeed={60,59,58,57,56,55,54,52,50,48,46,44,42,40,38,36,34,32,30}
|
||||||
|
|
||||||
|
return
|
||||||
|
{
|
||||||
|
holdCount=0,
|
||||||
|
das=5,arr=1,
|
||||||
|
drop=0,lock=7,
|
||||||
|
wait=60,fall=0,
|
||||||
|
freshLimit=12,
|
||||||
|
mesDisp=function(P)
|
||||||
|
PLY.draw.drawProgress(P.stat.row,P.modeData.target)
|
||||||
|
PLY.draw.drawTargetLine(P,200-P.stat.row)
|
||||||
|
end,
|
||||||
|
task=function(P)
|
||||||
|
P.modeData.target=10
|
||||||
|
end,
|
||||||
|
hook_drop=function(P)
|
||||||
|
if P.stat.row>=P.modeData.target then
|
||||||
|
if P.modeData.target==200 then
|
||||||
|
P:win('finish')
|
||||||
|
else
|
||||||
|
if P.modeData.target==40 then
|
||||||
|
BG.set('rainbow')
|
||||||
|
elseif P.modeData.target==80 then
|
||||||
|
BG.set('rainbow2')
|
||||||
|
elseif P.modeData.target==100 then
|
||||||
|
BG.set('glow')
|
||||||
|
P.modeData.lock=6
|
||||||
|
elseif P.modeData.target==120 then
|
||||||
|
BG.set('lightning')
|
||||||
|
end
|
||||||
|
P.gameEnv.wait=waitSpeed[P.modeData.target/10]
|
||||||
|
P.modeData.target=P.modeData.target+10
|
||||||
|
SFX.play('reach')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
}
|
||||||
39
parts/eventsets/strategy_h_plus.lua
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
local waitSpeed={30,29,28,27,26,25,24,23,22,21,20,19,18,18,17,17,16,16,15}
|
||||||
|
|
||||||
|
return
|
||||||
|
{
|
||||||
|
holdCount=0,
|
||||||
|
das=4,arr=1,
|
||||||
|
drop=0,lock=6,
|
||||||
|
wait=30,fall=0,
|
||||||
|
freshLimit=12,
|
||||||
|
mesDisp=function(P)
|
||||||
|
PLY.draw.drawProgress(P.stat.row,P.modeData.target)
|
||||||
|
PLY.draw.drawTargetLine(P,200-P.stat.row)
|
||||||
|
end,
|
||||||
|
task=function(P)
|
||||||
|
P.modeData.target=10
|
||||||
|
end,
|
||||||
|
hook_drop=function(P)
|
||||||
|
if P.stat.row>=P.modeData.target then
|
||||||
|
if P.modeData.target==200 then
|
||||||
|
P:win('finish')
|
||||||
|
else
|
||||||
|
if P.modeData.target==40 then
|
||||||
|
BG.set('rainbow')
|
||||||
|
elseif P.modeData.target==80 then
|
||||||
|
BG.set('rainbow2')
|
||||||
|
elseif P.modeData.target==100 then
|
||||||
|
BG.set('glow')
|
||||||
|
P.modeData.lock=5
|
||||||
|
BGM.play('secret8th remix')
|
||||||
|
elseif P.modeData.target==120 then
|
||||||
|
BG.set('lightning')
|
||||||
|
end
|
||||||
|
P.gameEnv.wait=waitSpeed[P.modeData.target/10]
|
||||||
|
P.modeData.target=P.modeData.target+10
|
||||||
|
SFX.play('reach')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
}
|
||||||
39
parts/eventsets/strategy_u_plus.lua
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
local waitSpeed={15,15,14,14,13,13,12,12,11,11,10,10,9,9,8,8,7,7,7}
|
||||||
|
|
||||||
|
return
|
||||||
|
{
|
||||||
|
holdCount=0,
|
||||||
|
das=3,arr=1,
|
||||||
|
drop=0,lock=5,
|
||||||
|
wait=15,fall=0,
|
||||||
|
freshLimit=12,
|
||||||
|
mesDisp=function(P)
|
||||||
|
PLY.draw.drawProgress(P.stat.row,P.modeData.target)
|
||||||
|
PLY.draw.drawTargetLine(P,200-P.stat.row)
|
||||||
|
end,
|
||||||
|
task=function(P)
|
||||||
|
P.modeData.target=10
|
||||||
|
end,
|
||||||
|
hook_drop=function(P)
|
||||||
|
if P.stat.row>=P.modeData.target then
|
||||||
|
if P.modeData.target==200 then
|
||||||
|
P:win('finish')
|
||||||
|
else
|
||||||
|
if P.modeData.target==40 then
|
||||||
|
BG.set('rainbow')
|
||||||
|
elseif P.modeData.target==80 then
|
||||||
|
BG.set('rainbow2')
|
||||||
|
elseif P.modeData.target==100 then
|
||||||
|
BG.set('glow')
|
||||||
|
P.modeData.lock=4
|
||||||
|
BGM.play('secret7th remix')
|
||||||
|
elseif P.modeData.target==120 then
|
||||||
|
BG.set('lightning')
|
||||||
|
end
|
||||||
|
P.gameEnv.wait=waitSpeed[P.modeData.target/10]
|
||||||
|
P.modeData.target=P.modeData.target+10
|
||||||
|
SFX.play('reach')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
}
|
||||||
@@ -7,6 +7,7 @@ local gc_draw,gc_rectangle,gc_line,gc_printf=gc.draw,gc.rectangle,gc.line,gc.pri
|
|||||||
|
|
||||||
local ins,rem=table.insert,table.remove
|
local ins,rem=table.insert,table.remove
|
||||||
local int,rnd=math.floor,math.random
|
local int,rnd=math.floor,math.random
|
||||||
|
local approach=MATH.expApproach
|
||||||
|
|
||||||
local SETTING,GAME,SCR=SETTING,GAME,SCR
|
local SETTING,GAME,SCR=SETTING,GAME,SCR
|
||||||
local PLAYERS=PLAYERS
|
local PLAYERS=PLAYERS
|
||||||
@@ -79,7 +80,7 @@ do--function loadFile(name,args), function saveFile(data,name,args)
|
|||||||
local text=text or t
|
local text=text or t
|
||||||
local res,mes=pcall(FILE.save,data,name,args)
|
local res,mes=pcall(FILE.save,data,name,args)
|
||||||
if res then
|
if res then
|
||||||
return mes
|
return true
|
||||||
else
|
else
|
||||||
MES.new('error',
|
MES.new('error',
|
||||||
mes:find'duplicate'and
|
mes:find'duplicate'and
|
||||||
@@ -94,7 +95,8 @@ do--function loadFile(name,args), function saveFile(data,name,args)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
function isSafeFile(file,mes)
|
function isSafeFile(file,mes)
|
||||||
if love.filesystem.getRealDirectory(file)~=SAVEDIR then
|
local path=love.filesystem.getRealDirectory(file)
|
||||||
|
if path and path~=SAVEDIR then
|
||||||
return true
|
return true
|
||||||
elseif mes then
|
elseif mes then
|
||||||
MES.new('warn',mes)
|
MES.new('warn',mes)
|
||||||
@@ -109,23 +111,7 @@ end
|
|||||||
function saveSettings()
|
function saveSettings()
|
||||||
return saveFile(SETTING,'conf/settings')
|
return saveFile(SETTING,'conf/settings')
|
||||||
end
|
end
|
||||||
function applyLanguage()
|
do--function applySettings()
|
||||||
text=LANG.get(SETTING.locale)
|
|
||||||
WIDGET.setLang(text.WidgetText)
|
|
||||||
for k,v in next,TEXTOBJ do
|
|
||||||
if rawget(text,k)then
|
|
||||||
v:set(text[k])
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
function applyCursor()
|
|
||||||
love.mouse.setVisible(SETTING.sysCursor)
|
|
||||||
end
|
|
||||||
function applyFullscreen()
|
|
||||||
love.window.setFullscreen(SETTING.fullscreen)
|
|
||||||
love.resize(gc.getWidth(),gc.getHeight())
|
|
||||||
end
|
|
||||||
do--function applyBlockSatur,applyFieldSatur(mode)
|
|
||||||
local saturateValues={
|
local saturateValues={
|
||||||
normal={0,1},
|
normal={0,1},
|
||||||
soft={.2,.7},
|
soft={.2,.7},
|
||||||
@@ -133,58 +119,79 @@ do--function applyBlockSatur,applyFieldSatur(mode)
|
|||||||
light={.2,.8},
|
light={.2,.8},
|
||||||
color={-.2,1.2},
|
color={-.2,1.2},
|
||||||
}
|
}
|
||||||
function applyBlockSatur(mode)
|
function applySettings()
|
||||||
local m=saturateValues[mode]or saturateValues.normal
|
--Apply fullscreen
|
||||||
|
love.window.setFullscreen(SETTING.fullscreen)
|
||||||
|
love.resize(gc.getWidth(),gc.getHeight())
|
||||||
|
|
||||||
|
--Apply Zframework setting
|
||||||
|
Z.setClickFX(SETTING.clickFX)
|
||||||
|
Z.setFrameMul(SETTING.frameMul)
|
||||||
|
Z.setPowerInfo(SETTING.powerInfo)
|
||||||
|
Z.setCleanCanvas(SETTING.cleanCanvas)
|
||||||
|
|
||||||
|
--Apply VK shape
|
||||||
|
VK.setShape(SETTING.VKSkin)
|
||||||
|
|
||||||
|
--Apply sound
|
||||||
|
love.audio.setVolume(SETTING.mainVol)
|
||||||
|
BGM.setVol(SETTING.bgm)
|
||||||
|
SFX.setVol(SETTING.sfx)
|
||||||
|
VOC.setVol(SETTING.voc)
|
||||||
|
|
||||||
|
--Apply saturs
|
||||||
|
local m
|
||||||
|
m=saturateValues[SETTING.blockSatur]or saturateValues.normal
|
||||||
SHADER.blockSatur:send('b',m[1])
|
SHADER.blockSatur:send('b',m[1])
|
||||||
SHADER.blockSatur:send('k',m[2])
|
SHADER.blockSatur:send('k',m[2])
|
||||||
end
|
m=saturateValues[SETTING.fieldSatur]or saturateValues.normal
|
||||||
function applyFieldSatur(mode)
|
|
||||||
local m=saturateValues[mode]or saturateValues.normal
|
|
||||||
SHADER.fieldSatur:send('b',m[1])
|
SHADER.fieldSatur:send('b',m[1])
|
||||||
SHADER.fieldSatur:send('k',m[2])
|
SHADER.fieldSatur:send('k',m[2])
|
||||||
end
|
|
||||||
end
|
--Apply language
|
||||||
function applyBG()
|
text=LANG.get(SETTING.locale)
|
||||||
if SETTING.bg=='on'then
|
WIDGET.setLang(text.WidgetText)
|
||||||
BG.unlock()
|
for k,v in next,TEXTOBJ do
|
||||||
BG.set()
|
if rawget(text,k)then
|
||||||
elseif SETTING.bg=='off'then
|
v:set(text[k])
|
||||||
BG.unlock()
|
end
|
||||||
BG.set('gray')
|
end
|
||||||
BG.send(SETTING.bgAlpha)
|
|
||||||
BG.lock()
|
--Apply cursor
|
||||||
elseif SETTING.bg=='custom'then
|
love.mouse.setVisible(SETTING.sysCursor)
|
||||||
if love.filesystem.getInfo('conf/customBG')then
|
|
||||||
local res,image=pcall(gc.newImage,love.filesystem.newFile('conf/customBG'))
|
--Apply BG
|
||||||
if res then
|
if SETTING.bg=='on'then
|
||||||
BG.unlock()
|
BG.unlock()
|
||||||
BG.set('custom')
|
BG.set()
|
||||||
gc.setDefaultFilter('linear','linear')
|
elseif SETTING.bg=='off'then
|
||||||
BG.send(SETTING.bgAlpha,image)
|
BG.unlock()
|
||||||
gc.setDefaultFilter('nearest','nearest')
|
BG.set('gray')
|
||||||
BG.lock()
|
BG.send(SETTING.bgAlpha)
|
||||||
else
|
BG.lock()
|
||||||
MES.new('error',text.customBGloadFailed)
|
elseif SETTING.bg=='custom'then
|
||||||
|
if love.filesystem.getInfo('conf/customBG')then
|
||||||
|
local res,image=pcall(gc.newImage,love.filesystem.newFile('conf/customBG'))
|
||||||
|
if res then
|
||||||
|
BG.unlock()
|
||||||
|
BG.set('custom')
|
||||||
|
gc.setDefaultFilter('linear','linear')
|
||||||
|
BG.send(SETTING.bgAlpha,image)
|
||||||
|
gc.setDefaultFilter('nearest','nearest')
|
||||||
|
BG.lock()
|
||||||
|
else
|
||||||
|
MES.new('error',text.customBGloadFailed)
|
||||||
|
end
|
||||||
|
else--Switch off when custom BG not found
|
||||||
|
SETTING.bg='off'
|
||||||
|
BG.unlock()
|
||||||
|
BG.set('gray')
|
||||||
|
BG.send(SETTING.bgAlpha)
|
||||||
|
BG.lock()
|
||||||
end
|
end
|
||||||
else
|
|
||||||
SETTING.bg='off'
|
|
||||||
applyBG()
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
function applyAllSettings()
|
|
||||||
applyFullscreen()
|
|
||||||
love.audio.setVolume(SETTING.mainVol)
|
|
||||||
VK.setShape(SETTING.VKSkin)
|
|
||||||
BGM.setVol(SETTING.bgm)
|
|
||||||
SFX.setVol(SETTING.sfx)
|
|
||||||
VOC.setVol(SETTING.voc)
|
|
||||||
applyBlockSatur(SETTING.blockSatur)
|
|
||||||
applyFieldSatur(SETTING.fieldSatur)
|
|
||||||
applyLanguage()
|
|
||||||
applyCursor()
|
|
||||||
applyBG()
|
|
||||||
end
|
|
||||||
|
|
||||||
--Royale mode
|
--Royale mode
|
||||||
function randomTarget(P)--Return a random opponent for P
|
function randomTarget(P)--Return a random opponent for P
|
||||||
@@ -491,12 +498,9 @@ end
|
|||||||
function loadGame(mode,ifQuickPlay,ifNet)--Load a mode and go to game scene
|
function loadGame(mode,ifQuickPlay,ifNet)--Load a mode and go to game scene
|
||||||
freshDate()
|
freshDate()
|
||||||
if legalGameTime()then
|
if legalGameTime()then
|
||||||
if not MODES[mode]and love.filesystem.getRealDirectory('parts/modes/'..mode)~=SAVEDIR then
|
if not MODES[mode].available then
|
||||||
MODES[mode]=require('parts.modes.'..mode)
|
MES.new('error',"Unavailable mode: "..mode)
|
||||||
MODES[mode].name=mode
|
return
|
||||||
end
|
|
||||||
if MODES[mode].score then
|
|
||||||
STAT.lastPlay=mode
|
|
||||||
end
|
end
|
||||||
GAME.playing=true
|
GAME.playing=true
|
||||||
GAME.init=true
|
GAME.init=true
|
||||||
@@ -537,29 +541,9 @@ function gameOver()--Save record
|
|||||||
GAME.rank=R
|
GAME.rank=R
|
||||||
end
|
end
|
||||||
if not GAME.replaying and M.score and scoreValid()then
|
if not GAME.replaying and M.score and scoreValid()then
|
||||||
if RANKS[M.name]then--Old rank exist
|
if not RANKS[M.name]or R>RANKS[M.name]then--Old rank exist
|
||||||
local needSave
|
RANKS[M.name]=R
|
||||||
if R>RANKS[M.name]then
|
saveProgress()
|
||||||
RANKS[M.name]=R
|
|
||||||
needSave=true
|
|
||||||
end
|
|
||||||
if R>0 then
|
|
||||||
if M.unlock then
|
|
||||||
for i=1,#M.unlock do
|
|
||||||
local m=M.unlock[i]
|
|
||||||
local n=MODES[m].name
|
|
||||||
if not RANKS[n]then
|
|
||||||
if MODES[m].x then
|
|
||||||
RANKS[n]=0
|
|
||||||
end
|
|
||||||
needSave=true
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if needSave then
|
|
||||||
saveProgress()
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
local D=M.score(P)
|
local D=M.score(P)
|
||||||
local L=M.records
|
local L=M.records
|
||||||
@@ -771,7 +755,7 @@ do--function resetGameData(args)
|
|||||||
BGM.play(type(bgm)=='string'and bgm or type(bgm)=='table'and bgm[math.random(#bgm)])
|
BGM.play(type(bgm)=='string'and bgm or type(bgm)=='table'and bgm[math.random(#bgm)])
|
||||||
|
|
||||||
TEXT.clear()
|
TEXT.clear()
|
||||||
if GAME.modeEnv.royaleMode then
|
if GAME.modeEnv.eventSet=='royale'then
|
||||||
for i=1,#PLAYERS do
|
for i=1,#PLAYERS do
|
||||||
PLAYERS[i]:changeAtk(randomTarget(PLAYERS[i]))
|
PLAYERS[i]:changeAtk(randomTarget(PLAYERS[i]))
|
||||||
end
|
end
|
||||||
@@ -792,7 +776,7 @@ do--function resetGameData(args)
|
|||||||
end
|
end
|
||||||
do--function checkWarning()
|
do--function checkWarning()
|
||||||
local max=math.max
|
local max=math.max
|
||||||
function checkWarning()
|
function checkWarning(dt)
|
||||||
local P1=PLAYERS[1]
|
local P1=PLAYERS[1]
|
||||||
if P1.alive then
|
if P1.alive then
|
||||||
if P1.frameRun%26==0 then
|
if P1.frameRun%26==0 then
|
||||||
@@ -812,7 +796,7 @@ do--function checkWarning()
|
|||||||
end
|
end
|
||||||
local _=GAME.warnLVL
|
local _=GAME.warnLVL
|
||||||
if _<GAME.warnLVL0 then
|
if _<GAME.warnLVL0 then
|
||||||
_=_*.95+GAME.warnLVL0*.05
|
_=approach(_,GAME.warnLVL0,dt*6)
|
||||||
elseif _>0 then
|
elseif _>0 then
|
||||||
_=max(_-.026,0)
|
_=max(_-.026,0)
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -13,6 +13,13 @@ BLOCK_COLORS={
|
|||||||
COLOR.dH,COLOR.D,COLOR.lY,COLOR.H,COLOR.lH,COLOR.dV,COLOR.dR,COLOR.dG,
|
COLOR.dH,COLOR.D,COLOR.lY,COLOR.H,COLOR.lH,COLOR.dV,COLOR.dR,COLOR.dG,
|
||||||
}
|
}
|
||||||
RANK_CHARS={'B','A','S','U','X'}for i=1,#RANK_CHARS do RANK_CHARS[i]=CHAR.icon['rank'..RANK_CHARS[i]]end
|
RANK_CHARS={'B','A','S','U','X'}for i=1,#RANK_CHARS do RANK_CHARS[i]=CHAR.icon['rank'..RANK_CHARS[i]]end
|
||||||
|
RANK_BASE_COLORS={
|
||||||
|
{.1,.2,.3},
|
||||||
|
{.3,.42,.32},
|
||||||
|
{.45,.44,.15},
|
||||||
|
{.42,.25,.2},
|
||||||
|
{.42,.15,.4},
|
||||||
|
}
|
||||||
RANK_COLORS={
|
RANK_COLORS={
|
||||||
{.8,.86,.9},
|
{.8,.86,.9},
|
||||||
{.6,.9,.7},
|
{.6,.9,.7},
|
||||||
@@ -594,7 +601,7 @@ do--Userdata tables
|
|||||||
FTLock=true,
|
FTLock=true,
|
||||||
|
|
||||||
--System
|
--System
|
||||||
reTime=4,
|
reTime=2,
|
||||||
allowTAS=false,
|
allowTAS=false,
|
||||||
autoPause=true,
|
autoPause=true,
|
||||||
menuPos='middle',
|
menuPos='middle',
|
||||||
@@ -603,11 +610,13 @@ do--Userdata tables
|
|||||||
autoLogin=true,
|
autoLogin=true,
|
||||||
simpMode=false,
|
simpMode=false,
|
||||||
sysCursor=true,
|
sysCursor=true,
|
||||||
|
maxFPS=60,
|
||||||
|
frameMul=100,
|
||||||
locale='zh',
|
locale='zh',
|
||||||
skinSet='crystal_scf',
|
skinSet='crystal_scf',
|
||||||
skin={
|
skin={
|
||||||
1,7,11,3,14,4,9,
|
1,7,11,3,14,4,9,
|
||||||
1,7,2,6,10,2,13,5,9,15,10,11,3,12,2,16,8,4,
|
1,7,2,6,10,2,13,5,9,15,4,11,3,12,2,16,8,4,
|
||||||
10,13,2,8
|
10,13,2,8
|
||||||
},
|
},
|
||||||
face={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
|
face={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},
|
||||||
@@ -625,7 +634,6 @@ do--Userdata tables
|
|||||||
splashFX=2,
|
splashFX=2,
|
||||||
shakeFX=2,
|
shakeFX=2,
|
||||||
atkFX=2,
|
atkFX=2,
|
||||||
frameMul=100,
|
|
||||||
cleanCanvas=false,
|
cleanCanvas=false,
|
||||||
blockSatur='normal',
|
blockSatur='normal',
|
||||||
fieldSatur='normal',
|
fieldSatur='normal',
|
||||||
@@ -723,3 +731,44 @@ do--Userdata tables
|
|||||||
todayTime=0,
|
todayTime=0,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
do--Mode data tables
|
||||||
|
MODES=setmetatable({},{__index=function(self,name)
|
||||||
|
local M
|
||||||
|
if love.filesystem.getInfo('parts/modes/'..name..'.lua')and love.filesystem.getRealDirectory('parts/modes/'..name..'.lua')~=SAVEDIR then
|
||||||
|
M=require('parts.modes.'..name)
|
||||||
|
M.available=true
|
||||||
|
M.name=name
|
||||||
|
do--Check if need slowmark
|
||||||
|
for k in next,M.env do
|
||||||
|
if
|
||||||
|
k=='mindas'or k=='minarr'or
|
||||||
|
k=='das'or k=='arr'or
|
||||||
|
k=='minsdarr'
|
||||||
|
then
|
||||||
|
M.slowMark=true
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if M.score then
|
||||||
|
M.records=loadFile("record/"..name..".rec",'-luaon -canSkip')or{}
|
||||||
|
end
|
||||||
|
else
|
||||||
|
M={
|
||||||
|
available=false,
|
||||||
|
}
|
||||||
|
MES.new('error',"Failed to load mode file: "..name)
|
||||||
|
end
|
||||||
|
self[name]=M
|
||||||
|
return M
|
||||||
|
end})
|
||||||
|
MODEICON=setmetatable({},{__index=function(self,k)
|
||||||
|
if isSafeFile('media/image/modeicon/'..k..'.png')then
|
||||||
|
local img=love.graphics.newImage('media/image/modeicon/'..k..'.png')
|
||||||
|
self[k]=img
|
||||||
|
return img
|
||||||
|
else
|
||||||
|
return PAPER
|
||||||
|
end
|
||||||
|
end})
|
||||||
|
end
|
||||||
|
|||||||
@@ -1,20 +1,20 @@
|
|||||||
local HDsearch="https://harddrop.com/wiki?search="
|
local HDsearch="https://harddrop.com/wiki?search="
|
||||||
local HDwiki="\nVisit HD Wiki for more information"
|
local HDwiki="\nVisit Hard Drop Wiki for more information."
|
||||||
return{
|
return{
|
||||||
{"Translator Note 1",
|
{"Translator Note 1",
|
||||||
"",
|
"",
|
||||||
"help",
|
"help",
|
||||||
"This translation of the TetroDictionary is provided by me, User670 (Discord: User670#9501).\n\nThe translation may not completely reflect the contents of the original Chinese text.\n\nCorrected by C₂₉H₂₅N₃O₅ (Discord: C29H25N3O5#1606).\n\nTo view the list of contributors or make contributions, feel free to visit the GitHub page.",
|
"This translation of the TetroDictionary is maly provided by User670 (Discord: User670#9501).\n\nThe translation may not completely reflect the contents of the original Chinese text.\n\nTo view the list of contributors or make contributions, feel free to visit the GitHub page.",
|
||||||
"https://github.com/26F-Studio/Techmino/blob/main/parts/language/dict_en.lua",
|
"https://github.com/26F-Studio/Techmino/blob/main/parts/language/dict_en.lua",
|
||||||
},
|
},
|
||||||
{"Official Website",
|
{"Official Website",
|
||||||
"official website homepage",
|
"official website homepage mainpage",
|
||||||
"help",
|
"help",
|
||||||
"The official website of Techmino!\nYou can modify your profile on it",
|
"The official website of Techmino!\nYou can modify your profile on it",
|
||||||
"http://home.techmino.org",
|
"http://home.techmino.org",
|
||||||
},
|
},
|
||||||
{"To New Players",
|
{"To New Players",
|
||||||
"guide newbie noob",
|
"guide newbie noob readme",
|
||||||
"help",
|
"help",
|
||||||
"To new players that want to get better at the game:\n\tTwo principles:\n\t1. find a version with good controls (e.g. Techmino, Tetr.io, Tetris Online, Jstris, Tetr.js). Do not use those version used for programming practice.\n\t2. Build foundations in your skills (stable Techrashes using next queue to aid decisions), don't go for fancy T-Spins from the start.\n\n\tTwo main techniques:\n\t1. familiarize yourself with spawn locations of pieces, and the controls to move the piece into each location\n\t2. Plan ahead of where to put the pieces\nHere is a article written by a well-known player in Chinese Tetris community talking about advices to new players. Click the globe to read the translated article by User670.",
|
"To new players that want to get better at the game:\n\tTwo principles:\n\t1. find a version with good controls (e.g. Techmino, Tetr.io, Tetris Online, Jstris, Tetr.js). Do not use those version used for programming practice.\n\t2. Build foundations in your skills (stable Techrashes using next queue to aid decisions), don't go for fancy T-Spins from the start.\n\n\tTwo main techniques:\n\t1. familiarize yourself with spawn locations of pieces, and the controls to move the piece into each location\n\t2. Plan ahead of where to put the pieces\nHere is a article written by a well-known player in Chinese Tetris community talking about advices to new players. Click the globe to read the translated article by User670.",
|
||||||
"https://github.com/user670/temp/blob/master/tips_to_those_new_to_top.md",
|
"https://github.com/user670/temp/blob/master/tips_to_those_new_to_top.md",
|
||||||
@@ -39,7 +39,7 @@ return{
|
|||||||
{"Four.lol",
|
{"Four.lol",
|
||||||
"four wiki",
|
"four wiki",
|
||||||
"help",
|
"help",
|
||||||
"An website containing collections of various openings with simple UI and very detailed consecutive PC analyses (Not recommended for new players as you may have to memorize many techniques).",
|
"An website containing collections of various openings with simple UI and very detailed consecutive PC analyses (Not recommended for new players, as you may have to memorize many techniques).",
|
||||||
"https://four.lol",
|
"https://four.lol",
|
||||||
},
|
},
|
||||||
{"Tetris Wiki Fandom",
|
{"Tetris Wiki Fandom",
|
||||||
@@ -59,7 +59,7 @@ return{
|
|||||||
{"Github Repository",
|
{"Github Repository",
|
||||||
"githubrepository sourcecode",
|
"githubrepository sourcecode",
|
||||||
"org",
|
"org",
|
||||||
"Techmino's Github repository. Stars are appreciated.",
|
"Techmino's official Github repository. Stars are appreciated.",
|
||||||
"https://github.com/26F-Studio/Techmino",
|
"https://github.com/26F-Studio/Techmino",
|
||||||
},
|
},
|
||||||
{"Communities",
|
{"Communities",
|
||||||
@@ -69,7 +69,7 @@ return{
|
|||||||
"https://discord.gg/harddrop"
|
"https://discord.gg/harddrop"
|
||||||
},
|
},
|
||||||
{"Mew",
|
{"Mew",
|
||||||
"mew tieba forum",
|
"mew tieba forum reddit",
|
||||||
"org",
|
"org",
|
||||||
"The Mew forum owned by Chinese Tetris Research Community, and was founded in the second half of 2021. Mew is a Chinese social media that can be thought of a combination of Discord and Reddit, with many channels in a big community. Users can chat in the channels or submit posts to the channel. Mew also has a function called \"Library\" which allows storing documentations systematically. The Tetris Mew forum is currently under construction and not too much contents are available (2/Nov/2021).",
|
"The Mew forum owned by Chinese Tetris Research Community, and was founded in the second half of 2021. Mew is a Chinese social media that can be thought of a combination of Discord and Reddit, with many channels in a big community. Users can chat in the channels or submit posts to the channel. Mew also has a function called \"Library\" which allows storing documentations systematically. The Tetris Mew forum is currently under construction and not too much contents are available (2/Nov/2021).",
|
||||||
"https://mew.fun/n/tetris",
|
"https://mew.fun/n/tetris",
|
||||||
@@ -80,217 +80,244 @@ return{
|
|||||||
"Google \"Tetris Online Poland\" for the Poland server.\nClick on the globe icon for information about the Tetris Online Study server.",
|
"Google \"Tetris Online Poland\" for the Poland server.\nClick on the globe icon for information about the Tetris Online Study server.",
|
||||||
"http://teatube.ltd/tos",
|
"http://teatube.ltd/tos",
|
||||||
},
|
},
|
||||||
{"P\97\116\114\101\111\110",
|
{"Support 1",
|
||||||
"p\97\116\114\101\111\110 support",
|
"support wechat vx alipay zfb",
|
||||||
"org",
|
"org",
|
||||||
"Techmino's P\97\116\114\101\111\110 Page",
|
FNNS and "This feature is restricted due to platform policy restrictions. You may discuss about this feature in our Discord server." or "To donate to Techmino via WeChat Pay or Alipay, type \"support\" in console.",
|
||||||
FNSF and"https://www.youtube.com/watch?v=DVl0IiUKX_g"or"https://www.p\97\116\114\101\111\110.com/techmino",
|
|
||||||
},
|
},
|
||||||
|
{"Support 2",
|
||||||
|
"support afdian",
|
||||||
|
"org",
|
||||||
|
FNNS and "This feature is restricted due to platform policy restrictions. You may discuss about this feature in our Discord server. The URL in this entry is a rickroll, by the way." or "To donate to Techmino via Aifadian, use the globe icon on the bottom right to open URL. Aifadian charges 6% transaction fee off your purchase.",
|
||||||
|
FNNS and"https://youtu.be/dQw4w9WgXcQ"or"https://afdian.net/@MrZ_26",
|
||||||
|
},
|
||||||
|
{"Support 3",
|
||||||
|
"support p\97\116\114\101\111\110",
|
||||||
|
"org",
|
||||||
|
FNNS and "This feature is restricted due to platform policy restrictions. You may discuss about this feature in our Discord server. The URL in this entry is a rickroll, by the way." or "To donate to Techmino via P\97\116\114\101\111\110, use the globe icon on the bottom right to open URL. P\97\116\114\101\111\110 charges 7.9% + 0.30 USD transaction fee off your purchase that is greater than 3 USD.",
|
||||||
|
FNNS and"https://youtu.be/dQw4w9WgXcQ"or"https://www.p\97\116\114\101\111\110.com/techmino",
|
||||||
|
},
|
||||||
|
|
||||||
--Games
|
--Games
|
||||||
{"TTT",
|
{"TTT",
|
||||||
"ttt tetris trainer tres bien",
|
"ttt tetris trainer tres bien",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based, no mobile support | Single-player*\nTetris Trainer Tres-Bien. A hands-on tutorial of advanced techniques in modern Tetris.\nRecommended for players that can complete a 40-line Sprint with all Tetris line clears and no hold.\nCovered topics include T-Spin, finesse, SRS, and some battle setups.\nLink translated to Simplified Chinese; originally in Japanese.",
|
"Tetris Trainer Très-Bien. A hands-on tutorial of advanced techniques in modern Tetris.\nRecommended for players that can complete a 40-line Sprint with all Tetris line clears and no hold.\nCovered topics include T-Spin, finesse, SRS, and some battle setups.\nLink in Japanese.",
|
||||||
"http://teatube.ltd/ttt",
|
"http://taninkona.web.fc2.com/ttt/",
|
||||||
},
|
},
|
||||||
{"TTPC",
|
{"TTPC",
|
||||||
"ttpc tetris perfect clear challenge",
|
"ttpc tetris perfect clear challenge",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based, no mobile support | Single-player*\nTetris Perfect Clear Challenge. The PC opener tutorial for SRS+7 Bag.\nRecommended for players that have completed TTT. You need to know SRS to play this.\nIncludes only the basic PC opener.\nLink translated to Simplified Chinese; originally in Japanese.",
|
"Tetris Perfect Clear Challenge. The PC opener tutorial for SRS and 7-Bag.\nRecommended for players that have completed TTT. You need to know SRS to play this.\nIncludes only the basic PC opener.\nLink translated to Simplified Chinese; originally in Japanese.",
|
||||||
"http://teatube.ltd/ttpc",
|
"http://teatube.ltd/ttpc",
|
||||||
},
|
},
|
||||||
{"NAZO",
|
{"NAZO",
|
||||||
"nazo",
|
"nazo",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based, no mobile support | Single-player*\nAll sorts of SRS puzzles. Recommended for players that have completed TTT.\nHas T-Spin and all spin puzzles of all difficulties.\nLink translated to Simplified Chinese; originally in Japanese.",
|
"All sorts of SRS puzzles. Recommended for players that have completed TTT.\nHas T-Spin and all spin puzzles of all difficulties.\nLink translated to Simplified Chinese; originally in Japanese.",
|
||||||
"http://teatube.ltd/nazo",
|
"http://teatube.ltd/nazo",
|
||||||
},
|
},
|
||||||
|
|
||||||
|
{"Side Note 1",
|
||||||
|
"note nb NB DM notice",
|
||||||
|
"game",
|
||||||
|
"The following contents are some brief introductions about some official and fan-made Tetris games with high popularity. We make absolutely no guarantees that they would cover every Tetris game. Also, the author of this game has made some comments on some of these games. Notice that they are just personal opinions and cannot be used to judge the qualities of these games. To better differentiate between the facts and opinions, all the commentary contents are enclosed with square brackets and are separated from the main contents.",
|
||||||
|
},
|
||||||
{"King of Stackers",
|
{"King of Stackers",
|
||||||
"kos kingofstackers",
|
"kos kingofstackers",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based | Multiplayer*\nTurn-based battle Tetris game.",
|
"Browser Game | Multiplayer | Mobile Support\nKoS for short. A turn-based battle Tetris game. In this game, the players can place seven tetrominoes in his or her turn, and garbage lines can enter the field only if the player places a block that does not clear a line. This game requires careful thinking and there are multiple modes with different attack mechanics.",
|
||||||
"https://kingofstackers.com/games.php",
|
"https://kingofstackers.com/games.php",
|
||||||
},
|
},
|
||||||
{"Tetr.js",
|
{"Tetr.js",
|
||||||
"tetrjs tetr.js",
|
"tetrjs tetr.js",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based | Single-player*\nHas newbie-friendly custom modes (most common features). Only a few on-screen control schemes are available to mobile.\nLink to Farter's Dig Mod, which itself is a mod of another version. Also has another mod called Tetr.js Enhanced.",
|
"Browser Game | Singleplayer | Mobile Support\nA browser-based Tetris game. It has many professional tunings and many modes, but the visuals are simple and there are barely any animations; besides that, only a few on-screen control schemes are available to mobile.\nLink to Farter's Dig Mod, which itself is a mod of another version. Also has another mod called Tetr.js Enhanced (You can find the link on Tetris Wiki).",
|
||||||
"http://farter.cn/t",
|
"http://farter.cn/t",
|
||||||
},
|
},
|
||||||
{"Tetra Legends",
|
{"Tetra Legends",
|
||||||
"tl tetralegends",
|
"tl tetralegends",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based, no mobile support | Single-player*\nFeature-rich game with fancy visuals, also visualized some data that are otherwise hidden in other games, although controls aren't exactly the most comfortable. Has a rhythm mode.\nIt can be slow to load the game for the first time.",
|
"Browser Game | Singleplayer | No Mobile Support\nOr TL for short. It has many single-player modes, two hidden rhythm modes, and visualizes many hidden mechanics with rich animations. The development of this game was halted for multiple reasons in December 2020.",
|
||||||
"https://tetralegends.app",
|
"https://tetralegends.app",
|
||||||
},
|
},
|
||||||
{"Ascension",
|
{"Ascension",
|
||||||
"asc ascension",
|
"asc ascension ASC",
|
||||||
"game",
|
"game",
|
||||||
"Or ASC for short. A cross-platform web-based Tetris game using its own rotation system called ASC. It may take a very long time when first loading this game. It also has many single-player modes (The \"Stack\" mode in Techmino was inspired by Ascension). Battle mode is currently in the testing phase (08/20/2021).",
|
"Browser Game | Singleplayer/Multiplayer\nOr ASC for short. It uses its own rotation system (also called ASC) and has many single-player modes. Battle modes are currently under beta testing (15/Dec/2021). The Stack mode in this game was also inspired by Ascension. ",
|
||||||
"https://asc.winternebs.com",
|
"https://asc.winternebs.com",
|
||||||
},
|
},
|
||||||
{"Jstris",
|
{"Jstris",
|
||||||
"js jstris",
|
"js jstris",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based | Single-player and multiplayer*\nBasic web-based battle Tetris game.",
|
"Browser Game | Singleplayer/Multiplayer | Mobile Support\nOr JS for short. It has some single-player modes with multiple customizable parameters, Adjustable virtual keys layouts for mobile, but it doesn't have any animation. ",
|
||||||
"https://jstris.jezevec10.com",
|
"https://jstris.jezevec10.com",
|
||||||
},
|
},
|
||||||
{"TETR.IO",
|
{"TETR.IO",
|
||||||
"io tetrio tetr.io",
|
"io tetrio tetr.io",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based, no mobile support | Single-player and multiplayer*\nFancy online battling Tetris game.",
|
"Browser Game | Singleplayer/Multiplayer\nOr IO for short. It has a ranking system and custom game with many adjustable parameters. Also, it provides desktop clients for improved performances and no ads.\n[It seems that Safari cannot open this game.]",
|
||||||
"https://tetr.io",
|
"https://tetr.io",
|
||||||
},
|
},
|
||||||
{"Nuketris",
|
{"Nuketris",
|
||||||
"nuketris",
|
"nuketris",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based | Single-player and multiplayer*\nA block stacker game with 1-vs-1 ranked mode and a few single-player modes. A PC is recommended for playing this game.",
|
"*Browser Game | Singleplayer/Multiplayer\nA block stacker game with 1V1 ranked matches and basic single-player modes.",
|
||||||
"https://nuketris.herokuapp.com",
|
"https://nuketris.herokuapp.com",
|
||||||
},
|
},
|
||||||
{"WWC",
|
{"Worldwide Combos",
|
||||||
"wwc worldwidecombos",
|
"wwc worldwidecombos",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based | Multiplayer*\nWorldwide Combos, a web-based worldwide 1-vs-1 battle Tetris game.",
|
"Browser Game | Singleplayer/Multiplayer\nOr WWC for short. It has worldwide 1V1 ranked matches, recorded battles (which means that your opponent doesn't have to be a real person), many different rulesets, and bomb-handicapped garbage lines.",
|
||||||
"https://worldwidecombos.com",
|
"https://worldwidecombos.com",
|
||||||
},
|
},
|
||||||
{"Tetris Friends",
|
{"Tetris Friends",
|
||||||
"tf tetrisfriends notrisfoes",
|
"tf tetrisfriends notrisfoes",
|
||||||
"game",
|
"game",
|
||||||
"*Web-based, no mobile support | Single-player and multiplayer*\nA now-defunct web-based Tetris game; used to be a decent battle game. An unofficial private server known as Notris Foes exists.\nBuilt using Flash, which might require workarounds to play or cannot run at all on your devices.",
|
"Browser Game | Singleplayer/Multiplayer\n or TF for short, a now-defunct official Tetris game. Used to be a popular game but now nobody plays it because the website was shut down. However an unofficial private server known as \"Notris Foes\" still exists and you will need to download desktop client for full experiences.",
|
||||||
},
|
},
|
||||||
{"tetris.com",
|
{"tetris.com",
|
||||||
"tetris online official",
|
"tetris online official",
|
||||||
"game",
|
"game",
|
||||||
"The Tetris game on tetris.com. It only has one mode – marathon, and you can control the game with your mouse.",
|
"Browser Game | Singleplayer\nThe Tetris game on tetris.com. It only has one mode — marathon, and you can control the game with your mouse.",
|
||||||
},
|
},
|
||||||
{"Tetris Gems",
|
{"Tetris Gems",
|
||||||
"tetris online official gem",
|
"tetris online official gem",
|
||||||
"game",
|
"game",
|
||||||
"Another Tetris game from tetris.com. It has the gravity mechanism, and each game lasts for 1 minute. There are three kinds of gem blocks with different abilities.",
|
"Browser Game | Singleplayer\nAnother Tetris game from tetris.com. It has the gravity mechanism, and each game lasts for 1 minute. There are three kinds of gem blocks with different abilities.",
|
||||||
},
|
},
|
||||||
{"Tetris Mind Bender",
|
{"Tetris Mind Bender",
|
||||||
"tetris online official gem",
|
"tetris online official gem",
|
||||||
"game",
|
"game",
|
||||||
"Another Tetris game from tetris.com. It introduced \"Mind Bender\" minoes on the basis of marathon mode. Clearing a line with a Mind Bender mino will give you either a good or bad effect.",
|
"Browser Game | Singleplayer\nAnother Tetris game from tetris.com. It introduced \"Mind Bender\" minoes on the basis of marathon mode. Clearing a line with a Mind Bender mino will give you either a good or bad effect.",
|
||||||
|
},
|
||||||
|
|
||||||
|
{"Techmino",
|
||||||
|
"techmino",
|
||||||
|
"game",
|
||||||
|
"Cross-Platform | Singleplayer/Multiplayer\nOr Tech for short. A block stacker game developed using LÖVE. It has many single-player modes and many customizable parameters, and online multiplayer modes are gradually being developed.",
|
||||||
|
},
|
||||||
|
{"Falling Lightblocks",
|
||||||
|
"fl fallinglightblocks",
|
||||||
|
"game",
|
||||||
|
"Browser Game/iOS/Android | Singleplayer/Multiplayer\n A cross-platform Tetris game that can be played in portrait and landscape modes. It has fixed DAS and line clear ARE. Has some customizable controls on mobile. Most of the game modes are designed based on NES classic Tetris, but there are some modern-ish modes. Battles are half turn-based, half real-time, and garbage cannot be buffered or canceled.",
|
||||||
|
"https://golfgl.de/lightblocks/",
|
||||||
|
},
|
||||||
|
{"Cambridge",
|
||||||
|
"cambridge",
|
||||||
|
"game",
|
||||||
|
"Cross-Platform | Singleplayer\n A Tetris game developed using LÖVE and is dedicated to creating a robust, easily customizable platform for creating new, custom game modes. Originally made by Joe Zeng, but Milla took over the development on 08/Oct/2020 starting from V0.1.5.\n — Tetris Wiki",
|
||||||
|
},
|
||||||
|
{"Nanamino",
|
||||||
|
"nanamino",
|
||||||
|
"game",
|
||||||
|
"Windows/Android | Singleplayer\nA developing fan game which has a interesting original rotation system.",
|
||||||
},
|
},
|
||||||
|
|
||||||
{"TGM",
|
{"TGM",
|
||||||
"tgm tetrisgrandmaster tetristhegrandmaster",
|
"tgm tetrisgrandmaster tetristhegrandmaster",
|
||||||
"game",
|
"game",
|
||||||
"*Arcade | Single-player*\nTetris The Grand Master, an arcade Tetris series that can run on Microsoft Windows. Titles like S13 or GM come from this series.\n\nTGM3 is the most well-known game in this series.",
|
"Arcade | Singleplayer/Local Multiplayer\nTetris The Grand Master, an arcade Tetris series. Titles like S13 and GM come from this series.\n\nTGM3 is the most well-known game in this series.",
|
||||||
},
|
},
|
||||||
{"DTET",
|
{"DTET",
|
||||||
"dtet",
|
"dtet",
|
||||||
"game",
|
"game",
|
||||||
"*Windows | Single-player*\nA game based on TGM's Classic rule with 20G and a powerful rotation system. Decent controls, but has no customization other than control mappings. The game is a bit hard to find now and you might need to manually install required DLLs.",
|
"Windows | Singleplayer\nA game based on TGM's Classic rule with 20G and a powerful rotation system. Decent controls, but has no customization other than control mappings. The game is a bit hard to find now and you may need to manually install required DLLs.",
|
||||||
},
|
},
|
||||||
{"Heboris",
|
{"Heboris",
|
||||||
"hb heboris",
|
"hb heboris",
|
||||||
"game",
|
"game",
|
||||||
"*Windows*\nA game with Arcade-ish play style, simulates some modes of many Tetris games.",
|
"Windows | Singleplayer\nA game with Arcade-ish play style, capable of simulating many modes of other Tetris games.",
|
||||||
},
|
},
|
||||||
{"Texmaster",
|
{"Texmaster",
|
||||||
"txm texmaster",
|
"txm texmaster",
|
||||||
"game",
|
"game",
|
||||||
"*Windows | Single-player*\nA game with all modes from TGM which you can use to practice. Has better controls than actual TGM. The world rule is slightly different, however (eg, instant-lock soft drops, and slightly different kick tables)",
|
"Windows | Singleplayer\nA game with all modes from TGM which you can use to practice. The world rule is slightly different, however (e.g. instant-lock soft drops and slightly different kick tables).",
|
||||||
},
|
|
||||||
{"Cambridge",
|
|
||||||
"cambridge",
|
|
||||||
"game",
|
|
||||||
"*Windows, macOS, Linux | Single-player*\nA Lua-based game engine dedicated to creating a robust, easily customizable platform for creating new, custom game modes. It was originally made by Joe Zeng, and starting with version 0.1.5 on October 8, 2020, Milla took over development of the game.\n--Tetris Wiki",
|
|
||||||
},
|
},
|
||||||
|
|
||||||
{"Tetris99",
|
{"Tetris Effect",
|
||||||
|
"tec tetriseffectconnected",
|
||||||
|
"game",
|
||||||
|
"PS/Oculus Quest/Xbox/NS/Windows | Singleplayer/Multiplayer\nOr TE(C) for short. An official Tetris game with fancy graphics and soundtracks that react to your input. The basic version (without the word \"Connected\") only has singleplayer modes. The extended version, Tetris Effect Connected, features four online battle modes, Connected (VS), Zone Battle, Score Attack, and Classic Score Attack.",
|
||||||
|
},
|
||||||
|
{"Tetris 99",
|
||||||
"t99 tetris99",
|
"t99 tetris99",
|
||||||
"game",
|
"game",
|
||||||
"*Nintendo Switch | Multiplayer*\nA game famous for its 99-player battle royale mode and has many interesting strategies not present on traditional battle Tetris games. Also has limited single-player modes like Marathon and bot matches available as DLC.",
|
"Nintendo Switch | Singleplayer/Multiplayer\nA game famous for its 99-player battle royale mode and has many interesting strategies not present on traditional battle Tetris games. Also has limited single-player modes like Marathon and bot matches available as DLC.",
|
||||||
},
|
},
|
||||||
{"Puyo Puyo Tetris",
|
{"Puyo Puyo Tetris",
|
||||||
"ppt puyopuyotetris",
|
"ppt puyopuyotetris",
|
||||||
"game",
|
"game",
|
||||||
"*Multiple platforms | Single-player and multiplayer*\nA game that combines two games, Tetris and Puyo Puyo, and can battle between those two games. Has many modes for both single-player and online. The PC/Steam version has worse controls and horrible online experience, so it is not recommended.",
|
"PS/NS/Xbox/Windows | Singleplayer/multiplayer\nA game that combines two games, Tetris and Puyo Puyo, and can battle between those two games. Has many modes for both single-player and online\n\n[The Steam PC version has worse controls and horrible online experience.]",
|
||||||
},
|
},
|
||||||
{"Tetris Online",
|
{"Tetris Online",
|
||||||
"top tetrisonline",
|
"top tetrisonline",
|
||||||
"game",
|
"game",
|
||||||
"*Windows | Single-player and multiplayer*\nA now-defunct Japanese Tetris game with both online and single-player modes. Allows custom DAS/ARR but neither can be set to 0. Minor input delay. Private servers exist and is decent for new players to get started.",
|
"Windows | Singleplayer/Multiplayer*\nA now-defunct Japanese Tetris game with both online and single-player modes. Allows custom DAS/ARR but neither can be set to 0. Minor input delay. Private servers do exist and is decent for new players to get started.",
|
||||||
},
|
},
|
||||||
{"Tetris Effect",
|
{"Tetra Online",
|
||||||
"te tetriseffect",
|
"TO tetraonline",
|
||||||
"game",
|
"game",
|
||||||
"*PS4, Windows, Xbox | Single-player*\nFancy graphics and soundtrack that react to your actions. Not-so-good controls. You can have a go if you are into the visuals, but not exactly worth it if you are just trying to play some Tetris.",
|
"Windows/macOS/Linux | Singleplayer/Multiplayer\nTO for short. A Tetris game developed by Dr Ocelot and Mine. The delays are AREs are intentionally set to high values, and players who get used to Tetris games with no delays may not get used to this game.\nThe game was removed from Steam on 09/Dec/2020 due to a DMCA notice filed by TTC.\nHowever, an offline build can still be downloaded on GitHub.",
|
||||||
},
|
"https://github.com/Juan-Cartes/Tetra-Offline/releases/tag/1.0",
|
||||||
{"Techmino",
|
|
||||||
"techmino",
|
|
||||||
"game",
|
|
||||||
"*Windows, macOS, Android, Linux, iOS/iPadOS | Single-player and multiplayer*\nA game with many modes and loads of customization. Low input delay, decent controls.",
|
|
||||||
},
|
},
|
||||||
|
|
||||||
{"Cultris II",
|
{"Cultris II",
|
||||||
"c2 cultris2 cultrisii",
|
"c2 cultris2 cultrisii",
|
||||||
"game",
|
"game",
|
||||||
"*Windows, macOS, Linux | Single-player and multiplayer*\nA game focusing on speed. Has no hold and limited lockdown timer (like old school Tetris), but has customizable DAS/ARR. The main gimmick is its timer-based combos and emphasizes on speed, combo setups and digging.",
|
"Windows/OS X | Singleplayer/Multiplayer\nC2 for short. Designed based on classic Tetris, Cultris II supports customizable DAS and ARR. The battle mode is focused on time-based combos, which challenges players’ speed, n-wide setups, and downstacking skills.\n[The Mac version was not being maintained for a long time. Any macOS build newer than macOS Catalina cannot run this game at all.]",
|
||||||
},
|
},
|
||||||
{"Nullpomino",
|
{"Nullpomino",
|
||||||
"np nullpomino",
|
"np nullpomino",
|
||||||
"game",
|
"game",
|
||||||
"*Windows | Single-player and multiplayer*\nProfessional Tetris game with extreme room for customization. You can customize almost every aspect of the game. However, this is not a beginner-friendly game (you can get lost in the menus quite easily).",
|
"Windows/macOS/Linux | Singleplayer/Multiplayer\nOr NP for short. A high-customizable professional Tetris game. Nearly every parameter in the game can be adjusted.\n[But the UI was outdated, and this game requires full-keyboard controls. New players may have some problems getting used to it. Also, it seems that macOS Monterey cannot run this game.]",
|
||||||
},
|
|
||||||
{"Touhoumino",
|
|
||||||
"touhoumino",
|
|
||||||
"game",
|
|
||||||
"*Windows | Single-player*\nA Nullpomino mod with elements from Touhou Project. It is fun to play but difficult. Recommended for players with at least half-decent skills otherwise you don't even know how you die",
|
|
||||||
},
|
|
||||||
{"Nanamino",
|
|
||||||
"nanamino",
|
|
||||||
"game",
|
|
||||||
"*Windows, Android | Single-player*\nDeveloping game, has a interesting rotation system",
|
|
||||||
},
|
},
|
||||||
{"Misamino",
|
{"Misamino",
|
||||||
"misamino",
|
"misamino",
|
||||||
"game",
|
"game",
|
||||||
"*Windows | Single-player?*\nLocal 1-vs-1 game, mainly plays turn-based mode. You can write your own bot for it (though you need to learn its API if you do).\nMisamino is also the name of its built-in bot. Said bot is also the core for the Puyo Puyo Tetris bot, Zetris.",
|
"Windows | Single-player\nLocal 1V1 game, mainly plays turn-based mode. You can write your own bot for it (though you need to learn its API if you do).\nMisamino is also the name of its built-in bot.",
|
||||||
},
|
},
|
||||||
{"Tetris Journey",
|
{"Touhoumino",
|
||||||
"huanyouji tetrisjourney mobile phone",
|
"touhoumino",
|
||||||
"game",
|
"game",
|
||||||
"An official mobile Tetris game developed by Tencent (available only in China). It has level modes, battle modes, and some single-player modes. You can customize the sizes and positions of the virtual keys but you cannot adjust DAS or ARR.\n The battle mode lasts for 2 minutes and if both player did not top out, the one who sent more attacks wins."
|
"Windows | Singleplayer\nA fan-made Tetris game, basically Nullpomino with elements from Touhou Project. The \"Spellcards\" from Touhou was introduced in the game, and you can only get bonus scores if you can reach the target score within the given period of time.\n[Recommended for players with at least half-decent skills otherwise you don't even know how you die.]",
|
||||||
},
|
},
|
||||||
|
|
||||||
{"Tetris Blitz",
|
{"Tetris Blitz",
|
||||||
"blitz ea mobile phone",
|
"blitz ea mobile phone",
|
||||||
"game",
|
"game",
|
||||||
"A mobile Tetris game by Electronic Arts (EA). It has the gravity mechanism, and each game lasts for 2 minutes. A bunch of minoes fall down to the field at the beginning of the game, and you can enter the \"Frenzy\" mode by performing line clears continuously. There are many different power-ups available. Also, this game has no top-out mechanism. When an incoming block overlaps with existing blocks in the field, the top lines will be cleared automatically. \n\nThis game is no longer available since April 2020.",
|
"iOS/Android | Singleplayer\nA mobile Tetris game by Electronic Arts (EA). It has the gravity mechanism, and each game lasts for 2 minutes. A bunch of minoes fall down to the field at the beginning of the game, and you can enter the \"Frenzy\" mode by performing line clears continuously. There are many different power-ups available. Also, this game has no top-out mechanism. When an incoming block overlaps with existing blocks in the field, the top lines will be cleared automatically. \n\nThis game is no longer available since April 2020.",
|
||||||
},
|
},
|
||||||
{"Tetris (EA)",
|
{"Tetris (EA)",
|
||||||
"tetris ea galaxy universe cosmos mobile phone",
|
"tetris ea galaxy universe cosmos mobile phone",
|
||||||
"game",
|
"game",
|
||||||
"Another mobile Tetris game by EA. It has two control modes – Swipe and One-Touch. It also has a Galaxy Mode besides the Marathon Mode (with gravity mechanism), and the goal of this mode is to clear all Galaxy minoes before the sequence runs out.\n\nThis game is no longer available since April 2020."
|
"iOS/Android | Singleplayer/Multiplayer?\nAnother mobile Tetris game by EA. It has two control modes – Swipe and One-Touch. It also has a Galaxy Mode besides the Marathon Mode (with gravity mechanism), and the goal of this mode is to clear all Galaxy minoes before the sequence runs out.\n\nThis game is no longer available since April 2020."
|
||||||
},
|
},
|
||||||
{"Tetris (N3TWORK)",
|
{"Tetris (N3TWORK)",
|
||||||
"tetris n3twork mobile phone",
|
"tetris n3twork mobile phone",
|
||||||
"game",
|
"game",
|
||||||
"The latest mobile Tetris from N3TWORK Inc. It has a 3-minute ultra mode, a marathon mode and a 100-player Royale mode. The UI is great but its controls are not so good.",
|
"iOS/Android | Singleplayer\nThe mobile Tetris game from N3TWORK Inc. It has a 3-minute ultra mode, a marathon mode and a 100-player Royale mode.\n[The UI is great but its controls are not so good.]",
|
||||||
},
|
},
|
||||||
{"Tetris Beat",
|
{"Tetris Beat",
|
||||||
"tetris beat n3twork rhythm",
|
"tetris beat n3twork rhythm",
|
||||||
"game",
|
"game",
|
||||||
"A mobile Tetris game from N3TWORK. It has a \"Beat\" mode besides the Marathon mode, but in this game you only have drop the blocks in rhythm with the BGM. The effects are very heavy and the controls are not so good."
|
"iOS | Singleplayer\nA mobile Tetris game from N3TWORK. It has a \"Beat\" mode besides the Marathon mode, but in this game you only have drop the blocks in rhythm with the BGM.\n[The effects are very heavy and the controls are not so good.]"
|
||||||
|
},
|
||||||
|
{"Tetris Journey",
|
||||||
|
"tetrisjourney mobile phone huanyouji",
|
||||||
|
"game",
|
||||||
|
"iOS/Android | Singleplayer\nAn official mobile Tetris game developed by Tencent (available exclusively in China). It has level modes, battle modes, and some single-player modes. You can customize the sizes and positions of the virtual keys but you cannot adjust DAS or ARR.\n The battle mode lasts for 2 minutes and if both player did not top out, the one who sent more attacks wins."
|
||||||
},
|
},
|
||||||
{"JJ Tetris",
|
{"JJ Tetris",
|
||||||
"jjtetris",
|
"jjtetris",
|
||||||
"game",
|
"game",
|
||||||
"*Android | Multiplayer*\n(JJ块)\nA casual game on JJ Card Games (JJ棋牌). Portrait screen, low input delay, smooth controls. Customizable DAS/ARR and toggle-able 20G soft drop, limited control scheme customization. No hold nor B2B, no garbage buffer nor cancelling. Every attack sends at most 4 lines, combos are more powerful, otherwise similar to modern Tetris.",
|
"Android | Multiplayer\n(JJ块)\nA casual game on JJ Card Games (JJ棋牌). Portrait screen, low input delay, smooth controls. Customizable DAS/ARR and toggle-able 20G soft drop, limited control scheme customization. No hold nor B2B, no garbage buffer nor cancelling. Every attack sends at most 4 lines, combos are more powerful, otherwise similar to modern Tetris.",
|
||||||
},
|
|
||||||
{"Falling lightblock",
|
|
||||||
"fl fallinglightblock",
|
|
||||||
"game",
|
|
||||||
"*Android, iOS, Web | Single-player and multiplayer*\nA game that supports many platforms. Has delays that cannot be adjusted. Can, to some extent, customize controls on mobile. Most of the modes are similar to classic Tetris, but modern-ish modes also exist. Battles are half-turn-based-half-real-time, and garbage cannot be buffered or cancelled.",
|
|
||||||
"https://golfgl.de/lightblocks/",
|
|
||||||
},
|
},
|
||||||
|
|
||||||
{"Huopin Tetris",
|
{"Huopin Tetris",
|
||||||
"huopin qq",
|
"huopin qq",
|
||||||
"game",
|
"game",
|
||||||
"*Windows | Multiplayer*\n(火拼俄罗斯)\n\nThe Tetris game on Tencent Game Center, 12-wide board, DAS/ARR the same as your typing, 1 next, no hold. Can only send garbage through Tetris (sends 3 lines) and Triple (sends 2 lines). Garbage is checker-board-shaped and is very difficult to dig through.",
|
"Windows | Multiplayer\n(火拼俄罗斯)\n\nThe Tetris game on Tencent Game Center, 12-wide board, DAS/ARR the same as your typing, 1 next, no hold. Can only send garbage through Tetris (sends 3 lines) and Triple (sends 2 lines). Garbage is checker-board-shaped and is nearly impossible to dig through.",
|
||||||
},
|
},
|
||||||
|
|
||||||
--Terms
|
--Terms
|
||||||
@@ -788,6 +815,11 @@ return{
|
|||||||
"term",
|
"term",
|
||||||
"Vibrate your finger on the controller to achieve faster sideways movement speed than holding it.\nIt is most commonly used on classic Tetris where DAS is rather slow. In most cases, you do not need to hypertap in modern Tetris games, because their DAS is often fast enough.",
|
"Vibrate your finger on the controller to achieve faster sideways movement speed than holding it.\nIt is most commonly used on classic Tetris where DAS is rather slow. In most cases, you do not need to hypertap in modern Tetris games, because their DAS is often fast enough.",
|
||||||
},
|
},
|
||||||
|
{"Rolling",
|
||||||
|
"rolling",
|
||||||
|
"term",
|
||||||
|
"Another method of fast-tapping in high-gravity (around 1G) modes (with slow DAS/ARR setting).\nWhen you perform rolling, you fix the position of one hand and the controller, and then tap the back of the controller with fingers on your other hand repeatedly. This method allows even faster moving speeds than hypertapping (see \"Hypertapping\" for more)and requires much less effort.\nThis method was first discovered by Cheez-fish and he has once achieved a tapping speed of more than 20 Hz.",
|
||||||
|
},
|
||||||
{"Passthrough",
|
{"Passthrough",
|
||||||
"passthrough pingthrough",
|
"passthrough pingthrough",
|
||||||
"term",
|
"term",
|
||||||
@@ -859,12 +891,12 @@ return{
|
|||||||
"Any input device takes some time for the input to reach the game. This delay can range from a few milliseconds to a few dozen milliseconds.\nIf input delay is too long, the controls can feel uncomfortable.\nThis delay is often due to the performance of the hardware and software used, and often out of your control. Turn on performance mode (or turn off power saving mode) on your device, and turn on gaming mode on your monitor/TV (if you have one), may help reducing input delay.",
|
"Any input device takes some time for the input to reach the game. This delay can range from a few milliseconds to a few dozen milliseconds.\nIf input delay is too long, the controls can feel uncomfortable.\nThis delay is often due to the performance of the hardware and software used, and often out of your control. Turn on performance mode (or turn off power saving mode) on your device, and turn on gaming mode on your monitor/TV (if you have one), may help reducing input delay.",
|
||||||
},
|
},
|
||||||
{"Cold Clear",
|
{"Cold Clear",
|
||||||
"cc coldclear",
|
"cc coldclear ai bot",
|
||||||
"term",
|
"term",
|
||||||
"A Tetris bot. Originally built for Puyo Puyo Tetris, thus can be less powerful on Techmino.",
|
"A Tetris bot. Originally built for Puyo Puyo Tetris, thus can be less powerful on Techmino.",
|
||||||
},
|
},
|
||||||
{"ZZZbot",
|
{"ZZZbot",
|
||||||
"zzzbot",
|
"zzzbot ai bot",
|
||||||
"term",
|
"term",
|
||||||
"A Tetris bot. Built by the Chinese Tetris player 奏之章 (Zou Zhi Zhang) and has decent performance in many games",
|
"A Tetris bot. Built by the Chinese Tetris player 奏之章 (Zou Zhi Zhang) and has decent performance in many games",
|
||||||
},
|
},
|
||||||
@@ -1026,9 +1058,9 @@ return{
|
|||||||
|
|
||||||
--Savedata managing
|
--Savedata managing
|
||||||
{"Console",
|
{"Console",
|
||||||
"console cmd commamd minglinghang kongzhitai",
|
"console cmd commamd minglinghang kongzhitai terminal",
|
||||||
"command",
|
"command",
|
||||||
"Techmino has a console that enables debugging/advanced features.\nTo access the console, repeatedly tap the Techmino logo or press the C key on the keyboard on the main menu.\n\nCareless actions in the console may result in corrupting or losing saved data. Proceed at your own risk.",
|
"Techmino has a console that enables debugging/advanced features.\nTo access the console, repeatedly tap (or click) the Techmino logo or press the C key on the keyboard on the main menu.\n\nCareless actions in the console may result in corrupting or losing saved data. Proceed at your own risk.",
|
||||||
},
|
},
|
||||||
{"Reset setting",
|
{"Reset setting",
|
||||||
"reset setting",
|
"reset setting",
|
||||||
@@ -1132,7 +1164,7 @@ return{
|
|||||||
{"Jonas",
|
{"Jonas",
|
||||||
"jonas",
|
"jonas",
|
||||||
"name",
|
"name",
|
||||||
"One of the top players in Classic Tetris.\nFour-times-in-a-row champion of CTWC.\n\n(1981-2021)",
|
"(1981-2021) One of the top players in Classic Tetris.\nFour-times-in-a-row champion of CTWC.",
|
||||||
},
|
},
|
||||||
{"Joseph",
|
{"Joseph",
|
||||||
"joseph",
|
"joseph",
|
||||||
@@ -1172,10 +1204,10 @@ return{
|
|||||||
{"TetroDictionary",
|
{"TetroDictionary",
|
||||||
"zictionary tetrodictionary littlez",
|
"zictionary tetrodictionary littlez",
|
||||||
"name",
|
"name",
|
||||||
"(or Zictionary for short) The name of this dictionary!\nIt includes brief introductions on many common terms in Tetris.\nIt used to be a chatbot in our QQ group, which was used to answer new player's FAQs. The entries in the Tetrodictionary were also inherited from the database in the chatbot.",
|
"(or Zictionary for short) The name of this dictionary!\nIt includes brief introductions on many common terms in Tetris.\nIt used to be a chatbot in our QQ group, which was used to answer new player's FAQs. The entries in the Tetrodictionary were also inherited from the database in the chatbot.\nThe contents in the TetroDictionary was adapted from a variety of sources such as Tetris Wiki and Hard Drop Wiki.",
|
||||||
},
|
},
|
||||||
{"MrZ",
|
{"MrZ",
|
||||||
"mrz_26",
|
"mrz_26 t026 t626",
|
||||||
"name",
|
"name",
|
||||||
"Tetris Research community member, the author of Techmino.\nPersonal bests: Sprint 25.95 seconds, MPH Sprint 57 seconds, #8 on Jstris leaderboards, X rank on TETR.IO, cleared TGM3 (World rule, Shirase gold 1300).",
|
"Tetris Research community member, the author of Techmino.\nPersonal bests: Sprint 25.95 seconds, MPH Sprint 57 seconds, #8 on Jstris leaderboards, X rank on TETR.IO, cleared TGM3 (World rule, Shirase gold 1300).",
|
||||||
"https://space.bilibili.com/225238922",
|
"https://space.bilibili.com/225238922",
|
||||||
@@ -1184,7 +1216,7 @@ return{
|
|||||||
{"Circu1ation",
|
{"Circu1ation",
|
||||||
"circu1ation",
|
"circu1ation",
|
||||||
"name",
|
"name",
|
||||||
"One of the top players. First one to achieve sub-20 Sprint in China, X rank on TETR.IO.",
|
"One of the top players. First one to achieve sub-20 40L Sprint in China, X rank on TETR.IO.",
|
||||||
"https://space.bilibili.com/557547205",
|
"https://space.bilibili.com/557547205",
|
||||||
},
|
},
|
||||||
{"Farter",
|
{"Farter",
|
||||||
@@ -1265,7 +1297,7 @@ return{
|
|||||||
"https://space.bilibili.com/109356367",
|
"https://space.bilibili.com/109356367",
|
||||||
},
|
},
|
||||||
{"ZXC",
|
{"ZXC",
|
||||||
"zxc thtsod",
|
"zxc thtsod flag ctf",
|
||||||
"name",
|
"name",
|
||||||
"Also known as ThTsOd.\nTetris Research community member.\nA technical player.",
|
"Also known as ThTsOd.\nTetris Research community member.\nA technical player.",
|
||||||
"https://space.bilibili.com/4610502",
|
"https://space.bilibili.com/4610502",
|
||||||
@@ -1289,7 +1321,7 @@ return{
|
|||||||
"https://space.bilibili.com/471341780",
|
"https://space.bilibili.com/471341780",
|
||||||
},
|
},
|
||||||
{"思竣",
|
{"思竣",
|
||||||
"sijun",
|
"sijun acm oi",
|
||||||
"name",
|
"name",
|
||||||
"(Sī Jùn)\n\nTetris Research community member.\nLots of mental computation power.",
|
"(Sī Jùn)\n\nTetris Research community member.\nLots of mental computation power.",
|
||||||
"https://space.bilibili.com/403250559",
|
"https://space.bilibili.com/403250559",
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ return{
|
|||||||
loadSample="Loading instrument samples",
|
loadSample="Loading instrument samples",
|
||||||
loadVoice="Loading voice packs",
|
loadVoice="Loading voice packs",
|
||||||
loadFont="Loading fonts",
|
loadFont="Loading fonts",
|
||||||
loadModeIcon="Loading mode icons",
|
|
||||||
loadMode="Loading modes",
|
loadMode="Loading modes",
|
||||||
loadOther="Loading other assets",
|
loadOther="Loading other assets",
|
||||||
finish="Press any key to start!",
|
finish="Press any key to start!",
|
||||||
@@ -138,7 +137,8 @@ return{
|
|||||||
chatStart="------Beginning of log------",
|
chatStart="------Beginning of log------",
|
||||||
chatHistory="------New messages below------",
|
chatHistory="------New messages below------",
|
||||||
|
|
||||||
keySettingInstruction="Press to bind key\nescape: cancel\nbackspace: delete",
|
searchModeHelp="Type to search",
|
||||||
|
keySettingHelp="Press to bind key\nescape: cancel\nbackspace: delete",
|
||||||
customBGhelp="Drop image file here to apply custom background",
|
customBGhelp="Drop image file here to apply custom background",
|
||||||
customBGloadFailed="Unsupport image format for custom background",
|
customBGloadFailed="Unsupport image format for custom background",
|
||||||
|
|
||||||
@@ -206,9 +206,8 @@ return{
|
|||||||
"Make sure to get the game only from official sources,",
|
"Make sure to get the game only from official sources,",
|
||||||
"as we can't make sure you're safe if you got it elsewhere.",
|
"as we can't make sure you're safe if you got it elsewhere.",
|
||||||
"The author is not responsible for any modifications.",
|
"The author is not responsible for any modifications.",
|
||||||
FNSF and"/"or"While the game is free, donations are appreciated.",
|
FNNS and"/"or"While the game is free, donations are appreciated.",
|
||||||
FNSF and"/"or"If you are unable to use both WeChat Pay and AliPay,",
|
FNNS and"/"or"Check Zictionary for more",
|
||||||
FNSF and"/"or"you can go to our P\97\116\114\101\111\110 page (Link in Zictionary) to support us!",
|
|
||||||
},
|
},
|
||||||
staff={
|
staff={
|
||||||
"Author: MrZ Email: 1046101471@qq.com",
|
"Author: MrZ Email: 1046101471@qq.com",
|
||||||
@@ -219,7 +218,7 @@ return{
|
|||||||
"Music: MrZ, 柒栎流星, ERM, Trebor, C₂₉H₂₅N₃O₅, [T0722, Aether]",
|
"Music: MrZ, 柒栎流星, ERM, Trebor, C₂₉H₂₅N₃O₅, [T0722, Aether]",
|
||||||
"Voice & Sound: Miya, Xiaoya, Mono, MrZ, Trebor",
|
"Voice & Sound: Miya, Xiaoya, Mono, MrZ, Trebor",
|
||||||
"Performance: 模电, HBM",
|
"Performance: 模电, HBM",
|
||||||
"Translations: User670, MattMayuga, Mizu, Mr.Faq, ScF, C₂₉H₂₅N₃O₅",
|
"Translations: User670, MattMayuga, Mizu, Mr.Faq, ScF, C₂₉H₂₅N₃O₅, NOT_A_ROBOT",
|
||||||
"",
|
"",
|
||||||
"Special Thanks:",
|
"Special Thanks:",
|
||||||
"Flyz, Big_True, NOT_A_ROBOT, 思竣, yuhao7370",
|
"Flyz, Big_True, NOT_A_ROBOT, 思竣, yuhao7370",
|
||||||
@@ -253,9 +252,8 @@ return{
|
|||||||
sprint="Sprint",
|
sprint="Sprint",
|
||||||
marathon="Marathon",
|
marathon="Marathon",
|
||||||
},
|
},
|
||||||
mode={
|
modeExplorer={
|
||||||
mod="Mods (F1)",
|
mod="Mods (F1)",
|
||||||
start="Start",
|
|
||||||
},
|
},
|
||||||
mod={
|
mod={
|
||||||
title="Mods",
|
title="Mods",
|
||||||
@@ -339,7 +337,7 @@ return{
|
|||||||
title="Game Settings",
|
title="Game Settings",
|
||||||
graphic="←Video",
|
graphic="←Video",
|
||||||
sound="Audio→",
|
sound="Audio→",
|
||||||
layout="Layout",
|
style="Style",
|
||||||
|
|
||||||
ctrl="Control Settings",
|
ctrl="Control Settings",
|
||||||
key="Key Mappings",
|
key="Key Mappings",
|
||||||
@@ -460,7 +458,7 @@ return{
|
|||||||
},
|
},
|
||||||
setting_skin={
|
setting_skin={
|
||||||
skinSet="Block Skin",
|
skinSet="Block Skin",
|
||||||
title="Layout Settings",
|
title="Style Settings",
|
||||||
skinR="Reset Colors",
|
skinR="Reset Colors",
|
||||||
faceR="Reset Dir.",
|
faceR="Reset Dir.",
|
||||||
},
|
},
|
||||||
@@ -676,101 +674,105 @@ return{
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
modes={
|
modes={
|
||||||
['sprint_10l']= {"Sprint", "10L", "Clear 10 lines!"},
|
['sprint_10l']= {"Sprint", "10L", "Clear 10 lines!"},
|
||||||
['sprint_20l']= {"Sprint", "20L", "Clear 20 lines!"},
|
['sprint_20l']= {"Sprint", "20L", "Clear 20 lines!"},
|
||||||
['sprint_40l']= {"Sprint", "40L", "Clear 40 lines!"},
|
['sprint_40l']= {"Sprint", "40L", "Clear 40 lines!"},
|
||||||
['sprint_100l']= {"Sprint", "100L", "Clear 100 lines!"},
|
['sprint_100l']= {"Sprint", "100L", "Clear 100 lines!"},
|
||||||
['sprint_400l']= {"Sprint", "400L", "Clear 400 lines!"},
|
['sprint_400l']= {"Sprint", "400L", "Clear 400 lines!"},
|
||||||
['sprint_1000l']= {"Sprint", "1,000L", "Clear 1,000 lines!"},
|
['sprint_1000l']= {"Sprint", "1,000L", "Clear 1,000 lines!"},
|
||||||
['sprintPenta']= {"Sprint", "PENTOMINO", "40L with 18 pentominoes"},
|
['sprintPenta']= {"Sprint", "PENTOMINO", "40L with 18 pentominoes"},
|
||||||
['sprintMPH']= {"Sprint", "MPH", "Memoryless\nPreviewless\nHoldless"},
|
['sprintMPH']= {"Sprint", "MPH", "Memoryless\nPreviewless\nHoldless"},
|
||||||
['dig_10l']= {"Dig", "10L", "Dig 10 garbage lines"},
|
['dig_10l']= {"Dig", "10L", "Dig 10 garbage lines"},
|
||||||
['dig_40l']= {"Dig", "40L", "Dig 40 garbage lines"},
|
['dig_40l']= {"Dig", "40L", "Dig 40 garbage lines"},
|
||||||
['dig_100l']= {"Dig", "100L", "Dig 100 garbage lines"},
|
['dig_100l']= {"Dig", "100L", "Dig 100 garbage lines"},
|
||||||
['dig_400l']= {"Dig", "400L", "Dig 400 garbage lines"},
|
['dig_400l']= {"Dig", "400L", "Dig 400 garbage lines"},
|
||||||
['drought_n']= {"Drought", "100L", "No I-pieces available"},
|
['drought_n']= {"Drought", "100L", "No I-pieces available"},
|
||||||
['drought_l']= {"Drought+", "100L", "W T F"},
|
['drought_l']= {"Drought+", "100L", "W T F"},
|
||||||
['marathon_n']= {"Marathon", "NORMAL", "200-line marathon with increasing speed"},
|
['marathon_n']= {"Marathon", "NORMAL", "200-line marathon with increasing speed"},
|
||||||
['marathon_h']= {"Marathon", "HARD", "200-line high-speed marathon"},
|
['marathon_h']= {"Marathon", "HARD", "200-line high-speed marathon"},
|
||||||
['solo_e']= {"Battle", "EASY", "Defeat the AI!"},
|
['solo_e']= {"Battle", "EASY", "Defeat the AI!"},
|
||||||
['solo_n']= {"Battle", "NORMAL", "Defeat the AI!"},
|
['solo_n']= {"Battle", "NORMAL", "Defeat the AI!"},
|
||||||
['solo_h']= {"Battle", "HARD", "Defeat the AI!"},
|
['solo_h']= {"Battle", "HARD", "Defeat the AI!"},
|
||||||
['solo_l']= {"Battle", "LUNATIC", "Defeat the AI!"},
|
['solo_l']= {"Battle", "LUNATIC", "Defeat the AI!"},
|
||||||
['solo_u']= {"Battle", "ULTIMATE", "Defeat the AI!"},
|
['solo_u']= {"Battle", "ULTIMATE", "Defeat the AI!"},
|
||||||
['techmino49_e']= {"Tech 49", "EASY", "49-player battle.\nThe last one standing wins"},
|
['techmino49_e']= {"Tech 49", "EASY", "49-player battle.\nThe last one standing wins"},
|
||||||
['techmino49_h']= {"Tech 49", "HARD", "49-player battle.\nThe last one standing wins"},
|
['techmino49_h']= {"Tech 49", "HARD", "49-player battle.\nThe last one standing wins"},
|
||||||
['techmino49_u']= {"Tech 49", "ULTIMATE", "49-player battle.\nThe last one standing wins"},
|
['techmino49_u']= {"Tech 49", "ULTIMATE", "49-player battle.\nThe last one standing wins"},
|
||||||
['techmino99_e']= {"Tech 99", "EASY", "99-player battle.\nThe last one standing wins"},
|
['techmino99_e']= {"Tech 99", "EASY", "99-player battle.\nThe last one standing wins"},
|
||||||
['techmino99_h']= {"Tech 99", "HARD", "99-player battle.\nThe last one standing wins"},
|
['techmino99_h']= {"Tech 99", "HARD", "99-player battle.\nThe last one standing wins"},
|
||||||
['techmino99_u']= {"Tech 99", "ULTIMATE", "99-player battle.\nThe last one standing wins"},
|
['techmino99_u']= {"Tech 99", "ULTIMATE", "99-player battle.\nThe last one standing wins"},
|
||||||
['round_e']= {"Turn-Based", "EASY", "Take turns to play against the AI!"},
|
['round_e']= {"Turn-Based", "EASY", "Take turns to play against the AI!"},
|
||||||
['round_n']= {"Turn-Based", "NORMAL", "Take turns to play against the AI!"},
|
['round_n']= {"Turn-Based", "NORMAL", "Take turns to play against the AI!"},
|
||||||
['round_h']= {"Turn-Based", "HARD", "Take turns to play against the AI!"},
|
['round_h']= {"Turn-Based", "HARD", "Take turns to play against the AI!"},
|
||||||
['round_l']= {"Turn-Based", "LUNATIC", "Take turns to play against the AI!"},
|
['round_l']= {"Turn-Based", "LUNATIC", "Take turns to play against the AI!"},
|
||||||
['round_u']= {"Turn-Based", "ULTIMATE", "Take turns to play against the AI!"},
|
['round_u']= {"Turn-Based", "ULTIMATE", "Take turns to play against the AI!"},
|
||||||
['master_n']= {"Master", "NORMAL", "For 20G beginners"},
|
['master_n']= {"Master", "NORMAL", "For 20G beginners"},
|
||||||
['master_h']= {"Master", "HARD", "For 20G pros"},
|
['master_h']= {"Master", "HARD", "For 20G pros"},
|
||||||
['master_m']= {"Master", "M21", "For 20G Masters"},
|
['master_m']= {"Master", "M21", "For 20G Masters"},
|
||||||
['master_final']= {"Master", "FINAL", "20G and beyond"},
|
['master_final']= {"Master", "FINAL", "20G and beyond"},
|
||||||
['master_ph']= {"Master", "PHANTASM", "???"},
|
['master_ph']= {"Master", "PHANTASM", "???"},
|
||||||
['master_ex']= {"GrandMaster", "EXTRA", "An eternity shorter than an instant"},
|
['master_ex']= {"GrandMaster", "EXTRA", "An eternity shorter than an instant"},
|
||||||
['strategy_e']= {"Strategy", "EASY", "Fast 20G decision"},
|
['master_instinct']={"Master", "INSTINCT", "What if the active piece turned invisible?"},
|
||||||
['strategy_h']= {"Strategy", "HARD", "Fast 20G decision"},
|
['strategy_e']= {"Strategy", "EASY", "Fast 20G decision"},
|
||||||
['strategy_u']= {"Strategy", "ULTIMATE", "Fast 20G decision"},
|
['strategy_h']= {"Strategy", "HARD", "Fast 20G decision"},
|
||||||
['blind_e']= {"Invisible", "HALF", "For novices"},
|
['strategy_u']= {"Strategy", "ULTIMATE", "Fast 20G decision"},
|
||||||
['blind_n']= {"Invisible", "ALL", "For intermediates"},
|
['strategy_e_plus']={"Strategy", "EASY+", "Fast 20G decision"},
|
||||||
['blind_h']= {"Invisible", "SUDDEN", "For the experienced"},
|
['strategy_h_plus']={"Strategy", "HARD+", "Fast 20G decision"},
|
||||||
['blind_l']= {"Invisible", "SUDDEN+", "For professionals"},
|
['strategy_u_plus']={"Strategy", "ULTIMATE+", "Fast 20G decision"},
|
||||||
['blind_u']= {"Invisible", "?", "Are you ready?"},
|
['blind_e']= {"Invisible", "HALF", "For novices"},
|
||||||
['blind_wtf']= {"Invisible", "WTF", "You're not ready"},
|
['blind_n']= {"Invisible", "ALL", "For intermediates"},
|
||||||
['classic_e']= {"Classic", "EASY", "A very low-speed recreation from the 80s"},
|
['blind_h']= {"Invisible", "SUDDEN", "For the experienced"},
|
||||||
['classic_h']= {"Classic", "HARD", "A medium speed recreation from the 80s"},
|
['blind_l']= {"Invisible", "SUDDEN+", "For professionals"},
|
||||||
['classic_u']= {"Classic", "ULTIMATE", "A very high-speed recreation from the 80s"},
|
['blind_u']= {"Invisible", "?", "Are you ready?"},
|
||||||
['survivor_e']= {"Survival", "EASY", "How long can you survive?"},
|
['blind_wtf']= {"Invisible", "WTF", "You're not ready"},
|
||||||
['survivor_n']= {"Survival", "NORMAL", "How long can you survive?"},
|
['classic_e']= {"Classic", "EASY", "A very low-speed recreation from the 80s"},
|
||||||
['survivor_h']= {"Survival", "HARD", "How long can you survive?"},
|
['classic_h']= {"Classic", "HARD", "A medium speed recreation from the 80s"},
|
||||||
['survivor_l']= {"Survival", "LUNATIC", "How long can you survive?"},
|
['classic_u']= {"Classic", "ULTIMATE", "A very high-speed recreation from the 80s"},
|
||||||
['survivor_u']= {"Survival", "ULTIMATE", "How long can you survive?"},
|
['survivor_e']= {"Survival", "EASY", "How long can you survive?"},
|
||||||
['attacker_h']= {"Attacker", "HARD", "Practice your attacking skills!"},
|
['survivor_n']= {"Survival", "NORMAL", "How long can you survive?"},
|
||||||
['attacker_u']= {"Attacker", "ULTIMATE", "Practice your attacking skills!"},
|
['survivor_h']= {"Survival", "HARD", "How long can you survive?"},
|
||||||
['defender_n']= {"Defender", "NORMAL", "Practice your defencing skills!"},
|
['survivor_l']= {"Survival", "LUNATIC", "How long can you survive?"},
|
||||||
['defender_l']= {"Defender", "LUNATIC", "Practice your defencing skills!"},
|
['survivor_u']= {"Survival", "ULTIMATE", "How long can you survive?"},
|
||||||
['dig_h']= {"Driller", "HARD", "Digging practice!"},
|
['attacker_h']= {"Attacker", "HARD", "Practice your attacking skills!"},
|
||||||
['dig_u']= {"Driller", "ULTIMATE", "Digging practice!"},
|
['attacker_u']= {"Attacker", "ULTIMATE", "Practice your attacking skills!"},
|
||||||
['clearRush']= {"Clear Rush", "NORMAL", "All-spin tutorial!\n[Under construction]"},
|
['defender_n']= {"Defender", "NORMAL", "Practice your defencing skills!"},
|
||||||
['c4wtrain_n']= {"C4W Training", "NORMAL", "Infinite combos"},
|
['defender_l']= {"Defender", "LUNATIC", "Practice your defencing skills!"},
|
||||||
['c4wtrain_l']= {"C4W Training", "LUNATIC", "Infinite combos"},
|
['dig_h']= {"Driller", "HARD", "Digging practice!"},
|
||||||
['pctrain_n']= {"PC Training", "NORMAL", "Perfect Clear practice"},
|
['dig_u']= {"Driller", "ULTIMATE", "Digging practice!"},
|
||||||
['pctrain_l']= {"PC Training", "LUNATIC", "A harder Perfect Clear practice"},
|
['clearRush']= {"Clear Rush", "NORMAL", "All-spin tutorial!\n[Under construction]"},
|
||||||
['pc_n']= {"PC Challenge", "NORMAL", "Get PCs within 100 lines!"},
|
['c4wtrain_n']= {"C4W Training", "NORMAL", "Infinite combos"},
|
||||||
['pc_h']= {"PC Challenge", "HARD", "Get PCs within 100 lines!"},
|
['c4wtrain_l']= {"C4W Training", "LUNATIC", "Infinite combos"},
|
||||||
['pc_l']= {"PC Challenge", "LUNATIC", "Get PCs within 100 lines!"},
|
['pctrain_n']= {"PC Training", "NORMAL", "Perfect Clear practice"},
|
||||||
['pc_inf']= {"Inf. PC Challenge", "", "Get PCs as much as you can"},
|
['pctrain_l']= {"PC Training", "LUNATIC", "A harder Perfect Clear practice"},
|
||||||
['tech_n']= {"Tech", "NORMAL", "Try to keep the\nBack-to-Back chain!"},
|
['pc_n']= {"PC Challenge", "NORMAL", "Get PCs within 100 lines!"},
|
||||||
['tech_n_plus']= {"Tech", "NORMAL+", "Spins & PCs only"},
|
['pc_h']= {"PC Challenge", "HARD", "Get PCs within 100 lines!"},
|
||||||
['tech_h']= {"Tech", "HARD", "Try to keep the\nBack-to-Back chain!"},
|
['pc_l']= {"PC Challenge", "LUNATIC", "Get PCs within 100 lines!"},
|
||||||
['tech_h_plus']= {"Tech", "HARD+", "Spins & PCs only"},
|
['pc_inf']= {"Inf. PC Challenge", "", "Get PCs as much as you can"},
|
||||||
['tech_l']= {"Tech", "LUNATIC", "Try to keep the\nBack-to-Back chain!"},
|
['tech_n']= {"Tech", "NORMAL", "Try to keep the\nBack-to-Back chain!"},
|
||||||
['tech_l_plus']= {"Tech", "LUNATIC+", "Spins & PCs only"},
|
['tech_n_plus']= {"Tech", "NORMAL+", "Spins & PCs only"},
|
||||||
['tech_finesse']= {"Tech", "FINESSE", "No finesse faults!"},
|
['tech_h']= {"Tech", "HARD", "Try to keep the\nBack-to-Back chain!"},
|
||||||
['tech_finesse_f']={"Tech", "FINESSE+", "No normal clears and finesse faults!"},
|
['tech_h_plus']= {"Tech", "HARD+", "Spins & PCs only"},
|
||||||
['tsd_e']= {"TSD Challenge", "EASY", "T-Spin Doubles only!"},
|
['tech_l']= {"Tech", "LUNATIC", "Try to keep the\nBack-to-Back chain!"},
|
||||||
['tsd_h']= {"TSD Challenge", "HARD", "T-Spin Doubles only!"},
|
['tech_l_plus']= {"Tech", "LUNATIC+", "Spins & PCs only"},
|
||||||
['tsd_u']= {"TSD Challenge", "ULTIMATE", "T-Spin Doubles only!"},
|
['tech_finesse']= {"Tech", "FINESSE", "No finesse faults!"},
|
||||||
['backfire_n']= {"Backfire", "NORMAL", "Hold back the backfiring garbage lines"},
|
['tech_finesse_f']= {"Tech", "FINESSE+", "No normal clears and finesse faults!"},
|
||||||
['backfire_h']= {"Backfire", "HARD", "Hold back the backfiring garbage lines"},
|
['tsd_e']= {"TSD Challenge", "EASY", "T-Spin Doubles only!"},
|
||||||
['backfire_l']= {"Backfire", "LUNATIC", "Hold back the backfiring garbage lines"},
|
['tsd_h']= {"TSD Challenge", "HARD", "T-Spin Doubles only!"},
|
||||||
['backfire_u']= {"Backfire", "ULTIMATE", "Hold back the backfiring garbage lines"},
|
['tsd_u']= {"TSD Challenge", "ULTIMATE", "T-Spin Doubles only!"},
|
||||||
['sprintAtk']= {"Sprint", "100 Attack", "Send 100 lines!"},
|
['backfire_n']= {"Backfire", "NORMAL", "Hold back the backfiring garbage lines"},
|
||||||
['sprintEff']= {"Sprint", "Efficiency", "Send more attack in 40lines!"},
|
['backfire_h']= {"Backfire", "HARD", "Hold back the backfiring garbage lines"},
|
||||||
['zen']= {'Zen', "200", "A 200-line run without a time limit"},
|
['backfire_l']= {"Backfire", "LUNATIC", "Hold back the backfiring garbage lines"},
|
||||||
['ultra']= {'Ultra', "EXTRA", "A 2-minute score attack"},
|
['backfire_u']= {"Backfire", "ULTIMATE", "Hold back the backfiring garbage lines"},
|
||||||
['infinite']= {"Infinite", "", "Just a sandbox"},
|
['sprintAtk']= {"Sprint", "100 Attack", "Send 100 lines!"},
|
||||||
['infinite_dig']= {"Infinite: Dig", "", "Dig-diggin'-dug"},
|
['sprintEff']= {"Sprint", "Efficiency", "Send more attack in 40lines!"},
|
||||||
['marathon_inf']= {"Marathon", "INFINITE", "Infinite marathon."},
|
['zen']= {'Zen', "200", "A 200-line run without a time limit"},
|
||||||
|
['ultra']= {'Ultra', "EXTRA", "A 2-minute score attack"},
|
||||||
|
['infinite']= {"Infinite", "", "Just a sandbox"},
|
||||||
|
['infinite_dig']= {"Infinite: Dig", "", "Dig-diggin'-dug"},
|
||||||
|
['marathon_inf']= {"Marathon", "INFINITE", "Infinite marathon."},
|
||||||
|
|
||||||
['custom_clear']= {"Custom", "NORMAL"},
|
['custom_clear']= {"Custom", "NORMAL"},
|
||||||
['custom_puzzle']= {"Custom", "PUZZLE"},
|
['custom_puzzle']= {"Custom", "PUZZLE"},
|
||||||
},
|
},
|
||||||
getTip={refuseCopy=true,
|
getTip={refuseCopy=true,
|
||||||
":pog:",
|
":pog:",
|
||||||
@@ -848,9 +850,9 @@ return{
|
|||||||
"Soon you'll be able to play against friends and foes all over the world.",
|
"Soon you'll be able to play against friends and foes all over the world.",
|
||||||
"Split clear coming soon!",
|
"Split clear coming soon!",
|
||||||
"sudo rm -rf /*",
|
"sudo rm -rf /*",
|
||||||
"Techmino is a combination of Technique and Tetromino.",
|
"Techmino is a portmanteau of \"technique\" and \"tetromino\".",
|
||||||
"Techmino has a Nspire-CX edition!",
|
|
||||||
"Techmino is so fun!",
|
"Techmino is so fun!",
|
||||||
|
"Techmino on Nspire-CX: yes it exists, no it's not the same game.",
|
||||||
"TetroDictionary is now available in English.",
|
"TetroDictionary is now available in English.",
|
||||||
"Most of the music tracks in this game are made using Beepbox.",
|
"Most of the music tracks in this game are made using Beepbox.",
|
||||||
"The names that appeared in the background of the Staff page is a list of our sponsors.",
|
"The names that appeared in the background of the Staff page is a list of our sponsors.",
|
||||||
@@ -872,7 +874,7 @@ return{
|
|||||||
"You can connect a keyboard to your phone or tablet (not functional on iOS though).",
|
"You can connect a keyboard to your phone or tablet (not functional on iOS though).",
|
||||||
"You can customize the key mappings in settings!",
|
"You can customize the key mappings in settings!",
|
||||||
"You can open the save directory from the Stats page.",
|
"You can open the save directory from the Stats page.",
|
||||||
"You can perform a spin with 28 of the 29 minoes in this game; the exception being O1.",
|
"You can perform a spin with all of the minoes in this game.",
|
||||||
"You can set the spawning orientation for each piece.",
|
"You can set the spawning orientation for each piece.",
|
||||||
"ZS JL T O I",
|
"ZS JL T O I",
|
||||||
{C.C,"Also try 15puzzle!"},
|
{C.C,"Also try 15puzzle!"},
|
||||||
|
|||||||
@@ -1,25 +1,25 @@
|
|||||||
return{
|
return{
|
||||||
fallback='en',
|
fallback='en',
|
||||||
sureQuit="Pulsa de nuevo para salir",
|
sureQuit="Pulsa de nuevo para salir",
|
||||||
-- sureReset="Press again to reset",
|
sureReset="Pulsa de nuevo para reiniciar",
|
||||||
-- sureDelete="Press again to delete",
|
sureDelete="Pulsa de nuevo para borrar",
|
||||||
newDay="[Anti-adicción] ¡Nuevo día, nuevo comienzo!",
|
newDay="[Anti-adicción] ¡Nuevo día, nuevo comienzo!",
|
||||||
playedLong="[Anti-adicción] Estuviste jugando un buen rato hoy. Recuerda descansar de vez en cuando.",
|
playedLong="[Anti-adicción] Estuviste jugando un buen rato hoy. Recuerda descansar de vez en cuando.",
|
||||||
playedTooMuch="[Anti-adicción] ¡Has jugado mucho por hoy! No puedes jugar más.",
|
playedTooMuch="[Anti-adicción] ¡Has jugado mucho por hoy! No puedes jugar más.",
|
||||||
-- settingWarn="Modifing uncommon setting, be careful!",
|
settingWarn="¡Ten cuidado con modificar esto!",
|
||||||
|
|
||||||
atkModeName={"Al azar","Medallas","KOs","Atacantes"},
|
atkModeName={"Al azar","Medallas","KOs","Atacantes"},
|
||||||
royale_remain="$1 Jugadores Restantes",
|
royale_remain="$1 Jugadores Restantes",
|
||||||
cmb={nil,"Combo de 1","Combo de 2","Combo de 3","Combo de 4","Combo de 5","Combo de 6","Combo de 7","Combo de 8","Combo de 9","¡Combo de 10!","¡Combo de 11!","¡Combo de 12!","¡Combo de 13!","¡Combo de 14!","¡Combo de 15!","¡Combo de 16!","¡Combo de 17!","¡Combo de 18!","¡Combo de 19!","MEGACOMBO"},
|
cmb={nil,"Combo de 1","Combo de 2","Combo de 3","Combo de 4","Combo de 5","Combo de 6","Combo de 7","Combo de 8","Combo de 9","¡Combo de 10!","¡Combo de 11!","¡Combo de 12!","¡Combo de 13!","¡Combo de 14!","¡Combo de 15!","¡Combo de 16!","¡Combo de 17!","¡Combo de 18!","¡Combo de 19!","MEGACOMBO"},
|
||||||
spin="-spin",
|
spin="-spin",
|
||||||
clear={"Single","Doble","Triple","Techrash","Pentacrash","Hexacrash","Heptacrash","Octacrash","Nonacrash","Decacrash","Undecacrash","Dodecacrash","Tridecacrash","Tetradecacrash","Pentadecacrash","Hexadecacrash","Heptadecacrash","Octadecacrash","Nonadecacrash","Ultracrash","Impossicrash"},
|
clear={"Single","Doble","Triple","Techrash","Pentacrash","Hexacrash","Heptacrash","Octacrash","Nonacrash","Decacrash","Undecacrash","Dodecacrash","Tridecacrash","Tetradecacrash","Pentadecacrash","Hexadecacrash","Heptadecacrash","Octadecacrash","Nonadecacrash","Ultracrash","Impossicrash"},
|
||||||
-- cleared="$1 lines",
|
cleared="$1 líneas",
|
||||||
mini="Mini",b2b="B2B ",b3b="B2B2B ",
|
mini="Mini",b2b="B2B ",b3b="B2B2B ",
|
||||||
PC="Perfect Clear",HPC="Half Clear",
|
PC="Perfect Clear",HPC="Half Clear",
|
||||||
replaying="[Repetición]",
|
replaying="[Repetición]",
|
||||||
tasUsing="[TAS]",
|
tasUsing="[TAS]",
|
||||||
|
|
||||||
-- stage="Stage $1 completed",
|
stage="Fase $1 Completada",
|
||||||
great="¡Genial!",
|
great="¡Genial!",
|
||||||
awesome="¡Fantástico!",
|
awesome="¡Fantástico!",
|
||||||
almost="¡Casi!",
|
almost="¡Casi!",
|
||||||
@@ -28,7 +28,7 @@ return{
|
|||||||
speedup="¡Más rápido!",
|
speedup="¡Más rápido!",
|
||||||
missionFailed="Misión Fallida",
|
missionFailed="Misión Fallida",
|
||||||
|
|
||||||
speedLV="Vel. de juego",
|
speedLV="Veloc. de juego",
|
||||||
piece="Piezas",line="Líneas",atk="Ataque",eff="Eficiencia",
|
piece="Piezas",line="Líneas",atk="Ataque",eff="Eficiencia",
|
||||||
rpm="RPM",tsd="TSD",
|
rpm="RPM",tsd="TSD",
|
||||||
grade="Grado",techrash="Techrash",
|
grade="Grado",techrash="Techrash",
|
||||||
@@ -50,25 +50,25 @@ return{
|
|||||||
|
|
||||||
page="Página:",
|
page="Página:",
|
||||||
|
|
||||||
-- cc_fixed="CC is incompatible with fixed sequences",
|
cc_fixed="CC no es compatible con piezas prefijadas",
|
||||||
-- cc_swap="CC is incompatible with swap holdmode",
|
cc_swap="CC no es compatible con Swap Hold",
|
||||||
ai_prebag="La IA no es compatible con piezas que no sean Tetrominos.",
|
ai_prebag="La IA no es compatible con piezas que no sean Tetrominos.",
|
||||||
ai_mission="La IA no es compatible con misiones personalizadas.",
|
ai_mission="La IA no es compatible con misiones personalizadas.",
|
||||||
switchSpawnSFX="Habilita los sonidos de aparición de las piezas ;)",
|
switchSpawnSFX="Habilita los sonidos de aparición de las piezas ;)",
|
||||||
needRestart="Reinicia Techmino para que los cambios tengan efecto.",
|
needRestart="Reinicia Techmino para que los cambios tengan efecto.",
|
||||||
|
|
||||||
-- loadError_errorMode="'$1' loading failed: no load mode '$2'",
|
loadError_errorMode="'$1' Error al cargar: no hay modo '$2'",
|
||||||
-- loadError_read="'$1' loading failed: read failed",
|
loadError_read="'$1' Error al cargar: error de lectura",
|
||||||
-- loadError_noFile="'$1' loading failed no file:",
|
loadError_noFile="'$1' Error al cargar, no existe el archivo:",
|
||||||
-- loadError_other="'$1' loading failed: $2",
|
loadError_other="'$1' Error al cargar: $2",
|
||||||
-- loadError_unknown="'$1' loading failed: unknown reason",
|
loadError_unknown="'$1' Error al cargar: desconocido",
|
||||||
|
|
||||||
-- saveError_duplicate="'$1' saving failed: duplicated filename",
|
saveError_duplicate="'$1' Error al guardar: archivo duplicado",
|
||||||
-- saveError_encode="'$1' saving failed: encode failed",
|
saveError_encode="'$1' Error al guardar: error de encoding",
|
||||||
-- saveError_other="'$1' saving failed: $2",
|
saveError_other="'$1' Error al guardar: $2",
|
||||||
-- saveError_unknown="'$1' saving failed: unknown reason",
|
saveError_unknown="'$1' Error al guardar: desconocido",
|
||||||
|
|
||||||
-- copyDone="Copied!",
|
copyDone="¡Copiado con éxito!",
|
||||||
saveDone="Datos guardados",
|
saveDone="Datos guardados",
|
||||||
exportSuccess="Exportado con éxito",
|
exportSuccess="Exportado con éxito",
|
||||||
importSuccess="Importado con éxito",
|
importSuccess="Importado con éxito",
|
||||||
@@ -90,7 +90,7 @@ return{
|
|||||||
|
|
||||||
replayBroken="No se puede cargar la repetición",
|
replayBroken="No se puede cargar la repetición",
|
||||||
|
|
||||||
-- dictNote="==Copied from TetroDictionary==",
|
dictNote="==Copia de TetroDictionary==",
|
||||||
|
|
||||||
getNoticeFail="Error al buscar novedades.",
|
getNoticeFail="Error al buscar novedades.",
|
||||||
oldVersion="¡Está disponible la nueva versión $1!",
|
oldVersion="¡Está disponible la nueva versión $1!",
|
||||||
@@ -127,12 +127,13 @@ return{
|
|||||||
chatStart="------Comienzo del historial------",
|
chatStart="------Comienzo del historial------",
|
||||||
chatHistory="------Nuevos mensajes------",
|
chatHistory="------Nuevos mensajes------",
|
||||||
|
|
||||||
-- keySettingInstruction="Press to bind key\nescape: cancel\nbackspace: delete",
|
-- searchModeHelp="Type to search",
|
||||||
-- customBGhelp="Drop image file here to apply custom background",
|
keySettingHelp="Pulsa la tecla a mapear\nEsc.: Cancelar\nBackspace: Borrar",
|
||||||
-- customBGloadFailed="Unsupport image format for custom background",
|
customBGhelp="Suelta una imagen aquí para aplicarla de fondo",
|
||||||
|
customBGloadFailed="Formato de imagen no soportado",
|
||||||
|
|
||||||
errorMsg="Ha ocurrido un error y Techmino necesita reiniciarse.\nSe creó un registro de error, puedes enviarlo al autor.",
|
errorMsg="Ha ocurrido un error y Techmino necesita reiniciarse.\nSe creó un registro de error, puedes enviarlo al autor.",
|
||||||
-- tryAnotherBuild="[Invalid UTF-8] If you are on Windows, try downloading Techmino-win32 or Techmino-win64 (different from what you are using now).",
|
tryAnotherBuild="[UTF-8 Inválido] Si estás usando Windows, intenta descargar Techmino-win32 o Techmino-win64 (el que no estés usando ahora).",
|
||||||
|
|
||||||
-- modInstruction="",
|
-- modInstruction="",
|
||||||
-- modInfo={},--See lang_en.lua
|
-- modInfo={},--See lang_en.lua
|
||||||
@@ -172,9 +173,8 @@ return{
|
|||||||
"Descarga disponible únicamente vía el grupo de testeo y discord.gg/f9pUvkh",
|
"Descarga disponible únicamente vía el grupo de testeo y discord.gg/f9pUvkh",
|
||||||
"Descargas desde otros sitios pueden contener malware/viruses, y en smartphones sólo requiere permisos de internet y vibración.",
|
"Descargas desde otros sitios pueden contener malware/viruses, y en smartphones sólo requiere permisos de internet y vibración.",
|
||||||
"El autor no se responabiliza por daños ocasionados debido a modificaciones del juego.",
|
"El autor no se responabiliza por daños ocasionados debido a modificaciones del juego.",
|
||||||
FNSF and"/"or"Por favor descarga las últimas versiones desde los sitios oficiales. El juego es gratuito",
|
FNNS and"/"or"Por favor descarga las últimas versiones desde los sitios oficiales. El juego es gratuito",
|
||||||
FNSF and"/"or"Si no puede usar WeChat Pay y AliPay,",
|
FNNS and"/"or"Ve el Zictionary (en inglés) para más info",
|
||||||
FNSF and"/"or"puede ir a nuestra página de P\97\116\114\101\111\110 para apoyarnos.",
|
|
||||||
},
|
},
|
||||||
staff={
|
staff={
|
||||||
"Autor:MrZ Email: 1046101471@qq.com",
|
"Autor:MrZ Email: 1046101471@qq.com",
|
||||||
@@ -185,7 +185,7 @@ return{
|
|||||||
"Música: MrZ, 柒栎流星, ERM, Trebor, C₂₉H₂₅N₃O₅, [T0722, Aether]",
|
"Música: MrZ, 柒栎流星, ERM, Trebor, C₂₉H₂₅N₃O₅, [T0722, Aether]",
|
||||||
"Voces/Sonidos: Miya, Xiaoya, Mono, MrZ, Trebor",
|
"Voces/Sonidos: Miya, Xiaoya, Mono, MrZ, Trebor",
|
||||||
"Performance: 模电, HBM",
|
"Performance: 模电, HBM",
|
||||||
"Traducción: User670, MattMayuga, Mizu, Mr.Faq, ScF, C₂₉H₂₅N₃O₅",
|
"Traducción: User670, MattMayuga, Mizu, Mr.Faq, ScF, C₂₉H₂₅N₃O₅, NOT_A_ROBOT",
|
||||||
"",
|
"",
|
||||||
"Agradecimientos:",
|
"Agradecimientos:",
|
||||||
"Flyz, Big_True, NOT_A_ROBOT, 思竣, yuhao7370",
|
"Flyz, Big_True, NOT_A_ROBOT, 思竣, yuhao7370",
|
||||||
@@ -219,9 +219,8 @@ return{
|
|||||||
sprint="Sprint",
|
sprint="Sprint",
|
||||||
marathon="Maratón",
|
marathon="Maratón",
|
||||||
},
|
},
|
||||||
mode={
|
modeExplorer={
|
||||||
mod="Mods (F1)",
|
mod="Mods (F1)",
|
||||||
start="Empezar",
|
|
||||||
},
|
},
|
||||||
mod={
|
mod={
|
||||||
title="Mods",
|
title="Mods",
|
||||||
@@ -274,8 +273,8 @@ return{
|
|||||||
lock="Retraso de Bloqueo",
|
lock="Retraso de Bloqueo",
|
||||||
wait="Retraso de Spawneo",
|
wait="Retraso de Spawneo",
|
||||||
fall="Retraso de Línea",
|
fall="Retraso de Línea",
|
||||||
-- hang="Death Delay",
|
hang="Retraso de Muerte",
|
||||||
-- hurry="ARE Interruption",
|
hurry="Interrupc. de ARE",
|
||||||
|
|
||||||
capacity="Capacidad",
|
capacity="Capacidad",
|
||||||
create="Crear",
|
create="Crear",
|
||||||
@@ -283,14 +282,14 @@ return{
|
|||||||
ospin="O-Spin",
|
ospin="O-Spin",
|
||||||
fineKill="100% Finesse",
|
fineKill="100% Finesse",
|
||||||
b2bKill="No Romper B2B ",
|
b2bKill="No Romper B2B ",
|
||||||
-- lockout="Fail when lock out",
|
lockout="Derrota al ocurrir Lock Out",
|
||||||
easyFresh="Reinicio de Bloqueo Normal",
|
easyFresh="Reinicio de Bloqueo Normal",
|
||||||
deepDrop="Deep Drop",
|
deepDrop="Deep Drop",
|
||||||
bone="Bone Block",
|
bone="Bone Block",
|
||||||
|
|
||||||
-- eventSet="Rule Set",
|
eventSet="Ruleset",
|
||||||
|
|
||||||
-- holdMode="Hold Mode",
|
holdMode="Modo de Reserva",
|
||||||
nextCount="Siguiente",
|
nextCount="Siguiente",
|
||||||
holdCount="Reserva",
|
holdCount="Reserva",
|
||||||
infHold="Reserva Inft.",
|
infHold="Reserva Inft.",
|
||||||
@@ -299,13 +298,13 @@ return{
|
|||||||
net_game={
|
net_game={
|
||||||
ready="Estoy Listo",
|
ready="Estoy Listo",
|
||||||
spectate="Espectear",
|
spectate="Espectear",
|
||||||
-- cancel="Cancel ready",
|
cancel="Esperar",
|
||||||
},
|
},
|
||||||
setting_game={
|
setting_game={
|
||||||
title="Ajustes del Juego",
|
title="Ajustes del Juego",
|
||||||
graphic="←Video",
|
graphic="←Video",
|
||||||
sound="Sonido→",
|
sound="Sonido→",
|
||||||
layout="Diseño",
|
style="Estilo",
|
||||||
|
|
||||||
ctrl="Sensibilidad",
|
ctrl="Sensibilidad",
|
||||||
key="Teclas",
|
key="Teclas",
|
||||||
@@ -314,10 +313,10 @@ return{
|
|||||||
reTime="Retraso de Inicio",
|
reTime="Retraso de Inicio",
|
||||||
RS="Sistema de Rotación",
|
RS="Sistema de Rotación",
|
||||||
menuPos="Pos. del Botón de Menú",
|
menuPos="Pos. del Botón de Menú",
|
||||||
-- sysCursor="Use system cursor",
|
sysCursor="Usar cursor del sistema",
|
||||||
autoPause="Pausar cuando la ventana no está enfocada",
|
autoPause="Pausar cuando la ventana no está enfocada",
|
||||||
autoSave="Autograbar Récords",
|
autoSave="Autograbar Récords",
|
||||||
-- autoLogin="Auto Login on Start",
|
autoLogin="Autologueo al Iniciar",
|
||||||
simpMode="Modo Sencillo",
|
simpMode="Modo Sencillo",
|
||||||
},
|
},
|
||||||
setting_video={
|
setting_video={
|
||||||
@@ -345,13 +344,13 @@ return{
|
|||||||
atkFX="FX Vis. de Ataque",
|
atkFX="FX Vis. de Ataque",
|
||||||
|
|
||||||
frame="Ratio de FPSs(%)",
|
frame="Ratio de FPSs(%)",
|
||||||
-- FTlock="Frame-Time Lock",
|
FTlock="Bloqueo por frames",
|
||||||
|
|
||||||
text="Texto de Acciones",
|
text="Texto de Acciones",
|
||||||
score="Puntaje en Pantalla",
|
score="Puntaje en Pantalla",
|
||||||
bufferWarn="Alerta de Búfer",
|
bufferWarn="Alerta de Búfer",
|
||||||
showSpike="Contador de Spike",
|
showSpike="Contador de Spike",
|
||||||
-- nextPos="Spawn Preview",
|
nextPos="Prever Spawn de Pzas.",
|
||||||
highCam="Cám. Vista Aérea",
|
highCam="Cám. Vista Aérea",
|
||||||
warn="Alerta de Peligro",
|
warn="Alerta de Peligro",
|
||||||
|
|
||||||
@@ -360,9 +359,9 @@ return{
|
|||||||
clean="Fast Draw",
|
clean="Fast Draw",
|
||||||
fullscreen="Pant. Completa",
|
fullscreen="Pant. Completa",
|
||||||
|
|
||||||
-- bg_on="Normal B.G.",
|
bg_on="Fondo Normal",
|
||||||
-- bg_on="No B.G.",
|
bg_off="Sin Fondo",
|
||||||
-- bg_custom="Use Custom B.G.",
|
bg_custom="Fondo Personalizado",
|
||||||
|
|
||||||
blockSatur="Saturac. de los Bloques",
|
blockSatur="Saturac. de los Bloques",
|
||||||
fieldSatur="Saturac. del Tablero",
|
fieldSatur="Saturac. del Tablero",
|
||||||
@@ -372,7 +371,7 @@ return{
|
|||||||
game="←Juego",
|
game="←Juego",
|
||||||
graphic="Video→",
|
graphic="Video→",
|
||||||
|
|
||||||
-- mainVol="Main Volume",
|
mainVol="Vol. Principal",
|
||||||
bgm="BGM",
|
bgm="BGM",
|
||||||
sfx="SFX",
|
sfx="SFX",
|
||||||
stereo="Estéreo",
|
stereo="Estéreo",
|
||||||
@@ -381,9 +380,9 @@ return{
|
|||||||
vib="Vibración",
|
vib="Vibración",
|
||||||
voc="Voces",
|
voc="Voces",
|
||||||
|
|
||||||
-- autoMute="Mute while unfocused",
|
autoMute="Silenciar cuando la ventana no está enfocada",
|
||||||
fine="Sonido de Error de Finesse",
|
fine="Sonido de Error de Finesse",
|
||||||
-- sfxPack="SFX Pack",
|
sfxPack="Pack de SFX",
|
||||||
vocPack="Pack de Voces",
|
vocPack="Pack de Voces",
|
||||||
apply="Aplicar",
|
apply="Aplicar",
|
||||||
},
|
},
|
||||||
@@ -461,8 +460,8 @@ return{
|
|||||||
lock="Retraso de Bloqueo",
|
lock="Retraso de Bloqueo",
|
||||||
wait="Retraso de Spawneo",
|
wait="Retraso de Spawneo",
|
||||||
fall="Retraso de Línea",
|
fall="Retraso de Línea",
|
||||||
-- hang="Death Delay",
|
hang="Retraso de Muerte",
|
||||||
-- hurry="ARE Interruption",
|
hurry="Interrupc. de ARE",
|
||||||
|
|
||||||
bg="Fondo",
|
bg="Fondo",
|
||||||
bgm="Música",
|
bgm="Música",
|
||||||
@@ -479,9 +478,9 @@ return{
|
|||||||
sequence="Editar Secuencia (S)",
|
sequence="Editar Secuencia (S)",
|
||||||
mission="Editar Misiones (M)",
|
mission="Editar Misiones (M)",
|
||||||
|
|
||||||
-- eventSet="Rule Set",
|
eventSet="Ruleset",
|
||||||
|
|
||||||
-- holdMode="Hold Mode",
|
holdMode="Modo de Reserva",
|
||||||
nextCount="Siguiente",
|
nextCount="Siguiente",
|
||||||
holdCount="Reserva",
|
holdCount="Reserva",
|
||||||
infHold="Reserva Inft.",
|
infHold="Reserva Inft.",
|
||||||
@@ -500,7 +499,7 @@ return{
|
|||||||
ospin="O-Spin",
|
ospin="O-Spin",
|
||||||
fineKill="100% Finesse",
|
fineKill="100% Finesse",
|
||||||
b2bKill="No Romper B2B ",
|
b2bKill="No Romper B2B ",
|
||||||
-- lockout="Fail when lock out",
|
lockout="Derrota al ocurrir Lock Out",
|
||||||
easyFresh="Reinicio de Bloqueo Normal",
|
easyFresh="Reinicio de Bloqueo Normal",
|
||||||
deepDrop="Deep Drop",
|
deepDrop="Deep Drop",
|
||||||
bone="Bone Block",
|
bone="Bone Block",
|
||||||
@@ -535,7 +534,7 @@ return{
|
|||||||
about={
|
about={
|
||||||
staff="Staff",
|
staff="Staff",
|
||||||
his="Hist. de Acts.",
|
his="Hist. de Acts.",
|
||||||
-- legals="Legals",
|
legals="Legalidades",
|
||||||
},
|
},
|
||||||
dict={
|
dict={
|
||||||
title="TetroDictionary",
|
title="TetroDictionary",
|
||||||
@@ -559,7 +558,7 @@ return{
|
|||||||
sfx="SFX",
|
sfx="SFX",
|
||||||
voc="Voces",
|
voc="Voces",
|
||||||
music="BGMs",
|
music="BGMs",
|
||||||
-- label="label",
|
label="Etiq.",
|
||||||
},
|
},
|
||||||
login={
|
login={
|
||||||
title="Entrar",
|
title="Entrar",
|
||||||
@@ -646,7 +645,7 @@ return{
|
|||||||
['dig_100l']= {"Queso", "100L", "Limpia 100 líneas de queso."},
|
['dig_100l']= {"Queso", "100L", "Limpia 100 líneas de queso."},
|
||||||
['dig_400l']= {"Queso", "400L", "Limpia 400 líneas de queso."},
|
['dig_400l']= {"Queso", "400L", "Limpia 400 líneas de queso."},
|
||||||
['drought_n']= {"Sequía", "100L", "¡Sin piezas I!"},
|
['drought_n']= {"Sequía", "100L", "¡Sin piezas I!"},
|
||||||
['drought_l']= {"Sequía+", "100L", "Guat de foc..."},
|
['drought_l']= {"Sequía+", "100L", "Qué es esto..."},
|
||||||
['marathon_n']= {"Maratón", "Normal", "Maratón de 200 líneas con velocidad en aumento."},
|
['marathon_n']= {"Maratón", "Normal", "Maratón de 200 líneas con velocidad en aumento."},
|
||||||
['marathon_h']= {"Maratón", "Difícil", "Maratón de 200 líneas a velocidad máxima."},
|
['marathon_h']= {"Maratón", "Difícil", "Maratón de 200 líneas a velocidad máxima."},
|
||||||
['solo_e']= {"VS.", "Fácil", "¡Derrota a la CPU!"},
|
['solo_e']= {"VS.", "Fácil", "¡Derrota a la CPU!"},
|
||||||
@@ -654,12 +653,12 @@ return{
|
|||||||
['solo_h']= {"VS.", "Difícil", "¡Derrota a la CPU!"},
|
['solo_h']= {"VS.", "Difícil", "¡Derrota a la CPU!"},
|
||||||
['solo_l']= {"VS.", "Lunático", "¡Derrota a la CPU!"},
|
['solo_l']= {"VS.", "Lunático", "¡Derrota a la CPU!"},
|
||||||
['solo_u']= {"VS.", "Supremo", "¡Derrota a la CPU!"},
|
['solo_u']= {"VS.", "Supremo", "¡Derrota a la CPU!"},
|
||||||
['techmino49_e']= {"Tech 49", "Fácil", "Batalla de 49 jugadores. ¡El último en pie gana!"},
|
['techmino49_e']= {"Tech 49", "Fácil", "Batalla de 49 jugadores.\n¡El último en pie gana!"},
|
||||||
['techmino49_h']= {"Tech 49", "Difícil", "Batalla de 49 jugadores. ¡El último en pie gana!"},
|
['techmino49_h']= {"Tech 49", "Difícil", "Batalla de 49 jugadores.\n¡El último en pie gana!"},
|
||||||
['techmino49_u']= {"Tech 49", "Supremo", "Batalla de 49 jugadores. ¡El último en pie gana!"},
|
['techmino49_u']= {"Tech 49", "Supremo", "Batalla de 49 jugadores.\n¡El último en pie gana!"},
|
||||||
['techmino99_e']= {"Tech 99", "Fácil", "Batalla de 99 jugadores. ¡El último en pie gana!"},
|
['techmino99_e']= {"Tech 99", "Fácil", "Batalla de 99 jugadores.\n¡El último en pie gana!"},
|
||||||
['techmino99_h']= {"Tech 99", "Difícil", "Batalla de 99 jugadores. ¡El último en pie gana!"},
|
['techmino99_h']= {"Tech 99", "Difícil", "Batalla de 99 jugadores.\n¡El último en pie gana!"},
|
||||||
['techmino99_u']= {"Tech 99", "Supremo", "Batalla de 99 jugadores. ¡El último en pie gana!"},
|
['techmino99_u']= {"Tech 99", "Supremo", "Batalla de 99 jugadores.\n¡El último en pie gana!"},
|
||||||
['round_e']= {"Por Turnos", "Fácil", "Modo ajedrez."},
|
['round_e']= {"Por Turnos", "Fácil", "Modo ajedrez."},
|
||||||
['round_n']= {"Por Turnos", "Normal", "Modo ajedrez."},
|
['round_n']= {"Por Turnos", "Normal", "Modo ajedrez."},
|
||||||
['round_h']= {"Por Turnos", "Difícil", "Modo ajedrez."},
|
['round_h']= {"Por Turnos", "Difícil", "Modo ajedrez."},
|
||||||
@@ -667,12 +666,15 @@ return{
|
|||||||
['round_u']= {"Por Turnos", "Supremo", "Modo ajedrez."},
|
['round_u']= {"Por Turnos", "Supremo", "Modo ajedrez."},
|
||||||
['master_n']= {"Master", "Normal", "Para principiantes en 20G"},
|
['master_n']= {"Master", "Normal", "Para principiantes en 20G"},
|
||||||
['master_h']= {"Master", "Difícil", "¡Desafío profesional de 20G!"},
|
['master_h']= {"Master", "Difícil", "¡Desafío profesional de 20G!"},
|
||||||
-- ['master_m']= {"Master", "M21", "For 20G Masters."},
|
['master_m']= {"Master", "M21", "Para Maestros del 20G."},
|
||||||
['master_final']= {"Master", "FINAL", "El verdadero 20G Supremo: el final es inalcanzable."},
|
['master_final']= {"Master", "FINAL", "El verdadero 20G Supremo:\nel final es inalcanzable."},
|
||||||
['master_ex']= {"GrandMaster", "EXTRA", "Para ser un gran maestro, acepta este desafío"},
|
['master_ex']= {"GrandMaster", "EXTRA", "Para ser un gran maestro,\nacepta este desafío"},
|
||||||
-- ['strategy_e']= {"Strategy", "EASY", "Fast 20G decision"},
|
['strategy_e']= {"Strategy", "EASY", "Decisiones rápidas en 20G."},
|
||||||
-- ['strategy_h']= {"Strategy", "HARD", "Fast 20G decision"},
|
['strategy_h']= {"Strategy", "HARD", "Decisiones rápidas en 20G."},
|
||||||
-- ['strategy_u']= {"Strategy", "ULTIMATE", "Fast 20G decision"},
|
['strategy_u']= {"Strategy", "ULTIMATE", "Decisiones rápidas en 20G."},
|
||||||
|
['strategy_e_plus']={"Strategi", "MUDAH+", "Decisiones rápidas en 20G."},
|
||||||
|
['strategy_h_plus']={"Strategi", "SULIT+", "Decisiones rápidas en 20G."},
|
||||||
|
['strategy_u_plus']={"Strategi", "TERAKHIR+", "Decisiones rápidas en 20G."},
|
||||||
['blind_e']= {"A Ciegas", "Parcial", "Para novatos."},
|
['blind_e']= {"A Ciegas", "Parcial", "Para novatos."},
|
||||||
['blind_n']= {"A Ciegas", "Total", "Para jugadores intermedios."},
|
['blind_n']= {"A Ciegas", "Total", "Para jugadores intermedios."},
|
||||||
['blind_h']= {"A Ciegas", "Inmediato", "Para jugadores experimentados"},
|
['blind_h']= {"A Ciegas", "Inmediato", "Para jugadores experimentados"},
|
||||||
@@ -693,7 +695,7 @@ return{
|
|||||||
['defender_l']= {"Defensor", "Lunático", "¡Practica la defensa!"},
|
['defender_l']= {"Defensor", "Lunático", "¡Practica la defensa!"},
|
||||||
['dig_h']= {"Downstack", "Difícil", "¡Practica el downstackeo!"},
|
['dig_h']= {"Downstack", "Difícil", "¡Practica el downstackeo!"},
|
||||||
['dig_u']= {"Downstack", "Supremo", "¡Practica el downstackeo!"},
|
['dig_u']= {"Downstack", "Supremo", "¡Practica el downstackeo!"},
|
||||||
-- ['clearRush']= {"Clear Rush", "NORMAL", "All-spin tutorial!\n[Under construction]"},
|
['clearRush']= {"Clear Rush", "NORMAL", "¡Tutorial de Allspins!\n[En construcción]"},
|
||||||
['c4wtrain_n']= {"Entrenar C4W", "Normal", "Combos infinitos."},
|
['c4wtrain_n']= {"Entrenar C4W", "Normal", "Combos infinitos."},
|
||||||
['c4wtrain_l']= {"Entrenar C4W", "Lunático", "Combos infinitos."},
|
['c4wtrain_l']= {"Entrenar C4W", "Lunático", "Combos infinitos."},
|
||||||
['pctrain_n']= {"Entrenar PC", "Normal", "Modo sencillo para practicar Perfect Clears."},
|
['pctrain_n']= {"Entrenar PC", "Normal", "Modo sencillo para practicar Perfect Clears."},
|
||||||
@@ -709,7 +711,7 @@ return{
|
|||||||
['tech_l']= {"Tech", "Lunático", "¡Mantén el B2B!"},
|
['tech_l']= {"Tech", "Lunático", "¡Mantén el B2B!"},
|
||||||
['tech_l_plus']= {"Tech", "Lunático+", "¡Sólo se permiten Spins y PCs!"},
|
['tech_l_plus']= {"Tech", "Lunático+", "¡Sólo se permiten Spins y PCs!"},
|
||||||
['tech_finesse']= {"Tech", "Finesse", "¡No cometas errores de Finesse!"},
|
['tech_finesse']= {"Tech", "Finesse", "¡No cometas errores de Finesse!"},
|
||||||
['tech_finesse_f']= {"Tech", "Finesse+", "Sin errores de finesse, ¡pero tampoco clears normales!"},
|
['tech_finesse_f']= {"Tech", "Finesse+", "Sin errores de finesse,\n¡pero tampoco clears normales!"},
|
||||||
['tsd_e']= {"Desafío de TSD", "Fácil", "¡Sólo se permiten T-Spin Dobles!"},
|
['tsd_e']= {"Desafío de TSD", "Fácil", "¡Sólo se permiten T-Spin Dobles!"},
|
||||||
['tsd_h']= {"Desafío de TSD", "Difícil", "¡Sólo se permiten T-Spin Dobles!"},
|
['tsd_h']= {"Desafío de TSD", "Difícil", "¡Sólo se permiten T-Spin Dobles!"},
|
||||||
['tsd_u']= {"Desafío de TSD", "Supremo", "¡Sólo se permiten T-Spin Dobles!"},
|
['tsd_u']= {"Desafío de TSD", "Supremo", "¡Sólo se permiten T-Spin Dobles!"},
|
||||||
@@ -718,7 +720,7 @@ return{
|
|||||||
['backfire_l']= {"Retorno", "Lunático", "Lidia con tus propias líneas basura."},
|
['backfire_l']= {"Retorno", "Lunático", "Lidia con tus propias líneas basura."},
|
||||||
['backfire_u']= {"Retorno", "Supremo", "Lidia con tus propias líneas basura."},
|
['backfire_u']= {"Retorno", "Supremo", "Lidia con tus propias líneas basura."},
|
||||||
['sprintAtk']= {"Sprint", "100L - Ataque", "¡Envía 100 líneas de ataque!"},
|
['sprintAtk']= {"Sprint", "100L - Ataque", "¡Envía 100 líneas de ataque!"},
|
||||||
-- ['sprintEff']= {"Sprint", "Efficiency", "Send more attack in 40lines!"},
|
['sprintEff']= {"Sprint", "Efficiency", "¡Envía ataque eficiente en 40 líneas!"},
|
||||||
['zen']= {'Zen', "200L", "200 líneas sin límite de tiempo."},
|
['zen']= {'Zen', "200L", "200 líneas sin límite de tiempo."},
|
||||||
['ultra']= {'Ultra', "Extra", "¡Consigue el mayor puntaje posible en 2 minutos!"},
|
['ultra']= {'Ultra', "Extra", "¡Consigue el mayor puntaje posible en 2 minutos!"},
|
||||||
['infinite']= {"Infinito", "", "Modo Sandbox."},
|
['infinite']= {"Infinito", "", "Modo Sandbox."},
|
||||||
|
|||||||
@@ -128,7 +128,8 @@ return{
|
|||||||
chatStart="--------Début des logs--------",
|
chatStart="--------Début des logs--------",
|
||||||
chatHistory="-Nouveaux messages en dessous-",
|
chatHistory="-Nouveaux messages en dessous-",
|
||||||
|
|
||||||
-- keySettingInstruction="Press to bind key\nescape: cancel\nbackspace: delete",
|
-- searchModeHelp="Type to search",
|
||||||
|
-- keySettingHelp="Press to bind key\nescape: cancel\nbackspace: delete",
|
||||||
-- customBGhelp="Drop image file here to apply custom background",
|
-- customBGhelp="Drop image file here to apply custom background",
|
||||||
-- customBGloadFailed="Unsupport image format for custom background",
|
-- customBGloadFailed="Unsupport image format for custom background",
|
||||||
|
|
||||||
@@ -172,9 +173,8 @@ return{
|
|||||||
"Ce jeu est gratuit et est uniquement disponible via discord.gg/f9pUvkh",
|
"Ce jeu est gratuit et est uniquement disponible via discord.gg/f9pUvkh",
|
||||||
"Ne téléchargez pas ce jeu depuis une autre source au risque d'avoir des virus,",
|
"Ne téléchargez pas ce jeu depuis une autre source au risque d'avoir des virus,",
|
||||||
"et vous n'avez besoin que des permissions de vibration et de communication réseau pour les versions mobiles !",
|
"et vous n'avez besoin que des permissions de vibration et de communication réseau pour les versions mobiles !",
|
||||||
FNSF and"/"or"Le créateur n'est pas responsable pour n'importe quel type de perte de données suite à une modification du jeu.",
|
FNNS and"/"or"Le créateur n'est pas responsable pour n'importe quel type de perte de données suite à une modification du jeu.",
|
||||||
FNSF and"/"or"Si vous ne parvenez pas à utiliser à la fois WeChat Pay et AliPay,",
|
-- FNNS and"/"or"Check Zictionary for more",
|
||||||
FNSF and"/"or"vous pouvez vous rendre sur notre page P\97\116\114\101\111\110 pour nous soutenir !",
|
|
||||||
},
|
},
|
||||||
staff={
|
staff={
|
||||||
"Author: MrZ E-mail: 1046101471@qq.com",
|
"Author: MrZ E-mail: 1046101471@qq.com",
|
||||||
@@ -185,7 +185,7 @@ return{
|
|||||||
"Musique : MrZ, 柒栎流星, ERM, Trebor, C₂₉H₂₅N₃O₅, [T0722, Aether]",
|
"Musique : MrZ, 柒栎流星, ERM, Trebor, C₂₉H₂₅N₃O₅, [T0722, Aether]",
|
||||||
"Voix & Sons: Miya, Xiaoya, Mono, MrZ, Trebor",
|
"Voix & Sons: Miya, Xiaoya, Mono, MrZ, Trebor",
|
||||||
"Performance: 模电, HBM",
|
"Performance: 模电, HBM",
|
||||||
"Traduction: User670, MattMayuga, Mizu, Mr.Faq, ScF, C₂₉H₂₅N₃O₅",
|
"Traduction: User670, MattMayuga, Mizu, Mr.Faq, ScF, C₂₉H₂₅N₃O₅, NOT_A_ROBOT",
|
||||||
"",
|
"",
|
||||||
"Merci à:",
|
"Merci à:",
|
||||||
"Flyz, Big_True, NOT_A_ROBOT, 思竣, yuhao7370",
|
"Flyz, Big_True, NOT_A_ROBOT, 思竣, yuhao7370",
|
||||||
@@ -215,9 +215,8 @@ return{
|
|||||||
dict="Zictionary",
|
dict="Zictionary",
|
||||||
-- replays="Replays",
|
-- replays="Replays",
|
||||||
},
|
},
|
||||||
mode={
|
modeExplorer={
|
||||||
mod="Mods (F1)",
|
mod="Mods (F1)",
|
||||||
start="Démarrer",
|
|
||||||
},
|
},
|
||||||
mod={
|
mod={
|
||||||
title="Mods",
|
title="Mods",
|
||||||
@@ -299,10 +298,9 @@ return{
|
|||||||
},
|
},
|
||||||
setting_game={
|
setting_game={
|
||||||
title="Paramètres du jeu",
|
title="Paramètres du jeu",
|
||||||
|
|
||||||
graphic="←Vidéo",
|
graphic="←Vidéo",
|
||||||
sound="Son→",
|
sound="Son→",
|
||||||
layout="Disposition",
|
-- style="Style",
|
||||||
|
|
||||||
ctrl="Paramètres de contrôle",
|
ctrl="Paramètres de contrôle",
|
||||||
key="Touches",
|
key="Touches",
|
||||||
@@ -359,7 +357,7 @@ return{
|
|||||||
fullscreen="Plein écran",
|
fullscreen="Plein écran",
|
||||||
|
|
||||||
-- bg_on="Normal B.G.",
|
-- bg_on="Normal B.G.",
|
||||||
-- bg_on="No B.G.",
|
-- bg_off="No B.G.",
|
||||||
-- bg_custom="Use Custom B.G.",
|
-- bg_custom="Use Custom B.G.",
|
||||||
|
|
||||||
-- blockSatur="Block Saturation",
|
-- blockSatur="Block Saturation",
|
||||||
@@ -674,9 +672,12 @@ return{
|
|||||||
['master_final']= {"Master", "FINAL", "20G : Un point final impossible à atteindre !"},
|
['master_final']= {"Master", "FINAL", "20G : Un point final impossible à atteindre !"},
|
||||||
-- ['master_ph']= {"Mester", "FANTASMA", "20G: ???"},
|
-- ['master_ph']= {"Mester", "FANTASMA", "20G: ???"},
|
||||||
['master_ex']= {"GrandMaster", "EXTRA", "Tentez de devenir un Grandmaster."},
|
['master_ex']= {"GrandMaster", "EXTRA", "Tentez de devenir un Grandmaster."},
|
||||||
-- ['strategy_e']= {"Strategy", "EASY", "Fast 20G decision"},
|
['strategy_e']= {"Strategy", "EASY", "Fast 20G decision"},
|
||||||
-- ['strategy_h']= {"Strategy", "HARD", "Fast 20G decision"},
|
['strategy_h']= {"Strategy", "HARD", "Fast 20G decision"},
|
||||||
-- ['strategy_u']= {"Strategy", "ULTIMATE", "Fast 20G decision"},
|
['strategy_u']= {"Strategy", "ULTIMATE", "Fast 20G decision"},
|
||||||
|
-- ['strategy_e_plus']={"Strategi", "MUDAH+", "Keputusan 20G cepat"},
|
||||||
|
-- ['strategy_h_plus']={"Strategi", "SULIT+", "Keputusan 20G cepat"},
|
||||||
|
-- ['strategy_u_plus']={"Strategi", "TERAKHIR+", "Keputusan 20G cepat"},
|
||||||
['blind_e']= {"Aveugle", "MOITIE", "Pour les novices."},
|
['blind_e']= {"Aveugle", "MOITIE", "Pour les novices."},
|
||||||
['blind_n']= {"Aveugle", "TOUT", "Pour les joueurs intermédiaires."},
|
['blind_n']= {"Aveugle", "TOUT", "Pour les joueurs intermédiaires."},
|
||||||
['blind_h']= {"Aveugle", "SOUDAIN", "Pour les bons jooeurs."},
|
['blind_h']= {"Aveugle", "SOUDAIN", "Pour les bons jooeurs."},
|
||||||
@@ -713,7 +714,7 @@ return{
|
|||||||
['tech_l']= {"Tech", "LUNATIQUE", "Gardez le B2B !"},
|
['tech_l']= {"Tech", "LUNATIQUE", "Gardez le B2B !"},
|
||||||
['tech_l_plus']= {"Tech", "LUNATIQUE+", "Spin & PC uniquement"},
|
['tech_l_plus']= {"Tech", "LUNATIQUE+", "Spin & PC uniquement"},
|
||||||
['tech_finesse']= {"Tech", "FINESSE", "Pas d'erreurs de finesse !"},
|
['tech_finesse']= {"Tech", "FINESSE", "Pas d'erreurs de finesse !"},
|
||||||
['tech_finesse_f']={"Tech", "FINESSE+", "Pas de nettoyages normaux, Pas d'erreurs de finesse !"},
|
['tech_finesse_f']={"Tech", "FINESSE+", "Pas de nettoyages normaux,\nPas d'erreurs de finesse !"},
|
||||||
['tsd_e']= {"TSD Challenge", "FACILE", "T-spin doubles uniquement !"},
|
['tsd_e']= {"TSD Challenge", "FACILE", "T-spin doubles uniquement !"},
|
||||||
['tsd_h']= {"TSD Challenge", "DIFFICILE", "T-spin doubles uniquement !"},
|
['tsd_h']= {"TSD Challenge", "DIFFICILE", "T-spin doubles uniquement !"},
|
||||||
['tsd_u']= {"TSD Challenge", "ULTIME", "T-spin doubles uniquement !"},
|
['tsd_u']= {"TSD Challenge", "ULTIME", "T-spin doubles uniquement !"},
|
||||||
|
|||||||
899
parts/language/lang_id.lua
Normal file
@@ -0,0 +1,899 @@
|
|||||||
|
local C=COLOR
|
||||||
|
return{
|
||||||
|
fallback='en',
|
||||||
|
loadText={
|
||||||
|
loadSFX="Memuat efek suara",
|
||||||
|
loadSample="Memuat sampel-sampel instrumen",
|
||||||
|
loadVoice="Memuat kumpulan suara",
|
||||||
|
loadFont="Memuat fon",
|
||||||
|
loadMode="Memuat mode-mode",
|
||||||
|
loadOther="Memuat aset-aset yang lain",
|
||||||
|
finish="Tekan tombol apapun untuk memulai!",
|
||||||
|
},
|
||||||
|
sureQuit="Tekan lagi untuk keluar",
|
||||||
|
sureReset="Tekan lagi untuk mereset",
|
||||||
|
sureDelete="Tekan lagi untuk menghapus",
|
||||||
|
newDay="Hari baru, awal baru!",
|
||||||
|
playedLong="Anda telah bermain lama. Waktunya istirahat!",
|
||||||
|
playedTooMuch="Anda telah bermain terlalu lama! Techmino sangat menyenangkan, tetapi jangan lupa istirahat!",
|
||||||
|
settingWarn="Awas, Anda akan mengubah beberapa pengaturan yang tidak biasanya diubah!",
|
||||||
|
|
||||||
|
atkModeName={"Acak","Badge","K.O.","Penyerang"},
|
||||||
|
royale_remain="$1 Pemain Tersisa",
|
||||||
|
powerUp={[0]="+000%","+025%","+050%","+075%","+100%"},
|
||||||
|
cmb={nil,"1 Kombo","2 Kombo","3 Kombo","4 Kombo","5 Kombo","6 Kombo","7 Kombo","8 Kombo","9 Kombo","10 Kombo!","11 Kombo!","12 Kombo!","13 Kombo!","14 Kombo!!","15 Kombo!!","16 Kombo!!","17 Kombo!!!","18 Kombo!!!","19 Kombo!!!","MEGA KOMBO"},
|
||||||
|
spin=" spin",
|
||||||
|
clear={"Single","Double","Triple","Techrash","Pentacrash","Hexacrash","Heptacrash","Octacrash","Nonacrash","Decacrash","Undecacrash","Dodecacrash","Tridecacrash","Tetradecacrash","Pentadecacrash","Hexadecacrash","Heptadecacrash","Octadecacrash","Nonadecacrash","Ultracrash","Impossicrash"},
|
||||||
|
cleared="$1 baris",
|
||||||
|
mini="Mini",b2b="B2B ",b3b="B2B2B ",
|
||||||
|
PC="PC",HPC="Hampir PC",
|
||||||
|
replaying="[Diulang]",
|
||||||
|
tasUsing="[TAS]",
|
||||||
|
|
||||||
|
stage="Tahap $1 selesai!",
|
||||||
|
great="Bagus!",
|
||||||
|
awesome="Luar biasa!",
|
||||||
|
almost="Hampir!",
|
||||||
|
continue="Lanjut!",
|
||||||
|
maxspeed="KECEPATAN MAXIMUM!",
|
||||||
|
speedup="Percepatkan!",
|
||||||
|
missionFailed="Salah",
|
||||||
|
|
||||||
|
speedLV="Kecepatan lvl",
|
||||||
|
piece="Blok",line="Baris",atk="Baris Terkirim",eff="Efisiensi",
|
||||||
|
rpm="RPM",tsd="TSD",
|
||||||
|
grade="Nilai",techrash="Techrash",
|
||||||
|
wave="Gelombang",nextWave="Lanjutan",
|
||||||
|
combo="Kombo",maxcmb="Max Kombo",
|
||||||
|
pc="PC",ko="KOs",
|
||||||
|
|
||||||
|
win="Menang!",
|
||||||
|
lose="Kalah",
|
||||||
|
|
||||||
|
finish="Selesai",
|
||||||
|
gamewin="Anda menang!",
|
||||||
|
gameover="Tamat",
|
||||||
|
|
||||||
|
pause="Terjeda",
|
||||||
|
pauseCount="Jeda-jeda",
|
||||||
|
finesse_ap="Semua sempurna",
|
||||||
|
finesse_fc="Kombo penuh",
|
||||||
|
|
||||||
|
page="Halaman:",
|
||||||
|
|
||||||
|
cc_fixed="CC tidak cocok dengan urutan tetap.",
|
||||||
|
cc_swap="CC tidak cocok dengan mode simpan tukar.",
|
||||||
|
ai_prebag="AI tidak cocok dengan urutan terubah yang memiliki non-tetromino.",
|
||||||
|
ai_mission="AI tidak cocok dengan misi terubah.",
|
||||||
|
switchSpawnSFX="Nyalakan efek suara munculan blok!",
|
||||||
|
needRestart="Ulangi untuk menerapkan perubahan.",
|
||||||
|
|
||||||
|
loadError_errorMode="'$1' eror memuat: tidak ada mode memuat '$2'",
|
||||||
|
loadError_read="'$1' eror memuat: gagal membaca",
|
||||||
|
loadError_noFile="'$1' eror memuat: tidak ada file:",
|
||||||
|
loadError_other="'$1' eror memuat: $2",
|
||||||
|
loadError_unknown="'$1' eror memuat: alasan tidak diketahui",
|
||||||
|
|
||||||
|
saveError_duplicate="'$1' eror menyimpan: nama file tergAnda",
|
||||||
|
saveError_encode="'$1' eror menyimpan: gagal menyandi",
|
||||||
|
saveError_other="'$1' eror menyimpan: $2",
|
||||||
|
saveError_unknown="'$1' eror menyimpan: alasan tidak diketahui",
|
||||||
|
|
||||||
|
copyDone="Tersalin!",
|
||||||
|
saveDone="Data disimpan",
|
||||||
|
exportSuccess="Ekspor berhasil",
|
||||||
|
importSuccess="Impor berhasil",
|
||||||
|
dataCorrupted="Data rusak",
|
||||||
|
pasteWrongPlace="Menempel di tempat yang salah?",
|
||||||
|
noFile="File tidak ada",
|
||||||
|
|
||||||
|
nowPlaying="Sekarang mendengarkan:",
|
||||||
|
|
||||||
|
VKTchW="Berat sentuhan",
|
||||||
|
VKOrgW="Berat asal",
|
||||||
|
VKCurW="Berat posisi saat ini",
|
||||||
|
|
||||||
|
noScore="Tidak ada nilai",
|
||||||
|
modeLocked="Terkunci",
|
||||||
|
unlockHint="Raih nilai B keatas dalam mode sebelumnya untuk membuka kunci.",
|
||||||
|
highScore="Nilai-nilai tertinggi",
|
||||||
|
newRecord="Rekor baru!",
|
||||||
|
|
||||||
|
replayBroken="Tidak bisa memuat ulangan permainan",
|
||||||
|
|
||||||
|
dictNote="==Tersalin dari TetroDictionary==",
|
||||||
|
|
||||||
|
getNoticeFail="Gagal mengambil pengumuman-pengumuman",
|
||||||
|
oldVersion="Versi $1 sekarang tersedia",
|
||||||
|
needUpdate="Butuh versi lebih baru!",
|
||||||
|
versionNotMatch="Versi tidak sama!",
|
||||||
|
notFinished="Segera akan datang!",
|
||||||
|
|
||||||
|
jsonError="Eror JSON",
|
||||||
|
|
||||||
|
noUsername="Silahkan masukki username Anda",
|
||||||
|
wrongEmail="Alamat email tidak sah",
|
||||||
|
noPassword="Silahkan masukki kata sandi Anda",
|
||||||
|
diffPassword="Kata sandi tidak sama",
|
||||||
|
registerRequestSent="Permintaan daftar telah terkirim.",
|
||||||
|
registerSuccessed="Pendaftaran sukses!",
|
||||||
|
loginSuccessed="Anda sekarang tergabung!",
|
||||||
|
accessSuccessed="Akses diberikan",
|
||||||
|
|
||||||
|
wsConnecting="Menghubungkan websocket…",
|
||||||
|
wsFailed="Koneksi websocket gagal",
|
||||||
|
wsClose="Websocket tertutup:",
|
||||||
|
netTimeout="Koneksi waktu habis",
|
||||||
|
|
||||||
|
onlinePlayerCount="Online",
|
||||||
|
createRoomSuccessed="Ruang dibuat",
|
||||||
|
started="Bermain",
|
||||||
|
joinRoom="telah memasuki ruangan.",
|
||||||
|
leaveRoom="telah keluar dari ruangan.",
|
||||||
|
ready="Siap",
|
||||||
|
connStream="Menghubungi",
|
||||||
|
waitStream="Menunggu",
|
||||||
|
spectating="Menonton",
|
||||||
|
chatRemain="Online",
|
||||||
|
chatStart="------Awal percakapan------",
|
||||||
|
chatHistory="------Pesan-pesan baru di bawah ini------",
|
||||||
|
|
||||||
|
-- searchModeHelp="Type to search",
|
||||||
|
keySettingHelp="Tekan untuk menghubung tombol ke aksi tertentu\nescape: batal\nbackspace: hapus",
|
||||||
|
customBGhelp="Seret file gambar di sini untuk memasangkan background",
|
||||||
|
customBGloadFailed="Format file gambar tidak didukung untuk background",
|
||||||
|
|
||||||
|
errorMsg="Techmino mengalami eror dan harus memuat ulang.\nAnda bisa mengirim log eror ke developer.",
|
||||||
|
tryAnotherBuild="[Invalid UTF-8] Jika Anda di Windows, coba download Techmino-win32 atau Techmino-win64 (berbeda dari yang Anda menggunakan sekarang).",
|
||||||
|
|
||||||
|
modInstruction="Pilih mod Anda!\nMod memungkinkan Anda untuk mengubah permainan,\ntetapi juga bisa menghancur permainan.\nNilai-nilai tidak akan disimpan saat menggunakan mod.",
|
||||||
|
modInfo={
|
||||||
|
next="BLOK LANJUT\nMengubah jumlah blok lanjut yang ditampilkan.",
|
||||||
|
hold="SIMPAN\nMengubah jumlah blok yang bisa disimpan.",
|
||||||
|
hideNext="BLOK LANJUT Tersembunyi\nMenyembunyikan beberapa blok lanjut.",
|
||||||
|
infHold="SIMPAN SELAMANYA\nMemungkinkan Anda untuk menyimpan blok-blok selamanya.",
|
||||||
|
hideBlock="Sembunyikan Blok Aktif\nMenyembunyikan blok yang Anda mengontrol.",
|
||||||
|
hideGhost="Sembunyikan Blok Hantu\nMenyembunyikan blok yang menunjukkan tempat blok yang sedang dikontrol akan jatuh.",
|
||||||
|
hidden="Sembunyikan Blok Terdarat\nMenyembunyikan blok yang sudah mendarat setelah waktu yang tertentu.",
|
||||||
|
hideBoard="Sembunyikan Tempat Main\nMenyembunyikan bagian atau seluruh tempat main.",
|
||||||
|
flipBoard="Putar Tempat Main\nMembalik atau memutar tempat main.",
|
||||||
|
dropDelay="Gravitasi\nMengubah gravitasi dalam frame per blok.",
|
||||||
|
lockDelay="Tunda Mengunci\nMengubah tunda mengunci dalam frame.",
|
||||||
|
waitDelay="Tunda Muncul\nMengubah tunda muncul blok dalam frame.",
|
||||||
|
fallDelay="Tunda Baris\nMengubah tunda saat membuat baris dalam frame.",
|
||||||
|
life="Nyawa\nMengubah nomor awal nyawa.",
|
||||||
|
forceB2B="Hanya B2B\nMengakhirkan permainan jika meter B2B jatuh ke 0.",
|
||||||
|
forceFinesse="Efisiensi Tombol Maximum\nMengakhirkan permainan jika efisiensi tombol tidak maksimum.",
|
||||||
|
tele="Teleport\nMengubah DAS dan ARR ke 0.",
|
||||||
|
noRotation="Tidak berputar\nMematikan pemutaran blok.",
|
||||||
|
noMove="Tidak bergerak\nMematikan pergerakan kiri dan kanan blok.",
|
||||||
|
customSeq="Pengacak\nMengganti pengacak blok.",
|
||||||
|
pushSpeed="Kecepatan blok serangan\nMengubah kecepatan muncul blok serangan (blok/frame).",
|
||||||
|
boneBlock="[ ]\nMain dengan blok [ ].",
|
||||||
|
},
|
||||||
|
pauseStat={
|
||||||
|
"Waktu:",
|
||||||
|
"Tombol/Putar/Simpan:",
|
||||||
|
"Blok:",
|
||||||
|
"Baris/Baris Gali:",
|
||||||
|
"Serangan/Serangan Gali:",
|
||||||
|
"Diterima:",
|
||||||
|
"Jumlah Tindakan Membuat Baris:",
|
||||||
|
"Spins:",
|
||||||
|
"B2B/B3B/PC/Hampir PC:",
|
||||||
|
"Efisiensi Tombol:",
|
||||||
|
},
|
||||||
|
radar={"BLOK","SERANGAN","SRGN + BLOK","SRGN TERKIRIM","KECEPATAN","GALI"},
|
||||||
|
radarData={"D'PM","ADPM","APM","SPM","L'PM","DPM"},
|
||||||
|
stat={
|
||||||
|
"Jumlah Pembukaan:",
|
||||||
|
"Jumlah Permainan:",
|
||||||
|
"Jumlah Waktu Bermain:",
|
||||||
|
"Tombol/Putar/Simpan:",
|
||||||
|
"Blok/Baris/Serangan:",
|
||||||
|
"Serangan Diterima/Ditolak/Muncul:", -- what is this
|
||||||
|
"Gali/Serangan Gali:",
|
||||||
|
"Efisiensi/Efisiensi Gali:",
|
||||||
|
"B2B/B2B2B:",
|
||||||
|
"PC/Hampir PC:",
|
||||||
|
"Efisiensi Tombol Tidak Maksimal/Nilai:",
|
||||||
|
},
|
||||||
|
aboutTexts={
|
||||||
|
"Ini hanya penyusun blok *normal*. Sungguh, hanya itu saja.",
|
||||||
|
"Terinspirasi oleh C2, IO, JS, WWC, KOS, dll.",
|
||||||
|
"",
|
||||||
|
"Dipersembahkan oleh kerangka permainan LÖVE",
|
||||||
|
"Saran dan laporan bug dihargai!",
|
||||||
|
"Pastikan untuk mendapat permainan ini hanya dari sumber resmi,",
|
||||||
|
"karena kita tidak bisa meyakinkan Anda aman jika Anda mendapat permainan ini dari sumber lain.",
|
||||||
|
"Penciptanya tidak bertanggung jawab untuk modifikasi.",
|
||||||
|
FNNS and"/"or"Permainan ini gratis, tetapi sumbangan sangat dihargai.",
|
||||||
|
-- FNNS and"/"or"Check Zictionary for more",
|
||||||
|
},
|
||||||
|
staff={
|
||||||
|
"Pencipta: MrZ Email: 1046101471@qq.com",
|
||||||
|
"Dipersembahkan oleh kerangka permainan LÖVE",
|
||||||
|
"",
|
||||||
|
"Program: MrZ, Particle_G, [scdhh, FinnTenzor]",
|
||||||
|
"Penggambar: MrZ, Gnyar, C₂₉H₂₅N₃O₅, ScF, [旋律星萤, T0722]",
|
||||||
|
"Musik: MrZ, 柒栎流星, ERM, Trebor, C₂₉H₂₅N₃O₅, [T0722, Aether]",
|
||||||
|
"Suara: Miya, Xiaoya, Mono, MrZ, Trebor",
|
||||||
|
"Pertunjukan: 模电, HBM",
|
||||||
|
"Translasi: User670, MattMayuga, Mizu, Mr.Faq, ScF, C₂₉H₂₅N₃O₅, NOT_A_ROBOT",
|
||||||
|
"",
|
||||||
|
"Terima Kasih Khusus:",
|
||||||
|
"Flyz, Big_True, NOT_A_ROBOT, 思竣, yuhao7370",
|
||||||
|
"Farter, Teatube, 蕴空之灵, T9972, [All test staff]",
|
||||||
|
},
|
||||||
|
used=[[
|
||||||
|
Alat-alat yang digunakan:
|
||||||
|
BeepBox
|
||||||
|
GoldWave
|
||||||
|
GFIE
|
||||||
|
FL Mobile
|
||||||
|
Library yang digunakan:
|
||||||
|
Cold_Clear [MinusKelvin]
|
||||||
|
json.lua [rxi]
|
||||||
|
profile.lua [itraykov]
|
||||||
|
simple-love-lights [dylhunn]
|
||||||
|
]],
|
||||||
|
support="Dukung pencipta",
|
||||||
|
WidgetText={
|
||||||
|
main={
|
||||||
|
offline="Main Sendiri",
|
||||||
|
qplay="Terakhir Dimain",
|
||||||
|
online="Multipemain",
|
||||||
|
custom="Permainan Tersesuai",
|
||||||
|
setting="Pengaturan",
|
||||||
|
stat="Statistik",
|
||||||
|
dict="Zictionary",
|
||||||
|
replays="Permainan Terulang",
|
||||||
|
},
|
||||||
|
main_simple={
|
||||||
|
sprint="Balapan",
|
||||||
|
marathon="Maraton",
|
||||||
|
},
|
||||||
|
modeExplorer={
|
||||||
|
mod="Mod (F1)",
|
||||||
|
},
|
||||||
|
mod={
|
||||||
|
title="Mod",
|
||||||
|
reset="Reset (tab)",
|
||||||
|
unranked="Tidak Berperingkat",
|
||||||
|
},
|
||||||
|
pause={
|
||||||
|
setting="Pengaturan (S)",
|
||||||
|
replay="Ulang (P)",
|
||||||
|
save="Simpan Pengulangan (O)",
|
||||||
|
resume="Lanjut (esc)",
|
||||||
|
restart="Coba lagi (R)",
|
||||||
|
quit="Berhenti (Q)",
|
||||||
|
tas="TAS (T)",
|
||||||
|
},
|
||||||
|
net_menu={
|
||||||
|
league="Tech League",
|
||||||
|
ffa="FFA",
|
||||||
|
rooms="Ruang-ruang",
|
||||||
|
logout="Log out",
|
||||||
|
},
|
||||||
|
net_league={
|
||||||
|
match="Cari Tandingan",
|
||||||
|
},
|
||||||
|
net_rooms={
|
||||||
|
password="Password",
|
||||||
|
refreshing="Merefresh daftar",
|
||||||
|
noRoom="Tidak ada ruangan",
|
||||||
|
refresh="Refresh",
|
||||||
|
new="Ruangan Baru",
|
||||||
|
join="Masuk",
|
||||||
|
},
|
||||||
|
net_newRoom={
|
||||||
|
title="Pengaturan Ruangan",
|
||||||
|
roomName="Nama ruangan (Jika kosong: \"[username]'s room\")",
|
||||||
|
password="Password (opsional)",
|
||||||
|
description="Deskripsi Ruangan",
|
||||||
|
|
||||||
|
life="Nyawa",
|
||||||
|
pushSpeed="Kcptn. Dorongan",
|
||||||
|
garbageSpeed="Kcptn. Serangan",
|
||||||
|
visible="Visibilitas",
|
||||||
|
freshLimit="Batas Reset Tunda Kunci",
|
||||||
|
|
||||||
|
fieldH="Ketinggian",
|
||||||
|
bufferLimit="Batas Serangan",
|
||||||
|
heightLimit="Batas Tinggi",
|
||||||
|
|
||||||
|
drop="Tunda Jatuh",
|
||||||
|
lock="Tunda Kunci",
|
||||||
|
wait="Tunda Muncul",
|
||||||
|
fall="Tunda Baris",
|
||||||
|
hang="Tunda Kalah",
|
||||||
|
hurry="Menggangu Tunda",
|
||||||
|
|
||||||
|
capacity="Kapasitas",
|
||||||
|
create="Buat",
|
||||||
|
|
||||||
|
ospin="O-spin",
|
||||||
|
fineKill="100% Efisiensi Tombol",
|
||||||
|
b2bKill="Akhirkan Permainan Jika Tidak B2B",
|
||||||
|
lockout="Akhirkan Permainan Jika Lock Out",
|
||||||
|
easyFresh="Reset Tunda Kunci Normal",
|
||||||
|
deepDrop="Jatuh Dalam",
|
||||||
|
bone="Blok [ ]",
|
||||||
|
|
||||||
|
eventSet="Aturan",
|
||||||
|
|
||||||
|
holdMode="Mode Simpan",
|
||||||
|
nextCount="Pratinjau Blok Lanjut",
|
||||||
|
holdCount="Blok Simpan",
|
||||||
|
infHold="Simpan Selamanya",
|
||||||
|
phyHold="Simpan Di Tempat",
|
||||||
|
},
|
||||||
|
net_game={
|
||||||
|
ready="Siap",
|
||||||
|
spectate="Nonton",
|
||||||
|
cancel="Batal Siap",
|
||||||
|
},
|
||||||
|
setting_game={
|
||||||
|
title="Pengaturan Permainan",
|
||||||
|
graphic="←Video",
|
||||||
|
sound="Audio→",
|
||||||
|
layout="Ubah Blok-blok",
|
||||||
|
|
||||||
|
ctrl="Ubah Kontrol",
|
||||||
|
key="Ubah Tindakan Tombol",
|
||||||
|
touch="Pengaturan Sentuhan",
|
||||||
|
showVK="Tunjuk Tombol Sentuh",
|
||||||
|
reTime="Tunda Mulai",
|
||||||
|
RS="Sistem Putar",
|
||||||
|
menuPos="Pos. Tombol Menu",
|
||||||
|
sysCursor="Guna Mouse Bawaan",
|
||||||
|
autoPause="Jeda Jika Tidak Difokus",
|
||||||
|
autoSave="Simpan Rekor Otomatis",
|
||||||
|
autoLogin="Auto-login Saat Membuka",
|
||||||
|
simpMode="Mode Sederhana",
|
||||||
|
},
|
||||||
|
setting_video={
|
||||||
|
title="Pengaturan Video",
|
||||||
|
sound="←Audio",
|
||||||
|
game="Permainan→",
|
||||||
|
|
||||||
|
block="Gambarkan Blok",
|
||||||
|
smooth="Jatuh Halus",
|
||||||
|
upEdge="Blok 3D",
|
||||||
|
bagLine="Pemisah Kantong",
|
||||||
|
|
||||||
|
ghostType="Tipe Hantu",
|
||||||
|
ghost="Kegelapan Hantu",
|
||||||
|
center="Kegelapan Tengah Pemutaran",
|
||||||
|
grid="Kegelapan Kisi",
|
||||||
|
lineNum="Kegelapan Nomor Baris",
|
||||||
|
|
||||||
|
lockFX="Efek Kunci",
|
||||||
|
dropFX="Efek Jatuh",
|
||||||
|
moveFX="Efek Pindah",
|
||||||
|
clearFX="Efek Baris",
|
||||||
|
splashFX="Efek Guyuran Baris",
|
||||||
|
shakeFX="Goyang Tempat Main",
|
||||||
|
atkFX="Efek Serang",
|
||||||
|
|
||||||
|
frame="Kecepatan Bingkai (%)",
|
||||||
|
FTlock="Lewat Bingkai",
|
||||||
|
|
||||||
|
text="Teks Baris",
|
||||||
|
score="Teks Nilai",
|
||||||
|
bufferWarn="Peringatan Serangan",
|
||||||
|
showSpike="Teks Serang",
|
||||||
|
nextPos="Pratinjau Muncul Blok",
|
||||||
|
highCam="Scroll Tempat Main",
|
||||||
|
warn="Peringatan Bahaya",
|
||||||
|
|
||||||
|
clickFX="Efek Klik",
|
||||||
|
power="Info Baterai",
|
||||||
|
clean="Gambar Cepat",
|
||||||
|
fullscreen="Layar Penuh",
|
||||||
|
|
||||||
|
bg_on="B.G. Normal",
|
||||||
|
bg_off="Tidak Ada B.G.",
|
||||||
|
bg_custom="Ubah B.G.",
|
||||||
|
|
||||||
|
blockSatur="Kejenuhan Blok Aktif",
|
||||||
|
fieldSatur="Kejenuhan Blok Terkunci",
|
||||||
|
},
|
||||||
|
setting_sound={
|
||||||
|
title="Pengaturan Audio",
|
||||||
|
|
||||||
|
game="←Permainan",
|
||||||
|
graphic="Video→",
|
||||||
|
|
||||||
|
mainVol="Volume Utama",
|
||||||
|
bgm="Musik",
|
||||||
|
sfx="Efek Suara",
|
||||||
|
stereo="Stereo",
|
||||||
|
spawn="Efek Muncul Blok",
|
||||||
|
warn="Efek Bahaya",
|
||||||
|
vib="Getaran",
|
||||||
|
voc="Suara",
|
||||||
|
|
||||||
|
autoMute="Bisukan Bila Tidak Fokus",
|
||||||
|
fine="Efek Efisiensi Tombol Tidak Maksimum",
|
||||||
|
sfxPack="Kumpulan Efek Suara",
|
||||||
|
vocPack="Kumpulan Suara",
|
||||||
|
apply="Terapkan",
|
||||||
|
},
|
||||||
|
setting_control={
|
||||||
|
title="Pengaturan Kontrol",
|
||||||
|
preview="Pratinjau",
|
||||||
|
|
||||||
|
das="DAS",arr="ARR",
|
||||||
|
dascut="Gangguan DAS",
|
||||||
|
dropcut="Gangguan Auto-kunci",
|
||||||
|
sddas="DAS Jatuh",sdarr="ARR Jatuh",
|
||||||
|
ihs="Simpan Saat Tunda",
|
||||||
|
irs="Putar Saat Tunda",
|
||||||
|
ims="Pindah Saat Tunda",
|
||||||
|
reset="Reset",
|
||||||
|
},
|
||||||
|
setting_key={
|
||||||
|
a1="Pindah Kiri",
|
||||||
|
a2="Pindah Kanan",
|
||||||
|
a3="Putar Kanan",
|
||||||
|
a4="Putar Kiri",
|
||||||
|
a5="Putar 180°",
|
||||||
|
a6="Jatuh Cepat",
|
||||||
|
a7="Jatuh Pelan",
|
||||||
|
a8="Simpan",
|
||||||
|
a9="Fungsi 1",
|
||||||
|
a10="Fungsi 2",
|
||||||
|
a11="Kiri Instan",
|
||||||
|
a12="Kanan Instan",
|
||||||
|
a13="Jatuh Instan",
|
||||||
|
a14="Jatuh 1",
|
||||||
|
a15="Jatuh 4",
|
||||||
|
a16="Jatuh 10",
|
||||||
|
a17="Jatuh Kiri",
|
||||||
|
a18="Jatuh Kanan",
|
||||||
|
a19="Zangi Kiri",
|
||||||
|
a20="Zangi Kanan",
|
||||||
|
restart="Coba Lagi",
|
||||||
|
},
|
||||||
|
setting_skin={
|
||||||
|
skinSet="Tekstur Blok",
|
||||||
|
title="Pengaturan Ragam",
|
||||||
|
skinR="Reset Warna",
|
||||||
|
faceR="Reset Arah",
|
||||||
|
},
|
||||||
|
setting_touch={
|
||||||
|
default="Bawaan",
|
||||||
|
snap="Kisi",
|
||||||
|
size="Ukuran",
|
||||||
|
shape="Bentuk",
|
||||||
|
},
|
||||||
|
setting_touchSwitch={
|
||||||
|
b1= "Pindah Kiri:", b2="Pindah Kanan:",b3="Putar Kanan:", b4="Putar Kiri:",
|
||||||
|
b5= "Putar 180°:", b6="Jatuh Cepat:", b7="Jatuh Pelan:", b8="Simpan:",
|
||||||
|
b9= "Fungsi 1:", b10="Fungsi 2:", b11="Kiri Instan:",b12="Kanan Instan:",
|
||||||
|
b13="Jatuh Instan:",b14="Jatuh 1:", b15="Jatuh 4:", b16="Jatuh 10:",
|
||||||
|
b17="Jatuh Kiri:", b18="Jatuh Kanan:",b19="Zangi Kiri:", b20="Zangi Kanan:",
|
||||||
|
|
||||||
|
norm="Normal",
|
||||||
|
pro="Canggih",
|
||||||
|
icon="Ikon",
|
||||||
|
sfx="Efek Suara",
|
||||||
|
vib="Getaran",
|
||||||
|
alpha="Kegelapan",
|
||||||
|
|
||||||
|
track="Auto Lacak",
|
||||||
|
dodge="Auto Hindar",
|
||||||
|
},
|
||||||
|
customGame={
|
||||||
|
title="Permainan Tersesuai",
|
||||||
|
defSeq="Urutan Bawaan",
|
||||||
|
noMsn="Tidak Ada Misi",
|
||||||
|
|
||||||
|
drop="Tunda Jatuh",
|
||||||
|
lock="Tunda Kunci",
|
||||||
|
wait="Tunda Muncul",
|
||||||
|
fall="Tunda Garis",
|
||||||
|
hang="Tunda Kalah",
|
||||||
|
hurry="Gangguan Tunda",
|
||||||
|
|
||||||
|
bg="Latar Belakang",
|
||||||
|
bgm="Musik",
|
||||||
|
|
||||||
|
copy="Salin Permainan",
|
||||||
|
paste="Tempel Permainan",
|
||||||
|
play_clear="Mulai Normal",
|
||||||
|
play_puzzle="Mulai Membangun",
|
||||||
|
|
||||||
|
reset="Reset (del)",
|
||||||
|
advance="More (A)",
|
||||||
|
mod="Mod (F1)",
|
||||||
|
field="Ubah Blok (F)",
|
||||||
|
sequence="Ubah Urutan (S)",
|
||||||
|
mission="Ubah Misi (M)",
|
||||||
|
|
||||||
|
eventSet="Aturan",
|
||||||
|
|
||||||
|
holdMode="Mode Simpan",
|
||||||
|
nextCount="Pratinjau Blok Lanjut",
|
||||||
|
holdCount="Simpan Blok",
|
||||||
|
infHold="Simpan Selamanya",
|
||||||
|
phyHold="Simpan Di Tempat",
|
||||||
|
|
||||||
|
fieldH="Ketinggian",
|
||||||
|
visible="Visibilitas",
|
||||||
|
freshLimit="Batas Reset Tunda Kunci",
|
||||||
|
opponent="Lawan",
|
||||||
|
life="Nyawa",
|
||||||
|
pushSpeed="Kcptn. Dorongan",
|
||||||
|
garbageSpeed="Kcptn. Serangan",
|
||||||
|
|
||||||
|
bufferLimit="Batas Serangan",
|
||||||
|
heightLimit="Batas Tinggi",
|
||||||
|
ospin="O-Spin",
|
||||||
|
fineKill="Maksimum Efisiensi Tombol",
|
||||||
|
b2bKill="Akhirkan Permainan Jika Tidak B2B",
|
||||||
|
lockout="Akhirkan Permainan Jika Lock Out",
|
||||||
|
easyFresh="Reset Tunda Kunci Normal",
|
||||||
|
deepDrop="Jatuh Dalam",
|
||||||
|
bone="Blok []",
|
||||||
|
},
|
||||||
|
custom_field={
|
||||||
|
title="Permainan Tersesuai",
|
||||||
|
subTitle="Blok Awalan",
|
||||||
|
|
||||||
|
any="Hapus",
|
||||||
|
smart="Auto",
|
||||||
|
|
||||||
|
push="Tambah Baris (K)",
|
||||||
|
del="Hapus Garis (L)",
|
||||||
|
|
||||||
|
demo="Jangan Menunjukkan ×",
|
||||||
|
|
||||||
|
newPg="Hal. Baru (N)",
|
||||||
|
delPg="Hapus Hal. (M)",
|
||||||
|
prevPg="Hal. Sebelumnya",
|
||||||
|
nextPg="Hal. Selanjuynya",
|
||||||
|
},
|
||||||
|
custom_sequence={
|
||||||
|
title="Permainan Tersesuai",
|
||||||
|
subTitle="Urutan Blok",
|
||||||
|
sequence="Urutan Blok",
|
||||||
|
},
|
||||||
|
custom_mission={
|
||||||
|
title="Permainan Tersesuai",
|
||||||
|
subTitle="Misi",
|
||||||
|
|
||||||
|
_1="1",_2="2",_3="3",_4="4",
|
||||||
|
any1="apapun-1",any2="apapun-2",any3="apapun-3",any4="apapun-4",
|
||||||
|
PC="PC",
|
||||||
|
Z1="Z1",S1="S1",J1="J1",L1="L1",T1="T1",O1="O1",I1="I1",
|
||||||
|
Z2="Z2",S2="S2",J2="J2",L2="L2",T2="T2",O2="O2",I2="I2",
|
||||||
|
Z3="Z3",S3="S3",J3="J3",L3="L3",T3="T3",O3="O3",I3="I3",
|
||||||
|
O4="O4",I4="I4",
|
||||||
|
mission="Paksa Misi",
|
||||||
|
},
|
||||||
|
about={
|
||||||
|
staff="Staf",
|
||||||
|
his="Riwayat",
|
||||||
|
legals="Info Legal",
|
||||||
|
},
|
||||||
|
dict={
|
||||||
|
title="TetroKamus",
|
||||||
|
},
|
||||||
|
stat={
|
||||||
|
path="Buka Folder Data",
|
||||||
|
save="Kelola Data",
|
||||||
|
},
|
||||||
|
music={
|
||||||
|
title="Ruang Musik",
|
||||||
|
arrow="→",
|
||||||
|
now="Sekarang bermain:",
|
||||||
|
|
||||||
|
bgm="Volume",
|
||||||
|
sound="Efek Suara",
|
||||||
|
},
|
||||||
|
launchpad={
|
||||||
|
title="Ruang Efek Suara",
|
||||||
|
bgm="Volume Musik",
|
||||||
|
sfx="Volume Efek",
|
||||||
|
voc="Volume Suara",
|
||||||
|
music="Musik",
|
||||||
|
label="label",
|
||||||
|
},
|
||||||
|
login={
|
||||||
|
title="Masuk",
|
||||||
|
register="Daftar",
|
||||||
|
email="Alamat Email",
|
||||||
|
password="Password",
|
||||||
|
keepPW="Ingat Saya",
|
||||||
|
login="Masuk",
|
||||||
|
},
|
||||||
|
register={
|
||||||
|
title="Daftar",
|
||||||
|
login="Masuk",
|
||||||
|
username="Username",
|
||||||
|
email="Alamat Email",
|
||||||
|
password="Password",
|
||||||
|
password2="Ulangi Password",
|
||||||
|
register="Daftar",
|
||||||
|
registering="Menunggu respon…",
|
||||||
|
},
|
||||||
|
account={
|
||||||
|
title="Akun",
|
||||||
|
},
|
||||||
|
app_15p={
|
||||||
|
color="Warna",
|
||||||
|
invis="Sembunyi",
|
||||||
|
slide="Geser",
|
||||||
|
pathVis="Tunjuk Jalur",
|
||||||
|
revKB="Dibalik",
|
||||||
|
},
|
||||||
|
app_schulteG={
|
||||||
|
rank="Ukuran",
|
||||||
|
invis="Sembunyi",
|
||||||
|
disappear="Hilangkan",
|
||||||
|
tapFX="Efek Sentuh",
|
||||||
|
},
|
||||||
|
app_AtoZ={
|
||||||
|
level="Level",
|
||||||
|
keyboard="Keyboard",
|
||||||
|
},
|
||||||
|
app_2048={
|
||||||
|
invis="Sembunyi",
|
||||||
|
tapControl="Kontrol Sentuh",
|
||||||
|
|
||||||
|
skip="Lewati Ronde",
|
||||||
|
},
|
||||||
|
app_ten={
|
||||||
|
next="Pratinjau",
|
||||||
|
invis="Sembunyi",
|
||||||
|
fast="Cepat",
|
||||||
|
},
|
||||||
|
app_dtw={
|
||||||
|
color="Warna",
|
||||||
|
mode="Mode",
|
||||||
|
bgm="Musik",
|
||||||
|
arcade="Arcade",
|
||||||
|
},
|
||||||
|
app_link={
|
||||||
|
invis="Sembunyi",
|
||||||
|
},
|
||||||
|
savedata={
|
||||||
|
export="Expor ke papan klip",
|
||||||
|
import="Impor dari papan klip",
|
||||||
|
unlock="Kemajuan",
|
||||||
|
data="Statistik",
|
||||||
|
setting="Pengaturan",
|
||||||
|
vk="Aturan Tombol Sentuh",
|
||||||
|
|
||||||
|
couldSave="Penyimpanan Cloud (PERINGATAN: HANYA PERCOBAAN)",
|
||||||
|
notLogin="[Masuk ke akun untuk mengakses penyimpanan cloud",
|
||||||
|
upload="Unggah ke Cloud",
|
||||||
|
download="Unduh dari Cloud",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
modes={
|
||||||
|
['sprint_10l']= {"Balapan", "10L", "Buat 10 baris!"},
|
||||||
|
['sprint_20l']= {"Balapan", "20L", "Buat 20 baris!"},
|
||||||
|
['sprint_40l']= {"Balapan", "40L", "Buat 40 baris!"},
|
||||||
|
['sprint_100l']= {"Balapan", "100L", "Buat 100 baris!"},
|
||||||
|
['sprint_400l']= {"Balapan", "400L", "Buat 400 baris!"},
|
||||||
|
['sprint_1000l']= {"Balapan", "1.000L", "Buat 1.000 baris!"},
|
||||||
|
['sprintPenta']= {"Balapan", "PENTOMINO", "40L dengan pentomino!"},
|
||||||
|
['sprintMPH']= {"Balapan", "MPH", "Tanpa ingatan\nTanpa pratinjau\nTanpa simpan"},
|
||||||
|
['dig_10l']= {"Gali", "10L", "Gali 10 baris!"},
|
||||||
|
['dig_40l']= {"Gali", "40L", "Gali 40 baris!"},
|
||||||
|
['dig_100l']= {"Gali", "100L", "Gali 100 baris!"},
|
||||||
|
['dig_400l']= {"Gali", "400L", "Gali 400 baris!"},
|
||||||
|
['drought_n']= {"Nasib Buruk", "100L", "Tidak ada blok I..."},
|
||||||
|
['drought_l']= {"Nasib Buruk+", "100L", "Nasib sangat buruk..."},
|
||||||
|
['marathon_n']= {"Maraton", "NORMAL", "200-baris maraton dengan kecepatan meningkat"},
|
||||||
|
['marathon_h']= {"Maraton", "SULIT", "200-baris maraton dengan kecepatan tinggi"},
|
||||||
|
['solo_e']= {"Tarung", "MUDAH", "Kalahkan AInya!"},
|
||||||
|
['solo_n']= {"Tarung", "NORMAL", "Kalahkan AInya!"},
|
||||||
|
['solo_h']= {"Tarung", "SULIT", "Kalahkan AInya!"},
|
||||||
|
['solo_l']= {"Tarung", "GILA", "Kalahkan AInya!"},
|
||||||
|
['solo_u']= {"Tarung", "TERAKHIR", "Kalahkan AInya!"},
|
||||||
|
['techmino49_e']= {"Tech 49", "MUDAH", "Pertarungan dengan 49 pemain."},
|
||||||
|
['techmino49_h']= {"Tech 49", "SULIT", "Pertarungan dengan 49 pemain."},
|
||||||
|
['techmino49_u']= {"Tech 49", "TERAKHIR", "Pertarungan dengan 49 pemain."},
|
||||||
|
['techmino99_e']= {"Tech 99", "MUDAH", "Pertarungan dengan 99 pemain."},
|
||||||
|
['techmino99_h']= {"Tech 99", "SULIT", "Pertarungan dengan 99 pemain."},
|
||||||
|
['techmino99_u']= {"Tech 99", "TERAKHIR", "Pertarungan dengan 99 pemain."},
|
||||||
|
['round_e']= {"Giliran", "MUDAH", "Giliran main melawan AI!"},
|
||||||
|
['round_n']= {"Giliran", "NORMAL", "Giliran main melawan AI!"},
|
||||||
|
['round_h']= {"Giliran", "SULIT", "Giliran main melawan AI!"},
|
||||||
|
['round_l']= {"Giliran", "GILA", "Giliran main melawan AI!"},
|
||||||
|
['round_u']= {"Giliran", "TERAKHIR", "Giliran main melawan AI!"},
|
||||||
|
['master_n']= {"Jago", "NORMAL", "Untuk pemula 20G"},
|
||||||
|
['master_h']= {"Jago", "SULIT", "Untuk pro 20G"},
|
||||||
|
['master_m']= {"Jago", "M21", "Untuk jago 20G"},
|
||||||
|
['master_final']= {"Jago", "TERAKHIR", "Lebih dari 20G"},
|
||||||
|
['master_ph']= {"Jago", "KHAYALAN", "???"},
|
||||||
|
['master_ex']= {"Sangat Jago", "EKSTRA", "Blok tidak kelihatan"},
|
||||||
|
['master_instinct']={"Jago", "INSTINK", "Bagaimana jika blok terkontrol tersembunyi?"},
|
||||||
|
['strategy_e']= {"Strategi", "MUDAH", "Keputusan 20G cepat"},
|
||||||
|
['strategy_h']= {"Strategi", "SULIT", "Keputusan 20G cepat"},
|
||||||
|
['strategy_u']= {"Strategi", "TERAKHIR", "Keputusan 20G cepat"},
|
||||||
|
['strategy_e_plus']={"Strategi", "MUDAH+", "Keputusan 20G cepat"},
|
||||||
|
['strategy_h_plus']={"Strategi", "SULIT+", "Keputusan 20G cepat"},
|
||||||
|
['strategy_u_plus']={"Strategi", "TERAKHIR+", "Keputusan 20G cepat"},
|
||||||
|
['blind_e']= {"Tak Terlihat", "MUDAH", "Untuk pemula"},
|
||||||
|
['blind_n']= {"Tak Terlihat", "NORMAL", "Untuk amatir"},
|
||||||
|
['blind_h']= {"Tak Terlihat", "SULIT", "Untuk orang berpengalaman"},
|
||||||
|
['blind_l']= {"Tak Terlihat", "GILA", "Untuk profesional"},
|
||||||
|
['blind_u']= {"Tak Terlihat", "???", "Apakah Anda siap?"},
|
||||||
|
['blind_wtf']= {"Tak Terlihat", "TERAKHIR", "Anda belum siap"},
|
||||||
|
['classic_e']= {"Klasik", "MUDAH", "Rekreasi berkecepatan rendah dari tahun 80-an"},
|
||||||
|
['classic_h']= {"Klasik", "SULIT", "Rekreasi berkecepatan medium dari tahun 80-an"},
|
||||||
|
['classic_u']= {"Klasik", "TERAKHIR", "Rekreasi berkecepatan tinggi dari tahun 80-an"},
|
||||||
|
['survivor_e']= {"Bertahan", "MUDAH", "Berapa lama Anda bisa bertahan?"},
|
||||||
|
['survivor_n']= {"Bertahan", "NORMAL", "Berapa lama Anda bisa bertahan?"},
|
||||||
|
['survivor_h']= {"Bertahan", "SULIT", "Berapa lama Anda bisa bertahan?"},
|
||||||
|
['survivor_l']= {"Bertahan", "GILA", "Berapa lama Anda bisa bertahan?"},
|
||||||
|
['survivor_u']= {"Bertahan", "TERAKHIR", "Berapa lama Anda bisa bertahan?"},
|
||||||
|
['attacker_h']= {"Penyerang", "SULIT", "Praktekkan keahlian menyerang Anda!"},
|
||||||
|
['attacker_u']= {"Penyerang", "TERAKHIR", "Praktekkan keahlian menyerang Anda!"},
|
||||||
|
['defender_n']= {"Pembela", "NORMAL", "Praktekkan keahlian membela Anda!"},
|
||||||
|
['defender_l']= {"Pembela", "GILA", "Praktekkan keahlian membela Anda!"},
|
||||||
|
['dig_h']= {"Pembor", "SULIT", "Praktekkan keahlian menggali Anda!"},
|
||||||
|
['dig_u']= {"Pembor", "TERAKHIR", "Praktekkan keahlian menggali Anda!"},
|
||||||
|
['clearRush']= {"Gegas Baris", "NORMAL", "Tutorial all-spin!\n[Dalam pengembangan]"},
|
||||||
|
['c4wtrain_n']= {"Latihan C4W", "NORMAL", "Kombo tidak terbatas."},
|
||||||
|
['c4wtrain_l']= {"Latihan C4W", "GILA", "Kombo tidak terbatas."},
|
||||||
|
['pctrain_n']= {"Latihan PC", "NORMAL", "Latihan PC"},
|
||||||
|
['pctrain_l']= {"Latihan PC", "GILA", "Latihan PC yang lebih sulit"},
|
||||||
|
['pc_n']= {"Tantangan PC", "NORMAL", "Dapatkan PC sampai 100 baris!"},
|
||||||
|
['pc_h']= {"Tantangan PC", "SULIT", "Dapatkan PC sampai 100 baris!"},
|
||||||
|
['pc_l']= {"Tantangan PC", "GILA", "Dapatkan PC sampai 100 baris!"},
|
||||||
|
['pc_inf']= {"Tantangan PC", "TAK TERBATAS", "Dapatkan PC sebanyaknya!"},
|
||||||
|
['tech_n']= {"Tech", "NORMAL", "Coba jaga deret Back-To-Back!"},
|
||||||
|
['tech_n_plus']= {"Tech", "NORMAL+", "Hanya Spins & PCs dibolehkan"},
|
||||||
|
['tech_h']= {"Tech", "SULIT", "Coba jaga deret Back-To-Back!"},
|
||||||
|
['tech_h_plus']= {"Tech", "SULIT+", "Hanya Spins & PCs dibolehkan"},
|
||||||
|
['tech_l']= {"Tech", "GILA", "Coba jaga deret Back-To-Back!"},
|
||||||
|
['tech_l_plus']= {"Tech", "GILA+", "Hanya Spins & PCs dibolehkan"},
|
||||||
|
['tech_finesse']= {"Tech", "EF. TOMBOL", "Efisiensi tombol harus maksimal!"},
|
||||||
|
['tech_finesse_f']= {"Tech", "EF. TOMBOL+", "Efisiensi tombol maksimal dan tidak ada garis normal!"},
|
||||||
|
['tsd_e']= {"Tantangan TSD", "MUDAH", "Hanya T-Spin Double dibolehkan!"},
|
||||||
|
['tsd_h']= {"Tantangan TSD", "SULIT", "Hanya T-Spin Double dibolehkan!"},
|
||||||
|
['tsd_u']= {"Tantangan TSD", "TERAKHIR", "Hanya T-Spin Double dibolehkan!"},
|
||||||
|
['backfire_n']= {"Serangan Balik", "NORMAL", "Tahankan serang baliknya!"},
|
||||||
|
['backfire_h']= {"Serangan Balik", "SULIT", "Tahankan serang baliknya!"},
|
||||||
|
['backfire_l']= {"Serangan Balik", "GILA", "Tahankan serang baliknya!"},
|
||||||
|
['backfire_u']= {"Serangan Balik", "TERAKHIR", "Tahankan serang baliknya!"},
|
||||||
|
['sprintAtk']= {"Balapan", "100 Serangan", "Kirim 100 baris serangan!"},
|
||||||
|
['sprintEff']= {"Balapan", "Efisiensi", "Kirim lebih banyak serangan sampai 40 baris!"},
|
||||||
|
['zen']= {"Zen", "200L", "Permainan 200-garis tanpa batas waktu"},
|
||||||
|
['ultra']= {"Ultra", "EKSTRA", "Permainan 2 menit. Dapatkan nilai sebanyaknya!"},
|
||||||
|
['infinite']= {"Tak Terbatas", "", "Bak pasir"},
|
||||||
|
['infinite_dig']= {"Tak Terbatas: Gali","", "Gali, gali, gali"},
|
||||||
|
['marathon_inf']= {"Maraton", "TAK TERBATAS", "Maraton tanpa akhir."},
|
||||||
|
|
||||||
|
['custom_clear']= {"Tersesuai", "NORMAL"},
|
||||||
|
['custom_puzzle']= {"Tersesuai", "TEKA-TEKI"},
|
||||||
|
},
|
||||||
|
getTip={refuseCopy=true,
|
||||||
|
"(RUR'U')R'FR2U'R'U'(RUR'F')",
|
||||||
|
"\"Techmino.app\" tidak bisa dibuka karena penciptanya tidak bisa diverifikasi.",
|
||||||
|
"\"Techmino.app\" akan merusak komputer Anda. Anda sebaiknya memindah itu ke tempat sampah.",
|
||||||
|
"\"TechminOS\"",
|
||||||
|
"\\jezevec/\\jezevec/\\jezevec/",
|
||||||
|
"\\osk/\\osk/\\osk/",
|
||||||
|
"↑↑↓↓←→←→BA",
|
||||||
|
"$include<studio.h>",
|
||||||
|
"20G sebenarnya peraturan permainan baru!",
|
||||||
|
"Rekor dunia 40L: 14.915s dari Reset_",
|
||||||
|
"Sistem pencapaian segera akan datang!",
|
||||||
|
"ALL SPIN!",
|
||||||
|
"Am G F G",
|
||||||
|
"B2B2B???",
|
||||||
|
"B2B2B2B tidak ada.",
|
||||||
|
"Back-to-Back Techrash, 10 Kombo, PC!",
|
||||||
|
"Pastikan untuk memberikan yang terbaik lagi hari ini!",
|
||||||
|
"Bridge clear segera akan datang!",
|
||||||
|
"Bisakah Anda menguasai penyusun modern namun akrab ini?",
|
||||||
|
"Changelog dalam Bahasa Inggris bisa ditemukan di Discord.",
|
||||||
|
"Color clear segera akan datang!",
|
||||||
|
"Menurunkan DAS dan ARR membuat permainannya lebih cepat tetapi lebih sulit untuk mengontrol.",
|
||||||
|
"Apakah saya baru saja melihat Back-to-Back-to-Back?",
|
||||||
|
"Apakah B2B2B2B ada?",
|
||||||
|
"Jangan biarkan bug kecil menghancur harimu!",
|
||||||
|
"Jangan melihat langsung ke bug!",
|
||||||
|
"Nikmati sistem rotasi Techmino!",
|
||||||
|
"Luar biasa, tapi mari kita pergi lebih baik lain kali…",
|
||||||
|
"Cari tahu apa yang ada di pengaturan!",
|
||||||
|
"Apakah Anda menemukan bug? Buka issue di halaman GitHub kami!",
|
||||||
|
"Permainan penyusun blok gratis dengan mode Battle Royale!",
|
||||||
|
"git commit",
|
||||||
|
"git push -f",
|
||||||
|
"Punya saran? Post sarannya di Discord kami!",
|
||||||
|
"Pernahkah Anda memperhatikan apa \"memutar\" melakukan ke blok?",
|
||||||
|
"Headphone direkomendasikan untuk pengalaman yang lebih baik.",
|
||||||
|
"Hello world!",
|
||||||
|
"Hanya ada 2 jenis trimino, yaitu I3 dan L3.",
|
||||||
|
"if a==true",
|
||||||
|
"Tingkatkan frekuensi gambar Anda untuk pengalaman yang lebih baik.",
|
||||||
|
"Sistem [tindakan] awal dapat menyelamatkan Anda.",
|
||||||
|
"Apakah B2B2B2B mungkin?",
|
||||||
|
"Ini sedang memuat! Bukan sekedar cutscene!",
|
||||||
|
"Anda dapat menyelesaikan 40L tanpa tombol kiri/kanan.",
|
||||||
|
"Anda dapat menyelesaikan 40L tanpa tombol putar.",
|
||||||
|
"Bergabunglah server Discord kami!",
|
||||||
|
"l-=-1",
|
||||||
|
"Biarkan bass menendang!",
|
||||||
|
"Kecepatan bingkai rendah mengurangi pengalaman bermain game Anda.",
|
||||||
|
"LrL RlR LLr RRl RRR LLL FFF RfR RRf rFF",
|
||||||
|
"Lua No.1",
|
||||||
|
"Mix clear segera akan datang!",
|
||||||
|
"Sebagian besar ikon tombol dibuat oleh mesin terbang yang digambar sendiri di Unicode Private Use Area.",
|
||||||
|
"Apakah musiknya terlalu mengganggu? Anda dapat mematikannya.",
|
||||||
|
"Tidak ada easter egg di menu ini jika Anda menyalakan gaya sederhana!",
|
||||||
|
"O-Spin Triple!",
|
||||||
|
"OHHHHHHHHHHHHHH",
|
||||||
|
"Main dengan satu tangan!",
|
||||||
|
"Bermain bagus membutuhkan waktu!",
|
||||||
|
"dipersembahkan oleh LÖVE",
|
||||||
|
"dipersembahkan oleh Un..LÖVE",
|
||||||
|
"Server kadang tidak berfungsi",
|
||||||
|
"Beberapa persyaratan untuk mencapai peringkat X sengaja dibuat sulit bahkan untuk pemain terbaik.",
|
||||||
|
"Segera Anda akan dapat bermain melawan teman dan musuh di seluruh dunia.",
|
||||||
|
"Split Clear segera akan datang!",
|
||||||
|
"sudo rm -rf /*",
|
||||||
|
"Techmino merupakan kombinasi dari Technique dan Tetromino.",
|
||||||
|
"Techmino memiliki edisi Nspire-CX!",
|
||||||
|
"Techmino sangat menyenangkan!",
|
||||||
|
"TetroDictionary sekarang tersedia dalam bahasa Inggris.",
|
||||||
|
"Sebagian besar musik dalam permainan ini dibuat menggunakan Beepbox.",
|
||||||
|
"Nama-nama yang muncul di latar belakang halaman Staf adalah daftar pendukung kami.",
|
||||||
|
"Masa depan penyusun blok milik Anda di Techmino!",
|
||||||
|
"Ada beberapa mode tersembunyi dalam permainan ini yang tidak dapat dimasuki menggunakan peta.",
|
||||||
|
"Ada total 18 pentomino yang berbeda.",
|
||||||
|
"Ada total 7 tetromino yang berbeda.",
|
||||||
|
"Coba gunakan beberapa slot simpan!",
|
||||||
|
"Try using two rotation buttons. Using all three of them is better.",
|
||||||
|
"Peringatan: Seni Programmer",
|
||||||
|
"Bagaimana dengan 20 PCs?",
|
||||||
|
"Bagaimana dengan 23 PCs dalam 100 baris?",
|
||||||
|
"Bagaimana dengan 26 TSDs?",
|
||||||
|
"while(false)",
|
||||||
|
"Anda adalah seorang jago!",
|
||||||
|
"Anda dipersilakan untuk membantu kami membuat musik dan efek suara!",
|
||||||
|
"Anda dapat menghubungkan keyboard ke ponsel atau tablet Anda (tetapi tidak berfungsi di iOS).",
|
||||||
|
"Anda bisa mengubah tindakan tombol di pengaturan!",
|
||||||
|
"Anda bisa menavigasi menu dengan keyboard.",
|
||||||
|
"Anda bisa membuka folder penyimpanan data dari halaman Statistik.",
|
||||||
|
"Anda bisa melakukan spin dengan semua blok di permainan ini kecuali blok O1.",
|
||||||
|
"Anda bisa mengubah arah muncul blok.",
|
||||||
|
"ZS JL T O I",
|
||||||
|
{C.C,"Coba juga 15puzzle!"},
|
||||||
|
{C.C,"Coba juga Ballance!"},
|
||||||
|
{C.C,"Coba juga Minecraft!"},
|
||||||
|
{C.C,"Coba juga Minesweeper!"},
|
||||||
|
{C.C,"Coba juga Orzmic!"},
|
||||||
|
{C.C,"Coba juga osu!"},
|
||||||
|
{C.C,"Coba juga Phigros!"},
|
||||||
|
{C.C,"Coba juga Puyo Puyo!"},
|
||||||
|
{C.C,"Coba juga Rubik's cube!"},
|
||||||
|
{C.C,"Coba juga Terraria!"},
|
||||||
|
{C.C,"Coba juga Touhou Project!"},
|
||||||
|
{C.C,"Coba juga VVVVVV!"},
|
||||||
|
{C.C,"Coba juga World of goo!"},
|
||||||
|
{C.C,"Coba juga Zuma!"},
|
||||||
|
{C.H,"REGRET!!"},
|
||||||
|
{C.lP,"Nomor rahasia: 626"},
|
||||||
|
{C.lR,"Z ",C.lG,"S ",C.lS,"J ",C.lO,"L ",C.lP,"T ",C.lY,"O ",C.lC,"I"},
|
||||||
|
{C.lY,"COOL!!"},
|
||||||
|
{C.N,"Lua",C.Z," No.1"},
|
||||||
|
{C.P,"T-spin!"},
|
||||||
|
{C.R,"\"Penyalahgunaan DMCA\""},
|
||||||
|
{C.R,"\"Hukum kekayaan intelektual\""},
|
||||||
|
{C.R,"DD",C.Z," Cannon=",C.P,"TS",C.R,"D",C.Z,"+",C.P,"TS",C.R,"D",C.Z," Cannon"},
|
||||||
|
{C.R,"DT",C.Z," Cannon=",C.P,"TS",C.R,"D",C.Z,"+",C.P,"TS",C.R,"T",C.Z," Cannon"},
|
||||||
|
{C.R,"LrL ",C.G,"RlR ",C.B,"LLr ",C.O,"RRl ",C.P,"RRR ",C.P,"LLL ",C.C,"FFF ",C.Y,"RfR ",C.Y,"RRf ",C.Y,"rFF"},
|
||||||
|
{C.Y,"O-Spin Triple!"},
|
||||||
|
{C.Z,"Apa? ",C.lC,"X-spin?"},
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -126,7 +126,8 @@ return{
|
|||||||
chatStart="------Começo do log------",
|
chatStart="------Começo do log------",
|
||||||
chatHistory="------Novas mensagens abaixo------",
|
chatHistory="------Novas mensagens abaixo------",
|
||||||
|
|
||||||
-- keySettingInstruction="Press to bind key\nescape: cancel\nbackspace: delete",
|
-- searchModeHelp="Type to search",
|
||||||
|
-- keySettingHelp="Press to bind key\nescape: cancel\nbackspace: delete",
|
||||||
-- customBGhelp="Drop image file here to apply custom background",
|
-- customBGhelp="Drop image file here to apply custom background",
|
||||||
-- customBGloadFailed="Unsupport image format for custom background",
|
-- customBGloadFailed="Unsupport image format for custom background",
|
||||||
|
|
||||||
@@ -194,9 +195,8 @@ return{
|
|||||||
"certifique-se de pegar o jogo de fontes oficiais;",
|
"certifique-se de pegar o jogo de fontes oficiais;",
|
||||||
"binários obtidos em outros lugares pode conter malware.",
|
"binários obtidos em outros lugares pode conter malware.",
|
||||||
"O autor não é responsável por qualquer binários modificados",
|
"O autor não é responsável por qualquer binários modificados",
|
||||||
FNSF and"/"or"O jogo é gratis, mas doações são apreciadas.",
|
FNNS and"/"or"O jogo é gratis, mas doações são apreciadas.",
|
||||||
FNSF and"/"or"Se você não conseguir usar o WeChat Pay e o AliPay,",
|
-- FNNS and"/"or"Check Zictionary for more",
|
||||||
FNSF and"/"or"pode acessar a página do P\97\116\114\101\111\110 para nos ajudar!",
|
|
||||||
},
|
},
|
||||||
staff={
|
staff={
|
||||||
"Author: MrZ E-mail: 1046101471@qq.com",
|
"Author: MrZ E-mail: 1046101471@qq.com",
|
||||||
@@ -207,7 +207,7 @@ return{
|
|||||||
"Music: MrZ, 柒栎流星, ERM, Trebor, C₂₉H₂₅N₃O₅, [T0722, Aether]",
|
"Music: MrZ, 柒栎流星, ERM, Trebor, C₂₉H₂₅N₃O₅, [T0722, Aether]",
|
||||||
"Voice & Sound: Miya, Xiaoya, Mono, MrZ, Trebor",
|
"Voice & Sound: Miya, Xiaoya, Mono, MrZ, Trebor",
|
||||||
"Performance: 模电, HBM",
|
"Performance: 模电, HBM",
|
||||||
"Traduzir: User670, MattMayuga, Mizu, Mr.Faq, ScF, C₂₉H₂₅N₃O₅",
|
"Traduzir: User670, MattMayuga, Mizu, Mr.Faq, ScF, C₂₉H₂₅N₃O₅, NOT_A_ROBOT",
|
||||||
"",
|
"",
|
||||||
"Special Thanks:",
|
"Special Thanks:",
|
||||||
"Flyz, Big_True, NOT_A_ROBOT, 思竣, yuhao7370",
|
"Flyz, Big_True, NOT_A_ROBOT, 思竣, yuhao7370",
|
||||||
@@ -241,9 +241,8 @@ return{
|
|||||||
sprint="Sprint",
|
sprint="Sprint",
|
||||||
marathon="Maratona",
|
marathon="Maratona",
|
||||||
},
|
},
|
||||||
mode={
|
modeExplorer={
|
||||||
mod="Mods (F1)",
|
mod="Mods (F1)",
|
||||||
start="Começar",
|
|
||||||
},
|
},
|
||||||
mod={
|
mod={
|
||||||
title="Mods",
|
title="Mods",
|
||||||
@@ -327,7 +326,7 @@ return{
|
|||||||
title="Config. de jogo",
|
title="Config. de jogo",
|
||||||
graphic="←Video",
|
graphic="←Video",
|
||||||
sound="Som→",
|
sound="Som→",
|
||||||
layout="Layout",
|
-- style="Style",
|
||||||
|
|
||||||
ctrl="Config. controle",
|
ctrl="Config. controle",
|
||||||
key="Map. teclas",
|
key="Map. teclas",
|
||||||
@@ -383,7 +382,7 @@ return{
|
|||||||
fullscreen="Tela cheia",
|
fullscreen="Tela cheia",
|
||||||
|
|
||||||
-- bg_on="Normal B.G.",
|
-- bg_on="Normal B.G.",
|
||||||
-- bg_on="No B.G.",
|
-- bg_off="No B.G.",
|
||||||
-- bg_custom="Use Custom B.G.",
|
-- bg_custom="Use Custom B.G.",
|
||||||
|
|
||||||
-- blockSatur="Block Saturation",
|
-- blockSatur="Block Saturation",
|
||||||
@@ -707,6 +706,9 @@ return{
|
|||||||
-- ['strategy_e']= {"Strategy", "EASY", "Fast 20G decision"},
|
-- ['strategy_e']= {"Strategy", "EASY", "Fast 20G decision"},
|
||||||
-- ['strategy_h']= {"Strategy", "HARD", "Fast 20G decision"},
|
-- ['strategy_h']= {"Strategy", "HARD", "Fast 20G decision"},
|
||||||
-- ['strategy_u']= {"Strategy", "ULTIMATE", "Fast 20G decision"},
|
-- ['strategy_u']= {"Strategy", "ULTIMATE", "Fast 20G decision"},
|
||||||
|
-- ['strategy_e_plus']={"Strategi", "MUDAH+", "Keputusan 20G cepat"},
|
||||||
|
-- ['strategy_h_plus']={"Strategi", "SULIT+", "Keputusan 20G cepat"},
|
||||||
|
-- ['strategy_u_plus']={"Strategi", "TERAKHIR+", "Keputusan 20G cepat"},
|
||||||
['blind_e']= {"Cego", "METADE", "Para novatos."},
|
['blind_e']= {"Cego", "METADE", "Para novatos."},
|
||||||
['blind_n']= {"Cego", "TUDO", "Para intermediários."},
|
['blind_n']= {"Cego", "TUDO", "Para intermediários."},
|
||||||
['blind_h']= {"Cego", "DE REPENTE", "Para experientes."},
|
['blind_h']= {"Cego", "DE REPENTE", "Para experientes."},
|
||||||
@@ -743,7 +745,7 @@ return{
|
|||||||
['tech_l']= {"Tech", "LUNÁTICO", "Não quebre o B2B!"},
|
['tech_l']= {"Tech", "LUNÁTICO", "Não quebre o B2B!"},
|
||||||
['tech_l_plus']= {"Tech", "LUNÁTICO+", "Apenas spins e PC"},
|
['tech_l_plus']= {"Tech", "LUNÁTICO+", "Apenas spins e PC"},
|
||||||
['tech_finesse']= {"Tech", "FINESSE", "Não erre a destreza!"},
|
['tech_finesse']= {"Tech", "FINESSE", "Não erre a destreza!"},
|
||||||
['tech_finesse_f']= {"Tech", "FINESSE+", "Sem limpas normais, não erre a destreza!"},
|
['tech_finesse_f']= {"Tech", "FINESSE+", "Sem limpas normais,\nnão erre a destreza!"},
|
||||||
['tsd_e']= {"Desafio TSD", "FÁCIL", "Apenas T-spin-doubles!"},
|
['tsd_e']= {"Desafio TSD", "FÁCIL", "Apenas T-spin-doubles!"},
|
||||||
['tsd_h']= {"Desafio TSD", "DIFÍCIL", "Apenas T-spin-doubles!"},
|
['tsd_h']= {"Desafio TSD", "DIFÍCIL", "Apenas T-spin-doubles!"},
|
||||||
['tsd_u']= {"Desafio TSD", "ULTIMATE", "Apenas T-spin-doubles!"},
|
['tsd_u']= {"Desafio TSD", "ULTIMATE", "Apenas T-spin-doubles!"},
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ return{
|
|||||||
loadSample="#~#",
|
loadSample="#~#",
|
||||||
loadVoice="#<()==)#",
|
loadVoice="#<()==)#",
|
||||||
loadFont="#Aa#",
|
loadFont="#Aa#",
|
||||||
loadModeIcon="#[ ]#",
|
|
||||||
loadMode="#[…]#",
|
loadMode="#[…]#",
|
||||||
loadOther="#…#",
|
loadOther="#…#",
|
||||||
finish="&",
|
finish="&",
|
||||||
@@ -130,8 +129,7 @@ return{
|
|||||||
"MrZ XXX A→B",
|
"MrZ XXX A→B",
|
||||||
"",
|
"",
|
||||||
"□$X, ↑$↑ XD!",
|
"□$X, ↑$↑ XD!",
|
||||||
"C0, 支 XXX,",
|
"[z]~~~",
|
||||||
"|^O : )",
|
|
||||||
},
|
},
|
||||||
WidgetText={
|
WidgetText={
|
||||||
main={
|
main={
|
||||||
@@ -144,9 +142,8 @@ return{
|
|||||||
dict="z",
|
dict="z",
|
||||||
replays="=~~~",
|
replays="=~~~",
|
||||||
},
|
},
|
||||||
mode={
|
modeExplorer={
|
||||||
mod="?!?!?!(F1)",
|
mod="?!?!?!(F1)",
|
||||||
start="!!!",
|
|
||||||
},
|
},
|
||||||
mod={
|
mod={
|
||||||
title="?!?!?!",
|
title="?!?!?!",
|
||||||
@@ -228,10 +225,9 @@ return{
|
|||||||
},
|
},
|
||||||
setting_game={
|
setting_game={
|
||||||
title="%~~%",
|
title="%~~%",
|
||||||
|
|
||||||
graphic="←Video",
|
graphic="←Video",
|
||||||
sound="Sound→",
|
sound="Sound→",
|
||||||
layout="=-=-=",
|
style="=-=-=",
|
||||||
|
|
||||||
ctrl="=?=",
|
ctrl="=?=",
|
||||||
key="=?",
|
key="=?",
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ return{fallback='zh',
|
|||||||
loadSample="乐器",
|
loadSample="乐器",
|
||||||
loadVoice="语音",
|
loadVoice="语音",
|
||||||
loadFont="字体",
|
loadFont="字体",
|
||||||
loadModeIcon="模式图标",
|
|
||||||
loadMode="模式",
|
loadMode="模式",
|
||||||
loadOther="其他",
|
loadOther="其他",
|
||||||
finish="走你",
|
finish="走你",
|
||||||
@@ -87,7 +86,6 @@ return{fallback='zh',
|
|||||||
WidgetText={
|
WidgetText={
|
||||||
setting_game={
|
setting_game={
|
||||||
title="改游戏",
|
title="改游戏",
|
||||||
|
|
||||||
graphic="←改画面",
|
graphic="←改画面",
|
||||||
sound="改声音→",
|
sound="改声音→",
|
||||||
|
|
||||||
@@ -233,6 +231,9 @@ return{fallback='zh',
|
|||||||
['strategy_e']= {"策略堆叠", "简单", "有区别吗"},
|
['strategy_e']= {"策略堆叠", "简单", "有区别吗"},
|
||||||
['strategy_h']= {"策略堆叠", "困难", "没区别吧"},
|
['strategy_h']= {"策略堆叠", "困难", "没区别吧"},
|
||||||
['strategy_u']= {"策略堆叠", "极限", "没区别"},
|
['strategy_u']= {"策略堆叠", "极限", "没区别"},
|
||||||
|
['strategy_e_plus']={"策略堆叠", "简单+", "有区别吗"},
|
||||||
|
['strategy_h_plus']={"策略堆叠", "困难+", "没区别吧"},
|
||||||
|
['strategy_u_plus']={"策略堆叠", "极限+", "没区别"},
|
||||||
['blind_e']= {"隐形", "半隐", "谁都能玩"},
|
['blind_e']= {"隐形", "半隐", "谁都能玩"},
|
||||||
['blind_n']= {"隐形", "全隐", "稍加练习即可"},
|
['blind_n']= {"隐形", "全隐", "稍加练习即可"},
|
||||||
['blind_h']= {"隐形", "瞬隐", "和上一个一样"},
|
['blind_h']= {"隐形", "瞬隐", "和上一个一样"},
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ return{
|
|||||||
loadSample="加载乐器采样",
|
loadSample="加载乐器采样",
|
||||||
loadVoice="加载语音资源",
|
loadVoice="加载语音资源",
|
||||||
loadFont="缓存字体资源",
|
loadFont="缓存字体资源",
|
||||||
loadModeIcon="加载模式图标",
|
|
||||||
loadMode="加载模式",
|
loadMode="加载模式",
|
||||||
loadOther="加载杂项",
|
loadOther="加载杂项",
|
||||||
finish="按任意键继续",
|
finish="按任意键继续",
|
||||||
@@ -138,7 +137,8 @@ return{
|
|||||||
chatStart="------消息的开头------",
|
chatStart="------消息的开头------",
|
||||||
chatHistory="------以上是历史消息------",
|
chatHistory="------以上是历史消息------",
|
||||||
|
|
||||||
keySettingInstruction="点击添加键位绑定\nesc取消选中\n退格键清空选中",
|
searchModeHelp="直接输入关键词搜索",
|
||||||
|
keySettingHelp="点击添加键位绑定\nesc取消选中\n退格键清空选中",
|
||||||
customBGhelp="把图片文件拖到这个窗口里使用自定义背景",
|
customBGhelp="把图片文件拖到这个窗口里使用自定义背景",
|
||||||
customBGloadFailed="自定义背景的图片文件格式不支持",
|
customBGloadFailed="自定义背景的图片文件格式不支持",
|
||||||
|
|
||||||
@@ -206,9 +206,8 @@ return{
|
|||||||
"仅通过官网 home.techmino.org 免费下载/更新",
|
"仅通过官网 home.techmino.org 免费下载/更新",
|
||||||
"其他渠道获得游戏皆有被修改/加广告/植入病毒的风险,程序只申请了振动&联网权限!",
|
"其他渠道获得游戏皆有被修改/加广告/植入病毒的风险,程序只申请了振动&联网权限!",
|
||||||
"若由于被修改的本游戏产生的各种损失作者不负责(怎么负责啊我又没法管)",
|
"若由于被修改的本游戏产生的各种损失作者不负责(怎么负责啊我又没法管)",
|
||||||
FNSF and"/"or"请从正规途径获得最新版,游戏现为免费,不过有打赏当然感谢啦~",
|
FNNS and"/"or"请从正规途径获得最新版,游戏现为免费,不过有打赏当然感谢啦~",
|
||||||
FNSF and"/"or"记得备注id备注id备注id,不然可能会没法记录到赞助列表!",
|
FNNS and"/"or"更多信息见小z词典",
|
||||||
FNSF and"/"or"你也可以去我们的P\97\116\114\101\111\110页面(链接见小Z词典)来支持我们!",
|
|
||||||
},
|
},
|
||||||
staff={
|
staff={
|
||||||
"作者:MrZ 邮箱:1046101471@qq.com",
|
"作者:MrZ 邮箱:1046101471@qq.com",
|
||||||
@@ -219,7 +218,7 @@ return{
|
|||||||
"音乐: MrZ,柒栎流星,ERM,Trebor,C₂₉H₂₅N₃O₅,[T0722,Aether]",
|
"音乐: MrZ,柒栎流星,ERM,Trebor,C₂₉H₂₅N₃O₅,[T0722,Aether]",
|
||||||
"音效/语音: Miya,Xiaoya,Mono,MrZ,Trebor",
|
"音效/语音: Miya,Xiaoya,Mono,MrZ,Trebor",
|
||||||
"演出: 模电,HBM",
|
"演出: 模电,HBM",
|
||||||
"翻译: User670,MattMayuga,Mizu,Mr.Faq,ScF,C₂₉H₂₅N₃O₅",
|
"翻译: User670,MattMayuga,Mizu,Mr.Faq,ScF,C₂₉H₂₅N₃O₅,NOT_A_ROBOT",
|
||||||
"",
|
"",
|
||||||
"特别感谢:",
|
"特别感谢:",
|
||||||
"Flyz,Big_True,NOT_A_ROBOT,思竣,yuhao7370",
|
"Flyz,Big_True,NOT_A_ROBOT,思竣,yuhao7370",
|
||||||
@@ -253,9 +252,8 @@ return{
|
|||||||
sprint="40行",
|
sprint="40行",
|
||||||
marathon="马拉松",
|
marathon="马拉松",
|
||||||
},
|
},
|
||||||
mode={
|
modeExplorer={
|
||||||
mod="Mods (F1)",
|
mod="Mods (F1)",
|
||||||
start="开始",
|
|
||||||
},
|
},
|
||||||
mod={
|
mod={
|
||||||
title="Mods",
|
title="Mods",
|
||||||
@@ -337,9 +335,9 @@ return{
|
|||||||
},
|
},
|
||||||
setting_game={
|
setting_game={
|
||||||
title="游戏设置",
|
title="游戏设置",
|
||||||
graphic="←画面设置",
|
graphic="←画面",
|
||||||
sound="声音设置→",
|
sound="声音→",
|
||||||
layout="外观",
|
style="风格",
|
||||||
|
|
||||||
ctrl="控制设置",
|
ctrl="控制设置",
|
||||||
key="键位设置",
|
key="键位设置",
|
||||||
@@ -356,8 +354,8 @@ return{
|
|||||||
},
|
},
|
||||||
setting_video={
|
setting_video={
|
||||||
title="画面设置",
|
title="画面设置",
|
||||||
sound="←声音设置",
|
sound="←声音",
|
||||||
game="游戏设置→",
|
game="游戏→",
|
||||||
|
|
||||||
block="方块可见",
|
block="方块可见",
|
||||||
smooth="平滑下落",
|
smooth="平滑下落",
|
||||||
@@ -403,8 +401,8 @@ return{
|
|||||||
},
|
},
|
||||||
setting_sound={
|
setting_sound={
|
||||||
title="声音设置",
|
title="声音设置",
|
||||||
game="←游戏设置",
|
game="←游戏",
|
||||||
graphic="画面设置→",
|
graphic="画面→",
|
||||||
|
|
||||||
mainVol="总音量",
|
mainVol="总音量",
|
||||||
bgm="音乐",
|
bgm="音乐",
|
||||||
@@ -713,9 +711,13 @@ return{
|
|||||||
['master_final']= {"大师", "终点", "究极20G:无法触及的终点"},
|
['master_final']= {"大师", "终点", "究极20G:无法触及的终点"},
|
||||||
['master_ph']= {"大师", "虚幻", "虚幻20G:???"},
|
['master_ph']= {"大师", "虚幻", "虚幻20G:???"},
|
||||||
['master_ex']= {"宗师", "EX", "成为方块大师"},
|
['master_ex']= {"宗师", "EX", "成为方块大师"},
|
||||||
|
['master_instinct']={"大师", "本能", "隐藏当前块"},
|
||||||
['strategy_e']= {"策略堆叠", "简单", "20G堆叠中速决策练习"},
|
['strategy_e']= {"策略堆叠", "简单", "20G堆叠中速决策练习"},
|
||||||
['strategy_h']= {"策略堆叠", "困难", "20G堆叠快速决策练习"},
|
['strategy_h']= {"策略堆叠", "困难", "20G堆叠快速决策练习"},
|
||||||
['strategy_u']= {"策略堆叠", "极限", "20G堆叠极速决策练习"},
|
['strategy_u']= {"策略堆叠", "极限", "20G堆叠极速决策练习"},
|
||||||
|
['strategy_e_plus']={"策略堆叠", "简单+", "20G堆叠中速决策练习"},
|
||||||
|
['strategy_h_plus']={"策略堆叠", "困难+", "20G堆叠快速决策练习"},
|
||||||
|
['strategy_u_plus']={"策略堆叠", "极限+", "20G堆叠极速决策练习"},
|
||||||
['blind_e']= {"隐形", "半隐", "不强大脑"},
|
['blind_e']= {"隐形", "半隐", "不强大脑"},
|
||||||
['blind_n']= {"隐形", "全隐", "挺强大脑"},
|
['blind_n']= {"隐形", "全隐", "挺强大脑"},
|
||||||
['blind_h']= {"隐形", "瞬隐", "很强大脑"},
|
['blind_h']= {"隐形", "瞬隐", "很强大脑"},
|
||||||
@@ -794,6 +796,7 @@ return{
|
|||||||
"报时机器人:新的一天开始了",
|
"报时机器人:新的一天开始了",
|
||||||
"本游戏还在测试中,出各种问题都是有可能的哦",
|
"本游戏还在测试中,出各种问题都是有可能的哦",
|
||||||
"本游戏使用精简版字体,可能有些特殊字符不能正确显示",
|
"本游戏使用精简版字体,可能有些特殊字符不能正确显示",
|
||||||
|
"别催了,在做了!",
|
||||||
"不要大力拍打或滑动哦",
|
"不要大力拍打或滑动哦",
|
||||||
"不要卖弱不要卖弱不要卖弱",
|
"不要卖弱不要卖弱不要卖弱",
|
||||||
"不知道有多少人玩游戏的时候会关心游戏是谁做的",
|
"不知道有多少人玩游戏的时候会关心游戏是谁做的",
|
||||||
@@ -801,9 +804,7 @@ return{
|
|||||||
"彩色消除即将到来!",
|
"彩色消除即将到来!",
|
||||||
"草(日本语)",
|
"草(日本语)",
|
||||||
"车万方块是一家(暴论",
|
"车万方块是一家(暴论",
|
||||||
"成就系统在做了!",
|
|
||||||
"吃键?真的吗?建议回放看看到底按没按到,按了多久",
|
"吃键?真的吗?建议回放看看到底按没按到,按了多久",
|
||||||
"触摸板打osu也很好!",
|
|
||||||
"凑数tip什么时候能站起来!",
|
"凑数tip什么时候能站起来!",
|
||||||
"打铁.png",
|
"打铁.png",
|
||||||
"打铁",
|
"打铁",
|
||||||
@@ -834,7 +835,6 @@ return{
|
|||||||
"混合消除即将到来!",
|
"混合消除即将到来!",
|
||||||
"架空消除即将到来!",
|
"架空消除即将到来!",
|
||||||
"建议使用双手游玩",
|
"建议使用双手游玩",
|
||||||
"据某个群友描述玩了Techmino之后打字速度变快了",
|
|
||||||
"绝大多数按钮上的图标是调用Unicode私用区里的自制字符实现的",
|
"绝大多数按钮上的图标是调用Unicode私用区里的自制字符实现的",
|
||||||
"科技骨牌 你的创新式块堆栈业务技术管理器",
|
"科技骨牌 你的创新式块堆栈业务技术管理器",
|
||||||
"块东V共荣",
|
"块东V共荣",
|
||||||
@@ -852,8 +852,9 @@ return{
|
|||||||
"你今天的人品值是(满分100):"..math.random(100),
|
"你今天的人品值是(满分100):"..math.random(100),
|
||||||
"你们考虑过Z酱的感受吗?没有!你们只考虑你自己。",
|
"你们考虑过Z酱的感受吗?没有!你们只考虑你自己。",
|
||||||
"你有一个好",
|
"你有一个好",
|
||||||
"你这场地是金子堆的还是块是金子做的",
|
"你这块是金子做的还是垃圾行是金子做的",
|
||||||
"你准备好了吗?",
|
"你准备好了吗?",
|
||||||
|
"配乐是有考虑到模式氛围的哦",
|
||||||
"请谨慎向没有方块经验的玩家推荐,会对本游戏的生存环境造成影响,感谢配合。",
|
"请谨慎向没有方块经验的玩家推荐,会对本游戏的生存环境造成影响,感谢配合。",
|
||||||
"请勿大力敲打设备!敲坏了就没有Techmino玩了",
|
"请勿大力敲打设备!敲坏了就没有Techmino玩了",
|
||||||
"请勿使用三只手游玩",
|
"请勿使用三只手游玩",
|
||||||
@@ -880,7 +881,6 @@ return{
|
|||||||
"物理hold了解一下",
|
"物理hold了解一下",
|
||||||
"希望极简率没事",
|
"希望极简率没事",
|
||||||
"希望你们都能喜欢Z……哦不是,喜欢Techmino",
|
"希望你们都能喜欢Z……哦不是,喜欢Techmino",
|
||||||
"喜欢本游戏的话可以到应用商店下载",
|
|
||||||
"享受Tech的特色旋转系统!",
|
"享受Tech的特色旋转系统!",
|
||||||
"写不出那种很酷的音乐(哭",
|
"写不出那种很酷的音乐(哭",
|
||||||
"要盯着bug不放",
|
"要盯着bug不放",
|
||||||
@@ -896,7 +896,7 @@ return{
|
|||||||
"中文方块百科全书:tetris.huijiwiki.com",
|
"中文方块百科全书:tetris.huijiwiki.com",
|
||||||
"众所周知俄罗斯方块是经典编程练手游戏(?",
|
"众所周知俄罗斯方块是经典编程练手游戏(?",
|
||||||
"众所周知mac不能拿来玩游戏",
|
"众所周知mac不能拿来玩游戏",
|
||||||
"作业都没做完别玩手机",
|
"作业没做完别玩手机",
|
||||||
"作者40行sub26了",
|
"作者40行sub26了",
|
||||||
"作者电脑上装了11个方块",
|
"作者电脑上装了11个方块",
|
||||||
"作者浏览器收藏夹里有6个方块",
|
"作者浏览器收藏夹里有6个方块",
|
||||||
@@ -943,6 +943,26 @@ return{
|
|||||||
"Z酱是谁",
|
"Z酱是谁",
|
||||||
"Z酱只是个写代码的,懂什么方块",
|
"Z酱只是个写代码的,懂什么方块",
|
||||||
"Z块等身抱枕来一个(x",
|
"Z块等身抱枕来一个(x",
|
||||||
|
"时间碎片[000] 2021/11/21加入这个版块",
|
||||||
|
"时间碎片[001] V0.0.091726加入TRS旋转系统",
|
||||||
|
"时间碎片[002] V0.7.9加入O-spin",
|
||||||
|
"时间碎片[003] V0.7.19加入语音系统",
|
||||||
|
"时间碎片[004] V0.7.22加入平滑下落",
|
||||||
|
"时间碎片[005] V0.8.5加入模式地图",
|
||||||
|
"时间碎片[006] V0.8.19加入五连块",
|
||||||
|
"时间碎片[007] V0.9.0加入自定义序列和模式",
|
||||||
|
"时间碎片[008] V0.10.0加入录像回放",
|
||||||
|
"时间碎片[009] V0.11.1加入小z词典",
|
||||||
|
"时间碎片[010] V0.12.2加入mod系统",
|
||||||
|
"时间碎片[011] V0.13.0联网对战测试",
|
||||||
|
"时间碎片[012] V0.13.2加入任意场地高度",
|
||||||
|
"时间碎片[013] V0.13.3加入控制台",
|
||||||
|
"时间碎片[014] V0.14.4加入第一首非Beepbox制作的BGM",
|
||||||
|
"时间碎片[015] V0.14.5加入第一首社区玩家自制BGM",
|
||||||
|
"时间碎片[016] V0.15.5加入录像回放菜单",
|
||||||
|
"时间碎片[017] V0.16.0加入BIRS",
|
||||||
|
"时间碎片[018] V0.16.2加入打击垫样式的音效室",
|
||||||
|
"时间碎片[019] V0.17.0加入手柄的摇杆和扳机支持",
|
||||||
"豆知识[001]总共有400多条tip哦",
|
"豆知识[001]总共有400多条tip哦",
|
||||||
"豆知识[002]背景影响游玩?可以去设置关闭",
|
"豆知识[002]背景影响游玩?可以去设置关闭",
|
||||||
"豆知识[003]方块默认出现的方向都是重心在下哦(如果你没乱动设置",
|
"豆知识[003]方块默认出现的方向都是重心在下哦(如果你没乱动设置",
|
||||||
@@ -1045,18 +1065,16 @@ return{
|
|||||||
"豆知识[100]Techmino生日不太清楚,那就定在2019.6.26吧",
|
"豆知识[100]Techmino生日不太清楚,那就定在2019.6.26吧",
|
||||||
"豆知识[101]Techmino有一个简单的节日主题系统",
|
"豆知识[101]Techmino有一个简单的节日主题系统",
|
||||||
"豆知识[102]Techmino有一个Nspire-CX原型版本",
|
"豆知识[102]Techmino有一个Nspire-CX原型版本",
|
||||||
|
"豆知识[103]请在有一定基础之后再学Tspin!不然副作用非常大!",
|
||||||
|
"豆知识[104]新人请千万记住,打好基础,不要太早学那些花里胡哨的。",
|
||||||
|
"豆知识[105]长时间游戏状态会越来越差!玩久了记得放松一下~",
|
||||||
"健康小贴士[01]玩游戏多眨眼,不然会干眼病",
|
"健康小贴士[01]玩游戏多眨眼,不然会干眼病",
|
||||||
"健康小贴士[02]少玩点游戏,多注意眨眼和休息",
|
"健康小贴士[02]少玩点游戏,多注意眨眼和休息",
|
||||||
"健康小贴士[03]戴耳机(尤其是半入耳式)时音量千万别拉满,不然真的会影响听力(虽然很慢)",
|
"健康小贴士[03]戴耳机(尤其是半入耳式)时音量千万别拉满,不然真的会影响听力(虽然很慢)",
|
||||||
"健康小贴士[04]不要熬夜,真的会猝死",
|
"健康小贴士[04]不要熬夜,真的会猝死",
|
||||||
"健康小贴士[05]长期睡眠不足会引起不可逆的脑损伤(变傻)",
|
"健康小贴士[05]长期睡眠不足会引起不可逆的脑损伤(变傻)",
|
||||||
"Z思辨[01]《教育的力量》",
|
"群友名言[001]“玩了Techmino之后发现打字速度变快了”",
|
||||||
"Z思辨[02]《学习的意义》",
|
"群友名言[002]“我要陪伴着tech一步步成长,然后就可以疯狂的享受他”",
|
||||||
"Z思辨[03]《练习的力量》",
|
|
||||||
"Z思辨[04]《知识的力量》",
|
|
||||||
"Z思辨[05]《梦想的价值》",
|
|
||||||
"Z思辨[06]《天赋的力量》",
|
|
||||||
"Z思辨[07]《游戏的意义》",
|
|
||||||
"Frt评[01]“成天被夸赞‘好玩’的”",
|
"Frt评[01]“成天被夸赞‘好玩’的”",
|
||||||
"Frt评[02]“可以形成方块圈子小中心话题,同作者一起衍生一些概念与梗的”",
|
"Frt评[02]“可以形成方块圈子小中心话题,同作者一起衍生一些概念与梗的”",
|
||||||
"Frt评[03]“论方块的软工意义(就算这么小个范围内,各种取舍蒙混翻车现象都总会以很易懂的方式出现(”",
|
"Frt评[03]“论方块的软工意义(就算这么小个范围内,各种取舍蒙混翻车现象都总会以很易懂的方式出现(”",
|
||||||
@@ -1084,26 +1102,6 @@ return{
|
|||||||
"今日数学[13]sin²α-cos²β=-C(α+β)C(α-β)",
|
"今日数学[13]sin²α-cos²β=-C(α+β)C(α-β)",
|
||||||
"今日数学[14]sin²α-sin²β=S(α+β)S(α-β)",
|
"今日数学[14]sin²α-sin²β=S(α+β)S(α-β)",
|
||||||
"今日数学[15]sin2α=2SαCα",
|
"今日数学[15]sin2α=2SαCα",
|
||||||
"时间碎片[000] 2021/11/21加入这个版块",
|
|
||||||
"时间碎片[001] V0.0.091726加入TRS旋转系统",
|
|
||||||
"时间碎片[002] V0.7.9加入O-spin",
|
|
||||||
"时间碎片[003] V0.7.19加入语音系统",
|
|
||||||
"时间碎片[004] V0.7.22加入平滑下落",
|
|
||||||
"时间碎片[005] V0.8.5加入模式地图",
|
|
||||||
"时间碎片[006] V0.8.19加入五连块",
|
|
||||||
"时间碎片[007] V0.9.0加入自定义序列和模式",
|
|
||||||
"时间碎片[008] V0.10.0加入录像回放",
|
|
||||||
"时间碎片[009] V0.11.1加入小z词典",
|
|
||||||
"时间碎片[010] V0.12.2加入mod系统",
|
|
||||||
"时间碎片[011] V0.13.0联网对战测试",
|
|
||||||
"时间碎片[012] V0.13.2加入任意场地高度",
|
|
||||||
"时间碎片[013] V0.13.3加入控制台",
|
|
||||||
"时间碎片[014] V0.14.4加入第一首非Beepbox制作的BGM",
|
|
||||||
"时间碎片[015] V0.14.5加入第一首社区玩家自制BGM",
|
|
||||||
"时间碎片[016] V0.15.5加入录像回放菜单",
|
|
||||||
"时间碎片[017] V0.16.0加入BIRS",
|
|
||||||
"时间碎片[018] V0.16.2加入打击垫样式的音效室",
|
|
||||||
"时间碎片[019] V0.17.0加入手柄的摇杆和扳机支持",
|
|
||||||
"Z哲[01]方块教会我们,合群了就会消失,……",
|
"Z哲[01]方块教会我们,合群了就会消失,……",
|
||||||
"Z哲[02]假如生活欺骗了你,不要悲伤,不要心急,还有块陪着你",
|
"Z哲[02]假如生活欺骗了你,不要悲伤,不要心急,还有块陪着你",
|
||||||
"Z哲[03]……,合群了就会消失,不合群世界毁灭(指game over",
|
"Z哲[03]……,合群了就会消失,不合群世界毁灭(指game over",
|
||||||
@@ -1118,22 +1116,32 @@ return{
|
|||||||
"Z哲[12]学习能力很重要,只要你以变强为目的,无论玩游戏学知识都可以很难",
|
"Z哲[12]学习能力很重要,只要你以变强为目的,无论玩游戏学知识都可以很难",
|
||||||
"Z哲[13]游戏确实可以是一种艺术形式,而不一定是纯“玩具”",
|
"Z哲[13]游戏确实可以是一种艺术形式,而不一定是纯“玩具”",
|
||||||
"Z哲[14]不希望激烈的零和竞争充斥整个游戏",
|
"Z哲[14]不希望激烈的零和竞争充斥整个游戏",
|
||||||
|
"Z哲[15]尝试手动控制圈子规模扩大速度,希望能对维持社区氛围有帮助",
|
||||||
|
"Z哲[16]圈子大了真的会……吗?我们可以试着做些什么,起码让这个过程慢一点",
|
||||||
|
"Z思辨[01]《教育的力量》",
|
||||||
|
"Z思辨[02]《学习的意义》",
|
||||||
|
"Z思辨[03]《练习的力量》",
|
||||||
|
"Z思辨[04]《知识的力量》",
|
||||||
|
"Z思辨[05]《梦想的价值》",
|
||||||
|
"Z思辨[06]《天赋的力量》",
|
||||||
|
"Z思辨[07]《游戏的意义》",
|
||||||
|
"Z思辨[08]《自强与竞争》",
|
||||||
|
"Z推[01]东方Project好玩!",
|
||||||
|
"Z推[02]Minecraft好玩!",
|
||||||
|
"Z推[03]Osu!好玩!",
|
||||||
|
"Z推[04]Terraria好玩!",
|
||||||
|
"Z推[05]Celeste好玩!",
|
||||||
|
"Z推[06]World of goo好玩!",
|
||||||
|
"Z推[07]Orzmic好玩!",
|
||||||
|
"Z推[08]噗哟噗哟好玩!",
|
||||||
|
"Z推[09]Phigros好玩!",
|
||||||
|
"Z推[10]VVVVVV好玩!",
|
||||||
|
"Z推[11]Ballance好玩!",
|
||||||
|
"Z推[12]Zuma好玩!",
|
||||||
|
"Z推[13]魔方好玩!",
|
||||||
|
"Z推[14]15puzzle好玩!",
|
||||||
|
"Z推[15]扫雷好玩!",
|
||||||
{C.C,"<PURE ",C.P,"MEMORY>"},
|
{C.C,"<PURE ",C.P,"MEMORY>"},
|
||||||
{C.C,"z推[01]东方Project好玩!"},
|
|
||||||
{C.C,"z推[02]Minecraft好玩!"},
|
|
||||||
{C.C,"z推[03]Osu!好玩!"},
|
|
||||||
{C.C,"z推[04]Terraria好玩!"},
|
|
||||||
{C.C,"z推[05]Celeste好玩!"},
|
|
||||||
{C.C,"z推[06]World of goo好玩!"},
|
|
||||||
{C.C,"z推[07]Orzmic好玩!"},
|
|
||||||
{C.C,"z推[08]噗哟噗哟好玩!"},
|
|
||||||
{C.C,"z推[09]Phigros好玩!"},
|
|
||||||
{C.C,"z推[10]VVVVVV好玩!"},
|
|
||||||
{C.C,"z推[11]Ballance好玩!"},
|
|
||||||
{C.C,"z推[12]Zuma好玩!"},
|
|
||||||
{C.C,"z推[13]魔方好玩!"},
|
|
||||||
{C.C,"z推[14]15puzzle好玩!"},
|
|
||||||
{C.C,"z推[15]扫雷好玩!"},
|
|
||||||
{C.H,"暂定段位:9"},
|
{C.H,"暂定段位:9"},
|
||||||
{C.H,"REGRET!!"},
|
{C.H,"REGRET!!"},
|
||||||
{C.lC,"Xspin",C.Z,"是啥"},
|
{C.lC,"Xspin",C.Z,"是啥"},
|
||||||
@@ -1147,12 +1155,8 @@ return{
|
|||||||
{C.R,"《滥用DMCA》"},
|
{C.R,"《滥用DMCA》"},
|
||||||
{C.R,"《知识产权法》"},
|
{C.R,"《知识产权法》"},
|
||||||
{C.R,"本游戏难度上限很高,做好心理准备。"},
|
{C.R,"本游戏难度上限很高,做好心理准备。"},
|
||||||
{C.R,"不要向不感兴趣的路人推荐!!!!!!!!"},
|
{C.R,"上班时间不许摸鱼打块!"},
|
||||||
{C.R,"不要在上课时玩游戏!"},
|
{C.R,"上课时间不许摸鱼打块!"},
|
||||||
{C.R,"光敏性癫痫警告"},
|
|
||||||
{C.R,"请在有一定游戏基础之后再学Tspin!不然副作用非常大!"},
|
|
||||||
{C.R,"新人请千万记住,打好基础,不要太早学那些花里胡哨的。"},
|
|
||||||
{C.R,"长时间游戏状态会越来越差!玩久了记得放松一下~"},
|
|
||||||
{C.R,"DD",C.Z,"炮=",C.P,"TS",C.R,"D",C.Z,"+",C.P,"TS",C.R,"D",C.Z,"炮"},
|
{C.R,"DD",C.Z,"炮=",C.P,"TS",C.R,"D",C.Z,"+",C.P,"TS",C.R,"D",C.Z,"炮"},
|
||||||
{C.R,"DT",C.Z,"炮=",C.P,"TS",C.R,"D",C.Z,"+",C.P,"TS",C.R,"T",C.Z,"炮"},
|
{C.R,"DT",C.Z,"炮=",C.P,"TS",C.R,"D",C.Z,"+",C.P,"TS",C.R,"T",C.Z,"炮"},
|
||||||
{C.R,"LrL ",C.G,"RlR ",C.B,"LLr ",C.O,"RRl ",C.P,"RRR LLL ",C.C,"FFF ",C.Y,"RfR RRf rFF"},
|
{C.R,"LrL ",C.G,"RlR ",C.B,"LLr ",C.O,"RRl ",C.P,"RRR LLL ",C.C,"FFF ",C.Y,"RfR RRf rFF"},
|
||||||
@@ -1166,9 +1170,11 @@ return{
|
|||||||
{C.Y,"暂定段位:MO"},
|
{C.Y,"暂定段位:MO"},
|
||||||
{C.Y,"暂定段位:MV"},
|
{C.Y,"暂定段位:MV"},
|
||||||
{C.Y,"Miya",C.Z," 可爱!"},
|
{C.Y,"Miya",C.Z," 可爱!"},
|
||||||
{C.Y,"O-spin Triple!"},
|
{C.Y,"O-spin!"},
|
||||||
{C.Z,"1,2,",C.C,"⑨",C.Z,"!!!!!"},
|
{C.Z,"1,2,",C.C,"⑨",C.Z,"!!!!!"},
|
||||||
{C.Z,"效率药水",C.H," 效率提升 (8:00)"},
|
{C.Z,"堆叠药水",C.H," 堆叠提升 (3:00)"},
|
||||||
|
{C.Z,"挖掘药水",C.H," 挖掘提升 (8:00)"},
|
||||||
|
{C.Z,"效率药水",C.H," 效率提升 (3:00)"},
|
||||||
{C.Z,"协调药水",C.H," MD减少 II(1:30)"},
|
{C.Z,"协调药水",C.H," MD减少 II(1:30)"},
|
||||||
-- "Z酱 可爱!",
|
-- "Z酱 可爱!",
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -50,7 +50,7 @@ return{
|
|||||||
radar={"防","守","攻","送","速","挖"},
|
radar={"防","守","攻","送","速","挖"},
|
||||||
radarData={"防/分","守/分","攻/分","送/分","行/分","挖/分"},
|
radarData={"防/分","守/分","攻/分","送/分","行/分","挖/分"},
|
||||||
WidgetText={
|
WidgetText={
|
||||||
mode={
|
modeExplorer={
|
||||||
mod="模组(F1)",
|
mod="模组(F1)",
|
||||||
},
|
},
|
||||||
mod={
|
mod={
|
||||||
@@ -119,9 +119,13 @@ return{
|
|||||||
['master_final']= {"大师", "终点", "究极20G:无法触及的终点"},
|
['master_final']= {"大师", "终点", "究极20G:无法触及的终点"},
|
||||||
['master_ph']= {"大师", "虚幻", "虚幻20G:???"},
|
['master_ph']= {"大师", "虚幻", "虚幻20G:???"},
|
||||||
['master_ex']= {"宗师", "EX", "成为方块大师"},
|
['master_ex']= {"宗师", "EX", "成为方块大师"},
|
||||||
|
['master_instinct']={"大师", "本能", "隐藏当前块"},
|
||||||
['strategy_e']= {"策略堆叠", "简单", "20G堆叠中速决策练习"},
|
['strategy_e']= {"策略堆叠", "简单", "20G堆叠中速决策练习"},
|
||||||
['strategy_h']= {"策略堆叠", "困难", "20G堆叠快速决策练习"},
|
['strategy_h']= {"策略堆叠", "困难", "20G堆叠快速决策练习"},
|
||||||
['strategy_u']= {"策略堆叠", "极限", "20G堆叠极速决策练习"},
|
['strategy_u']= {"策略堆叠", "极限", "20G堆叠极速决策练习"},
|
||||||
|
['strategy_e_plus']={"策略堆叠", "简单+", "20G堆叠中速决策练习"},
|
||||||
|
['strategy_h_plus']={"策略堆叠", "困难+", "20G堆叠快速决策练习"},
|
||||||
|
['strategy_u_plus']={"策略堆叠", "极限+", "20G堆叠极速决策练习"},
|
||||||
['blind_e']= {"隐形", "半隐", "不强大脑"},
|
['blind_e']= {"隐形", "半隐", "不强大脑"},
|
||||||
['blind_n']= {"隐形", "全隐", "挺强大脑"},
|
['blind_n']= {"隐形", "全隐", "挺强大脑"},
|
||||||
['blind_h']= {"隐形", "瞬隐", "很强大脑"},
|
['blind_h']= {"隐形", "瞬隐", "很强大脑"},
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ return{
|
|||||||
loadSample="装载仪器样品",
|
loadSample="装载仪器样品",
|
||||||
loadVoice="加载语音包",
|
loadVoice="加载语音包",
|
||||||
loadFont="加载字体",
|
loadFont="加载字体",
|
||||||
loadModeIcon="加载模式图标",
|
|
||||||
loadMode="加载方式",
|
loadMode="加载方式",
|
||||||
loadOther="加载其他资产",
|
loadOther="加载其他资产",
|
||||||
finish="按任意按钮开始!",
|
finish="按任意按钮开始!",
|
||||||
@@ -136,7 +135,8 @@ return{
|
|||||||
chatStart="------日志开始------",
|
chatStart="------日志开始------",
|
||||||
chatHistory="------下面是新消息------",
|
chatHistory="------下面是新消息------",
|
||||||
|
|
||||||
keySettingInstruction="按绑定键\n退出:取消\n退格:删除",
|
searchModeHelp="键入要搜索的内容",
|
||||||
|
keySettingHelp="按绑定键\n退出:取消\n退格:删除",
|
||||||
customBGhelp="将图像文件拖放到此处以应用自定义背景",
|
customBGhelp="将图像文件拖放到此处以应用自定义背景",
|
||||||
customBGloadFailed="不支持自定义背景的图像格式",
|
customBGloadFailed="不支持自定义背景的图像格式",
|
||||||
|
|
||||||
@@ -204,9 +204,8 @@ return{
|
|||||||
"确保只从官方渠道获得游戏,",
|
"确保只从官方渠道获得游戏,",
|
||||||
"因为如果你在别处找到它,我们无法确保你的安全",
|
"因为如果你在别处找到它,我们无法确保你的安全",
|
||||||
"作者不对任何修改负责",
|
"作者不对任何修改负责",
|
||||||
FNSF and"/"or"虽然游戏是免费的,但我们会感谢捐赠.",
|
FNNS and"/"or"虽然游戏是免费的,但我们感谢捐款。",
|
||||||
FNSF and"/"or"如果您无法同时使用我们的聊天支付和阿里支付,",
|
FNNS and"/"or"查看Zictionary以了解更多信息",
|
||||||
FNSF and"/"or"你可以去我们的P\97\116\114\111\110页面(连接到四联词典)支持我们!",
|
|
||||||
},
|
},
|
||||||
staff={
|
staff={
|
||||||
"作者:Z先生 邮箱:1046101471@qq.com",
|
"作者:Z先生 邮箱:1046101471@qq.com",
|
||||||
@@ -217,7 +216,7 @@ return{
|
|||||||
"音乐: Z先生,柒栎流星,ERM,特雷伯尔,蛋白激酶G抑制剂,[T0722,以太]",
|
"音乐: Z先生,柒栎流星,ERM,特雷伯尔,蛋白激酶G抑制剂,[T0722,以太]",
|
||||||
"音效/语音: 米娅,小亚,东西,Z先生,特雷伯尔",
|
"音效/语音: 米娅,小亚,东西,Z先生,特雷伯尔",
|
||||||
"演出: 模电,HBM",
|
"演出: 模电,HBM",
|
||||||
"翻译: 用户670,马特·马尤加,水,法克先生,氟化钪,蛋白激酶G抑制剂",
|
"翻译: 用户670,马特·马尤加,水,法克先生,氟化钪,蛋白激酶G抑制剂,不是机器人",
|
||||||
"",
|
"",
|
||||||
"特别感谢:",
|
"特别感谢:",
|
||||||
"飞天,大真,不是机器人,思竣,yuhao7370",
|
"飞天,大真,不是机器人,思竣,yuhao7370",
|
||||||
@@ -251,9 +250,9 @@ return{
|
|||||||
sprint="冲刺",
|
sprint="冲刺",
|
||||||
marathon="马拉松赛跑",
|
marathon="马拉松赛跑",
|
||||||
},
|
},
|
||||||
mode={
|
modeExplorer={
|
||||||
mod="多重器官衰竭(F1)",
|
mod="多重器官衰竭(F1)",
|
||||||
start="开始",
|
sel="选择",
|
||||||
},
|
},
|
||||||
mod={
|
mod={
|
||||||
title="多重器官衰竭",
|
title="多重器官衰竭",
|
||||||
@@ -337,7 +336,7 @@ return{
|
|||||||
title="游戏设置",
|
title="游戏设置",
|
||||||
graphic="←视频",
|
graphic="←视频",
|
||||||
sound="声音→",
|
sound="声音→",
|
||||||
layout="布局",
|
style="风格",
|
||||||
|
|
||||||
ctrl="控制设置",
|
ctrl="控制设置",
|
||||||
key="键映射",
|
key="键映射",
|
||||||
@@ -673,100 +672,104 @@ return{
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
modes={
|
modes={
|
||||||
['sprint_10l']= {"冲刺", "10升", "清除10行!"},
|
['sprint_10l']= {"冲刺", "10升", "清除10行!"},
|
||||||
['sprint_20l']= {"冲刺", "20升", "清除20行!"},
|
['sprint_20l']= {"冲刺", "20升", "清除20行!"},
|
||||||
['sprint_40l']= {"冲刺", "40升", "清除40行!"},
|
['sprint_40l']= {"冲刺", "40升", "清除40行!"},
|
||||||
['sprint_100l']= {"冲刺", "100升", "清除100行!"},
|
['sprint_100l']= {"冲刺", "100升", "清除100行!"},
|
||||||
['sprint_400l']= {"冲刺", "400升", "清除400行!"},
|
['sprint_400l']= {"冲刺", "400升", "清除400行!"},
|
||||||
['sprint_1000l']= {"冲刺", "1000升", "清除1000行!"},
|
['sprint_1000l']= {"冲刺", "1000升", "清除1000行!"},
|
||||||
['sprintPenta']= {"冲刺", "五联骨牌", "40升,配18个五分钟"},
|
['sprintPenta']= {"冲刺", "五联骨牌", "40升,配18个五分钟"},
|
||||||
['sprintMPH']= {"冲刺", "每小时英里数", "无记忆\n无先前\n无记忆"},
|
['sprintMPH']= {"冲刺", "每小时英里数", "无记忆\n无先前\n无记忆"},
|
||||||
['dig_10l']= {"挖掘", "10升", "挖10条垃圾线"},
|
['dig_10l']= {"挖掘", "10升", "挖10条垃圾线"},
|
||||||
['dig_40l']= {"挖掘", "40升", "挖40条垃圾线"},
|
['dig_40l']= {"挖掘", "40升", "挖40条垃圾线"},
|
||||||
['dig_100l']= {"挖掘", "100升", "挖100条垃圾线"},
|
['dig_100l']= {"挖掘", "100升", "挖100条垃圾线"},
|
||||||
['dig_400l']= {"挖掘", "400升", "挖400条垃圾线"},
|
['dig_400l']= {"挖掘", "400升", "挖400条垃圾线"},
|
||||||
['drought_n']= {"干旱", "100升", "没有工装"},
|
['drought_n']= {"干旱", "100升", "没有工装"},
|
||||||
['drought_l']= {"干旱+", "100升", "搞什么呀"},
|
['drought_l']= {"干旱+", "100升", "搞什么呀"},
|
||||||
['marathon_n']= {"马拉松赛跑", "正常", "200线加速马拉松"},
|
['marathon_n']= {"马拉松赛跑", "正常", "200线加速马拉松"},
|
||||||
['marathon_h']= {"马拉松赛跑", "硬的", "200线高速马拉松"},
|
['marathon_h']= {"马拉松赛跑", "硬的", "200线高速马拉松"},
|
||||||
['solo_e']= {"战争", "容易", "打败AI!"},
|
['solo_e']= {"战争", "容易", "打败AI!"},
|
||||||
['solo_n']= {"战争", "正常", "打败AI!"},
|
['solo_n']= {"战争", "正常", "打败AI!"},
|
||||||
['solo_h']= {"战争", "硬的", "打败AI!"},
|
['solo_h']= {"战争", "硬的", "打败AI!"},
|
||||||
['solo_l']= {"战争", "疯子", "打败AI!"},
|
['solo_l']= {"战争", "疯子", "打败AI!"},
|
||||||
['solo_u']= {"战争", "终极", "打败AI!"},
|
['solo_u']= {"战争", "终极", "打败AI!"},
|
||||||
['techmino49_e']= {"技术49", "容易", "49人战斗\n最后一个站着的人获胜"},
|
['techmino49_e']= {"技术49", "容易", "49人战斗\n最后一个站着的人获胜"},
|
||||||
['techmino49_h']= {"技术49", "硬的", "49人战斗\n最后一个站着的人获胜"},
|
['techmino49_h']= {"技术49", "硬的", "49人战斗\n最后一个站着的人获胜"},
|
||||||
['techmino49_u']= {"技术49", "终极", "49人战斗\n最后一个站着的人获胜"},
|
['techmino49_u']= {"技术49", "终极", "49人战斗\n最后一个站着的人获胜"},
|
||||||
['techmino99_e']= {"科技99", "容易", "99人战斗\n最后一个站着的人获胜"},
|
['techmino99_e']= {"科技99", "容易", "99人战斗\n最后一个站着的人获胜"},
|
||||||
['techmino99_h']= {"科技99", "硬的", "99人战斗\n最后一个站着的人获胜"},
|
['techmino99_h']= {"科技99", "硬的", "99人战斗\n最后一个站着的人获胜"},
|
||||||
['techmino99_u']= {"科技99", "终极", "99人战斗\n最后一个站着的人获胜"},
|
['techmino99_u']= {"科技99", "终极", "99人战斗\n最后一个站着的人获胜"},
|
||||||
['round_e']= {"回合制", "容易", "轮流玩AI!"},
|
['round_e']= {"回合制", "容易", "轮流玩AI!"},
|
||||||
['round_n']= {"回合制", "正常", "轮流玩AI!"},
|
['round_n']= {"回合制", "正常", "轮流玩AI!"},
|
||||||
['round_h']= {"回合制", "硬的", "轮流玩AI!"},
|
['round_h']= {"回合制", "硬的", "轮流玩AI!"},
|
||||||
['round_l']= {"回合制", "疯子", "轮流玩AI!"},
|
['round_l']= {"回合制", "疯子", "轮流玩AI!"},
|
||||||
['round_u']= {"回合制", "终极", "轮流玩AI!"},
|
['round_u']= {"回合制", "终极", "轮流玩AI!"},
|
||||||
['master_n']= {"主人", "正常", "适合20G初学者"},
|
['master_n']= {"主人", "正常", "适合20G初学者"},
|
||||||
['master_h']= {"主人", "硬的", "20克的职业选手"},
|
['master_h']= {"主人", "硬的", "20克的职业选手"},
|
||||||
['master_m']= {"主人", "M21", "20克大师赛"},
|
['master_m']= {"主人", "M21", "20克大师赛"},
|
||||||
['master_final']= {"主人", "最终", "20G及以上"},
|
['master_final']= {"主人", "最终", "20G及以上"},
|
||||||
['master_ph']= {"主人", "幻觉", "???"},
|
['master_ph']= {"主人", "幻觉", "???"},
|
||||||
['master_ex']= {"大师", "额外的", "比瞬间还短的永恒"},
|
['master_ex']= {"主人", "额外的", "比瞬间还短的永恒"},
|
||||||
['strategy_e']= {"策略堆叠", "简单", "20G堆叠中速决策练习"},
|
['master_instinct']={"主人", "情绪", "步行的秘密部分"},
|
||||||
['strategy_h']= {"策略堆叠", "困难", "20G堆叠快速决策练习"},
|
['strategy_e']= {"策略堆叠", "简单", "20G堆叠中速决策练习"},
|
||||||
['strategy_u']= {"策略堆叠", "极限", "20G堆叠极速决策练习"},
|
['strategy_h']= {"策略堆叠", "困难", "20G堆叠快速决策练习"},
|
||||||
['blind_e']= {"看不见的", "一半", "对于新手来说"},
|
['strategy_u']= {"策略堆叠", "极限", "20G堆叠极速决策练习"},
|
||||||
['blind_n']= {"看不见的", "全部", "对于中间产品"},
|
['strategy_e_plus']={"策略堆叠", "简单", "20G堆叠中速决策练习"},
|
||||||
['blind_h']= {"看不见的", "突然", "对于有经验的人"},
|
['strategy_h_plus']={"策略堆叠", "困难", "20G堆叠快速决策练习"},
|
||||||
['blind_l']= {"看不见的", "突然+", "对于专业人士"},
|
['strategy_u_plus']={"策略堆叠", "极限", "20G堆叠极速决策练习"},
|
||||||
['blind_u']= {"看不见的", "?", "你准备好了吗?"},
|
['blind_e']= {"看不见的", "一半", "对于新手来说"},
|
||||||
['blind_wtf']= {"看不见的", "世界跆拳道联盟", "你还没准备好"},
|
['blind_n']= {"看不见的", "全部", "对于中间产品"},
|
||||||
['classic_e']= {"经典", "容易", "80年代的低速娱乐"},
|
['blind_h']= {"看不见的", "突然", "对于有经验的人"},
|
||||||
['classic_h']= {"经典", "困难", "80年代的中速娱乐"},
|
['blind_l']= {"看不见的", "突然+", "对于专业人士"},
|
||||||
['classic_u']= {"经典", "终极", "80年代的高速娱乐"},
|
['blind_u']= {"看不见的", "?", "你准备好了吗?"},
|
||||||
['survivor_e']= {"幸存者", "容易", "你能活多久?"},
|
['blind_wtf']= {"看不见的", "世界跆拳道联盟", "你还没准备好"},
|
||||||
['survivor_n']= {"幸存者", "正常", "你能活多久?"},
|
['classic_e']= {"经典", "容易", "80年代的低速娱乐"},
|
||||||
['survivor_h']= {"幸存者", "硬的", "你能活多久?"},
|
['classic_h']= {"经典", "困难", "80年代的中速娱乐"},
|
||||||
['survivor_l']= {"幸存者", "疯子", "你能活多久?"},
|
['classic_u']= {"经典", "终极", "80年代的高速娱乐"},
|
||||||
['survivor_u']= {"幸存者", "终极", "你能活多久?"},
|
['survivor_e']= {"幸存者", "容易", "你能活多久?"},
|
||||||
['attacker_h']= {"攻击者", "硬的", "练习你的进攻技巧!"},
|
['survivor_n']= {"幸存者", "正常", "你能活多久?"},
|
||||||
['attacker_u']= {"攻击者", "终极", "练习你的进攻技巧!"},
|
['survivor_h']= {"幸存者", "硬的", "你能活多久?"},
|
||||||
['defender_n']= {"防守者", "正常", "练习你的防守技巧!"},
|
['survivor_l']= {"幸存者", "疯子", "你能活多久?"},
|
||||||
['defender_l']= {"防守者", "疯子", "练习你的防守技巧!"},
|
['survivor_u']= {"幸存者", "终极", "你能活多久?"},
|
||||||
['dig_h']= {"钻机", "硬的", "挖掘练习!"},
|
['attacker_h']= {"攻击者", "硬的", "练习你的进攻技巧!"},
|
||||||
['dig_u']= {"钻机", "终极", "挖掘练习!"},
|
['attacker_u']= {"攻击者", "终极", "练习你的进攻技巧!"},
|
||||||
['clearRush']= {"清晰的冲", "普通", "所有旋转教程\n[在建]"},
|
['defender_n']= {"防守者", "正常", "练习你的防守技巧!"},
|
||||||
['c4wtrain_n']= {"C4W训练", "正常", "无限组合"},
|
['defender_l']= {"防守者", "疯子", "练习你的防守技巧!"},
|
||||||
['c4wtrain_l']= {"C4W训练", "疯子", "无限组合"},
|
['dig_h']= {"钻机", "硬的", "挖掘练习!"},
|
||||||
['pctrain_n']= {"电脑培训", "正常", "完美清晰的实践"},
|
['dig_u']= {"钻机", "终极", "挖掘练习!"},
|
||||||
['pctrain_l']= {"电脑培训", "疯子", "更难的完美清晰的练习"},
|
['clearRush']= {"清晰的冲", "普通", "所有旋转教程\n[在建]"},
|
||||||
['pc_n']= {"电脑挑战", "正常", "让电脑在100线以内!"},
|
['c4wtrain_n']= {"C4W训练", "正常", "无限组合"},
|
||||||
['pc_h']= {"电脑挑战", "硬的", "让电脑在100线以内!"},
|
['c4wtrain_l']= {"C4W训练", "疯子", "无限组合"},
|
||||||
['pc_l']= {"电脑挑战", "疯子", "让电脑在100线以内!"},
|
['pctrain_n']= {"电脑培训", "正常", "完美清晰的实践"},
|
||||||
['pc_inf']= {"无尽个人电脑挑战", "", "尽可能多地获取个人电脑"},
|
['pctrain_l']= {"电脑培训", "疯子", "更难的完美清晰的练习"},
|
||||||
['tech_n']= {"技术人员", "正常", "试着保持背靠背的链条!"},
|
['pc_n']= {"电脑挑战", "正常", "让电脑在100线以内!"},
|
||||||
['tech_n_plus']= {"技术人员", "正常+", "仅限旋转和个人电脑"},
|
['pc_h']= {"电脑挑战", "硬的", "让电脑在100线以内!"},
|
||||||
['tech_h']= {"技术人员", "硬的", "试着保持背靠背的链条!"},
|
['pc_l']= {"电脑挑战", "疯子", "让电脑在100线以内!"},
|
||||||
['tech_h_plus']= {"技术人员", "硬的+", "仅限旋转和个人电脑"},
|
['pc_inf']= {"无尽个人电脑挑战", "", "尽可能多地获取个人电脑"},
|
||||||
['tech_l']= {"技术人员", "疯子", "试着保持背靠背的链条!"},
|
['tech_n']= {"技术人员", "正常", "试着保持背靠背的链条!"},
|
||||||
['tech_l_plus']= {"技术人员", "疯子+", "仅限旋转和个人电脑"},
|
['tech_n_plus']= {"技术人员", "正常+", "仅限旋转和个人电脑"},
|
||||||
['tech_finesse']= {"技术人员", "手腕", "没有技巧错误!"},
|
['tech_h']= {"技术人员", "硬的", "试着保持背靠背的链条!"},
|
||||||
['tech_finesse_f']={"技术人员", "技巧+", "没有正常的清除和技巧错误!"},
|
['tech_h_plus']= {"技术人员", "硬的+", "仅限旋转和个人电脑"},
|
||||||
['tsd_e']= {"热关断挑战赛", "容易", "只有T-Spin双打!"},
|
['tech_l']= {"技术人员", "疯子", "试着保持背靠背的链条!"},
|
||||||
['tsd_h']= {"热关断挑战赛", "硬的", "只有T-Spin双打!"},
|
['tech_l_plus']= {"技术人员", "疯子+", "仅限旋转和个人电脑"},
|
||||||
['tsd_u']= {"热关断挑战赛", "终极", "只有T-Spin双打!"},
|
['tech_finesse']= {"技术人员", "手腕", "没有技巧错误!"},
|
||||||
['backfire_n']= {"适得其反", "正常", "挡住回火的垃圾管道"},
|
['tech_finesse_f']= {"技术人员", "技巧+", "没有正常的清除和技巧错误!"},
|
||||||
['backfire_h']= {"适得其反", "硬的", "挡住回火的垃圾管道"},
|
['tsd_e']= {"热关断挑战赛", "容易", "只有T-Spin双打!"},
|
||||||
['backfire_l']= {"适得其反", "疯子", "挡住回火的垃圾管道"},
|
['tsd_h']= {"热关断挑战赛", "硬的", "只有T-Spin双打!"},
|
||||||
['backfire_u']= {"适得其反", "终极", "挡住回火的垃圾管道"},
|
['tsd_u']= {"热关断挑战赛", "终极", "只有T-Spin双打!"},
|
||||||
['sprintAtk']= {"冲刺", "100次攻击", "发送100行!"},
|
['backfire_n']= {"适得其反", "正常", "挡住回火的垃圾管道"},
|
||||||
['sprintEff']= {"竞速", "效率", "在40行内发动更多攻击!"},
|
['backfire_h']= {"适得其反", "硬的", "挡住回火的垃圾管道"},
|
||||||
['zen']= {"禅宗", "200", "没有时间限制的200线跑步"},
|
['backfire_l']= {"适得其反", "疯子", "挡住回火的垃圾管道"},
|
||||||
['ultra']= {"Ultra", "额外", "2分钟的得分进攻"},
|
['backfire_u']= {"适得其反", "终极", "挡住回火的垃圾管道"},
|
||||||
['infinite']= {"无限", "", "这只是一个沙箱"},
|
['sprintAtk']= {"冲刺", "100次攻击", "发送100行!"},
|
||||||
['infinite_dig']= {"无限:挖掘", "", "挖,挖,挖"},
|
['sprintEff']= {"竞速", "效率", "在40行内发动更多攻击!"},
|
||||||
['marathon_inf']= {"马拉松", "无尽", "无尽马拉松"},
|
['zen']= {"禅宗", "200", "没有时间限制的200线跑步"},
|
||||||
|
['ultra']= {"Ultra", "额外", "2分钟的得分进攻"},
|
||||||
|
['infinite']= {"无限", "", "这只是一个沙箱"},
|
||||||
|
['infinite_dig']= {"无限:挖掘", "", "挖,挖,挖"},
|
||||||
|
['marathon_inf']= {"马拉松", "无尽", "无尽马拉松"},
|
||||||
|
|
||||||
['custom_clear']= {"习俗", "正常"},
|
['custom_clear']= {"习俗", "正常"},
|
||||||
['custom_puzzle']= {"习俗", "令人费解的"},
|
['custom_puzzle']= {"习俗", "令人费解的"},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ return{
|
|||||||
loadSample="加載樂器取樣",
|
loadSample="加載樂器取樣",
|
||||||
loadVoice="加載語音資源",
|
loadVoice="加載語音資源",
|
||||||
loadFont="加載字體資源",
|
loadFont="加載字體資源",
|
||||||
loadModeIcon="加載模式圖標",
|
|
||||||
loadMode="加載模式",
|
loadMode="加載模式",
|
||||||
loadOther="加載雜項",
|
loadOther="加載雜項",
|
||||||
finish="按任意鍵繼續!",
|
finish="按任意鍵繼續!",
|
||||||
@@ -138,7 +137,8 @@ return{
|
|||||||
chatStart="------訊息開始------",
|
chatStart="------訊息開始------",
|
||||||
chatHistory="------以上為歷史訊息------",
|
chatHistory="------以上為歷史訊息------",
|
||||||
|
|
||||||
keySettingInstruction="點擊來設置鍵位\n按esc來取消選中\n按退格鍵來清除選中",
|
searchModeHelp="直接輸入關鍵字搜索",
|
||||||
|
keySettingHelp="點擊來設置鍵位\n按esc來取消選中\n按退格鍵來清除選中",
|
||||||
customBGhelp="把圖片檔案拖到這個視窗裏使用自定義背景",
|
customBGhelp="把圖片檔案拖到這個視窗裏使用自定義背景",
|
||||||
customBGloadFailed="自定義背景的圖片檔案格式不支持",
|
customBGloadFailed="自定義背景的圖片檔案格式不支持",
|
||||||
|
|
||||||
@@ -206,8 +206,8 @@ return{
|
|||||||
"僅透過內測QQ群/discord伺服器進行免費下載/更新",
|
"僅透過內測QQ群/discord伺服器進行免費下載/更新",
|
||||||
"從其他渠道獲得遊戲皆有被修改/加入廣告/植入病毒的風險,程序只申請了振動&網路權限!",
|
"從其他渠道獲得遊戲皆有被修改/加入廣告/植入病毒的風險,程序只申請了振動&網路權限!",
|
||||||
"若由於被修改的本遊戲產生的各種損失作者概不負責(我怎麼負責啊跟我有什麼關係)",
|
"若由於被修改的本遊戲產生的各種損失作者概不負責(我怎麼負責啊跟我有什麼關係)",
|
||||||
FNSF and"/"or"請從正規途徑獲得最新版,遊戲現為免費,不過有讚賞當然感謝啦~ 記得備註用戶名,方便記錄!",
|
FNNS and"/"or"請從正規途徑獲得最新版,遊戲現為免費,不過有打賞當然感謝啦~",
|
||||||
FNSF and"/"or"如果你不使用微信或支付寶,你可以前往我們的P\97\116\114\101\111\110頁面來贊助我們!"
|
FNNS and"/"or"更多資訊見小z詞典"
|
||||||
},
|
},
|
||||||
staff={
|
staff={
|
||||||
"作者:MrZ 電郵:1046101471@qq.com",
|
"作者:MrZ 電郵:1046101471@qq.com",
|
||||||
@@ -218,7 +218,7 @@ return{
|
|||||||
"音樂: MrZ,柒栎流星,ERM,Trebor,C₂₉H₂₅N₃O₅,[T0722,Aether]",
|
"音樂: MrZ,柒栎流星,ERM,Trebor,C₂₉H₂₅N₃O₅,[T0722,Aether]",
|
||||||
"音效/語音: Miya,Xiaoya,Mono,MrZ,Trebor",
|
"音效/語音: Miya,Xiaoya,Mono,MrZ,Trebor",
|
||||||
"演出: 模电,HBM",
|
"演出: 模电,HBM",
|
||||||
"翻譯: User670,MattMayuga,Mizu,Mr.Faq,ScF,C₂₉H₂₅N₃O₅",
|
"翻譯: User670,MattMayuga,Mizu,Mr.Faq,ScF,C₂₉H₂₅N₃O₅, NOT_A_ROBOT",
|
||||||
"",
|
"",
|
||||||
"特別感謝:",
|
"特別感謝:",
|
||||||
"Flyz,Big_True,NOT_A_ROBOT,思竣,yuhao7370",
|
"Flyz,Big_True,NOT_A_ROBOT,思竣,yuhao7370",
|
||||||
@@ -252,9 +252,8 @@ return{
|
|||||||
sprint="40行",
|
sprint="40行",
|
||||||
marathon="馬拉松",
|
marathon="馬拉松",
|
||||||
},
|
},
|
||||||
mode={
|
modeExplorer={
|
||||||
mod="Mods (F1)",
|
mod="Mods (F1)",
|
||||||
start="開始",
|
|
||||||
},
|
},
|
||||||
mod={
|
mod={
|
||||||
title="Mods",
|
title="Mods",
|
||||||
@@ -336,9 +335,9 @@ return{
|
|||||||
},
|
},
|
||||||
setting_game={
|
setting_game={
|
||||||
title="遊戲設置",
|
title="遊戲設置",
|
||||||
graphic="←畫面設置",
|
graphic="←畫面",
|
||||||
sound="音頻設置→",
|
sound="音頻→",
|
||||||
layout="外觀",
|
style="風格",
|
||||||
|
|
||||||
ctrl="控制設置",
|
ctrl="控制設置",
|
||||||
key="鍵位設置",
|
key="鍵位設置",
|
||||||
@@ -355,8 +354,8 @@ return{
|
|||||||
},
|
},
|
||||||
setting_video={
|
setting_video={
|
||||||
title="畫面設置",
|
title="畫面設置",
|
||||||
sound="←音頻設置",
|
sound="←音頻",
|
||||||
game="遊戲設置→",
|
game="遊戲→",
|
||||||
|
|
||||||
block="方塊可見",
|
block="方塊可見",
|
||||||
smooth="平滑下落",
|
smooth="平滑下落",
|
||||||
@@ -402,8 +401,8 @@ return{
|
|||||||
},
|
},
|
||||||
setting_sound={
|
setting_sound={
|
||||||
title="音頻設置",
|
title="音頻設置",
|
||||||
game="←遊戲設置",
|
game="←遊戲",
|
||||||
graphic="畫面設置→",
|
graphic="畫面→",
|
||||||
|
|
||||||
mainVol="主音量",
|
mainVol="主音量",
|
||||||
bgm="音樂",
|
bgm="音樂",
|
||||||
@@ -712,15 +711,20 @@ return{
|
|||||||
['master_final']= {"大師", "究極", "究極20G:無法觸及的終點"},
|
['master_final']= {"大師", "究極", "究極20G:無法觸及的終點"},
|
||||||
['master_ph']= {"大師", "虛幻", "虛幻20G:???"},
|
['master_ph']= {"大師", "虛幻", "虛幻20G:???"},
|
||||||
['master_ex']= {"宗師", "EX", "成為方塊大師"},
|
['master_ex']= {"宗師", "EX", "成為方塊大師"},
|
||||||
|
['master_instinct']={"大師", "本能", "隱藏當前塊"},
|
||||||
['strategy_e']= {"策略堆疊", "簡單", "20G堆疊中速決策練習"},
|
['strategy_e']= {"策略堆疊", "簡單", "20G堆疊中速決策練習"},
|
||||||
['strategy_h']= {"策略堆疊", "困難", "20G堆疊快速決策練習"},
|
['strategy_h']= {"策略堆疊", "困難", "20G堆疊快速決策練習"},
|
||||||
['strategy_u']= {"策略堆疊", "極限", "20G堆疊極速決策練習"},
|
['strategy_u']= {"策略堆疊", "極限", "20G堆疊極速決策練習"},
|
||||||
|
['strategy_e_plus']={"策略堆疊", "簡單+", "20G堆疊中速決策練習"},
|
||||||
|
['strategy_h_plus']={"策略堆疊", "困難+", "20G堆疊快速決策練習"},
|
||||||
|
['strategy_u_plus']={"策略堆疊", "極限+", "20G堆疊極速決策練習"},
|
||||||
['blind_e']= {"隱形", "半隱", "不強大腦"},
|
['blind_e']= {"隱形", "半隱", "不強大腦"},
|
||||||
['blind_n']= {"隱形", "全隱", "挺強大腦"},
|
['blind_n']= {"隱形", "全隱", "挺強大腦"},
|
||||||
['blind_h']= {"隱形", "瞬隱", "很強大腦"},
|
['blind_h']= {"隱形", "瞬隱", "很強大腦"},
|
||||||
['blind_l']= {"隱形", "瞬隱+", "最強大腦"},
|
['blind_l']= {"隱形", "瞬隱+", "最強大腦"},
|
||||||
['blind_u']= {"隱形", "啊這", "你準備好了嗎"},
|
['blind_u']= {"隱形", "啊這", "你準備好了嗎"},
|
||||||
['blind_wtf']= {"隱形", "不會吧", "還沒準備好"},
|
['blind_wtf']= {"隱形", "不會吧", "還沒準備好"},
|
||||||
|
['blind_inv']= {"隱形", "倒置的", "隱形活動件"},
|
||||||
['classic_e']= {"高速經典", "簡單", "高速經典"},
|
['classic_e']= {"高速經典", "簡單", "高速經典"},
|
||||||
['classic_h']= {"高速經典", "困難", "飛速經典"},
|
['classic_h']= {"高速經典", "困難", "飛速經典"},
|
||||||
['classic_u']= {"高速經典", "極限", "極速經典"},
|
['classic_u']= {"高速經典", "極限", "極速經典"},
|
||||||
|
|||||||
163
parts/modeTree.lua
Normal file
@@ -0,0 +1,163 @@
|
|||||||
|
return{
|
||||||
|
{folder=true,name='sprint',
|
||||||
|
{name='sprint_10l'},
|
||||||
|
{name='sprint_20l'},
|
||||||
|
{name='sprint_40l'},
|
||||||
|
{name='sprint_100l'},
|
||||||
|
{name='sprint_400l'},
|
||||||
|
{name='sprint_1000l'},
|
||||||
|
},
|
||||||
|
{folder=true,name='marathon',
|
||||||
|
{name='marathon_n'},
|
||||||
|
{name='marathon_h'},
|
||||||
|
{name='master_n'},
|
||||||
|
{name='master_h'},
|
||||||
|
{name='master_m'},
|
||||||
|
{name='master_final'},
|
||||||
|
{name='master_ph'},
|
||||||
|
{name='master_ex'},
|
||||||
|
},
|
||||||
|
{folder=true,name='dig_sprint',
|
||||||
|
{name='dig_10l'},
|
||||||
|
{name='dig_40l'},
|
||||||
|
{name='dig_100l'},
|
||||||
|
{name='dig_400l'},
|
||||||
|
},
|
||||||
|
{folder=true,name='survival',author='MrZ',
|
||||||
|
{folder=true,name='survivor',
|
||||||
|
{name='survivor_e'},
|
||||||
|
{name='survivor_n'},
|
||||||
|
{name='survivor_h'},
|
||||||
|
{name='survivor_l'},
|
||||||
|
{name='survivor_u'},
|
||||||
|
},
|
||||||
|
{folder=true,name='attacker',
|
||||||
|
{name='attacker_h'},
|
||||||
|
{name='attacker_u'},
|
||||||
|
},
|
||||||
|
{folder=true,name='defender',
|
||||||
|
{name='defender_n'},
|
||||||
|
{name='defender_l'},
|
||||||
|
},
|
||||||
|
{folder=true,name='dig',
|
||||||
|
{name='dig_h'},
|
||||||
|
{name='dig_u'},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{folder=true,name='battle',
|
||||||
|
{folder=true,name='solo',
|
||||||
|
{name='solo_e'},
|
||||||
|
{name='solo_n'},
|
||||||
|
{name='solo_h'},
|
||||||
|
{name='solo_l'},
|
||||||
|
{name='solo_u'},
|
||||||
|
},
|
||||||
|
{folder=true,name='round',
|
||||||
|
{name='round_e'},
|
||||||
|
{name='round_n'},
|
||||||
|
{name='round_h'},
|
||||||
|
{name='round_l'},
|
||||||
|
{name='round_u'},
|
||||||
|
},
|
||||||
|
{folder=true,name='techmino',author='MrZ',
|
||||||
|
{name='techmino49_e'},
|
||||||
|
{name='techmino49_h'},
|
||||||
|
{name='techmino49_u'},
|
||||||
|
{name='techmino99_e'},
|
||||||
|
{name='techmino99_h'},
|
||||||
|
{name='techmino99_u'},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{folder=true,name='drought',author='MrZ',
|
||||||
|
{name='drought_n'},
|
||||||
|
{name='drought_l'},
|
||||||
|
},
|
||||||
|
{folder=true,name='blind',author='MrZ',
|
||||||
|
{name='blind_e'},
|
||||||
|
{name='blind_n'},
|
||||||
|
{name='blind_h'},
|
||||||
|
{name='blind_l'},
|
||||||
|
{name='blind_u'},
|
||||||
|
{name='blind_wtf'},
|
||||||
|
},
|
||||||
|
{folder=true,name='classic',
|
||||||
|
{name='classic_e'},
|
||||||
|
{name='classic_h'},
|
||||||
|
{name='classic_u'},
|
||||||
|
},
|
||||||
|
{folder=true,name='train',author='MrZ',
|
||||||
|
{name='clearRush'},
|
||||||
|
{name='c4wtrain_n'},
|
||||||
|
{name='c4wtrain_l'},
|
||||||
|
{name='pctrain_n'},
|
||||||
|
{name='pctrain_l'},
|
||||||
|
},
|
||||||
|
{folder=true,name='pc',author='MrZ',
|
||||||
|
{name='pc_n'},
|
||||||
|
{name='pc_h'},
|
||||||
|
{name='pc_l'},
|
||||||
|
{name='pc_inf'},
|
||||||
|
},
|
||||||
|
{folder=true,name='tech',author='MrZ',
|
||||||
|
{name='sprintAtk'},
|
||||||
|
{name='sprintEff'},
|
||||||
|
{name='tech_n'},
|
||||||
|
{name='tech_n_plus'},
|
||||||
|
{name='tech_h'},
|
||||||
|
{name='tech_h_plus'},
|
||||||
|
{name='tech_l'},
|
||||||
|
{name='tech_l_plus'},
|
||||||
|
{name='tech_finesse'},
|
||||||
|
{name='tech_finesse_f'},
|
||||||
|
},
|
||||||
|
{folder=true,name='tsd',author='MrZ',
|
||||||
|
{name='tsd_e'},
|
||||||
|
{name='tsd_h'},
|
||||||
|
{name='tsd_u'},
|
||||||
|
},
|
||||||
|
{folder=true,name='backfire',author='MrZ',
|
||||||
|
{name='backfire_n'},
|
||||||
|
{name='backfire_h'},
|
||||||
|
{name='backfire_l'},
|
||||||
|
{name='backfire_u'},
|
||||||
|
},
|
||||||
|
{folder=true,name='infinite',
|
||||||
|
{name='zen'},
|
||||||
|
{name='ultra'},
|
||||||
|
{name='infinite'},
|
||||||
|
{name='infinite_dig'},
|
||||||
|
{name='marathon_inf'},
|
||||||
|
},
|
||||||
|
{folder=true,name='special',author='MrZ',
|
||||||
|
{folder=true,name='sprint',
|
||||||
|
{name='sprintPenta'},
|
||||||
|
{name='sprintMPH'},
|
||||||
|
{name='sprintSmooth'},
|
||||||
|
{name='sprintMD'},
|
||||||
|
{name='sprintSym'},
|
||||||
|
{name='sprintLock'},
|
||||||
|
{name='sprintFix'},
|
||||||
|
},
|
||||||
|
{folder=true,name='sprint',
|
||||||
|
{name='stack_e'},
|
||||||
|
{name='stack_u'},
|
||||||
|
},
|
||||||
|
{folder=true,name='sprint',
|
||||||
|
{name='techrash_n'},
|
||||||
|
{name='techrash_u'},
|
||||||
|
},
|
||||||
|
{name='marathon_bfmax'},
|
||||||
|
},
|
||||||
|
{folder=true,name='big_pack',author='NOT_A_ROBOT',
|
||||||
|
{name='big_n'},
|
||||||
|
{name='big_h'},
|
||||||
|
},
|
||||||
|
{folder=true,name='strategy_pack',author='Milla',
|
||||||
|
{name='strategy_e'},
|
||||||
|
{name='strategy_h'},
|
||||||
|
{name='strategy_u'},
|
||||||
|
{name='strategy_e_plus'},
|
||||||
|
{name='strategy_h_plus'},
|
||||||
|
{name='strategy_u_plus'},
|
||||||
|
},
|
||||||
|
}
|
||||||
119
parts/modes.lua
@@ -1,119 +0,0 @@
|
|||||||
return{
|
|
||||||
{name='sprint_10l', x=0, y=0, size=40,shape=1,icon="sprint1", unlock={'sprint_20l','sprint_40l'}},
|
|
||||||
{name='sprint_20l', x=-200, y=200, size=50,shape=1,icon="sprint1"},
|
|
||||||
{name='sprint_40l', x=0, y=-300, size=40,shape=1,icon="sprint2", unlock={'dig_10l','sprint_100l','marathon_n','sprintPenta','sprintMPH'}},
|
|
||||||
{name='sprint_100l', x=-200, y=0, size=50,shape=1,icon="sprint2", unlock={'sprint_400l','drought_n'}},
|
|
||||||
{name='sprint_400l', x=-400, y=0, size=40,shape=1,icon="sprint3", unlock={'sprint_1000l'}},
|
|
||||||
{name='sprint_1000l', x=-600, y=0, size=40,shape=1,icon="sprint3"},
|
|
||||||
|
|
||||||
{name='sprintPenta', x=180, y=-160, size=40,shape=3,icon="sprint2"},
|
|
||||||
{name='sprintMPH', x=220, y=-340, size=40,shape=3,icon="sprint2"},
|
|
||||||
|
|
||||||
{name='drought_n', x=-400, y=200, size=40,shape=1,icon="drought", unlock={'drought_l'}},
|
|
||||||
{name='drought_l', x=-600, y=200, size=40,shape=1,icon="drought"},
|
|
||||||
|
|
||||||
{name='dig_10l', x=-200, y=-200, size=40,shape=1,icon="dig_sprint", unlock={'dig_40l'}},
|
|
||||||
{name='dig_40l', x=-400, y=-200, size=40,shape=1,icon="dig_sprint", unlock={'dig_100l'}},
|
|
||||||
{name='dig_100l', x=-600, y=-200, size=40,shape=1,icon="dig_sprint", unlock={'dig_400l'}},
|
|
||||||
{name='dig_400l', x=-800, y=-200, size=40,shape=1,icon="dig_sprint"},
|
|
||||||
|
|
||||||
{name='marathon_n', x=0, y=-600, size=60,shape=1,icon="marathon", unlock={'marathon_h','solo_e','round_e','blind_e','classic_e','survivor_e','clearRush','zen'}},
|
|
||||||
{name='marathon_h', x=0, y=-800, size=50,shape=1,icon="marathon", unlock={'master_n','strategy_e'}},
|
|
||||||
|
|
||||||
{name='solo_e', x=-600, y=-1000, size=40,shape=1,icon="solo", unlock={'solo_n'}},
|
|
||||||
{name='solo_n', x=-800, y=-1000, size=40,shape=1,icon="solo", unlock={'solo_h'}},
|
|
||||||
{name='solo_h', x=-1000, y=-1000, size=40,shape=1,icon="solo", unlock={'solo_l','techmino49_e'}},
|
|
||||||
{name='solo_l', x=-1200, y=-1000, size=40,shape=1,icon="solo", unlock={'solo_u'}},
|
|
||||||
{name='solo_u', x=-1400, y=-1000, size=40,shape=1,icon="solo"},
|
|
||||||
|
|
||||||
{name='techmino49_e', x=-1100, y=-1200, size=40,shape=1,icon="t49", unlock={'techmino49_h','techmino99_e'}},
|
|
||||||
{name='techmino49_h', x=-1100, y=-1400, size=40,shape=1,icon="t49", unlock={'techmino49_u'}},
|
|
||||||
{name='techmino49_u', x=-1100, y=-1600, size=40,shape=1,icon="t49"},
|
|
||||||
{name='techmino99_e', x=-1300, y=-1400, size=40,shape=1,icon="t99", unlock={'techmino99_h'}},
|
|
||||||
{name='techmino99_h', x=-1300, y=-1600, size=40,shape=1,icon="t99", unlock={'techmino99_u'}},
|
|
||||||
{name='techmino99_u', x=-1300, y=-1800, size=40,shape=1,icon="t99"},
|
|
||||||
|
|
||||||
{name='round_e', x=-600, y=-800, size=40,shape=1,icon="round", unlock={'round_n'}},
|
|
||||||
{name='round_n', x=-800, y=-800, size=40,shape=1,icon="round", unlock={'round_h'}},
|
|
||||||
{name='round_h', x=-1000, y=-800, size=40,shape=1,icon="round", unlock={'round_l'}},
|
|
||||||
{name='round_l', x=-1200, y=-800, size=40,shape=1,icon="round", unlock={'round_u'}},
|
|
||||||
{name='round_u', x=-1400, y=-800, size=40,shape=1,icon="round"},
|
|
||||||
|
|
||||||
{name='master_n', x=0, y=-1000, size=40,shape=1,icon="master", unlock={'master_h','strategy_h'}},
|
|
||||||
{name='master_h', x=0, y=-1200, size=40,shape=3,icon="master", unlock={'master_final','master_ex','master_ph','master_m','strategy_u'}},
|
|
||||||
{name='master_m', x=150, y=-1320, size=30,shape=3,icon="master"},
|
|
||||||
{name='master_final', x=0, y=-1600, size=40,shape=2,icon="master"},
|
|
||||||
{name='master_ph', x=-150, y=-1500, size=40,shape=2,icon="master"},
|
|
||||||
{name='master_ex', x=150, y=-1500, size=40,shape=2,icon="master_ex"},
|
|
||||||
|
|
||||||
{name='strategy_e', x=-150, y=-1030, size=40,shape=3,icon="master"},
|
|
||||||
{name='strategy_h', x=-200, y=-1160, size=35,shape=3,icon="master"},
|
|
||||||
{name='strategy_u', x=-250, y=-1290, size=30,shape=2,icon="master"},
|
|
||||||
|
|
||||||
{name='blind_e', x=150, y=-700, size=40,shape=1,icon="hidden", unlock={'blind_n'}},
|
|
||||||
{name='blind_n', x=150, y=-800, size=40,shape=1,icon="hidden", unlock={'blind_h'}},
|
|
||||||
{name='blind_h', x=150, y=-900, size=35,shape=1,icon="hidden", unlock={'blind_l'}},
|
|
||||||
{name='blind_l', x=150, y=-1000, size=35,shape=3,icon="hidden2", unlock={'blind_u'}},
|
|
||||||
{name='blind_u', x=150, y=-1100, size=30,shape=3,icon="hidden2", unlock={'blind_wtf'}},
|
|
||||||
{name='blind_wtf', x=150, y=-1200, size=25,shape=2,icon="hidden2"},
|
|
||||||
|
|
||||||
{name='classic_e', x=-200, y=-850, size=40,shape=1,icon="classic", unlock={'classic_h'}},
|
|
||||||
{name='classic_h', x=-300, y=-950, size=35,shape=2,icon="classic", unlock={'classic_u'}},
|
|
||||||
{name='classic_u', x=-400, y=-1050, size=30,shape=2,icon="classic"},
|
|
||||||
|
|
||||||
{name='survivor_e', x=300, y=-600, size=40,shape=1,icon="survivor", unlock={'survivor_n'}},
|
|
||||||
{name='survivor_n', x=500, y=-600, size=40,shape=1,icon="survivor", unlock={'survivor_h','attacker_h','defender_n','dig_h'}},
|
|
||||||
{name='survivor_h', x=700, y=-600, size=40,shape=1,icon="survivor", unlock={'survivor_l'}},
|
|
||||||
{name='survivor_l', x=900, y=-600, size=40,shape=3,icon="survivor", unlock={'survivor_u'}},
|
|
||||||
{name='survivor_u', x=1100, y=-600, size=40,shape=2,icon="survivor"},
|
|
||||||
|
|
||||||
{name='attacker_h', x=300, y=-800, size=40,shape=1,icon="attack", unlock={'attacker_u'}},
|
|
||||||
{name='attacker_u', x=300, y=-1000, size=40,shape=1,icon="attack"},
|
|
||||||
|
|
||||||
{name='defender_n', x=500, y=-800, size=40,shape=1,icon="defend", unlock={'defender_l'}},
|
|
||||||
{name='defender_l', x=500, y=-1000, size=40,shape=1,icon="defend"},
|
|
||||||
|
|
||||||
{name='dig_h', x=700, y=-800, size=40,shape=1,icon="dig", unlock={'dig_u'}},
|
|
||||||
{name='dig_u', x=700, y=-1000, size=40,shape=1,icon="dig"},
|
|
||||||
|
|
||||||
{name='clearRush', x=400, y=-400, size=50,shape=1,icon="bigbang", unlock={'c4wtrain_n','pctrain_n','sprintAtk'}},
|
|
||||||
{name='c4wtrain_n', x=700, y=-400, size=40,shape=1,icon="pc", unlock={'c4wtrain_l'}},
|
|
||||||
{name='c4wtrain_l', x=900, y=-400, size=40,shape=1,icon="pc"},
|
|
||||||
|
|
||||||
{name='pctrain_n', x=700, y=-250, size=40,shape=1,icon="pc", unlock={'pctrain_l','pc_n'}},
|
|
||||||
{name='pctrain_l', x=900, y=-250, size=40,shape=1,icon="pc"},
|
|
||||||
|
|
||||||
{name='pc_n', x=800, y=-110, size=40,shape=1,icon="pc", unlock={'pc_h'}},
|
|
||||||
{name='pc_h', x=950, y=-110, size=40,shape=3,icon="pc", unlock={'pc_l','pc_inf'}},
|
|
||||||
{name='pc_l', x=1100, y=-110, size=40,shape=3,icon="pc"},
|
|
||||||
{name='pc_inf', x=1100, y=-250, size=40,shape=2,icon="pc"},
|
|
||||||
|
|
||||||
{name='sprintAtk', x=530, y=-150, size=40,shape=1,icon="sprint2", unlock={'sprintEff','tech_n','tech_finesse','tsd_e','backfire_n'}},
|
|
||||||
|
|
||||||
{name='sprintEff', x=360, y=-150, size=40,shape=1,icon="sprint2"},
|
|
||||||
|
|
||||||
{name='tech_n', x=400, y=50, size=40,shape=1,icon="tech", unlock={'tech_n_plus','tech_h'}},
|
|
||||||
{name='tech_n_plus', x=200, y=20, size=40,shape=3,icon="tech"},
|
|
||||||
{name='tech_h', x=400, y=200, size=40,shape=1,icon="tech", unlock={'tech_h_plus','tech_l'}},
|
|
||||||
{name='tech_h_plus', x=200, y=170, size=35,shape=3,icon="tech"},
|
|
||||||
{name='tech_l', x=400, y=350, size=40,shape=1,icon="tech", unlock={'tech_l_plus'}},
|
|
||||||
{name='tech_l_plus', x=200, y=320, size=35,shape=3,icon="tech"},
|
|
||||||
|
|
||||||
{name='tech_finesse', x=800, y=50, size=40,shape=1,icon="tech", unlock={'tech_finesse_f'}},
|
|
||||||
{name='tech_finesse_f',x=1000, y=50, size=40,shape=1,icon="tech"},
|
|
||||||
|
|
||||||
{name='tsd_e', x=720, y=200, size=40,shape=1,icon="tsd", unlock={'tsd_h'}},
|
|
||||||
{name='tsd_h', x=960, y=200, size=40,shape=1,icon="tsd", unlock={'tsd_u'}},
|
|
||||||
{name='tsd_u', x=1200, y=200, size=40,shape=1,icon="tsd"},
|
|
||||||
|
|
||||||
{name='backfire_n', x=650, y=350, size=40,shape=1,icon="backfire", unlock={'backfire_h'}},
|
|
||||||
{name='backfire_h', x=850, y=350, size=40,shape=1,icon="backfire", unlock={'backfire_l'}},
|
|
||||||
{name='backfire_l', x=1050, y=350, size=40,shape=3,icon="backfire", unlock={'backfire_u'}},
|
|
||||||
{name='backfire_u', x=1250, y=350, size=35,shape=2,icon="backfire"},
|
|
||||||
|
|
||||||
{name='zen', x=-1000, y=-600, size=40,shape=1,icon="zen", unlock={'ultra','infinite','infinite_dig','marathon_inf'}},
|
|
||||||
{name='ultra', x=-1200, y=-600, size=40,shape=1,icon="ultra"},
|
|
||||||
{name='infinite', x=-1200, y=-400, size=40,shape=1,icon='infinite'},
|
|
||||||
{name='infinite_dig', x=-1000, y=-400, size=40,shape=1,icon="dig"},
|
|
||||||
{name='marathon_inf', x=-800, y=-400, size=40,shape=1,icon="marathon"}
|
|
||||||
}
|
|
||||||
@@ -4,7 +4,7 @@ return{
|
|||||||
mindas=7,minarr=1,minsdarr=1,
|
mindas=7,minarr=1,minsdarr=1,
|
||||||
sequence="bagES",
|
sequence="bagES",
|
||||||
hook_drop=require'parts.eventsets.bigWallGen'.hook_drop,
|
hook_drop=require'parts.eventsets.bigWallGen'.hook_drop,
|
||||||
eventSet='big_h',
|
eventSet='big_h',
|
||||||
bg='cubes',bgm='push',
|
bg='cubes',bgm='push',
|
||||||
},
|
},
|
||||||
score=function(P)return{math.min(P.modeData.maxCombo,100),P.stat.time}end,
|
score=function(P)return{math.min(P.modeData.maxCombo,100),P.stat.time}end,
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ return{
|
|||||||
mindas=7,minarr=1,minsdarr=1,
|
mindas=7,minarr=1,minsdarr=1,
|
||||||
sequence="bagES",
|
sequence="bagES",
|
||||||
hook_drop=require'parts.eventsets.bigWallGen'.hook_drop,
|
hook_drop=require'parts.eventsets.bigWallGen'.hook_drop,
|
||||||
eventSet='big_n',
|
eventSet='big_n',
|
||||||
bg='bg2',bgm='push',
|
bg='bg2',bgm='push',
|
||||||
},
|
},
|
||||||
score=function(P)return{math.min(P.modeData.maxCombo,100),P.stat.time}end,
|
score=function(P)return{math.min(P.modeData.maxCombo,100),P.stat.time}end,
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ return{
|
|||||||
eventSet='classic_e',
|
eventSet='classic_e',
|
||||||
bg='rgb',bgm='1980s',
|
bg='rgb',bgm='1980s',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{P.stat.score,P.stat.row}end,
|
score=function(P)return{P.stat.score,P.stat.row}end,
|
||||||
scoreDisp=function(D)return D[1].." "..D[2].." Lines"end,
|
scoreDisp=function(D)return D[1].." "..D[2].." Lines"end,
|
||||||
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ return{
|
|||||||
eventSet='classic_h',
|
eventSet='classic_h',
|
||||||
bg='rgb',bgm='1980s',
|
bg='rgb',bgm='1980s',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{P.stat.score,P.stat.row}end,
|
score=function(P)return{P.stat.score,P.stat.row}end,
|
||||||
scoreDisp=function(D)return D[1].." "..D[2].." Lines"end,
|
scoreDisp=function(D)return D[1].." "..D[2].." Lines"end,
|
||||||
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ return{
|
|||||||
eventSet='classic_u',
|
eventSet='classic_u',
|
||||||
bg='rgb',bgm='1980s',
|
bg='rgb',bgm='1980s',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{P.stat.score,P.stat.row}end,
|
score=function(P)return{P.stat.score,P.stat.row}end,
|
||||||
scoreDisp=function(D)return D[1].." "..D[2].." Lines"end,
|
scoreDisp=function(D)return D[1].." "..D[2].." Lines"end,
|
||||||
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ return{
|
|||||||
eventSet='marathon_bfmax',
|
eventSet='marathon_bfmax',
|
||||||
bg='bg2',bgm='blank',
|
bg='bg2',bgm='blank',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
getRank=function(P)
|
getRank=function(P)
|
||||||
local L=P.stat.row
|
local L=P.stat.row
|
||||||
if L>=200 then
|
if L>=200 then
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ return{
|
|||||||
eventSet='marathon_h',
|
eventSet='marathon_h',
|
||||||
bg='cubes',bgm='push',
|
bg='cubes',bgm='push',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{math.min(P.stat.row,200),P.stat.time}end,
|
score=function(P)return{math.min(P.stat.row,200),P.stat.time}end,
|
||||||
scoreDisp=function(D)return D[1].." Lines "..STRING.time(D[2])end,
|
scoreDisp=function(D)return D[1].." Lines "..STRING.time(D[2])end,
|
||||||
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ return{
|
|||||||
eventSet='marathon_inf',
|
eventSet='marathon_inf',
|
||||||
bg='bg2',bgm='push',
|
bg='bg2',bgm='push',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{P.stat.score,P.stat.row,P.stat.time}end,
|
score=function(P)return{P.stat.score,P.stat.row,P.stat.time}end,
|
||||||
scoreDisp=function(D)return D[1].."P "..D[2].."L "..STRING.time(D[3])end,
|
scoreDisp=function(D)return D[1].."P "..D[2].."L "..STRING.time(D[3])end,
|
||||||
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ return{
|
|||||||
eventSet='marathon_n',
|
eventSet='marathon_n',
|
||||||
bg='bg2',bgm='push',
|
bg='bg2',bgm='push',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{math.min(P.stat.row,200),P.stat.time}end,
|
score=function(P)return{math.min(P.stat.row,200),P.stat.time}end,
|
||||||
scoreDisp=function(D)return D[1].." Lines "..STRING.time(D[2])end,
|
scoreDisp=function(D)return D[1].." Lines "..STRING.time(D[2])end,
|
||||||
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ return{
|
|||||||
eventSet='master_ex',
|
eventSet='master_ex',
|
||||||
bg='blockspace',bgm='hope',
|
bg='blockspace',bgm='hope',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{P.modeData.rankPoint,P.stat.score}end,
|
score=function(P)return{P.modeData.rankPoint,P.stat.score}end,
|
||||||
scoreDisp=function(D)return sectionName[math.floor(D[1]/10)+1].." "..D[2]end,
|
scoreDisp=function(D)return sectionName[math.floor(D[1]/10)+1].." "..D[2]end,
|
||||||
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]>b[2]end,
|
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]>b[2]end,
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ return{
|
|||||||
eventSet='master_final',
|
eventSet='master_final',
|
||||||
bg='lightning',bgm='rectification',
|
bg='lightning',bgm='rectification',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{P.modeData.pt,P.stat.time}end,
|
score=function(P)return{P.modeData.pt,P.stat.time}end,
|
||||||
scoreDisp=function(D)return D[1].."P "..STRING.time(D[2])end,
|
scoreDisp=function(D)return D[1].."P "..STRING.time(D[2])end,
|
||||||
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ return{
|
|||||||
eventSet='master_h',
|
eventSet='master_h',
|
||||||
bg='bg2',bgm='secret7th',
|
bg='bg2',bgm='secret7th',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{P.modeData.pt,P.stat.time}end,
|
score=function(P)return{P.modeData.pt,P.stat.time}end,
|
||||||
scoreDisp=function(D)return D[1].."P "..STRING.time(D[2])end,
|
scoreDisp=function(D)return D[1].."P "..STRING.time(D[2])end,
|
||||||
comp=function(a,b)
|
comp=function(a,b)
|
||||||
|
|||||||
24
parts/modes/master_instinct.lua
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
return{
|
||||||
|
env={
|
||||||
|
sequence="bagES",
|
||||||
|
freshLimit=15,
|
||||||
|
eventSet='master_instinct',
|
||||||
|
bg='glow',bgm='sugar fairy',
|
||||||
|
},
|
||||||
|
slowMark=true,
|
||||||
|
score=function(P)return{P.modeData.pt,P.stat.time}end,
|
||||||
|
scoreDisp=function(D)return D[1].."P "..STRING.time(D[2])end,
|
||||||
|
comp=function(a,b)
|
||||||
|
return a[1]>b[1]or(a[1]==b[1]and a[2]<b[2])
|
||||||
|
end,
|
||||||
|
getRank=function(P)
|
||||||
|
local S=P.modeData.pt
|
||||||
|
return
|
||||||
|
S>=1000 and 5 or
|
||||||
|
S>=800 and 4 or
|
||||||
|
S>=500 and 3 or
|
||||||
|
S>=300 and 2 or
|
||||||
|
S>=100 and 1 or
|
||||||
|
S>=60 and 0
|
||||||
|
end,
|
||||||
|
}
|
||||||
@@ -4,7 +4,6 @@ return{
|
|||||||
eventSet='master_m',
|
eventSet='master_m',
|
||||||
bg='bg2',bgm='super7th',
|
bg='bg2',bgm='super7th',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{math.min(P.stat.row,200),P.stat.time}end,
|
score=function(P)return{math.min(P.stat.row,200),P.stat.time}end,
|
||||||
scoreDisp=function(D)return D[1].." Lines "..STRING.time(D[2])end,
|
scoreDisp=function(D)return D[1].." Lines "..STRING.time(D[2])end,
|
||||||
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
comp=function(a,b)return a[1]>b[1]or a[1]==b[1]and a[2]<b[2]end,
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ return{
|
|||||||
eventSet='master_n',
|
eventSet='master_n',
|
||||||
bg='bg1',bgm='secret8th',
|
bg='bg1',bgm='secret8th',
|
||||||
},
|
},
|
||||||
slowMark=true,
|
|
||||||
score=function(P)return{P.modeData.pt,P.stat.time}end,
|
score=function(P)return{P.modeData.pt,P.stat.time}end,
|
||||||
scoreDisp=function(D)return D[1].."P "..STRING.time(D[2])end,
|
scoreDisp=function(D)return D[1].."P "..STRING.time(D[2])end,
|
||||||
comp=function(a,b)
|
comp=function(a,b)
|
||||||
|
|||||||