LLWiki正在建设中,欢迎加入我们

“模块:Lyrics”的版本间差异

来自LLWiki
跳转到导航 跳转到搜索
(// 使用Wikiplus小工具快速编辑)
标签移动版网页编辑 移动版编辑
(撤销Bhsd讨论)的版本31124)
标签撤销
 
(未显示2个用户的10个中间版本)
第13行: 第13行:
--getArgs是一个函数,作用是获取传入的args。第二参数是options的table。
--getArgs是一个函数,作用是获取传入的args。第二参数是options的table。


local data = mw.loadData( "module:lyrics/data" )
local colors = {["honoka"]="#ffae00", ["eli"]="#00bbff", ["kotori"]="#a8a8a8", ["umi"]="#6d56ff", ["rin"]="#fee155", ["maki"]="#ff6239", ["nozomi"]="#e44fff", ["hanayo"]="#44cd71",["nico"]="#ff62dd",
local colors = data.colors --角色名转换颜色的table
["tsubasa"]="#ff5555", ["erena"]="#88ccbb", ["anju"]="#ffcc66",
local fullnames = data.fullnames --角色名转换全名的table
["chika"]="#ff791b", ["riko"]="#ff7777", ["kanan"]="#00d29e", ["dia"]="#f43232", ["you"]="#2aa4db", ["yoshiko"]="#aeaeae", ["hanamaru"]="#cfba0f", ["mari"]="#a530e0", ["ruby"]="#ee55b7",
local classnames = data.classnames --小队名转换角色名的table
["sarah"]="#00ccff", ["leah"]="#bbbbbb",
["ayumu"]="#ed7d95", ["kasumi"]="#e7d600", ["shizuku"]="#01b7ed", ["karin"]="#485ec6", ["ai"]="#ff5800", ["kanata"]="#a664a0", ["setsuna"]="#d81c2f", ["emma"]="#84c36e", ["rina"]="#9ca5b9", ["shioriko"]="#37b484",
["kanon"]="#ff7f27", ["keke"]="#a0fff9", ["chisato"]="#ff6e90", ["sumire"]="#74f466", ["ren"]="#0000a0",
["muse"]="#e4007f", ["aqours"]="#32aaff", ["nijigaku"]="#f39800",
["printemps"]="hotpink", ['bibi']="gold", ["lilywhite"]="silver",
["cyaron"]="#ffa434", ["azalea"]="#ff5a79", ["guiltykiss"]="#825deb", ["saintsnow"]="#cb3935",
["musesmile"]="#df49a6", ["musepure"]="#37a75c", ["musecool"]="#0099ee",
["aqourssmile"]="#df49a6", ["aqourspure"]="#37a75c", ["aqourscool"]="#0099ee"
} --角色名转换颜色的table
local fullnames = {["honoka"]="高坂穗乃果", ["eli"]="绚濑绘里", ["kotori"]="南小鸟", ["umi"]="园田海未", ["rin"]="星空凛", ["maki"]="西木野真姬", ["nozomi"]="东条希", ["hanayo"]="小泉花阳", ["nico"]="矢泽妮可",
["tsubasa"]="绮罗翼", ["erena"]="统堂英玲奈", ["anju"]="优木杏树",
["chika"]="高海千歌", ["riko"]="樱内梨子", ["kanan"]="松浦果南", ["dia"]="黑泽黛雅", ["you"]="渡边曜", ["yoshiko"]="津岛善子", ["hanamaru"]="国木田花丸", ["mari"]="小原鞠莉", ["ruby"]="黑泽露比",
["sarah"]="鹿角圣良", ["leah"]="鹿角理亚",
["ayumu"]="上原步梦", ["kasumi"]="中须霞", ["shizuku"]="樱坂雫", ["karin"]="朝香果林", ["ai"]="宫下爱", ["kanata"]="近江彼方", ["setsuna"]="优木雪菜", ["emma"]="艾玛·维尔德", ["rina"]="天王寺璃奈", ["shioriko"]="三船栞子",
["kanon"]="涩谷花音", ["keke"]="唐可可", ["chisato"]="岚千砂都", ["sumire"]="平安名堇", ["ren"]="叶月恋",
["muse"]="μ's", ["aqours"]="Aqours", ["saintsnow"]="Saint Snow", ["nijigaku"]="虹咲学园学园偶像同好会",
["printemps"]="Printemps", ['bibi']="BiBi", ["lilywhite"]="lily white",
["cyaron"]="CYaRon!", ["azalea"]="AZALEA", ["guiltykiss"]="Guilty Kiss",
["diverdiva"]="DiverDiva", ["azuna"]="A・ZU・NA", ["qu4rtz"]="QU4RTZ",
["musesmile"]="高坂穗乃果、星空凛、矢泽妮可", ["musepure"]="南小鸟、东条希、小泉花阳", ["musecool"]="绚濑绘里、园田海未、西木野真姬",
["aqourssmile"]="高海千歌、国木田花丸、小原鞠莉", ["aqourspure"]="松浦果南、渡边曜、黑泽露比", ["aqourscool"]="樱内梨子、黑泽黛雅、津岛善子"
} --角色名转换全名的table
local classnames = {["muse"]="honoka-lyrics eli-lyrics kotori-lyrics umi-lyrics rin-lyrics maki-lyrics nozomi-lyrics hanayo-lyrics nico",
["arise"]="tsubasa-lyrics erena-lyrics anju",
["aqours"]="chika-lyrics riko-lyrics kanan-lyrics dia-lyrics you-lyrics yoshiko-lyrics hanamaru-lyrics mari-lyrics ruby",
["nijigaku"]="ayumu-lyrics kasumi-lyrics shizuku-lyrics karin-lyrics ai-lyrics kanata-lyrics setsuna-lyrics emma-lyrics rina-lyrics shioriko",
["printemps"]="honoka-lyrics kotori-lyrics hanayo", ['bibi']="eli-lyrics maki-lyrics nico", ["lilywhite"]="umi-lyrics rin-lyrics nozomi",
["cyaron"]="chika-lyrics you-lyrics ruby", ["azalea"]="kanan-lyrics dia-lyrics hanamaru", ["guiltykiss"]="riko-lyrics yoshiko-lyrics mari", ["saintsnow"]="sarah-lyrics leah",
["diverdiva"]="karin-lyrics ai", ["azuna"]="ayumu-lyrics shizuku-lyrics setsuna", ["qu4rtz"]="kasumi-lyrics kanata-lyrics emma-lyrics rina",
["musesmile"]="honoka-lyrics rin-lyrics nico", ["musepure"]="kotori-lyrics nozomi-lyrics hanayo", ["musecool"]="eli-lyrics umi-lyrics maki",
["aqourssmile"]="chika-lyrics hanamaru-lyrics mari", ["aqourspure"]="kanan-lyrics you-lyrics ruby", ["aqourscool"]="riko-lyrics dia-lyrics yoshiko"
} --小队名转换角色名的table


