--大家好我是hypercross。 --从这个文件开始讲解DIY接口的用法。 --首先,这个文件说明DIY需要的文件及其结构。 --DIY是以module的形式存在的。每个Module即是一个UTF8格式的Lua文件(建议用notepad++编辑),包含如下格式的代码: module("extensions.moligaloo", package.seeall) -- 进入module。这里moligaloo这个词必须和文件名相同。 extension = sgs.Package("moligaloo") -- 创建扩展包对象。变量名必须为extension。参数名为扩展包的objectName,也是通常会使用的扩展包标识 shiqian = sgs.General(extension, "shiqian", "qun") -- 创建武将对象,这里我们的武将是时迁。关于武将属性的详细说明见reference文档。 shentou = sgs.CreateViewAsSkill{ --创建技能,技能种类为ViewAsSkill。这里的技能是“出牌阶段,你可以将任意一张梅花手牌当作顺手牵羊使用。” name = "shentou", n = 1, view_filter = function(self, selected, to_select) return to_select:getSuit() == sgs.Card_Club and not to_select:isEquipped() end, view_as = function(self, cards) if #cards == 1 then local card = cards[1] local new_card =sgs.Sanguosha:cloneCard("snatch", card:getSuit(), card:getNumber()) new_card:addSubcard(card:getId()) new_card:setSkillName(self:objectName()) return new_card end end }--关于技能的说明将是几乎所有其他帮助文件的重点。此处省略。 sgs.LoadTranslationTable{ ["shentou"] = "神偷", [":shentou"] = "你可以将你的梅花手牌当做顺手牵羊使用。", } --此段为翻译,将技能名称与描述中文化,否则你将会看到拼音 shiqian:addSkill(shentou) --将神偷技能赋予时迁 --你可以将本文件保存至extension目录下的moligaloo.lua并启动游戏。此时扩展包即已经被添加至游戏。 --为了完善DIY扩展包,需要将音频、图片以及翻译代码放到指定目录。这一点将在其他文档中说明。 --技能详解1:ViewAsSkill(视为技,也叫视作技) --在太阳神三国杀中,常用的基本技能是两种:触发技和视为技。我们使用这两种基本技能的复合来完成大多数复杂的技能。 --此外,我们还有距离技,禁止技等特殊类型的技能,它们用于实现某些某种程度上 “要求改变游戏系统” 的技能。 --触发技可以用来实现”在某个时机,满足发动条件时,执行某个效果(包括做出选择)这样的技能。 --触发技也可以用来改变游戏事件而不仅是单纯的产生效果。比如,放弃摸牌阶段并执行xx这样的技能也可以用触发技实现。 --事实上,一个触发技就是一条游戏规则。如果某名武将具有某个触发技,这个触发技就会被在服务端“注册”成为这局游戏的一条规则。 --被注册的触发技,通常会根据玩家“是否存活”以及玩家的武将“是否具有该技能”来决定是否被执行。 --视为技可以用来实现“可将某牌作为某牌打出”这样的技能。 --视为技的定义对于AI而言是无效的。为了让AI使用视为技,你基本上需要在AI中重新写一遍技能的定义。 --这是因为视为技是在客户端运行的,而AI在服务器端运行;触发技也是在服务端运行。 --如果某名玩家具有某个视作技,该技能通常就会被”注册“到该玩家的客户端。这个动作与其他玩家是不相干的。 --总之,视为技负责在客户端管理,有哪些牌可以选中,选中的牌又会被当成什么牌,这样的效果; --但是视为技的运行本身不影响游戏进程;视为技做的事情是通过将特定的牌(甚至没有牌)“视为”特定的牌, --来允许你使用那张本来不存在的牌。这也是大多数”主动技能“的实现方式。 --距离技和禁止技则分别用于实现“修改玩家间的距离”,以及“某人不能对某人使用某牌”这样的效果。 --与其他两种技能不同,距离技和禁止技不需要在某局游戏中注册:距离技是永远生效。 --也就是说,如果你写了一个距离技能叫”所有玩家间的距离-1“,那么无论场上有没有玩家具有这个技能, --所有玩家间的距离都会被减一。禁止技也类似。 --这类技能的定义比较新,也比较清楚明了,可能你不需要看文档也能明白。 --正片开始 --首先讲解视为技。 --视为技在Lua中的创建使用了sgs.CreateViewAsSkill方法 -- **程序细节,以下可跳过 --sgs.CreateViewAsSkill方法可以在lua\sgs_ex.lua中找到。 --该方法会创建一个LuaViewAsSkill对象(定义见cpp源码),然后将你定义的Lua函数用于其成员函数。 --注意,本游戏cpp源码部分使用了类的继承重载来实现不同的技能,而在lua的DIY技能里面我们都使用固定的类 --我们通过将会被用作技能成员函数的lua function,直接赋给技能的实例来实现不同的技能。 -- **程序细节部分结束 --视为技在创建时,需要以下方法|变量的定义: --name, n, view_filter, view_as, enabled_at_play和enabled_at_response --name: --一个字符串即技能名称。 --该字段必须定义。(无默认值) --n: --整数值,每次发动技能所用牌数的最大值。绝大多数DIY用到的n可能都为1或2. --默认值为0,即不需要选择自己的任何牌. --view_filter: --lua函数,返回一个布尔值,即某张卡是否可被选中以用作发动技能。 --发动技能时,将对所有手牌、装备进行遍历,并执行view_filter方法。返回了true的牌可以被选择用作技能发动。 --传入的参数为self(技能对象本身),selected(lua表,已经选择的所有牌), to_select(当前需判断是否可选中的牌) --默认为"永远返回false",即如果你没有定义,则这个技能的发动不允许你选择任何牌。 本文来源:https://www.wddqw.com/doc/1c2da4807fd5360cbb1adb78.html