2023-04-09 05:35:35 +00:00
|
|
|
|
-- SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
|
2023-08-10 19:24:22 +00:00
|
|
|
|
---@alias PlayerId integer
|
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- CardsMoveInfo 一组牌的移动信息
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class CardsMoveInfo
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public ids integer[] @ 移动卡牌ID数组
|
|
|
|
|
---@field public from? integer @ 移动来源玩家ID
|
|
|
|
|
---@field public to? integer @ 移动终点玩家ID
|
|
|
|
|
---@field public toArea? CardArea @ 移动终点区域
|
|
|
|
|
---@field public moveReason? CardMoveReason @ 移动原因
|
|
|
|
|
---@field public proposer? integer @ 移动执行者
|
|
|
|
|
---@field public skillName? string @ 移动技能名
|
|
|
|
|
---@field public moveVisible? boolean @ 控制移动是否可见
|
|
|
|
|
---@field public specialName? string @ 若终点区域为PlayerSpecial,则存至对应私人牌堆内
|
|
|
|
|
---@field public specialVisible? boolean @ 控制上述创建私人牌堆后是否令其可见
|
|
|
|
|
---@field public drawPilePosition? integer @ 移至牌堆的索引位置,值为-1代表置入牌堆底,或者牌堆牌数+1也为牌堆底
|
|
|
|
|
---@field public moveMark? table @ 移动后自动赋予标记,格式:{标记名(支持-inarea后缀,移出值代表区域后清除), 值}
|
2022-04-08 10:39:58 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- MoveInfo 一张牌的来源信息
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class MoveInfo
|
2023-03-26 09:32:45 +00:00
|
|
|
|
---@field public cardId integer
|
|
|
|
|
---@field public fromArea CardArea
|
2023-12-03 11:35:14 +00:00
|
|
|
|
---@field public fromSpecialName? string
|
2022-04-08 10:39:58 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- CardsMoveStruct 一次完整移动
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class CardsMoveStruct
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public moveInfo MoveInfo[] @ 移动信息
|
|
|
|
|
---@field public from? integer @ 移动来源玩家ID
|
|
|
|
|
---@field public to? integer @ 移动终点玩家ID
|
|
|
|
|
---@field public toArea CardArea @ 移动终点区域
|
|
|
|
|
---@field public moveReason CardMoveReason @ 移动原因
|
|
|
|
|
---@field public proposer? integer @ 移动执行者
|
|
|
|
|
---@field public skillName? string @ 移动技能名
|
|
|
|
|
---@field public moveVisible? boolean @ 控制移动是否可见
|
|
|
|
|
---@field public specialName? string @ 若终点区域为PlayerSpecial,则存至对应私人牌堆内
|
|
|
|
|
---@field public specialVisible? boolean @ 控制上述创建私人牌堆后是否令其可见
|
2023-12-03 11:35:14 +00:00
|
|
|
|
---@field public drawPilePosition? integer @ 移至牌堆的索引位置,值为-1代表置入牌堆底,或者牌堆牌数+1也为牌堆底
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public moveMark? table @ 移动后自动赋予标记,格式:{标记名(支持-inarea后缀,移出值代表区域后清除), 值}
|
2022-04-08 10:39:58 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- PindianResult 拼点结果
|
2023-03-14 12:48:08 +00:00
|
|
|
|
---@class PindianResult
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public toCard Card @ 被拼点者所使用的牌
|
|
|
|
|
---@field public winner? ServerPlayer @ 赢家,可能不存在
|
2023-03-14 12:48:08 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- HpChangedData 描述和一次体力变化有关的数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class HpChangedData
|
2023-03-29 15:27:11 +00:00
|
|
|
|
---@field public num integer @ 体力变化量,可能是正数或者负数
|
2023-12-10 10:55:16 +00:00
|
|
|
|
---@field public shield_lost integer|nil
|
2023-03-29 15:27:11 +00:00
|
|
|
|
---@field public reason string @ 体力变化原因
|
|
|
|
|
---@field public skillName string @ 引起体力变化的技能名
|
2023-12-03 11:35:14 +00:00
|
|
|
|
---@field public damageEvent? DamageStruct @ 引起这次体力变化的伤害数据
|
|
|
|
|
---@field public preventDying? boolean @ 是否阻止本次体力变更流程引发濒死流程
|
2022-04-08 10:39:58 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- HpLostData 描述跟失去体力有关的数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class HpLostData
|
2023-03-29 15:27:11 +00:00
|
|
|
|
---@field public num integer @ 失去体力的数值
|
|
|
|
|
---@field public skillName string @ 导致这次失去的技能名
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- MaxHpChangedData 描述跟体力上限变化有关的数据
|
2024-02-04 07:30:27 +00:00
|
|
|
|
---@class MaxHpChangedData
|
|
|
|
|
---@field public num integer @ 体力上限变化量,可能是正数或者负数
|
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- DamageType 伤害的属性
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@alias DamageType integer
|
|
|
|
|
|
|
|
|
|
fk.NormalDamage = 1
|
|
|
|
|
fk.ThunderDamage = 2
|
|
|
|
|
fk.FireDamage = 3
|
2023-04-13 12:17:39 +00:00
|
|
|
|
fk.IceDamage = 4
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- DamageStruct 描述和伤害事件有关的数据。
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class DamageStruct
|
2023-12-03 11:35:14 +00:00
|
|
|
|
---@field public from? ServerPlayer @ 伤害来源
|
2023-03-29 15:27:11 +00:00
|
|
|
|
---@field public to ServerPlayer @ 伤害目标
|
|
|
|
|
---@field public damage integer @ 伤害值
|
2023-12-03 11:35:14 +00:00
|
|
|
|
---@field public card? Card @ 造成伤害的牌
|
|
|
|
|
---@field public chain? boolean @ 伤害是否是铁索传导的伤害
|
|
|
|
|
---@field public damageType? DamageType @ 伤害的属性
|
|
|
|
|
---@field public skillName? string @ 造成本次伤害的技能名
|
|
|
|
|
---@field public beginnerOfTheDamage? boolean @ 是否是本次铁索传导的起点
|
2024-04-06 16:51:29 +00:00
|
|
|
|
---@field public by_user? boolean @ 是否由卡牌直接生效造成的伤害
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- RecoverStruct 描述和回复体力有关的数据。
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class RecoverStruct
|
2023-03-29 15:27:11 +00:00
|
|
|
|
---@field public who ServerPlayer @ 回复体力的角色
|
|
|
|
|
---@field public num integer @ 回复值
|
2023-12-03 11:35:14 +00:00
|
|
|
|
---@field public recoverBy? ServerPlayer @ 此次回复的回复来源
|
|
|
|
|
---@field public skillName? string @ 因何种技能而回复
|
|
|
|
|
---@field public card? Card @ 造成此次回复的卡牌
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- DyingStruct 描述和濒死事件有关的数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class DyingStruct
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public who integer @ 濒死角色
|
|
|
|
|
---@field public damage DamageStruct @ 造成此次濒死的伤害数据
|
|
|
|
|
---@field public ignoreDeath? boolean @ 是否不进行死亡结算
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- DeathStruct 描述和死亡事件有关的数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class DeathStruct
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public who integer @ 死亡角色
|
|
|
|
|
---@field public damage DamageStruct @ 造成此次死亡的伤害数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2023-12-03 10:45:25 +00:00
|
|
|
|
--- askForUseCard中的extra_data
|
|
|
|
|
---@class UseExtraData
|
2023-12-12 13:20:35 +00:00
|
|
|
|
---@field public must_targets? integer[] @ 必须选择这些目标?
|
|
|
|
|
---@field public include_targets? integer[] @ 必须选其中一个目标?
|
|
|
|
|
---@field public exclusive_targets? integer[] @ 只能选择这些目标?
|
2023-12-03 10:45:25 +00:00
|
|
|
|
---@field public bypass_distances? boolean @ 无距离限制?
|
|
|
|
|
---@field public bypass_times? boolean @ 无次数限制?
|
|
|
|
|
---@field public playing? boolean @ (AI专用) 出牌阶段?
|
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- CardUseStruct 使用卡牌的数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class CardUseStruct
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public from integer @ 使用者
|
|
|
|
|
---@field public tos TargetGroup @ 角色目标组
|
|
|
|
|
---@field public card Card @ 卡牌本牌
|
|
|
|
|
---@field public toCard? Card @ 卡牌目标
|
|
|
|
|
---@field public responseToEvent? CardUseStruct @ 响应事件目标
|
|
|
|
|
---@field public nullifiedTargets? integer[] @ 对这些角色无效
|
|
|
|
|
---@field public extraUse? boolean @ 是否不计入次数
|
|
|
|
|
---@field public disresponsiveList? integer[] @ 这些角色不可响应此牌
|
|
|
|
|
---@field public unoffsetableList? integer[] @ 这些角色不可抵消此牌
|
|
|
|
|
---@field public additionalDamage? integer @ 额外伤害值(如酒之于杀)
|
|
|
|
|
---@field public additionalRecover? integer @ 额外回复值
|
|
|
|
|
---@field public extra_data? any @ 额外数据(如目标过滤等)
|
|
|
|
|
---@field public customFrom? integer @ 新使用者
|
|
|
|
|
---@field public cardsResponded? Card[] @ 响应此牌的牌
|
|
|
|
|
---@field public prohibitedCardNames? string[] @ 这些牌名的牌不可响应此牌
|
|
|
|
|
---@field public damageDealt? table<PlayerId, number> @ 此牌造成的伤害
|
|
|
|
|
---@field public additionalEffect? integer @ 额外结算次数
|
|
|
|
|
---@field public noIndicate? boolean @ 隐藏指示线
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- AimStruct 处理使用牌目标的数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class AimStruct
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public from integer @ 使用者
|
|
|
|
|
---@field public card Card @ 卡牌本牌
|
|
|
|
|
---@field public tos AimGroup @ 总角色目标
|
|
|
|
|
---@field public to integer @ 当前角色目标
|
|
|
|
|
---@field public subTargets? integer[] @ 子目标(借刀!)
|
|
|
|
|
---@field public targetGroup? TargetGroup @ 目标组
|
|
|
|
|
---@field public nullifiedTargets? integer[] @ 对这些角色无效
|
|
|
|
|
---@field public firstTarget boolean @ 是否是第一个目标
|
|
|
|
|
---@field public additionalDamage? integer @ 额外伤害值(如酒之于杀)
|
|
|
|
|
---@field public additionalRecover? integer @ 额外回复值
|
|
|
|
|
---@field public disresponsive? boolean @ 是否不可响应
|
|
|
|
|
---@field public unoffsetable? boolean @ 是否不可抵消
|
|
|
|
|
---@field public fixedResponseTimes? table<string, integer>|integer @ 额外响应请求
|
|
|
|
|
---@field public fixedAddTimesResponsors? integer[] @ 额外响应请求次数
|
|
|
|
|
---@field public additionalEffect? integer @额外结算次数
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- CardUseStruct 卡牌效果的数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class CardEffectEvent
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public from? integer @ 使用者
|
|
|
|
|
---@field public to integer @ 角色目标
|
|
|
|
|
---@field public subTargets? integer[] @ 子目标(借刀!)
|
|
|
|
|
---@field public tos TargetGroup @ 目标组
|
|
|
|
|
---@field public card Card @ 卡牌本牌
|
|
|
|
|
---@field public toCard? Card @ 卡牌目标
|
|
|
|
|
---@field public responseToEvent? CardEffectEvent @ 响应事件目标
|
|
|
|
|
---@field public nullifiedTargets? integer[] @ 对这些角色无效
|
|
|
|
|
---@field public extraUse? boolean @ 是否不计入次数
|
|
|
|
|
---@field public disresponsiveList? integer[] @ 这些角色不可响应此牌
|
|
|
|
|
---@field public unoffsetableList? integer[] @ 这些角色不可抵消此牌
|
|
|
|
|
---@field public additionalDamage? integer @ 额外伤害值(如酒之于杀)
|
|
|
|
|
---@field public additionalRecover? integer @ 额外回复值
|
|
|
|
|
---@field public extra_data? any @ 额外数据(如目标过滤等)
|
|
|
|
|
---@field public customFrom? integer @ 新使用者
|
|
|
|
|
---@field public cardsResponded? Card[] @ 响应此牌的牌
|
|
|
|
|
---@field public disresponsive? boolean @ 是否不可响应
|
|
|
|
|
---@field public unoffsetable? boolean @ 是否不可抵消
|
|
|
|
|
---@field public isCancellOut? boolean @ 是否被抵消
|
|
|
|
|
---@field public fixedResponseTimes? table<string, integer>|integer @ 额外响应请求
|
|
|
|
|
---@field public fixedAddTimesResponsors? integer[] @ 额外响应请求次数
|
|
|
|
|
---@field public prohibitedCardNames? string[] @ 这些牌名的牌不可响应此牌
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- SkillEffectEvent 技能效果的数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class SkillEffectEvent
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public from integer @ 使用者
|
|
|
|
|
---@field public tos integer[] @ 角色目标
|
|
|
|
|
---@field public cards integer[] @ 选择卡牌
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- JudgeStruct 判定的数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class JudgeStruct
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public who ServerPlayer @ 判定者
|
|
|
|
|
---@field public card Card @ 当前判定牌
|
|
|
|
|
---@field public reason string @ 判定原因
|
|
|
|
|
---@field public pattern string @ 钩叉条件
|
|
|
|
|
---@field public skipDrop? boolean @ 是否不进入弃牌堆
|
2023-02-15 11:54:35 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- CardResponseEvent 卡牌响应的数据
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class CardResponseEvent
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public from integer @ 响应者
|
|
|
|
|
---@field public card Card @ 卡牌本牌
|
|
|
|
|
---@field public responseToEvent? CardEffectEvent @ 响应事件目标
|
|
|
|
|
---@field public skipDrop? boolean @ 是否不进入弃牌堆
|
|
|
|
|
---@field public customFrom? integer @ 新响应者
|
2022-12-20 10:40:17 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- AskForCardUse 询问使用卡牌的数据
|
2023-03-05 17:07:54 +00:00
|
|
|
|
---@class AskForCardUse
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public user ServerPlayer @ 使用者
|
|
|
|
|
---@field public cardName string @ 烧条信息
|
|
|
|
|
---@field public pattern string @ 可用牌过滤
|
|
|
|
|
---@field public eventData CardEffectEvent @ 事件数据
|
|
|
|
|
---@field public extraData UseExtraData @ 额外数据
|
|
|
|
|
---@field public result? CardUseStruct @ 使用结果
|
2023-03-05 17:07:54 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- AskForCardResponse 询问响应卡牌的数据
|
2023-03-05 17:07:54 +00:00
|
|
|
|
---@class AskForCardResponse
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public user ServerPlayer @ 响应者
|
|
|
|
|
---@field public cardName string @ 烧条信息
|
|
|
|
|
---@field public pattern string @ 可用牌过滤
|
|
|
|
|
---@field public extraData UseExtraData @ 额外数据
|
|
|
|
|
---@field public result? Card
|
2023-03-05 17:07:54 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- PindianStruct 拼点的数据
|
2023-02-21 05:44:24 +00:00
|
|
|
|
---@class PindianStruct
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public from ServerPlayer @ 拼点发起者
|
|
|
|
|
---@field public tos ServerPlayer[] @ 拼点目标
|
|
|
|
|
---@field public fromCard Card @ 拼点发起者拼点牌
|
|
|
|
|
---@field public results table<integer, PindianResult> @ 结果
|
|
|
|
|
---@field public reason string @ 拼点原因
|
2023-02-21 05:44:24 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- LogMessage 战报信息
|
2023-02-15 11:54:35 +00:00
|
|
|
|
---@class LogMessage
|
2024-02-26 18:28:13 +00:00
|
|
|
|
---@field public type string @ log主体
|
|
|
|
|
---@field public from? integer @ 要替换%from的玩家的id
|
|
|
|
|
---@field public to? integer[] @ 要替换%to的玩家id列表
|
|
|
|
|
---@field public card? integer[] @ 要替换%card的卡牌id列表
|
|
|
|
|
---@field public arg? any @ 要替换%arg的内容
|
|
|
|
|
---@field public arg2? any @ 要替换%arg2的内容
|
|
|
|
|
---@field public arg3? any @ 要替换%arg3的内容
|
|
|
|
|
---@field public toast? boolean @ 是否顺手把消息发送一条相同的toast
|
2023-05-13 06:20:34 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- SkillUseStruct 使用技能的数据
|
2023-05-13 06:20:34 +00:00
|
|
|
|
---@class SkillUseStruct
|
|
|
|
|
---@field public skill Skill
|
|
|
|
|
---@field public willUse boolean
|
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- DrawCardStruct 摸牌的数据
|
2023-05-13 06:20:34 +00:00
|
|
|
|
---@class DrawCardStruct
|
2024-04-19 13:35:29 +00:00
|
|
|
|
---@field public who ServerPlayer @ 摸牌者
|
|
|
|
|
---@field public num number @ 摸牌数
|
|
|
|
|
---@field public skillName string @ 技能名
|
|
|
|
|
---@field public fromPlace "top"|"bottom" @ 摸牌的位置
|
2024-02-26 18:28:13 +00:00
|
|
|
|
|
2024-04-19 13:35:29 +00:00
|
|
|
|
--- 移动理由
|
2024-02-26 18:28:13 +00:00
|
|
|
|
---@alias CardMoveReason integer
|
|
|
|
|
fk.ReasonJustMove = 1
|
|
|
|
|
fk.ReasonDraw = 2
|
|
|
|
|
fk.ReasonDiscard = 3
|
|
|
|
|
fk.ReasonGive = 4
|
|
|
|
|
fk.ReasonPut = 5
|
|
|
|
|
fk.ReasonPutIntoDiscardPile = 6
|
|
|
|
|
fk.ReasonPrey = 7
|
|
|
|
|
fk.ReasonExchange = 8
|
|
|
|
|
fk.ReasonUse = 9
|
|
|
|
|
fk.ReasonResonpse = 10
|
|
|
|
|
fk.ReasonJudge = 11
|
|
|
|
|
fk.ReasonRecast = 12
|
2024-04-19 13:35:29 +00:00
|
|
|
|
|
|
|
|
|
--- 内置动画类型,理论上你可以自定义一个自己的动画类型(big会播放一段限定技动画)
|
|
|
|
|
---@alias AnimationType "special" | "drawcard" | "control" | "offensive" | "support" | "defensive" | "negative" | "masochism" | "switch" | "big"
|