function module.name2color(names,text,lang) --按角色名转换成的颜色给文字上色及加title和语言标识。
function module.name2color(names,text,lang) --按角色名转换成的颜色给文字上色及加title和语言标识。
第55行: 第24行:
local errorFlag=nil
local errorFlag=nil
names=mw.text.split(names, ',') --将角色列表全部转为小写后,在逗号处分割成table。
names=mw.text.split(names, ',') --将角色列表全部转为小写后,在逗号处分割成table。
local result="<span lang=\""..lang.."\" title=\"" --放置上色结果的span。title内放置角色全名
local result='<span title="' --放置上色结果的span。title内放置角色全名
for k,name in ipairs(names) do --将分割后的角色列表依次处理。k表示编号,从1开始。
for k,name in ipairs(names) do --将分割后的角色列表依次处理。k表示编号,从1开始。
result=result..(fullnames[name] or '') --把每个角色名转换成全名,并加入到结果。如果角色不存在,则为空。
result=result..(fullnames[name] or '') --把每个角色名转换成全名,并加入到结果。如果角色不存在,则为空。
第62行: 第31行:
end --因为连接过程需要转换文字,所以不使用join或listToText。
end --因为连接过程需要转换文字,所以不使用join或listToText。
end
end
result=result.."\" class=\""
result=result..'" class="'
for k,name in ipairs(names) do
for k,name in ipairs(names) do
result=result.." "..(classnames[name] or name)..'-lyrics' --与上面的类似,加入class
result=result.." "..(classnames[name] or name)..'-lyrics' --与上面的类似,加入class
第69行: 第38行:
end
end
end
end
result=result.." "..(errorFlag and "error" or "Lyrics_gradient").."\" style=\"background-image:-webkit-linear-gradient(left," -- Lyrics_gradient类会添加CSS样式:"-webkit-background-clip:text;background-clip:text;-webkit-box-decoration-break:clone;-webkit-text-fill-color:transparent;text-fill-color:transparent;"
result=result.." "..(errorFlag and "error" or "Lyrics_gradient")..'" style="background-image:-webkit-linear-gradient(left,'
for k,name in ipairs(names) do
for k,name in ipairs(names) do
result=result..(colors[name] or 'black') --与上面的类似,加入各颜色。如果颜色不存在,则为黑色。
result=result..(colors[name] or 'black') --与上面的类似,加入各颜色。如果颜色不存在,则为黑色。
第76行: 第45行:
end
end
end
end
return result..");"..(
return result..");"..(errorFlag and "background:none;\">[[category:Lyrics中出现错误颜色参数的页面]]Wrong color key: "..errorFlag or "\">"..module.langQuote(text, lang)).."</span>"
errorFlag and 'background:none;">[[category:Lyrics中出现错误颜色参数的页面]]Wrong color key: '..errorFlag
or '">'..module.langQuote(text, lang)
).."</span>"
else --如果颜色标识中没有逗号,则说明只有一位角色,直接上色。
else --如果颜色标识中没有逗号,则说明只有一位角色,直接上色。
return "<span lang=\""..lang.."\" class=\"Lyrics_single "..(classnames[names] or names).."-lyrics"..(colors[names] and '' or " error").."\" title=\""..(fullnames[names] or '').."\" style=\"color:"..(colors[names] or '')..";\">"..(colors[names] and module.langQuote(text, lang) or "[[category:Lyrics中出现错误颜色参数的页面]]Wrong color key: "..names).."</span>"
return '<span class="Lyrics_single '..(classnames[names] or names).."-lyrics"..(colors[names] and '' or " error")..
'" title="'..(fullnames[names] or '')..'" style="color:'..(colors[names] or '')..';">'..
(colors[names] and module.langQuote(text, lang) or "[[category:Lyrics中出现错误颜色参数的页面]]Wrong color key: "..names)
.."</span>"
end
end
end
end
第92行: 第67行:
function module.langWrap(text,lang) --改写自[[moegirl:Module:Lang]]的.wrap。给文字加上指定语言的attr。
function module.langWrap(text,lang) --改写自[[moegirl:Module:Lang]]的.wrap。给文字加上指定语言的attr。
local span = mw.html.create('span') --创建HTML标签span用于设置语言。
local span = mw.html.create('span') --创建HTML标签span用于设置语言。
:attr('lang', lang) --给这个span加上lang的attr。
:wikitext( module.langQuote(text, lang) ) --给这个span加上内容,内容为langQuote确定的是否需要繁简转换的维基文本。
:wikitext( module.langQuote(text, lang) ) --给这个span加上内容,内容为langQuote确定的是否需要繁简转换的维基文本。
return tostring(span)
return tostring(span)
end

