模块:装备
来自卡厄思梦境WIKI
此模块的文档可以在模块:装备/doc创建
local p = {}
local data = mw.loadData('模块:装备/data')
-- 获取装备稀有度对应的中文
local rarityMap = {
["蓝"] = "蓝",
["紫"] = "紫",
["金"] = "金"
}
-- 辅助函数:根据装备基础数据计算数值
local function calculateValue(rarity, itemType, level)
local BASE_VALUES = {
["蓝"] = {
["武器"] = { values = {25, 41, 56, 67, 74} },
["装甲"] = { values = {9, 15, 21, 24, 28} },
["戒指"] = { values = {20, 37, 54, 66, 75} },
},
["紫"] = {
["武器"] = { values = {28, 45, 62, 74, 82} },
["装甲"] = { values = {10, 17, 23, 27, 31} },
["戒指"] = { values = {22, 41, 60, 73, 83} },
},
["金"] = {
["武器"] = { values = {31, 50, 68, 81, 90} },
["装甲"] = { values = {11, 19, 25, 30, 34} },
["戒指"] = { values = {24, 45, 66, 80, 91} },
},
}
local levelNum = tonumber(level) or 1
if BASE_VALUES[rarity] and BASE_VALUES[rarity][itemType] then
return BASE_VALUES[rarity][itemType].values[levelNum]
end
return 0
end
-- 辅助函数:获取属性类型
local function getValueType(itemType)
local typeMap = {
["武器"] = "攻击力",
["装甲"] = "防御力",
["戒指"] = "HP"
}
return typeMap[itemType] or ""
end
-- 生成装备卡片列表(用于筛选页面)
function p.generateCards(frame)
local html = mw.html.create()
-- 遍历所有装备,生成5星卡片
for equipName, equipData in pairs(data) do
-- 创建可筛选的卡片容器
local cardWrapper = html:tag('div')
:addClass('divsort equipment-wrapper')
:attr('data-param1', equipData.rarity) -- 稀有度
:attr('data-param2', equipData.area or "") -- 区域(如果有的话)
:attr('data-param3', equipData.tag or "") -- TAG(多个用逗号分隔)
:cssText('display: inline-block; margin: 5px; position: relative;')
-- 创建卡片和名称的容器
local cardContainer = cardWrapper:tag('div')
:cssText('display: flex; flex-direction: column; align-items: center;')
-- 生成卡片内容
local cardDiv = cardContainer:tag('div')
:addClass('equipment-card')
:attr('data-equipment', equipName)
:attr('data-level', '5')
:cssText('position: relative; display: inline-block; width:150px; height: 230px; cursor: pointer;')
-- 背景
cardDiv:tag('div')
:cssText('position: absolute; top: 0px; left: 0px;')
:wikitext(string.format('[[File:bg_equipment_rarity_%s.png|150px|link=]]', equipData.rarity))
-- 装备图片
cardDiv:tag('div')
:cssText('position: absolute; top: 43px; left: 13px;')
:wikitext(string.format('[[File:%s|124px|link=]]', equipData.art))
-- 底部背景
cardDiv:tag('div')
:cssText('position: absolute; bottom: 5px; left: 5px; width: 140px; height: 35px; background-color: rgba(0,0,0,0.5); border-radius: 0px 0px 8px 8px')
-- 星级
cardDiv:tag('div')
:cssText('position: absolute; bottom: 10px; left: 20px;')
:wikitext('[[File:icon_star_rating_5.png|link=]]')
-- 顶层蒙版
cardDiv:tag('div')
:cssText('position: absolute; top: 0px; left: 0px;')
:wikitext('[[File:equipment_顶层蒙版.png|150px|link=]]')
-- 装备名称(可点击链接)
local nameDiv = cardContainer:tag('div')
:addClass('equipment-name-link')
:cssText('text-align: center; width: 150px;')
-- 根据稀有度设置名称颜色
local nameColor = '#34638c' -- 蓝色
if equipData.rarity == '紫' then
nameColor = '#b14fc5' -- 紫色
elseif equipData.rarity == '金' then
nameColor = '#ff9500' -- 金色
end
nameDiv:wikitext(string.format('[[%s|<span style="color:%s; font-size:14px; font-weight:bold;">%s</span>]]',
equipName, nameColor, equipName))
-- 生成对应的弹窗
local popupDiv = cardWrapper:tag('div')
:addClass('equipment-popup')
:attr('id', 'equipment-popup-' .. mw.uri.encode(equipName))
:cssText('position: fixed; display: none; width:368px; height: 335px; background-color: #343434; border-radius: 9px; z-index: 10000;')
-- 弹窗背景
popupDiv:tag('div')
:cssText('position: absolute; top: 0px; left: 0px;')
:wikitext(string.format('[[File:bg_collection_rarity_%s.png|link=]]', equipData.rarity))
-- 弹窗装备图片
popupDiv:tag('div')
:cssText('position: absolute; top: 40px; left: 128px;')
:wikitext(string.format('[[File:%s|124px|link=]]', equipData.art))
-- 星级背景
popupDiv:tag('div')
:cssText('position: absolute; top: 167px; left: 0px; width: 368px; height: 35px; background-color: rgba(0,0,0,0.5);')
-- 星级
popupDiv:tag('div')
:cssText('position: absolute; top: 173px; left: 128px;')
:wikitext('[[File:icon_star_rating_5.png|link=]]')
-- 类型图标
popupDiv:tag('div')
:cssText('position: absolute; top: 205px; left: 5px; color: white')
:wikitext(string.format('[[File:icon_equip_%s_%s.png|25px|link=]]', equipData.type, equipData.rarity))
-- 装备名称
popupDiv:tag('div')
:cssText('position: absolute; top: 209px; left: 33px; color: white')
:wikitext(equipName)
-- 属性背景
popupDiv:tag('div')
:cssText('position: absolute; top: 235px; left: 9px; width: 350px; height: 35px; background-color: rgba(255,255,255,0.3); border-radius: 2px')
-- 属性类型
local valueType = getValueType(equipData.type)
popupDiv:tag('div')
:cssText('position: absolute; top: 242px; left: 14px; color: white')
:wikitext(valueType)
-- 属性值
local value = calculateValue(equipData.rarity, equipData.type, "5")
popupDiv:tag('div')
:cssText('position: absolute; top: 242px; right: 14px; color: white')
:wikitext(value)
-- 处理描述文本
local desc = equipData.desc and equipData.desc[5] or ""
desc = string.gsub(desc, "{{文本|橙|([^}]+)}}", '<span style="color:#ff9500;">%1</span>')
desc = string.gsub(desc, "{{词典|([^}]+)}}", "[[%1]]")
-- 描述
popupDiv:tag('div')
:cssText('position: absolute; top: 277px; left: 10px; right: 10px; color: white; font-size: 14px;')
:wikitext(desc)
-- 关闭按钮
popupDiv:tag('div')
:addClass('equipment-popup-close')
:cssText('position: absolute; top: 10px; right: 10px; width: 24px; height: 24px; cursor: pointer; color: white; font-size: 20px;')
:wikitext('×')
end
return tostring(html)
end
-- 生成单个装备卡片
function p.card(frame)
local args = frame.args
local name = args[1] or args.name
local level = args[2] or args.level or "1"
if not name or not data[name] then
return "装备不存在: " .. (name or "未指定")
end
local equip = data[name]
-- 生成HTML
local html = mw.html.create('div')
:addClass('equipment-card')
:attr('data-equipment', name)
:attr('data-level', level)
:cssText('position: relative; display: inline-block; width:150px; height: 230px; cursor: pointer;')
-- 背景
html:tag('div')
:cssText('position: absolute; top: 0px; left: 0px;')
:wikitext(string.format('[[File:bg_equipment_rarity_%s.png|150px|link=]]', equip.rarity))
-- 装备图片
html:tag('div')
:cssText('position: absolute; top: 43px; left: 13px;')
:wikitext(string.format('[[File:%s|124px|link=]]', equip.art))
-- 底部背景
html:tag('div')
:cssText('position: absolute; bottom: 5px; left: 5px; width: 140px; height: 35px; background-color: rgba(0,0,0,0.5); border-radius: 0px 0px 8px 8px')
-- 星级
html:tag('div')
:cssText('position: absolute; bottom: 10px; left: 20px;')
:wikitext(string.format('[[File:icon_star_rating_%s.png|link=]]', level))
-- 顶层蒙版
html:tag('div')
:cssText('position: absolute; top: 0px; left: 0px;')
:wikitext('[[File:equipment_顶层蒙版.png|150px|link=]]')
return tostring(html)
end
return p