Merge pull request #1342 from PZ157/PR-Branch
使用牌类技能ai.effect改为effect_use,其他ai相关调整
This commit is contained in:
commit
8089431d61
|
@ -922,7 +922,7 @@ game.import("card", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (target.hasSkillTag("unequip2")) return;
|
if (target.hasSkillTag("unequip2")) return;
|
||||||
if (
|
if (
|
||||||
player.hasSkillTag("unequip", false, {
|
player.hasSkillTag("unequip", false, {
|
||||||
|
|
|
@ -1523,7 +1523,7 @@ game.import("card", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (
|
if (
|
||||||
["huoshaolianying", "huogong"].includes(card.name) ||
|
["huoshaolianying", "huogong"].includes(card.name) ||
|
||||||
(card.name == "sha" && game.hasNature(card, "fire"))
|
(card.name == "sha" && game.hasNature(card, "fire"))
|
||||||
|
@ -1575,7 +1575,7 @@ game.import("card", function () {
|
||||||
g_dinglanyemingzhu_ai: {
|
g_dinglanyemingzhu_ai: {
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player) {
|
player_use(card, player) {
|
||||||
if (player.hasSkill("jubao")) return;
|
if (player.hasSkill("jubao")) return;
|
||||||
if (
|
if (
|
||||||
card.name == "dinglanyemingzhu" &&
|
card.name == "dinglanyemingzhu" &&
|
||||||
|
@ -1592,7 +1592,7 @@ game.import("card", function () {
|
||||||
g_feilongduofeng_ai: {
|
g_feilongduofeng_ai: {
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player) {
|
player_use(card, player) {
|
||||||
if (player.hasSkill("zhangwu")) return;
|
if (player.hasSkill("zhangwu")) return;
|
||||||
if (
|
if (
|
||||||
card.name == "feilongduofeng" &&
|
card.name == "feilongduofeng" &&
|
||||||
|
@ -1609,7 +1609,7 @@ game.import("card", function () {
|
||||||
g_taipingyaoshu_ai: {
|
g_taipingyaoshu_ai: {
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player) {
|
player_use(card, player) {
|
||||||
if (player.hasSkill("wendao")) return;
|
if (player.hasSkill("wendao")) return;
|
||||||
if (
|
if (
|
||||||
card.name == "taipingyaoshu" &&
|
card.name == "taipingyaoshu" &&
|
||||||
|
@ -1620,7 +1620,7 @@ game.import("card", function () {
|
||||||
return [0, 0, 0, 0];
|
return [0, 0, 0, 0];
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
target: (card, player, target) => {
|
target_use(card, player, target) {
|
||||||
if (target._g_taipingyaoshu_temp) return;
|
if (target._g_taipingyaoshu_temp) return;
|
||||||
if (
|
if (
|
||||||
get.subtype(card) === "equip2" &&
|
get.subtype(card) === "equip2" &&
|
||||||
|
|
|
@ -2001,7 +2001,7 @@ game.import("card", function () {
|
||||||
ai: {
|
ai: {
|
||||||
weather: true,
|
weather: true,
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player) {
|
player_use(card, player) {
|
||||||
if (!player.needsToDiscard()) return "zeroplayertarget";
|
if (!player.needsToDiscard()) return "zeroplayertarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -2083,7 +2083,7 @@ game.import("card", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
wuxie: function (target, card, player, viewer) {
|
wuxie: function (target, card, player, viewer) {
|
||||||
if (get.attitude(viewer, player._trueMe || player) > 0) return 0;
|
if (!target.countCards("hej") ||get.attitude(viewer, player._trueMe || player) > 0) return 0;
|
||||||
},
|
},
|
||||||
basic: {
|
basic: {
|
||||||
order: 7.5,
|
order: 7.5,
|
||||||
|
@ -2366,6 +2366,7 @@ game.import("card", function () {
|
||||||
ai: {
|
ai: {
|
||||||
wuxie: (target, card, player, viewer, status) => {
|
wuxie: (target, card, player, viewer, status) => {
|
||||||
if (
|
if (
|
||||||
|
!target.countCards("hej") ||
|
||||||
status * get.attitude(viewer, player._trueMe || player) > 0 ||
|
status * get.attitude(viewer, player._trueMe || player) > 0 ||
|
||||||
(target.hp > 2 &&
|
(target.hp > 2 &&
|
||||||
!target.hasCard((i) => {
|
!target.hasCard((i) => {
|
||||||
|
@ -3117,7 +3118,7 @@ game.import("card", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (typeof card !== "object" || target.hasSkillTag("unequip2")) return;
|
if (typeof card !== "object" || target.hasSkillTag("unequip2")) return;
|
||||||
if (
|
if (
|
||||||
player.hasSkillTag("unequip", false, {
|
player.hasSkillTag("unequip", false, {
|
||||||
|
|
14
card/swd.js
14
card/swd.js
|
@ -5030,8 +5030,10 @@ game.import("card", function () {
|
||||||
player.updateMarks();
|
player.updateMarks();
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: function (card, player, target) {
|
effect: {
|
||||||
if (get.tag(card, "damage") && !target.hujia) return [1, 0.5];
|
target(card, player, target) {
|
||||||
|
if (get.tag(card, "damage") && !target.hujia) return [1, 0.5];
|
||||||
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
intro: {
|
intro: {
|
||||||
|
@ -5133,9 +5135,11 @@ game.import("card", function () {
|
||||||
player.recover(trigger.num);
|
player.recover(trigger.num);
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: function (card) {
|
effect: {
|
||||||
if (get.tag(card, "thunderDamage")) return [0, 2];
|
target(card) {
|
||||||
},
|
if (get.tag(card, "thunderDamage")) return [0, 2];
|
||||||
|
},
|
||||||
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
guiyanfadao: {
|
guiyanfadao: {
|
||||||
|
|
|
@ -754,7 +754,7 @@ game.import("card", function () {
|
||||||
heiguangkai_ai: {
|
heiguangkai_ai: {
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (
|
if (
|
||||||
typeof card !== "object" ||
|
typeof card !== "object" ||
|
||||||
!target ||
|
!target ||
|
||||||
|
|
|
@ -932,7 +932,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
threaten: 3,
|
threaten: 3,
|
||||||
effect: {
|
effect: {
|
||||||
player(card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (!target || typeof card !== "object" || player._clanjiejian_mod_temp || get.type(card) === "equip" || get.attitude(player, target) <= 0 || get.cardNameLength(card) !== player.getHistory("useCard").length + 1) return;
|
if (!target || typeof card !== "object" || player._clanjiejian_mod_temp || get.type(card) === "equip" || get.attitude(player, target) <= 0 || get.cardNameLength(card) !== player.getHistory("useCard").length + 1) return;
|
||||||
let targets = [target],
|
let targets = [target],
|
||||||
evt = _status.event.getParent("useCard");
|
evt = _status.event.getParent("useCard");
|
||||||
|
@ -2705,7 +2705,7 @@ const skills = {
|
||||||
if (player.getHistory("useCard", evt => get.type(evt.card) == "equip").length > 0) return false;
|
if (player.getHistory("useCard", evt => get.type(evt.card) == "equip").length > 0) return false;
|
||||||
},
|
},
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (player == target && get.type(card) == "equip" && !player.getHistory("useCard", evt => get.type(evt.card) == "equip").length == 0) return [1, 3];
|
if (player == target && get.type(card) == "equip" && !player.getHistory("useCard", evt => get.type(evt.card) == "equip").length == 0) return [1, 3];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -759,7 +759,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (player == target && player.isPhaseUsing() && get.type(card) == "equip") {
|
if (player == target && player.isPhaseUsing() && get.type(card) == "equip") {
|
||||||
if (player.hasValueTarget("sha", false) && typeof player.getStat("skill").dcbianzhuang == "number") return [1, 3];
|
if (player.hasValueTarget("sha", false) && typeof player.getStat("skill").dcbianzhuang == "number") return [1, 3];
|
||||||
}
|
}
|
||||||
|
@ -1645,7 +1645,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player(card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (player !== target && get.type2(card) === "trick") {
|
if (player !== target && get.type2(card) === "trick") {
|
||||||
let tars = [target];
|
let tars = [target];
|
||||||
if (ui.selected.targets.length) tars.addArray(ui.selected.targets.filter(i => i !== player && i !== target));
|
if (ui.selected.targets.length) tars.addArray(ui.selected.targets.filter(i => i !== player && i !== target));
|
||||||
|
|
|
@ -2619,7 +2619,7 @@ const skills = {
|
||||||
order: 10,
|
order: 10,
|
||||||
result: { player: 1 },
|
result: { player: 1 },
|
||||||
effect: {
|
effect: {
|
||||||
target: (card, player, target) => {
|
target_use(card, player, target) {
|
||||||
if (card.name === "sha" && target.getExpansions("ddddongcha_effect").length < 2 && lib.skill["dddzhijie"].hiddenCard(target, "shan")) return [1, 1, 1, -get.sgn(get.attitude(player, _status.currentPhase))];
|
if (card.name === "sha" && target.getExpansions("ddddongcha_effect").length < 2 && lib.skill["dddzhijie"].hiddenCard(target, "shan")) return [1, 1, 1, -get.sgn(get.attitude(player, _status.currentPhase))];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -1918,6 +1918,13 @@ const skills = {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
nszhihuang: {
|
nszhihuang: {
|
||||||
|
available(mode) {
|
||||||
|
return (
|
||||||
|
mode == "identity" ||
|
||||||
|
mode == "versus" && (_status.mode == "four" || _status.mode == "guandu") ||
|
||||||
|
mode == "guozhan"
|
||||||
|
);
|
||||||
|
},
|
||||||
group: "nszhihuang_damage",
|
group: "nszhihuang_damage",
|
||||||
trigger: { global: "useCard" },
|
trigger: { global: "useCard" },
|
||||||
usable: 1,
|
usable: 1,
|
||||||
|
@ -3169,7 +3176,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (get.type(card, "trick") == "trick" && get.distance(player, target) > 1) return "zeroplayertarget";
|
if (get.type(card, "trick") == "trick" && get.distance(player, target) > 1) return "zeroplayertarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -4494,7 +4501,7 @@ const skills = {
|
||||||
content() {
|
content() {
|
||||||
"step 0";
|
"step 0";
|
||||||
player
|
player
|
||||||
.chooseTarget("恭俭:将置的牌交给一名体力值大于你的角色", function (card, player, target) {
|
.chooseTarget("恭俭:将弃置的牌交给一名体力值大于你的角色", function (card, player, target) {
|
||||||
return target.hp > player.hp;
|
return target.hp > player.hp;
|
||||||
})
|
})
|
||||||
.set("ai", function (target) {
|
.set("ai", function (target) {
|
||||||
|
@ -4506,6 +4513,9 @@ const skills = {
|
||||||
result.targets[0].gain(trigger.cards, "gain2");
|
result.targets[0].gain(trigger.cards, "gain2");
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
ai: {
|
||||||
|
halfneg: true
|
||||||
|
},
|
||||||
},
|
},
|
||||||
nscaijian: {
|
nscaijian: {
|
||||||
enable: "phaseUse",
|
enable: "phaseUse",
|
||||||
|
@ -4599,7 +4609,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (get.type(card, "trick") == "trick" && _status.currentPhase == player) return "zeroplayertarget";
|
if (get.type(card, "trick") == "trick" && _status.currentPhase == player) return "zeroplayertarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -6228,7 +6238,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (get.tag(card, "multineg")) {
|
if (get.tag(card, "multineg")) {
|
||||||
return "zerotarget";
|
return "zerotarget";
|
||||||
}
|
}
|
||||||
|
@ -6718,9 +6728,11 @@ const skills = {
|
||||||
player.draw();
|
player.draw();
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect(card, player, target) {
|
effect: {
|
||||||
if (get.color(card) == "red") return [1, 1];
|
target_use(card, player, target) {
|
||||||
},
|
if (get.color(card) == "red") return [1, 1];
|
||||||
|
},
|
||||||
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
zaiqix: {
|
zaiqix: {
|
||||||
|
|
|
@ -2327,7 +2327,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
threaten: 1.5,
|
threaten: 1.5,
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (get.type(card) == "equip" && !get.cardtag(card, "gifts")) return [1, 0.1];
|
if (get.type(card) == "equip" && !get.cardtag(card, "gifts")) return [1, 0.1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -3297,7 +3297,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: (card, player, target) => {
|
player_use(card, player, target) {
|
||||||
if (typeof card !== "object") return;
|
if (typeof card !== "object") return;
|
||||||
let suit = get.suit(card);
|
let suit = get.suit(card);
|
||||||
if (
|
if (
|
||||||
|
@ -4286,7 +4286,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (card && card.name == "qizhengxiangsheng") return "zeroplayertarget";
|
if (card && card.name == "qizhengxiangsheng") return "zeroplayertarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -4413,7 +4413,7 @@ const skills = {
|
||||||
global: {
|
global: {
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: (card, player, target) => {
|
player_use(card, player, target) {
|
||||||
let num = 0,
|
let num = 0,
|
||||||
nohave = true;
|
nohave = true;
|
||||||
game.countPlayer(i => {
|
game.countPlayer(i => {
|
||||||
|
@ -4529,7 +4529,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target, current, isLink) {
|
target_use(card, player, target, current, isLink) {
|
||||||
if (card.name == "sha" && !isLink && player.hp > target.hp) return 0.5;
|
if (card.name == "sha" && !isLink && player.hp > target.hp) return 0.5;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -1289,7 +1289,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (get.color(card) == "red" && target.isDamaged()) return [1, 1];
|
if (get.color(card) == "red" && target.isDamaged()) return [1, 1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -1480,7 +1480,7 @@ game.import("character", function () {
|
||||||
ai: {
|
ai: {
|
||||||
halfneg: true,
|
halfneg: true,
|
||||||
effect: {
|
effect: {
|
||||||
player(card, player, target, current) {
|
player_use(card, player, target, current) {
|
||||||
if (get.color(card) == "red") return [1, 0, 1, -2];
|
if (get.color(card) == "red") return [1, 0, 1, -2];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -2517,7 +2517,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (get.type(card, "trick") == "trick" && player == target) return [1, 1];
|
if (get.type(card, "trick") == "trick" && player == target) return [1, 1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -9820,7 +9820,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (player !== target && get.itemtype(target) === "player" && (card.name === "sha" || get.type(card, false) === "trick") && target.countCards("he") && !target.hasSkillTag("noh")) return [1, 0, 1, -1];
|
if (player !== target && get.itemtype(target) === "player" && (card.name === "sha" || get.type(card, false) === "trick") && target.countCards("he") && !target.hasSkillTag("noh")) return [1, 0, 1, -1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -10483,7 +10483,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (typeof card == "object" && player != target) {
|
if (typeof card == "object" && player != target) {
|
||||||
var suit = get.suit(card);
|
var suit = get.suit(card);
|
||||||
if (suit == "none") return;
|
if (suit == "none") return;
|
||||||
|
@ -13093,7 +13093,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (_status._dcdanying_aiChecking) return;
|
if (_status._dcdanying_aiChecking) return;
|
||||||
_status._dcdanying_aiChecking = true;
|
_status._dcdanying_aiChecking = true;
|
||||||
let eff = get.effect(target, { name: "guohe_copy2" }, player, player);
|
let eff = get.effect(target, { name: "guohe_copy2" }, player, player);
|
||||||
|
@ -13362,6 +13362,9 @@ const skills = {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
ai: {
|
||||||
|
combo: "recangchu"
|
||||||
|
},
|
||||||
},
|
},
|
||||||
reshishou: {
|
reshishou: {
|
||||||
audio: 2,
|
audio: 2,
|
||||||
|
|
|
@ -137,6 +137,9 @@ const skills = {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
jsrgchushi: {
|
jsrgchushi: {
|
||||||
|
available(mode) {
|
||||||
|
return mode == "identity" || mode == "versus" && (_status.mode == "four" || _status.mode == "guandu");
|
||||||
|
},
|
||||||
audio: 2,
|
audio: 2,
|
||||||
enable: "phaseUse",
|
enable: "phaseUse",
|
||||||
usable: 1,
|
usable: 1,
|
||||||
|
@ -5961,7 +5964,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
halfneg: true,
|
halfneg: true,
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (card.name == "jiu") return [1, 1];
|
if (card.name == "jiu") return [1, 1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -6770,7 +6773,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (lib.skill.jsrgjuxia.countSkill(target) >= lib.skill.jsrgjuxia.countSkill(player)) return;
|
if (lib.skill.jsrgjuxia.countSkill(target) >= lib.skill.jsrgjuxia.countSkill(player)) return;
|
||||||
if (card && (card.cards || card.isCard) && get.attitude(target, player) > 0 && (!target.storage.counttrigger || !target.storage.counttrigger.jsrgjuxia)) return [0, 0.5, 0, 0.5];
|
if (card && (card.cards || card.isCard) && get.attitude(target, player) > 0 && (!target.storage.counttrigger || !target.storage.counttrigger.jsrgjuxia)) return [0, 0.5, 0, 0.5];
|
||||||
},
|
},
|
||||||
|
@ -8031,7 +8034,7 @@ const skills = {
|
||||||
pretao: true,
|
pretao: true,
|
||||||
threaten: 1.8,
|
threaten: 1.8,
|
||||||
effect: {
|
effect: {
|
||||||
player(card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (
|
if (
|
||||||
typeof card === "object" &&
|
typeof card === "object" &&
|
||||||
card.name !== "shan" &&
|
card.name !== "shan" &&
|
||||||
|
|
|
@ -2250,7 +2250,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
threaten: 0.7,
|
threaten: 0.7,
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (card.name == "sha") return 0.7;
|
if (card.name == "sha") return 0.7;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -6484,6 +6484,9 @@ const skills = {
|
||||||
"step 2";
|
"step 2";
|
||||||
event.cards = result.cards;
|
event.cards = result.cards;
|
||||||
},
|
},
|
||||||
|
ai: {
|
||||||
|
halfneg: true
|
||||||
|
},
|
||||||
},
|
},
|
||||||
//乙坂有宇
|
//乙坂有宇
|
||||||
yuu_lveduo: {
|
yuu_lveduo: {
|
||||||
|
@ -6627,6 +6630,9 @@ const skills = {
|
||||||
player.draw(3);
|
player.draw(3);
|
||||||
player.removeSkills("godan_feiqu");
|
player.removeSkills("godan_feiqu");
|
||||||
},
|
},
|
||||||
|
ai: {
|
||||||
|
halfneg: true
|
||||||
|
},
|
||||||
},
|
},
|
||||||
//游佐
|
//游佐
|
||||||
abyusa_jueqing: {
|
abyusa_jueqing: {
|
||||||
|
@ -8785,6 +8791,7 @@ const skills = {
|
||||||
else trigger.directHit.add(player);
|
else trigger.directHit.add(player);
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
|
halfneg: true,
|
||||||
directHit_ai: true,
|
directHit_ai: true,
|
||||||
skillTagFilter(player, tag, arg) {
|
skillTagFilter(player, tag, arg) {
|
||||||
return arg.card.name == "sha";
|
return arg.card.name == "sha";
|
||||||
|
@ -9790,10 +9797,10 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (card.name == "sha" && get.color(card) == "red") return [1, 0.6];
|
if (card.name == "sha" && get.color(card) == "red") return [1, 0.6];
|
||||||
},
|
},
|
||||||
player(card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (card.name == "sha" && get.color(card) == "red") return [1, 1];
|
if (card.name == "sha" && get.color(card) == "red") return [1, 1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -119,7 +119,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player(card, player, target, current) {
|
player_use(card, player, target, current) {
|
||||||
if (!target) return;
|
if (!target) return;
|
||||||
const counttrigger = player.storage.counttrigger;
|
const counttrigger = player.storage.counttrigger;
|
||||||
if (counttrigger && counttrigger.mbkuangli_target && counttrigger.mbkuangli_target >= lib.skill.mbkuangli_target.usable) return;
|
if (counttrigger && counttrigger.mbkuangli_target && counttrigger.mbkuangli_target >= lib.skill.mbkuangli_target.usable) return;
|
||||||
|
@ -5176,7 +5176,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (player.canUse(card, target) && get.distance(player, target) != 1) return 1.2;
|
if (player.canUse(card, target) && get.distance(player, target) != 1) return 1.2;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -7599,7 +7599,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (card.name == "sha" && current < 0) return 0.7;
|
if (card.name == "sha" && current < 0) return 0.7;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -8046,7 +8046,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
reverseEquip: true,
|
reverseEquip: true,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (get.type(card) == "equip" && !get.tag(card, "gifts") && target.storage.jueyong && target.storage.jueyong[1].length) {
|
if (get.type(card) == "equip" && !get.tag(card, "gifts") && target.storage.jueyong && target.storage.jueyong[1].length) {
|
||||||
var result1 = get.equipResult(player, target, card.name),
|
var result1 = get.equipResult(player, target, card.name),
|
||||||
subtype = get.subtype(card);
|
subtype = get.subtype(card);
|
||||||
|
@ -10239,7 +10239,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
expose: 0.2,
|
expose: 0.2,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (card.name != "sha") return;
|
if (card.name != "sha") return;
|
||||||
var players = game.filterPlayer();
|
var players = game.filterPlayer();
|
||||||
if (get.attitude(player, target) <= 0) {
|
if (get.attitude(player, target) <= 0) {
|
||||||
|
@ -15180,7 +15180,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (["tiesuo", "lulitongxin"].includes(card.name)) {
|
if (["tiesuo", "lulitongxin"].includes(card.name)) {
|
||||||
return "zerotarget";
|
return "zerotarget";
|
||||||
}
|
}
|
||||||
|
@ -15205,7 +15205,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (typeof card !== "object" || target.hasSkillTag("unequip2")) return;
|
if (typeof card !== "object" || target.hasSkillTag("unequip2")) return;
|
||||||
if (
|
if (
|
||||||
player.hasSkillTag("unequip", false, {
|
player.hasSkillTag("unequip", false, {
|
||||||
|
@ -15238,7 +15238,7 @@ const skills = {
|
||||||
inherit: "rw_minguangkai_link",
|
inherit: "rw_minguangkai_link",
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (["tiesuo", "lulitongxin"].includes(card.name)) {
|
if (["tiesuo", "lulitongxin"].includes(card.name)) {
|
||||||
return "zeroplayertarget";
|
return "zeroplayertarget";
|
||||||
}
|
}
|
||||||
|
|
|
@ -442,7 +442,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (card.name == "sha" && !game.hasNature(card) && game.countPlayer(targetx => player.inRange(targetx)) >= 3) return "zerotarget";
|
if (card.name == "sha" && !game.hasNature(card) && game.countPlayer(targetx => player.inRange(targetx)) >= 3) return "zerotarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -1487,7 +1487,7 @@ const skills = {
|
||||||
threaten: 100,
|
threaten: 100,
|
||||||
reverseEquip: true,
|
reverseEquip: true,
|
||||||
effect: {
|
effect: {
|
||||||
player: (card, player, target) => {
|
player_use(card, player, target) {
|
||||||
if (typeof card !== "object") return;
|
if (typeof card !== "object") return;
|
||||||
let suit = get.suit(card);
|
let suit = get.suit(card);
|
||||||
if (
|
if (
|
||||||
|
@ -1506,7 +1506,7 @@ const skills = {
|
||||||
}),
|
}),
|
||||||
];
|
];
|
||||||
},
|
},
|
||||||
target: (card, player, target) => {
|
target(card, player, target) {
|
||||||
if (
|
if (
|
||||||
card.name === "sha" &&
|
card.name === "sha" &&
|
||||||
!player.hasSkillTag(
|
!player.hasSkillTag(
|
||||||
|
@ -1580,7 +1580,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (card.name === "sha" && game.hasNature(card) && target.hasEmptySlot(2)) return "zeroplayertarget";
|
if (card.name === "sha" && game.hasNature(card) && target.hasEmptySlot(2)) return "zeroplayertarget";
|
||||||
if (get.subtype(card) == "equip2" && target.isEmpty(2)) return [0.6, -0.8];
|
if (get.subtype(card) == "equip2" && target.isEmpty(2)) return [0.6, -0.8];
|
||||||
},
|
},
|
||||||
|
@ -2290,7 +2290,7 @@ const skills = {
|
||||||
threaten: 1.1,
|
threaten: 1.1,
|
||||||
combo: "psshiyin",
|
combo: "psshiyin",
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
var list = target.getExpansions("psshiyin");
|
var list = target.getExpansions("psshiyin");
|
||||||
for (var cardx of list) {
|
for (var cardx of list) {
|
||||||
if (get.suit(cardx) == get.suit(card)) return "zeroplayertarget";
|
if (get.suit(cardx) == get.suit(card)) return "zeroplayertarget";
|
||||||
|
@ -6442,7 +6442,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
var type = get.type2(card);
|
var type = get.type2(card);
|
||||||
var list = target.getExpansions("zuixiang2");
|
var list = target.getExpansions("zuixiang2");
|
||||||
for (var i of list) {
|
for (var i of list) {
|
||||||
|
|
|
@ -432,7 +432,7 @@ const skills = {
|
||||||
subSkill: {
|
subSkill: {
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player(card, player) {
|
player_use(card, player) {
|
||||||
if (
|
if (
|
||||||
!game.hasPlayer(target => {
|
!game.hasPlayer(target => {
|
||||||
return target.hasSkill("olsbhetao") && (get.attitude(player, target) < 0 || get.attitude(target, player) < 0);
|
return target.hasSkill("olsbhetao") && (get.attitude(player, target) < 0 || get.attitude(target, player) < 0);
|
||||||
|
|
|
@ -180,7 +180,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (_status.woliu2_temp) return;
|
if (_status.woliu2_temp) return;
|
||||||
if (card.name == "sha" && target.storage.woliu2) {
|
if (card.name == "sha" && target.storage.woliu2) {
|
||||||
_status.woliu2_temp = true;
|
_status.woliu2_temp = true;
|
||||||
|
@ -266,7 +266,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (card.name == "sha") {
|
if (card.name == "sha") {
|
||||||
if (_status.event.name == "qianggu2") return;
|
if (_status.event.name == "qianggu2") return;
|
||||||
if (get.attitude(player, target) > 0) return;
|
if (get.attitude(player, target) > 0) return;
|
||||||
|
|
|
@ -7400,7 +7400,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
expose: 0.2,
|
expose: 0.2,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use: function (card, player, target) {
|
||||||
if (card.name != "sha") return;
|
if (card.name != "sha") return;
|
||||||
var players = game.filterPlayer();
|
var players = game.filterPlayer();
|
||||||
if (get.attitude(player, target) <= 0) {
|
if (get.attitude(player, target) <= 0) {
|
||||||
|
@ -7648,7 +7648,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use: function (card, player, target) {
|
||||||
if (target != _status.currentPhase && target.countCards("h") >= target.getHandcardLimit() && (get.type(card) == "delay" || get.color(card) == "none")) return "zerotarget";
|
if (target != _status.currentPhase && target.countCards("h") >= target.getHandcardLimit() && (get.type(card) == "delay" || get.color(card) == "none")) return "zerotarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -13465,7 +13465,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use: function (card, player, target) {
|
||||||
if (player == target && get.type(card) == "equip") {
|
if (player == target && get.type(card) == "equip") {
|
||||||
if (player.countCards("e", { subtype: get.subtype(card) })) {
|
if (player.countCards("e", { subtype: get.subtype(card) })) {
|
||||||
if (
|
if (
|
||||||
|
@ -13941,20 +13941,22 @@ const skills = {
|
||||||
player.addSkill("reqianxun2");
|
player.addSkill("reqianxun2");
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: function (card, player, target) {
|
effect: {
|
||||||
if (player == target || !target.hasFriend()) return;
|
target_use(card, player, target) {
|
||||||
var type = get.type(card);
|
if (player == target || !target.hasFriend()) return;
|
||||||
var nh = Math.min(
|
var type = get.type(card);
|
||||||
target.countCards(),
|
var nh = Math.min(
|
||||||
game.countPlayer(i => get.attitude(target, i) > 0)
|
target.countCards(),
|
||||||
);
|
game.countPlayer(i => get.attitude(target, i) > 0)
|
||||||
if (type == "trick") {
|
);
|
||||||
if (!get.tag(card, "multitarget") || get.info(card).singleCard) {
|
if (type == "trick") {
|
||||||
if (get.tag(card, "damage")) return [1.5, nh - 1];
|
if (!get.tag(card, "multitarget") || get.info(card).singleCard) {
|
||||||
return [1, nh];
|
if (get.tag(card, "damage")) return [1.5, nh - 1];
|
||||||
}
|
return [1, nh];
|
||||||
} else if (type == "delay") return [0.5, 0.5];
|
}
|
||||||
},
|
} else if (type == "delay") return [0.5, 0.5];
|
||||||
|
},
|
||||||
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
reqianxun2: {
|
reqianxun2: {
|
||||||
|
@ -14580,27 +14582,29 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
maihp: true,
|
maihp: true,
|
||||||
effect: function (card, player, target) {
|
effect: {
|
||||||
if (get.tag(card, "damage")) {
|
target(card, player, target) {
|
||||||
if (player.hasSkillTag("jueqing", false, target)) return [1, 1];
|
if (get.tag(card, "damage")) {
|
||||||
return 1.2;
|
if (player.hasSkillTag("jueqing", false, target)) return [1, 1];
|
||||||
}
|
return 1.2;
|
||||||
if (get.tag(card, "loseHp")) {
|
}
|
||||||
if (target.hp <= 1) return;
|
if (get.tag(card, "loseHp")) {
|
||||||
var using = target.isPhaseUsing();
|
if (target.hp <= 1) return;
|
||||||
if (target.hp <= 2) return [1, player.countCards("h") <= 1 && using ? 3 : 0];
|
var using = target.isPhaseUsing();
|
||||||
if (using && target.countCards("h", { name: "sha", color: "red" })) return [1, 3];
|
if (target.hp <= 2) return [1, player.countCards("h") <= 1 && using ? 3 : 0];
|
||||||
return [
|
if (using && target.countCards("h", { name: "sha", color: "red" })) return [1, 3];
|
||||||
1,
|
return [
|
||||||
target.countCards("h") <= target.hp ||
|
1,
|
||||||
(using &&
|
target.countCards("h") <= target.hp ||
|
||||||
game.hasPlayer(function (current) {
|
(using &&
|
||||||
return current != player && get.attitude(player, current) < 0 && player.inRange(current);
|
game.hasPlayer(function (current) {
|
||||||
}))
|
return current != player && get.attitude(player, current) < 0 && player.inRange(current);
|
||||||
? 3
|
}))
|
||||||
: 2,
|
? 3
|
||||||
];
|
: 2,
|
||||||
}
|
];
|
||||||
|
}
|
||||||
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -1479,7 +1479,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (player.getStorage("sbyijue_effect").includes(target)) return "zeroplayertarget";
|
if (player.getStorage("sbyijue_effect").includes(target)) return "zeroplayertarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -2736,10 +2736,10 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (card.name == "sha" && get.color(card) == "red") return [1, 0.6];
|
if (card.name == "sha" && get.color(card) == "red") return [1, 0.6];
|
||||||
},
|
},
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (card.name == "sha" && get.color(card) == "red") return [1, 1];
|
if (card.name == "sha" && get.color(card) == "red") return [1, 1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -3451,7 +3451,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (player != target && target && target.group == "qun" && card.name != "tao") return [1, 0.1];
|
if (player != target && target && target.group == "qun" && card.name != "tao") return [1, 0.1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -6090,16 +6090,18 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
maihp: true,
|
maihp: true,
|
||||||
effect: function (card, player, target) {
|
effect: {
|
||||||
if (get.tag(card, "damage")) {
|
target(card, player, target) {
|
||||||
if (player.hasSkillTag("jueqing", false, target)) return [1, 1];
|
if (get.tag(card, "damage")) {
|
||||||
return 1.2;
|
if (player.hasSkillTag("jueqing", false, target)) return [1, 1];
|
||||||
}
|
return 1.2;
|
||||||
if (get.tag(card, "loseHp")) {
|
}
|
||||||
if (target.hp <= 1 || target.hujia >= 5) return;
|
if (get.tag(card, "loseHp")) {
|
||||||
return [1, 1];
|
if (target.hp <= 1 || target.hujia >= 5) return;
|
||||||
}
|
return [1, 1];
|
||||||
},
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -971,7 +971,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target) {
|
target_use(card, player, target) {
|
||||||
let hs = player.getCards("h", i => i !== card && (!card.cards || !card.cards.includes(i))),
|
let hs = player.getCards("h", i => i !== card && (!card.cards || !card.cards.includes(i))),
|
||||||
num = player.getCardUsable("sha");
|
num = player.getCardUsable("sha");
|
||||||
if ((card.name !== "sha" && card.name !== "juedou") || hs.length < target.countCards("h")) return 1;
|
if ((card.name !== "sha" && card.name !== "juedou") || hs.length < target.countCards("h")) return 1;
|
||||||
|
@ -2382,7 +2382,7 @@ const skills = {
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (
|
if (
|
||||||
player == target &&
|
player == target &&
|
||||||
get.type(card) == "equip" &&
|
get.type(card) == "equip" &&
|
||||||
|
@ -3901,10 +3901,10 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (card.name == "sha" && get.color(card) == "red") return [1, 0.6];
|
if (card.name == "sha" && get.color(card) == "red") return [1, 0.6];
|
||||||
},
|
},
|
||||||
player(card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (card.name == "sha" && get.color(card) == "red") return [1, 1];
|
if (card.name == "sha" && get.color(card) == "red") return [1, 1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -1471,13 +1471,13 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
var hp = player.hp,
|
var hp = player.hp,
|
||||||
evt = _status.event;
|
evt = _status.event;
|
||||||
if (evt.name == "chooseToUse" && evt.player == player && evt.skill == "spjungong" && !ui.selected.cards.length) hp -= (player.getStat("skill").spjungong || 0) + 1;
|
if (evt.name == "chooseToUse" && evt.player == player && evt.skill == "spjungong" && !ui.selected.cards.length) hp -= (player.getStat("skill").spjungong || 0) + 1;
|
||||||
if (card && card.name == "sha" && hp == target.hp) return [1, 0.3];
|
if (card && card.name == "sha" && hp == target.hp) return [1, 0.3];
|
||||||
},
|
},
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (card && card.name == "sha" && player.hp == target.hp) return [1, 0.3];
|
if (card && card.name == "sha" && player.hp == target.hp) return [1, 0.3];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -1710,7 +1710,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (get.name(card) == "shan") {
|
if (get.name(card) == "shan") {
|
||||||
let num = get.number(card);
|
let num = get.number(card);
|
||||||
if (!num || num <= player.storage.shanxie_banned.num) return "zeroplayertarget";
|
if (!num || num <= player.storage.shanxie_banned.num) return "zeroplayertarget";
|
||||||
|
@ -2119,7 +2119,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (card.name == "sha" && player.hp > target.hp && get.attitude(player, target) < 0) {
|
if (card.name == "sha" && player.hp > target.hp && get.attitude(player, target) < 0) {
|
||||||
var num = get.number(card);
|
var num = get.number(card);
|
||||||
if (typeof num != "number") return false;
|
if (typeof num != "number") return false;
|
||||||
|
|
|
@ -2420,7 +2420,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (card.name == "tiesuo" && (!player.storage.counttrigger || !player.storage.counttrigger.hezhong_0)) return "zerotarget";
|
if (card.name == "tiesuo" && (!player.storage.counttrigger || !player.storage.counttrigger.hezhong_0)) return "zerotarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -2457,7 +2457,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (card.name == "tiesuo" && (!player.storage.counttrigger || !player.storage.counttrigger.hezhong_1)) return "zerotarget";
|
if (card.name == "tiesuo" && (!player.storage.counttrigger || !player.storage.counttrigger.hezhong_1)) return "zerotarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -4320,7 +4320,7 @@ const skills = {
|
||||||
diamond_ai: {
|
diamond_ai: {
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (get.name(card) == "sha" && !player.hasSkill("oltianhou_diamond") && target != player.getNext() && target != player.getPrevious()) {
|
if (get.name(card) == "sha" && !player.hasSkill("oltianhou_diamond") && target != player.getNext() && target != player.getPrevious()) {
|
||||||
let num = get.number(card),
|
let num = get.number(card),
|
||||||
max = _status.aiyh_MAXNUM || 13;
|
max = _status.aiyh_MAXNUM || 13;
|
||||||
|
@ -5067,7 +5067,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
threaten: 3,
|
threaten: 3,
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (
|
if (
|
||||||
typeof card == "object" &&
|
typeof card == "object" &&
|
||||||
card.cards &&
|
card.cards &&
|
||||||
|
@ -6242,6 +6242,9 @@ const skills = {
|
||||||
"step 1";
|
"step 1";
|
||||||
trigger.phaseList.splice(trigger.num, 0, "phaseUse|oldianjun");
|
trigger.phaseList.splice(trigger.num, 0, "phaseUse|oldianjun");
|
||||||
},
|
},
|
||||||
|
ai: {
|
||||||
|
halfneg: true
|
||||||
|
},
|
||||||
},
|
},
|
||||||
olkangrui: {
|
olkangrui: {
|
||||||
audio: 2,
|
audio: 2,
|
||||||
|
@ -6584,7 +6587,7 @@ const skills = {
|
||||||
order: 1,
|
order: 1,
|
||||||
threaten: 1.1,
|
threaten: 1.1,
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (_status._olkenshang_aiChecking || ui.selected.targets.length) return;
|
if (_status._olkenshang_aiChecking || ui.selected.targets.length) return;
|
||||||
if (typeof card != "object" || !card.storage || !card.storage.olkenshang) return false;
|
if (typeof card != "object" || !card.storage || !card.storage.olkenshang) return false;
|
||||||
_status._olkenshang_aiChecking = true;
|
_status._olkenshang_aiChecking = true;
|
||||||
|
@ -6792,7 +6795,7 @@ const skills = {
|
||||||
threaten: 0.8,
|
threaten: 0.8,
|
||||||
halfneg: true,
|
halfneg: true,
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if ((!card.isCard || !card.cards) && get.itemtype(card) != "card") return;
|
if ((!card.isCard || !card.cards) && get.itemtype(card) != "card") return;
|
||||||
let cs = 0;
|
let cs = 0;
|
||||||
if (
|
if (
|
||||||
|
@ -10743,7 +10746,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (card.name != "sha") return;
|
if (card.name != "sha") return;
|
||||||
if (
|
if (
|
||||||
target.hasSkillTag("unequip2") ||
|
target.hasSkillTag("unequip2") ||
|
||||||
|
@ -10868,7 +10871,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, effect) {
|
target_use(card, player, target, effect) {
|
||||||
if (
|
if (
|
||||||
effect > 0 ||
|
effect > 0 ||
|
||||||
player.hasSkillTag("unequip", false, {
|
player.hasSkillTag("unequip", false, {
|
||||||
|
@ -12039,7 +12042,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (!target || player._saodi_judging || ui.selected.targets.length || player == target || target.hasSkill("nodis")) return;
|
if (!target || player._saodi_judging || ui.selected.targets.length || player == target || target.hasSkill("nodis")) return;
|
||||||
if (typeof card != "object" || (card.name != "sha" && get.type(card) != "trick")) return false;
|
if (typeof card != "object" || (card.name != "sha" && get.type(card) != "trick")) return false;
|
||||||
player._saodi_judging = true;
|
player._saodi_judging = true;
|
||||||
|
@ -16189,17 +16192,6 @@ const skills = {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
group: "neifa_use",
|
group: "neifa_use",
|
||||||
ai: {
|
|
||||||
reverseOrder: true,
|
|
||||||
skillTagFilter: function (player) {
|
|
||||||
if (player.storage.counttrigger && player.storage.counttrigger.neifa_use >= 2) return false;
|
|
||||||
},
|
|
||||||
effect: {
|
|
||||||
target: function (card, player, target) {
|
|
||||||
if ((!player.storage.counttrigger || !player.storage.counttrigger.neifa_use || player.storage.counttrigger.neifa_use < 2) && player == target && get.type(card) == "equip") return [1, 3];
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
neifa_use: {
|
neifa_use: {
|
||||||
audio: "neifa",
|
audio: "neifa",
|
||||||
|
@ -16212,6 +16204,17 @@ const skills = {
|
||||||
content: function () {
|
content: function () {
|
||||||
player.draw(player.countMark("neifa_nobasic"));
|
player.draw(player.countMark("neifa_nobasic"));
|
||||||
},
|
},
|
||||||
|
ai: {
|
||||||
|
reverseOrder: true,
|
||||||
|
skillTagFilter(player) {
|
||||||
|
if (player.storage.counttrigger && player.storage.counttrigger.neifa_use >= 2) return false;
|
||||||
|
},
|
||||||
|
effect: {
|
||||||
|
player_use(card, player, target) {
|
||||||
|
if (player.countSkill("neifa_use") < 2 && get.type(card) == "equip") return [1, player.countMark("neifa_nobasic")];
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
//许靖
|
//许靖
|
||||||
yuxu: {
|
yuxu: {
|
||||||
|
@ -16683,7 +16686,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
threaten: 1.8,
|
threaten: 1.8,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
let used = target.getHistory("useCard").length + target.getHistory("respond").length;
|
let used = target.getHistory("useCard").length + target.getHistory("respond").length;
|
||||||
if (get.subtype(card) == "equip1" && !get.cardtag(card, "gifts")) {
|
if (get.subtype(card) == "equip1" && !get.cardtag(card, "gifts")) {
|
||||||
if (player != target || !player.isPhaseUsing()) return;
|
if (player != target || !player.isPhaseUsing()) return;
|
||||||
|
@ -20365,6 +20368,9 @@ const skills = {
|
||||||
charlotte: true,
|
charlotte: true,
|
||||||
},
|
},
|
||||||
weidi: {
|
weidi: {
|
||||||
|
available(mode) {
|
||||||
|
return mode == "identity" || mode == "versus" && _status.mode == "four";
|
||||||
|
},
|
||||||
init(player) {
|
init(player) {
|
||||||
const list = [];
|
const list = [];
|
||||||
const zhu = get.zhu(player);
|
const zhu = get.zhu(player);
|
||||||
|
@ -23888,7 +23894,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card) {
|
target_use(card) {
|
||||||
if (get.type(card) != "trick") return;
|
if (get.type(card) != "trick") return;
|
||||||
if (card.name == "tiesuo") return [0, 0];
|
if (card.name == "tiesuo") return [0, 0];
|
||||||
if (card.name == "yihuajiemu") return [0, 1];
|
if (card.name == "yihuajiemu") return [0, 1];
|
||||||
|
@ -24049,7 +24055,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (get.color(card) == "black" && target.countCards("h") > 0) {
|
if (get.color(card) == "black" && target.countCards("h") > 0) {
|
||||||
return [1, 0.5];
|
return [1, 0.5];
|
||||||
}
|
}
|
||||||
|
@ -26667,7 +26673,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (card.name == "sha") return [1, 0.5];
|
if (card.name == "sha") return [1, 0.5];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -889,7 +889,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
var targets = game.filterPlayer(targetx => targetx != player && targetx.getStorage("starcanxi_xiangsi").includes(player.group));
|
var targets = game.filterPlayer(targetx => targetx != player && targetx.getStorage("starcanxi_xiangsi").includes(player.group));
|
||||||
if (!targets.length) return;
|
if (!targets.length) return;
|
||||||
if (get.tag(card, "recover") && target == player && target.hp > 2) return 0;
|
if (get.tag(card, "recover") && target == player && target.hp > 2) return 0;
|
||||||
|
@ -2249,7 +2249,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (_status.event.name == "chooseToUse" && get.name(card) == "sha" && (!player.storage.counttrigger || !player.storage.counttrigger.dctingxian) && !_status._dctingxian_aiChecking) {
|
if (_status.event.name == "chooseToUse" && get.name(card) == "sha" && (!player.storage.counttrigger || !player.storage.counttrigger.dctingxian) && !_status._dctingxian_aiChecking) {
|
||||||
_status._dctingxian_aiChecking = true;
|
_status._dctingxian_aiChecking = true;
|
||||||
var eff = get.effect(target, { name: "sha" }, player, player);
|
var eff = get.effect(target, { name: "sha" }, player, player);
|
||||||
|
@ -11789,7 +11789,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
var evt = player.getLastUsed();
|
var evt = player.getLastUsed();
|
||||||
if (evt && evt.targets.includes(target) && (!player.storage.counttrigger || !player.storage.counttrigger.xinfu_lianpian || !player.storage.counttrigger.xinfu_lianpian < 3) && player.isPhaseUsing(player)) return [1.5, 0];
|
if (evt && evt.targets.includes(target) && (!player.storage.counttrigger || !player.storage.counttrigger.xinfu_lianpian || !player.storage.counttrigger.xinfu_lianpian < 3) && player.isPhaseUsing(player)) return [1.5, 0];
|
||||||
},
|
},
|
||||||
|
|
|
@ -1651,7 +1651,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target(card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (target.countCards("he") == 0) return;
|
if (target.countCards("he") == 0) return;
|
||||||
if (card.name != "sha") return;
|
if (card.name != "sha") return;
|
||||||
let min = 1;
|
let min = 1;
|
||||||
|
|
|
@ -1259,7 +1259,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (
|
if (
|
||||||
target == player &&
|
target == player &&
|
||||||
lib.skill.gaizao.filterx(card, target) &&
|
lib.skill.gaizao.filterx(card, target) &&
|
||||||
|
@ -1869,7 +1869,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (get.tag(card, "respondShan")) {
|
if (get.tag(card, "respondShan")) {
|
||||||
var shans = target.countCards("h", "shan");
|
var shans = target.countCards("h", "shan");
|
||||||
var hs = target.countCards("h");
|
var hs = target.countCards("h");
|
||||||
|
@ -1920,7 +1920,7 @@ game.import("character", function () {
|
||||||
mingzhi: false,
|
mingzhi: false,
|
||||||
useShan: true,
|
useShan: true,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (get.tag(card, "respondShan")) {
|
if (get.tag(card, "respondShan")) {
|
||||||
var shans = target.countCards("h", "shan");
|
var shans = target.countCards("h", "shan");
|
||||||
var hs = target.countCards("h");
|
var hs = target.countCards("h");
|
||||||
|
@ -2970,7 +2970,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card) {
|
target_use(card) {
|
||||||
if (card.name == "sha") return 1.3;
|
if (card.name == "sha") return 1.3;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -3307,7 +3307,7 @@ game.import("character", function () {
|
||||||
ai: {
|
ai: {
|
||||||
mingzhi: false,
|
mingzhi: false,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (player == _status.currentPhase) return;
|
if (player == _status.currentPhase) return;
|
||||||
if (
|
if (
|
||||||
!game.hasPlayer(function (current) {
|
!game.hasPlayer(function (current) {
|
||||||
|
@ -3834,22 +3834,24 @@ game.import("character", function () {
|
||||||
ai: {
|
ai: {
|
||||||
maixie: true,
|
maixie: true,
|
||||||
maixie_hp: true,
|
maixie_hp: true,
|
||||||
effect: function (card, player, target) {
|
effect: {
|
||||||
if (get.tag(card, "damage")) {
|
target(card, player, target) {
|
||||||
if (player.hasSkillTag("jueqing", false, target)) return [1, -0.5];
|
if (get.tag(card, "damage")) {
|
||||||
if (!target.hasFriend()) {
|
if (player.hasSkillTag("jueqing", false, target)) return [1, -0.5];
|
||||||
if (get.mode() == "guozhan") {
|
if (!target.hasFriend()) {
|
||||||
if (!player.hasFriend()) return;
|
if (get.mode() == "guozhan") {
|
||||||
} else {
|
if (!player.hasFriend()) return;
|
||||||
return;
|
} else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
if (target.countCards("h") > 2 || target.countCards("e", { color: "black" })) {
|
||||||
|
return [1, 0, 0, -1];
|
||||||
|
}
|
||||||
|
return [1, -0.5];
|
||||||
}
|
}
|
||||||
if (target.countCards("h") > 2 || target.countCards("e", { color: "black" })) {
|
},
|
||||||
return [1, 0, 0, -1];
|
}
|
||||||
}
|
|
||||||
return [1, -0.5];
|
|
||||||
}
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
xuanyuan: {
|
xuanyuan: {
|
||||||
|
@ -4482,7 +4484,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (player != target) return;
|
if (player != target) return;
|
||||||
if (get.type(card) == "equip" && !player.needsToDiscard()) {
|
if (get.type(card) == "equip" && !player.needsToDiscard()) {
|
||||||
return [0, 0, 0, 0];
|
return [0, 0, 0, 0];
|
||||||
|
@ -8404,7 +8406,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (
|
if (
|
||||||
get.color(card) == "black" &&
|
get.color(card) == "black" &&
|
||||||
get.attitude(target, player) < 0 &&
|
get.attitude(target, player) < 0 &&
|
||||||
|
@ -8674,7 +8676,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
return 0.7;
|
return 0.7;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -8888,7 +8888,7 @@ const skills = {
|
||||||
charlotte: true,
|
charlotte: true,
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (
|
if (
|
||||||
card.cards &&
|
card.cards &&
|
||||||
card.cards.some(i => i.hasGaintag("twkujianx")) &&
|
card.cards.some(i => i.hasGaintag("twkujianx")) &&
|
||||||
|
@ -9519,7 +9519,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (card.name == "sha" && player.hp > target.hp && get.attitude(player, target) < 0) {
|
if (card.name == "sha" && player.hp > target.hp && get.attitude(player, target) < 0) {
|
||||||
var num = get.number(card);
|
var num = get.number(card);
|
||||||
var bs = player.getCards("h", function (cardx) {
|
var bs = player.getCards("h", function (cardx) {
|
||||||
|
@ -13976,7 +13976,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current, isLink) {
|
target_use(card, player, target, current, isLink) {
|
||||||
if (card.name == "sha" && !isLink) return 0.8;
|
if (card.name == "sha" && !isLink) return 0.8;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -14317,7 +14317,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (get.type(card) !== "delay" && get.type(card) !== "equip") return 1;
|
if (get.type(card) !== "delay" && get.type(card) !== "equip") return 1;
|
||||||
let za = game.findPlayer(cur => cur.hasSkill("twzhian") && (!cur.storage.counttrigger || !cur.storage.counttrigger.twzhian) && get.attitude(player, cur) <= 0);
|
let za = game.findPlayer(cur => cur.hasSkill("twzhian") && (!cur.storage.counttrigger || !cur.storage.counttrigger.twzhian) && get.attitude(player, cur) <= 0);
|
||||||
if (za) return [0.5, -0.8];
|
if (za) return [0.5, -0.8];
|
||||||
|
|
|
@ -1156,7 +1156,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player(card, player, target, current) {
|
player_use(card, player, target, current) {
|
||||||
if (get.type(card) == "trick" && player.getStorage("dcjujian_forbid").includes(target)) return "zeroplayertarget";
|
if (get.type(card) == "trick" && player.getStorage("dcjujian_forbid").includes(target)) return "zeroplayertarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -5680,7 +5680,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: (card, player, target) => {
|
player_use(card, player, target) {
|
||||||
if (get.itemtype(card) === "card" && cardx.hasGaintag("dczhaowen_tag") && get.color(card, player) === "red") return [1, 1];
|
if (get.itemtype(card) === "card" && cardx.hasGaintag("dczhaowen_tag") && get.color(card, player) === "red") return [1, 1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -5747,7 +5747,7 @@ const skills = {
|
||||||
if (name != "phase") return false;
|
if (name != "phase") return false;
|
||||||
},
|
},
|
||||||
effect: {
|
effect: {
|
||||||
target: (card, player, target) => {
|
target_use(card, player, target) {
|
||||||
if (player === target || typeof card !== "object" || get.color(card) !== "black") return;
|
if (player === target || typeof card !== "object" || get.color(card) !== "black") return;
|
||||||
if (target.hasSkill("jiu")) {
|
if (target.hasSkill("jiu")) {
|
||||||
if (
|
if (
|
||||||
|
@ -7066,7 +7066,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
var evt = player.getLastUsed();
|
var evt = player.getLastUsed();
|
||||||
if (evt && evt.targets.includes(target)) return [1.5, 0];
|
if (evt && evt.targets.includes(target)) return [1.5, 0];
|
||||||
},
|
},
|
||||||
|
@ -8640,7 +8640,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (get.tag(card, "recover") && target.hp > 0) return 0;
|
if (get.tag(card, "recover") && target.hp > 0) return 0;
|
||||||
if (get.tag(card, "damage")) return 0.5;
|
if (get.tag(card, "damage")) return 0.5;
|
||||||
},
|
},
|
||||||
|
@ -8916,7 +8916,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: (card, player, target) => {
|
target_use(card, player, target) {
|
||||||
if (player === target) return;
|
if (player === target) return;
|
||||||
if (
|
if (
|
||||||
game.hasPlayer2(current => {
|
game.hasPlayer2(current => {
|
||||||
|
@ -9461,7 +9461,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (typeof card != "object") return;
|
if (typeof card != "object") return;
|
||||||
var storage = player.getStorage("olddcxiangmian_countdown");
|
var storage = player.getStorage("olddcxiangmian_countdown");
|
||||||
for (var i = 0; i < storage.length / 3; i++) {
|
for (var i = 0; i < storage.length / 3; i++) {
|
||||||
|
@ -9563,7 +9563,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (typeof card != "object") return;
|
if (typeof card != "object") return;
|
||||||
var storage = player.getStorage("dcxiangmian_countdown");
|
var storage = player.getStorage("dcxiangmian_countdown");
|
||||||
for (var i = 0; i < storage.length / 3; i++) {
|
for (var i = 0; i < storage.length / 3; i++) {
|
||||||
|
@ -13143,7 +13143,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (
|
if (
|
||||||
target &&
|
target &&
|
||||||
target.getExpansions("xinzhoufu2").length > 0 &&
|
target.getExpansions("xinzhoufu2").length > 0 &&
|
||||||
|
@ -13998,7 +13998,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (
|
if (
|
||||||
typeof card == "object" &&
|
typeof card == "object" &&
|
||||||
player == _status.currentPhase &&
|
player == _status.currentPhase &&
|
||||||
|
@ -14995,7 +14995,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (get.itemtype(player) !== "player" || player === target) return 1;
|
if (get.itemtype(player) !== "player" || player === target) return 1;
|
||||||
let num = 1,
|
let num = 1,
|
||||||
ds = 2 + get.sgn(player.hp - target.hp);
|
ds = 2 + get.sgn(player.hp - target.hp);
|
||||||
|
|
|
@ -287,7 +287,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player) {
|
player_use(card, player) {
|
||||||
if (_status.currentPhase != player) return;
|
if (_status.currentPhase != player) return;
|
||||||
if (get.type(card) == "basic") return;
|
if (get.type(card) == "basic") return;
|
||||||
if (get.tag(card, "gain")) return;
|
if (get.tag(card, "gain")) return;
|
||||||
|
@ -1029,7 +1029,7 @@ game.import("character", function () {
|
||||||
reverseEquip: true,
|
reverseEquip: true,
|
||||||
threaten: 1.5,
|
threaten: 1.5,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (get.type(card) == "equip") return [1, 3];
|
if (get.type(card) == "equip") return [1, 3];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -4157,7 +4157,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (
|
if (
|
||||||
target.storage.xjzhimeng2 &&
|
target.storage.xjzhimeng2 &&
|
||||||
get.type(card, "trick") == get.type(target.storage.xjzhimeng2, "trick")
|
get.type(card, "trick") == get.type(target.storage.xjzhimeng2, "trick")
|
||||||
|
@ -4268,7 +4268,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (target == player.next || target == player.previous) return 0.1;
|
if (target == player.next || target == player.previous) return 0.1;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -930,7 +930,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (typeof card != "object" || !player.isPhaseUsing()) return;
|
if (typeof card != "object" || !player.isPhaseUsing()) return;
|
||||||
var hasPanjun = game.hasPlayer(function (current) {
|
var hasPanjun = game.hasPlayer(function (current) {
|
||||||
return (
|
return (
|
||||||
|
@ -1581,7 +1581,7 @@ const skills = {
|
||||||
pretao: true,
|
pretao: true,
|
||||||
threaten: 1.8,
|
threaten: 1.8,
|
||||||
effect: {
|
effect: {
|
||||||
player(card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (
|
if (
|
||||||
typeof card === "object" &&
|
typeof card === "object" &&
|
||||||
card.name !== "shan" &&
|
card.name !== "shan" &&
|
||||||
|
|
|
@ -1609,7 +1609,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (target.isHealthy() || (card.name != "sha" && card.name != "juedou")) return;
|
if (target.isHealthy() || (card.name != "sha" && card.name != "juedou")) return;
|
||||||
if (target.storage.counttrigger && target.storage.counttrigger.yizu && current < 0) return 5;
|
if (target.storage.counttrigger && target.storage.counttrigger.yizu && current < 0) return 5;
|
||||||
if (player.hp < target.hp) return;
|
if (player.hp < target.hp) return;
|
||||||
|
@ -2495,7 +2495,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
threaten: 0.6,
|
threaten: 0.6,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (typeof card != "object" || target.hasSkill("xindanshou_as") || !["basic", "trick"].includes(get.type(card, "trick"))) return;
|
if (typeof card != "object" || target.hasSkill("xindanshou_as") || !["basic", "trick"].includes(get.type(card, "trick"))) return;
|
||||||
var num = 0;
|
var num = 0;
|
||||||
game.countPlayer2(function (current) {
|
game.countPlayer2(function (current) {
|
||||||
|
@ -4153,7 +4153,7 @@ const skills = {
|
||||||
return bool;
|
return bool;
|
||||||
},
|
},
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (card.name == "sha" && current < 0) return 0.7;
|
if (card.name == "sha" && current < 0) return 0.7;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -4857,7 +4857,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (card.name == "sha" && get.attitude(player, target) < 0) {
|
if (card.name == "sha" && get.attitude(player, target) < 0) {
|
||||||
return 0.3;
|
return 0.3;
|
||||||
}
|
}
|
||||||
|
@ -7307,7 +7307,7 @@ const skills = {
|
||||||
if (arg.target != player.storage.xinxianzhen) return false;
|
if (arg.target != player.storage.xinxianzhen) return false;
|
||||||
},
|
},
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target, current, isLink) {
|
player_use(card, player, target, current, isLink) {
|
||||||
if (isLink || !player.storage.xinxianzhen) return;
|
if (isLink || !player.storage.xinxianzhen) return;
|
||||||
if (target != player.storage.xinxianzhen && ["sha", "guohe", "shunshou", "huogong", "juedou"].includes(card.name)) {
|
if (target != player.storage.xinxianzhen && ["sha", "guohe", "shunshou", "huogong", "juedou"].includes(card.name)) {
|
||||||
if (get.effect(player.storage.xinxianzhen, card, player, player) > 0) {
|
if (get.effect(player.storage.xinxianzhen, card, player, player) > 0) {
|
||||||
|
@ -8350,7 +8350,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
respondShan: true,
|
respondShan: true,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (get.tag(card, "respondShan") && current < 0) {
|
if (get.tag(card, "respondShan") && current < 0) {
|
||||||
var nh = player.countCards("h");
|
var nh = player.countCards("h");
|
||||||
var players = game.filterPlayer();
|
var players = game.filterPlayer();
|
||||||
|
@ -9547,7 +9547,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player_use: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
var list = player.storage.taoxi_list;
|
var list = player.storage.taoxi_list;
|
||||||
if (!list || !list[1]) return;
|
if (!list || !list[1]) return;
|
||||||
if (list[1].includes(card)) return [1, 1];
|
if (list[1].includes(card)) return [1, 1];
|
||||||
|
@ -11102,9 +11102,11 @@ const skills = {
|
||||||
player.draw();
|
player.draw();
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: function (card, player, target) {
|
effect: {
|
||||||
if (get.type(card) == "trick") return [1, 1];
|
target_use(card, player, target) {
|
||||||
},
|
if (get.type(card) == "trick" && player !== target) return [1, 1];
|
||||||
|
},
|
||||||
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
shenxing: {
|
shenxing: {
|
||||||
|
@ -12067,7 +12069,7 @@ const skills = {
|
||||||
ai: {
|
ai: {
|
||||||
expose: 0.2,
|
expose: 0.2,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (card.name != "sha") return;
|
if (card.name != "sha") return;
|
||||||
var players = game.filterPlayer();
|
var players = game.filterPlayer();
|
||||||
if (get.attitude(player, target) <= 0) {
|
if (get.attitude(player, target) <= 0) {
|
||||||
|
@ -12785,7 +12787,7 @@ const skills = {
|
||||||
return arg && arg.jiu == true;
|
return arg && arg.jiu == true;
|
||||||
},
|
},
|
||||||
effect: {
|
effect: {
|
||||||
target: (card, player, target) => {
|
target_use(card, player, target) {
|
||||||
if (target.hp <= 0 && target.hasSkill("zhenlie_lose") && get.tag(card, "recover")) return [1, 1.2];
|
if (target.hp <= 0 && target.hasSkill("zhenlie_lose") && get.tag(card, "recover")) return [1, 1.2];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -12810,10 +12812,10 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (get.type(card) == "trick" && player != target) return "zeroplayertarget";
|
if (get.type(card) == "trick" && player != target) return "zeroplayertarget";
|
||||||
},
|
},
|
||||||
player: function (card, player, target, current) {
|
player_use(card, player, target, current) {
|
||||||
if (get.type(card) == "trick" && player != target) return "zeroplayertarget";
|
if (get.type(card) == "trick" && player != target) return "zeroplayertarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -12987,7 +12989,7 @@ const skills = {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
target_use(card, player, target) {
|
||||||
if (player == target && get.subtypes(card).includes("equip2")) {
|
if (player == target && get.subtypes(card).includes("equip2")) {
|
||||||
if (get.equipValue(card) <= 8) return 0;
|
if (get.equipValue(card) <= 8) return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,10 +101,16 @@ const skills = {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player: function (card, player, target) {
|
||||||
if (!get.tag(card, "damage")) return;
|
if (!get.tag(card, "damage")) return;
|
||||||
if (!lib.card[card.name] || !card.cards || !card.cards.length) return [1, 0, 1, -1];
|
if (!lib.card[card.name] || !card.cards || !card.cards.length) return [1, 0, 2, 0];
|
||||||
|
return [1, -1];
|
||||||
|
},
|
||||||
|
target: function (card, player, target) {
|
||||||
|
if (!get.tag(card, "damage")) return;
|
||||||
|
if (!lib.card[card.name] || !card.cards || !card.cards.length) return 2;
|
||||||
return [1, -1];
|
return [1, -1];
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
halfneg: true
|
||||||
},
|
},
|
||||||
subSkill: {
|
subSkill: {
|
||||||
effect: {
|
effect: {
|
||||||
|
@ -591,7 +597,7 @@ const skills = {
|
||||||
onremove: true,
|
onremove: true,
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
player: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (card.name == player.storage.xiongshu_ai) return "zeroplayertarget";
|
if (card.name == player.storage.xiongshu_ai) return "zeroplayertarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -1460,7 +1460,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (get.type(card) == "trick" || card.name == "sha") return "zeroplayertarget";
|
if (get.type(card) == "trick" || card.name == "sha") return "zeroplayertarget";
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -1781,7 +1781,7 @@ game.import("character", function () {
|
||||||
ai: {
|
ai: {
|
||||||
mingzhi: false,
|
mingzhi: false,
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target) {
|
player_use(card, player, target) {
|
||||||
if (get.tag(card, "respondShan")) {
|
if (get.tag(card, "respondShan")) {
|
||||||
return 0.8;
|
return 0.8;
|
||||||
}
|
}
|
||||||
|
|
|
@ -123,7 +123,7 @@ game.import("character", function () {
|
||||||
},
|
},
|
||||||
ai: {
|
ai: {
|
||||||
effect: {
|
effect: {
|
||||||
target: function (card, player, target, current) {
|
target_use(card, player, target, current) {
|
||||||
if (target.getEquip(2)) return;
|
if (target.getEquip(2)) return;
|
||||||
return lib.skill.tengjia1.ai.effect.target.apply(this, arguments);
|
return lib.skill.tengjia1.ai.effect.target.apply(this, arguments);
|
||||||
},
|
},
|
||||||
|
|
|
@ -4587,20 +4587,10 @@ export class Get {
|
||||||
game.expandSkills(skills2);
|
game.expandSkills(skills2);
|
||||||
for (var i = 0; i < skills2.length; i++) {
|
for (var i = 0; i < skills2.length; i++) {
|
||||||
temp2 = get.info(skills2[i]).ai;
|
temp2 = get.info(skills2[i]).ai;
|
||||||
if (temp2 && temp2.threaten) temp3 = cache.delegate(temp2).threaten;
|
if (!temp2) continue;
|
||||||
|
if (temp2.threaten) temp3 = cache.delegate(temp2).threaten;
|
||||||
else temp3 = undefined;
|
else temp3 = undefined;
|
||||||
if (temp2 && typeof temp2.effect == "function") {
|
if (typeof temp2.effect == "object" && typeof temp2.effect.target == "function") {
|
||||||
if (
|
|
||||||
!player.hasSkillTag("ignoreSkill", true, {
|
|
||||||
card: card,
|
|
||||||
target: target,
|
|
||||||
skill: skills2[i],
|
|
||||||
isLink: isLink,
|
|
||||||
})
|
|
||||||
)
|
|
||||||
temp2 = cache.delegate(temp2).effect(card, player, target, result2, isLink);
|
|
||||||
else temp2 = undefined;
|
|
||||||
} else if (temp2 && typeof temp2.effect == "object" && typeof temp2.effect.target == "function") {
|
|
||||||
if (
|
if (
|
||||||
!player.hasSkillTag("ignoreSkill", true, {
|
!player.hasSkillTag("ignoreSkill", true, {
|
||||||
card: card,
|
card: card,
|
||||||
|
@ -4611,6 +4601,18 @@ export class Get {
|
||||||
)
|
)
|
||||||
temp2 = cache.delegate(temp2.effect).target(card, player, target, result2, isLink);
|
temp2 = cache.delegate(temp2.effect).target(card, player, target, result2, isLink);
|
||||||
else temp2 = undefined;
|
else temp2 = undefined;
|
||||||
|
} else if (typeof temp2.effect == "function") { //考虑废弃
|
||||||
|
console.log("此写法使用频率极低且影响代码可读性,不建议使用");
|
||||||
|
if (
|
||||||
|
!player.hasSkillTag("ignoreSkill", true, {
|
||||||
|
card: card,
|
||||||
|
target: target,
|
||||||
|
skill: skills2[i],
|
||||||
|
isLink: isLink,
|
||||||
|
})
|
||||||
|
)
|
||||||
|
temp2 = cache.delegate(temp2).effect(card, player, target, result2, isLink);
|
||||||
|
else temp2 = undefined;
|
||||||
} else temp2 = undefined;
|
} else temp2 = undefined;
|
||||||
if (typeof temp2 == "object") {
|
if (typeof temp2 == "object") {
|
||||||
if (temp2.length == 2 || temp2.length == 4) {
|
if (temp2.length == 2 || temp2.length == 4) {
|
||||||
|
|
Loading…
Reference in New Issue