function module.split(text)
local result = {}
for v in mw.ustring.gmatch(text..'\n', '([^\n]*)\n') do
table.insert(result, v)
end
return result
end
end


function module._lyrics(args) --改写自[[moegirl:Module:Lyrics]]的._lyrics。args为传入参数的table。
function module._lyrics(args) --改写自[[moegirl:Module:Lyrics]]的._lyrics。args为传入参数的table。
local orig = mw.text.split(args[1] or args.original or '', '\n')
local orig = module.split(args[1] or args.original or '')
local tran = mw.text.split(args[2] or args.translated or '', '\n') --对传入的字符串进行初步处理。
local tran = module.split(args[2] or args.translated or '')
--对传入的字符串进行初步处理。
--1. 如果没有传入字符串,则默认为空字符串。
--1. 如果没有传入字符串,则默认为空字符串。
--2. 在所有换行处分割字符串,结果为一个table。
--2. 在所有换行处分割字符串,结果为一个table。
第128行: 第112行:
end
end


if (args[1] or args.original or ''):find('<ruby') or (args[2] or args.transalted or ''):find('<ruby') or (args.hasRuby or '') ~= '' then
if (args[1] or args.original or ''):find('<ruby') or (args[2] or args.translated or ''):find('<ruby') or (args.hasRuby or '') ~= '' then
html:addClass('Lyrics_has_ruby') --如果歌词原文或疑问中有ruby,或者手动设置的hasRuby不为空,则添加Lyrics_has_ruby的class;
html:addClass('Lyrics_has_ruby') --如果歌词中有ruby,或者手动设置的hasRuby不为空,则添加Lyrics_has_ruby的class;
else
else
html:addClass('Lyrics_no_ruby') --否则,添加Lyrics_no_ruby的class。
html:addClass('Lyrics_no_ruby') --否则,添加Lyrics_no_ruby的class。
第139行: 第123行:
local orig_line=orig[i] --准备转换颜色标识。
local orig_line=orig[i] --准备转换颜色标识。
if orig_line:find('@') then --如果有颜色标识,
if orig_line:find('@') then --如果有颜色标识,
orig_line=orig_line:gsub("^([^@]+)", function(n) return module.langWrap(n,llang) end) --则把开头没有颜色表示的文字加上语言标识,
orig_line=orig_line:gsub("^([^@]+)", function(n) return module.langWrap(n,llang) end) --则把开头没有颜色标识的文字加上语言标识,
orig_line=orig_line:gsub("@([^@]*)@([^@]+)", function(n1,n2) return module.name2color(n1,n2,llang) end) --并把颜色标识替换成有语言标识的颜色span。
orig_line=orig_line:gsub("@([^@]*)@([^@]+)", function(n1,n2) return module.name2color(n1,n2,llang) end) --并把颜色标识替换成有语言标识的颜色span。
else --如果没有颜色标识,
else --如果没有颜色标识,
第148行: 第132行:
:tag('div') --在div中创建一个div,用于放置歌词原文。
:tag('div') --在div中创建一个div,用于放置歌词原文。
:addClass('Lyrics_original') --添加Lyrics_original的class。
:addClass('Lyrics_original') --添加Lyrics_original的class。
:attr('lang', llang)
:cssText(lstyle) --添加设置的style。
:cssText(lstyle) --添加设置的style。
:node(orig_line or '') --添加歌词文字。语言已在添加颜色时设定。
:node(orig_line or '') --添加歌词文字。语言已在添加颜色时设定。
第154行: 第139行:
:addClass('Lyrics_translated')
:addClass('Lyrics_translated')
:cssText(rstyle)
:cssText(rstyle)
:node(rlang and module.langWrap(tran[i] or '', rlang) or tran[i])
:node(rlang and module.langQuote(tran[i] or '', rlang) or tran[i])
:done()
:done()
end
end

