From 52ba62bbef93810f7f0de22efd644622efd599ad Mon Sep 17 00:00:00 2001 From: zhangyuheng Date: Mon, 21 Oct 2024 10:01:40 +0800 Subject: [PATCH] fix wrong PlayerCrossDominionBorderEvent called --- core/src/main/java/cn/lunadeer/dominion/Cache.java | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/core/src/main/java/cn/lunadeer/dominion/Cache.java b/core/src/main/java/cn/lunadeer/dominion/Cache.java index 3f78ae76..1c15bd3d 100644 --- a/core/src/main/java/cn/lunadeer/dominion/Cache.java +++ b/core/src/main/java/cn/lunadeer/dominion/Cache.java @@ -233,13 +233,15 @@ public DominionDTO getPlayerCurrentDominion(@NotNull Player player) { } // 否则获取玩家当前所在领地,然后对比上次记录的领地 DominionDTO current_dominion = dominion_trees.getLocInDominionDTO(player.getLocation()); - new PlayerCrossDominionBorderEvent(player, last_dominion, current_dominion).callEvent(); - int last_dom_id = last_dominion == null ? -1 : last_dominion.getId(); int current_dom_id = current_dominion == null ? -1 : current_dominion.getId(); if (last_dom_id == current_dom_id) { return last_dominion; } + + // 如果玩家上次所在领地和当前所在领地不同,则触发玩家跨领地边界事件 + new PlayerCrossDominionBorderEvent(player, last_dominion, current_dominion).callEvent(); + // 如果上次记录的领地不为空,则触发玩家离开领地事件 if (last_dom_id != -1) { new PlayerMoveOutDominionEvent(player, last_dominion).callEvent();