一将成名2024一系列bugfix
This commit is contained in:
parent
74e6903d84
commit
236402ad64
|
@ -115,7 +115,7 @@ game.import("character", function () {
|
||||||
|
|
||||||
linghuyu: ["male", "wei", 4, ["xvzhi"]],
|
linghuyu: ["male", "wei", 4, ["xvzhi"]],
|
||||||
yj_simafu: ["male", "wei", 3, ["beiyu", "duchi"]],
|
yj_simafu: ["male", "wei", 3, ["beiyu", "duchi"]],
|
||||||
yj_xuangongzhu: ["female", "wei", 3, ["qimei", "zhuiji"]],
|
yj_xuangongzhu: ["female", "wei", 3, ["yjqimei", "yjzhuiji"]],
|
||||||
xukun: ["male", "wu", 4, ["fazhu"]],
|
xukun: ["male", "wu", 4, ["fazhu"]],
|
||||||
},
|
},
|
||||||
characterIntro: {
|
characterIntro: {
|
||||||
|
@ -242,7 +242,10 @@ game.import("character", function () {
|
||||||
const stat = player.getStat("xvzhi");
|
const stat = player.getStat("xvzhi");
|
||||||
return target.countCards("h") && (!stat || !stat.includes(target));
|
return target.countCards("h") && (!stat || !stat.includes(target));
|
||||||
},
|
},
|
||||||
|
selectTarget:2,
|
||||||
usable: 1,
|
usable: 1,
|
||||||
|
multiline: true,
|
||||||
|
multitarget: true,
|
||||||
async content(event, trigger, player) {
|
async content(event, trigger, player) {
|
||||||
const targets = event.targets;
|
const targets = event.targets;
|
||||||
if (targets.some(i => !i.countCards("h"))) return;
|
if (targets.some(i => !i.countCards("h"))) return;
|
||||||
|
@ -250,28 +253,25 @@ game.import("character", function () {
|
||||||
.chooseCardOL(targets, "h", true, [1, Infinity], "蓄志:选择任意张手牌并与对方交换")
|
.chooseCardOL(targets, "h", true, [1, Infinity], "蓄志:选择任意张手牌并与对方交换")
|
||||||
.set("ai", card => {
|
.set("ai", card => {
|
||||||
const player = get.event("player"),
|
const player = get.event("player"),
|
||||||
target = get
|
target = get.event().getParent(2).targets.find(i => i != player);
|
||||||
.event()
|
|
||||||
.getParent(2)
|
|
||||||
.targets.find(i => i != player);
|
|
||||||
const sha = new lib.element.VCard({ name: "sha" });
|
const sha = new lib.element.VCard({ name: "sha" });
|
||||||
const playerEffect = player.hasUseTarget(sha, false)
|
const playerEffect = player.hasUseTarget(sha, false)
|
||||||
? Math.max(
|
? Math.max(
|
||||||
...game.filterPlayer(current =>
|
...game.filterPlayer(current =>
|
||||||
player.canUse(sha, current, false).map(current => {
|
player.canUse(sha, current, false)
|
||||||
|
).map(current => {
|
||||||
return get.effect(current, sha, player, player);
|
return get.effect(current, sha, player, player);
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
)
|
|
||||||
: 0;
|
: 0;
|
||||||
const targetEffect = target.hasUseTarget(sha, false)
|
const targetEffect = target.hasUseTarget(sha, false)
|
||||||
? Math.max(
|
? Math.max(
|
||||||
...game.filterPlayer(current =>
|
...game.filterPlayer(current =>
|
||||||
target.canUse(sha, current, false).map(current => {
|
target.canUse(sha, current, false)
|
||||||
return get.effect(current, sha, target, target);
|
).map(current => {
|
||||||
|
return get.effect(current, sha, player, player);
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
)
|
|
||||||
: 0;
|
: 0;
|
||||||
return 5 + 3 * get.sgn(playerEffect - targetEffect) - get.value(card);
|
return 5 + 3 * get.sgn(playerEffect - targetEffect) - get.value(card);
|
||||||
})
|
})
|
||||||
|
@ -374,12 +374,12 @@ game.import("character", function () {
|
||||||
await player.showHandcards(get.translation(player) + "发动了【督持】");
|
await player.showHandcards(get.translation(player) + "发动了【督持】");
|
||||||
const colors = player.getCards("h").reduce((list, card) => list.add(get.color(card)), []);
|
const colors = player.getCards("h").reduce((list, card) => list.add(get.color(card)), []);
|
||||||
if (colors.length == 1) {
|
if (colors.length == 1) {
|
||||||
player.chat("洗具");
|
player.popup("洗具");
|
||||||
trigger.getParent().excluded.add(player);
|
trigger.getParent().excluded.add(player);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
player.chat("杯具");
|
player.popup("杯具");
|
||||||
},
|
},
|
||||||
ai: { threaten: 0.8 },
|
ai: { threaten: 0.8 },
|
||||||
},
|
},
|
||||||
|
@ -389,7 +389,7 @@ game.import("character", function () {
|
||||||
enable: "phaseUse",
|
enable: "phaseUse",
|
||||||
filter(event, player) {
|
filter(event, player) {
|
||||||
const count = player.getStat("skill").yjqimei;
|
const count = player.getStat("skill").yjqimei;
|
||||||
if (count && count > 0 && !player.hasSkill("yjqimei")) return false;
|
if (count && count > 0 && !player.hasSkill("yjqimei_rewrite")) return false;
|
||||||
return true;
|
return true;
|
||||||
},
|
},
|
||||||
filterTarget: lib.filter.notMe,
|
filterTarget: lib.filter.notMe,
|
||||||
|
|
Loading…
Reference in New Issue