2021年8月4日 (三) 11:43的最新版本

Template-info.png 模块文档
这个文档嵌入模块:Lyrics/doc

本页面含有来自萌娘百科的文本,以CC BY-NC-SA 3.0授权引入。经过双方的修改,内容可能已与来源有很大差异。

请使用{{lyrics}}调用模块。

--这是Lua语言。两个横线右侧的为注释,给看不懂的人(编者自己)用的。

--Lua快速入门:
--a..b表示字符串相连接。a+b表示转换为数字再相加。
--a.f(b,i)中的a.f表示类型a的函数f,函数对象为b,i是参数。a:f(i)等价于a.f(a,i)。
--table是array和dict的结合体。指定key时则为有key的dict;否则为key从1开始的array。
--只有false和nil为假;其他不管是不是空的,全都是真。
--字符串匹配和正则表达式很像,但有所不同。
--其他的和其他语言都差不多。

local module={} --模块的本质类似于函数库:下方定义的所有函数均放置在名为module的table中,最后返回module。
local getArgs = require('Module:Arguments').getArgs --调用其他模块中的函数。
--getArgs是一个函数,作用是获取传入的args。第二参数是options的table。

local data = mw.loadData( "module:lyrics/data" )
local colors = data.colors --角色名转换颜色的table
local fullnames = data.fullnames --角色名转换全名的table
local classnames = data.classnames --小队名转换角色名的table

function module.name2color(names,text,lang) --按角色名转换成的颜色给文字上色及加title和语言标识。
    if names=='' then
        return module.langWrap(text, lang)
    elseif names:find(',') then --如果颜色标识中有逗号,则说明有多位角色,使用渐变色。
        local errorFlag=nil
        names=mw.text.split(names, ',') --将角色列表全部转为小写后,在逗号处分割成table。
        local result='<span title="' --放置上色结果的span。title内放置角色全名
        for k,name in ipairs(names) do --将分割后的角色列表依次处理。k表示编号,从1开始。
            result=result..(fullnames[name] or '') --把每个角色名转换成全名,并加入到结果。如果角色不存在,则为空。
            if k<#names then --#表示求table的长度。如果当前不是最后一个,
                result=result..'、' --则加一个顿号。
            end --因为连接过程需要转换文字,所以不使用join或listToText。
        end
        result=result..'" class="'
        for k,name in ipairs(names) do
            result=result.." "..(classnames[name] or name)..'-lyrics' --与上面的类似,加入class
            if colors[name]==nil then
                errorFlag=(errorFlag and errorFlag..", " or '')..name
            end
        end
        result=result.." "..(errorFlag and "error" or "Lyrics_gradient")..'" style="background-image:-webkit-linear-gradient(left,'
        for k,name in ipairs(names) do
            result=result..(colors[name] or 'black') --与上面的类似,加入各颜色。如果颜色不存在,则为黑色。
            if k<#names then
                result=result..','
            end
        end
        return result..");"..(
            errorFlag and 'background:none;">[[category:Lyrics中出现错误颜色参数的页面]]Wrong color key: '..errorFlag
            or '">'..module.langQuote(text, lang)
        ).."</span>"
    else --如果颜色标识中没有逗号,则说明只有一位角色,直接上色。
        return '<span class="Lyrics_single '..(classnames[names] or names).."-lyrics"..(colors[names] and '' or " error")..
            '" title="'..(fullnames[names] or '')..'" style="color:'..(colors[names] or '')..';">'..
            (colors[names] and module.langQuote(text, lang) or "[[category:Lyrics中出现错误颜色参数的页面]]Wrong color key: "..names)
            .."</span>"
    end
end

function module.langQuote(text, lang) --改写自[[moegirl:Module:Lang]]的.quote。确定语言是否需要繁简转换。
    if lang == 'zh' then --中文则需要繁简转换。方法是不做改动,直接返回。
        return text
    else --其他语言则防止繁简转换。方法是在文字两侧加上防转换的-{ }-。
        return '-{' .. text .. '}-'
    end
end

function module.langWrap(text,lang) --改写自[[moegirl:Module:Lang]]的.wrap。给文字加上指定语言的attr。
    local span = mw.html.create('span') --创建HTML标签span用于设置语言。
        :wikitext( module.langQuote(text, lang) ) --给这个span加上内容,内容为langQuote确定的是否需要繁简转换的维基文本。
    return tostring(span)
end

function module.split(text)
    local result = {}
    for v in mw.ustring.gmatch(text..'\n', '([^\n]*)\n') do
        table.insert(result, v)
    end
    return result
end

function module._lyrics(args) --改写自[[moegirl:Module:Lyrics]]的._lyrics。args为传入参数的table。
    local orig = module.split(args[1] or args.original or '')
    local tran = module.split(args[2] or args.translated or '')
   
    --对传入的字符串进行初步处理。
    --1. 如果没有传入字符串,则默认为空字符串。
    --2. 在所有换行处分割字符串,结果为一个table。
    local llang = args.llang or 'ja'
    local rlang = args.rlang --传入的语言,没有传入则默认分别为日文与中文。
    local lcolor = colors[string.lower(args.lcolor or '')] or colors[string.lower(args.color or '')] or args.lcolor or args.color or ''
    local rcolor = colors[string.lower(args.rcolor or '')] or args.rcolor or '' --传入的默认颜色,没有传入则默认为空字符串。
    local lstyle = '' --准备处理传入的style。
    if lcolor ~= '' then --如果传入了color,
        lstyle = 'color:'..lcolor..';'..(args.lstyle or '') --则把color放在传入的style前;
    else --否则,
        lstyle = args.lstyle or '' --只有传入的style。
    end
    --如果没有传入style则默认为空字符串。style中如果包括color则会覆盖传入的color。
    local rstyle = '' --与上面的类似,处理译文的style。
    if rcolor ~='' then
        rstyle = 'color:'..rcolor..';'..(args.rstyle or '')
    else
        rstyle = args.rstyle or ''
    end
    
    local html = mw.html.create('div') --创建HTML标签div用于放置内容,此div为全部内容的最外层容器。
        :addClass('Lyrics_box') --给这个div添加Lyrics_box的class。
        :cssText(args.containerstyle or '') --设置容器的其他style。

    if (args[2] or args.translated or '') == '' then
        html:addClass('Lyrics_no_translation') --如果歌詞沒有添加譯文,則添加Lyrics_no_translation的class。
    end

    if (args[1] or args.original or ''):find('<ruby') or (args[2] or args.translated or ''):find('<ruby') or (args.hasRuby or '') ~= '' then
        html:addClass('Lyrics_has_ruby') --如果歌词中有ruby,或者手动设置的hasRuby不为空,则添加Lyrics_has_ruby的class;
    else
        html:addClass('Lyrics_no_ruby') --否则,添加Lyrics_no_ruby的class。
    end

    local len = math.max(#orig, #tran) --歌词行数。#表示求table的长度。原文和译文较长的即为总行数。

    for i=1,len do --为每一行进行一次。
        local orig_line=orig[i] --准备转换颜色标识。
        if orig_line:find('@') then --如果有颜色标识,
            orig_line=orig_line:gsub("^([^@]+)", function(n) return module.langWrap(n,llang) end) --则把开头没有颜色标识的文字加上语言标识,
            orig_line=orig_line:gsub("@([^@]*)@([^@]+)", function(n1,n2) return module.name2color(n1,n2,llang) end) --并把颜色标识替换成有语言标识的颜色span。
        else --如果没有颜色标识,
            orig_line=module.langWrap(orig_line,llang) --则直接添加语言标识。
        end 
        html:tag('div') --在容器中创建一个div,代表一行歌词。
            :addClass('Lyrics_line') --添加Lyrics_line的class。(这个class实际上未设置。)
                :tag('div') --在div中创建一个div,用于放置歌词原文。
                    :addClass('Lyrics_original') --添加Lyrics_original的class。
                    :attr('lang', llang)
                    :cssText(lstyle) --添加设置的style。
                    :node(orig_line or '') --添加歌词文字。语言已在添加颜色时设定。
                    :done() --完成这个div。
                :tag('div') --与上面的类似,用于放置歌词译文。
                    :addClass('Lyrics_translated')
                    :cssText(rstyle)
                    :node(rlang and module.langQuote(tran[i] or '', rlang) or tran[i])
                    :done()
    end

    html:tag('div'):cssText('clear:both;') --在容器最后添加一个div,用于与下文间clear开。

    return tostring(html) --将全部HTML转换成字符串并返回。这里是全部程序的输出结果。
end

function module.lyrics(frame) --改写自[[moegirl:Module:Lyrics]]的.lyrics。取用参数并进行计算。
    --将取用参数的步骤单独列成函数,是为了让模块可以直接取用模板的参数,而使用其他方法取用参数不受此影响。
    local args = getArgs(frame, {wrappers='Template:Lyrics'}) --获取传入参数。
    --wrappers意味着会优先在此部分中查找参数;如果找不到,再使用frame提供的参数。
    --在此例中,这可以使模块直接取用模板参数。
    return module._lyrics(args)
end

return module --返回module,也就是返回模块中定义的所有函数的库。
--使用#invoke调用模块时,第一参数为调用模块中的哪个函数。在此模块中为lyrics。