Improve Boss Blitz UI

This commit is contained in:
Melledy
2025-12-07 16:02:44 -08:00
parent c6ac09f112
commit be5a6709fd
5 changed files with 64 additions and 11 deletions

View File

@@ -27,7 +27,7 @@ public class ScoreBossManager extends PlayerManager {
return GameData.getScoreBossControlDataTable().get(this.getControlId());
}
public ScoreBossRankEntry getRanking() {
public ScoreBossRankEntry getRankEntry() {
if (this.ranking == null && !this.checkedDatabase) {
this.ranking = Nebula.getGameDatabase().getObjectByUid(ScoreBossRankEntry.class, this.getPlayerUid());
this.checkedDatabase = true;
@@ -57,7 +57,7 @@ public class ScoreBossManager extends PlayerManager {
return true;
}
public boolean settle(int stars, int score) {
public boolean settle(int stars, int score, int skillScore) {
// Get level
var control = getControlData();
if (control == null || !control.getLevelGroup().contains(this.getLevelId())) {
@@ -71,7 +71,7 @@ public class ScoreBossManager extends PlayerManager {
}
// Get ranking from database
this.getRanking();
this.getRankEntry();
// Create ranking if its not in the database
if (this.ranking == null) {
@@ -79,7 +79,7 @@ public class ScoreBossManager extends PlayerManager {
}
// Settle
this.ranking.settle(this.getPlayer(), build, getControlId(), getLevelId(), stars, score);
this.ranking.settle(this.getPlayer(), build, getControlId(), getLevelId(), stars, score, skillScore);
// Save ranking
this.ranking.save();

View File

@@ -33,6 +33,8 @@ public class ScoreBossRankEntry implements GameDatabaseObject {
private int titleSuffix;
private int[] honor;
private int score;
@SuppressWarnings("unused")
private int stars;
private int controlId;
private Map<Integer, ScoreBossTeamEntry> teams;
@@ -51,6 +53,17 @@ public class ScoreBossRankEntry implements GameDatabaseObject {
this.teams = new HashMap<>();
}
// TODO replace later
public int getStars() {
int stars = 0;
for (var team : this.getTeams().values()) {
stars += team.getStars();
}
return stars;
}
public void update(Player player) {
this.name = player.getName();
this.level = player.getLevel();
@@ -60,28 +73,38 @@ public class ScoreBossRankEntry implements GameDatabaseObject {
this.honor = player.getHonor();
}
public void settle(Player player, StarTowerBuild build, int controlId, int level, int stars, int score) {
public void settle(Player player, StarTowerBuild build, int controlId, int level, int stars, int score, int skillScore) {
// Update player data
this.update(player);
// Reset score entry if control id doesn't match
if (this.controlId != controlId) {
this.controlId = controlId;
this.getTeams().clear();
this.reset();
}
// Set team entry
var team = new ScoreBossTeamEntry(player, build, stars, score);
var team = new ScoreBossTeamEntry(player, build, stars, score, skillScore);
// Put in team map
this.getTeams().put(level, team);
// Calculate score
// Calculate score/stars
this.score = 0;
this.stars = 0;
for (var t : this.getTeams().values()) {
this.score += t.getLevelScore();
this.stars += t.getStars();
}
}
private void reset() {
this.score = 0;
this.stars = 0;
this.getTeams().clear();
}
// Proto
public ScoreBossRankData toProto() {
@@ -115,6 +138,7 @@ public class ScoreBossRankEntry implements GameDatabaseObject {
private int buildScore;
private int stars;
private int levelScore;
private int skillScore;
private List<ScoreBossCharEntry> characters;
@Deprecated // Morphia only
@@ -122,11 +146,12 @@ public class ScoreBossRankEntry implements GameDatabaseObject {
}
public ScoreBossTeamEntry(Player player, StarTowerBuild build, int stars, int score) {
public ScoreBossTeamEntry(Player player, StarTowerBuild build, int stars, int score, int skillScore) {
this.buildId = build.getUid();
this.buildScore = build.getScore();
this.stars = stars;
this.levelScore = score;
this.skillScore = skillScore;
this.characters = new ArrayList<>();
for (var charId : build.getCharIds()) {

View File

@@ -2,6 +2,7 @@ package emu.nebula.server.handlers;
import emu.nebula.net.NetHandler;
import emu.nebula.net.NetMsgId;
import emu.nebula.proto.Public.ScoreBossLevel;
import emu.nebula.proto.ScoreBossInfoOuterClass.ScoreBossInfo;
import emu.nebula.net.HandlerId;
import emu.nebula.net.GameSession;
@@ -15,6 +16,33 @@ public class HandlerScoreBossInfoReq extends NetHandler {
var rsp = ScoreBossInfo.newInstance()
.setControlId(session.getPlayer().getScoreBossManager().getControlId());
// Get rank entry
var rankEntry = session.getPlayer().getScoreBossManager().getRankEntry();
if (rankEntry != null) {
// Set total score
rsp.setScore(rankEntry.getScore());
rsp.setStar(rankEntry.getStars());
// Encode team data to proto
for (var teamEntry : rankEntry.getTeams().entrySet()) {
int id = teamEntry.getKey();
var team = teamEntry.getValue();
var info = ScoreBossLevel.newInstance()
.setBuildId(team.getBuildId())
.setLevelId(id)
.setScore(team.getLevelScore())
.setSkillScore(team.getSkillScore())
.setStar(team.getStars());
for (var charEntry : team.getCharacters()) {
info.addCharIds(charEntry.getId());
}
rsp.addLevels(info);
}
}
// Encode and send
return session.encodeMsg(NetMsgId.score_boss_info_succeed_ack, rsp);
}

View File

@@ -17,7 +17,7 @@ public class HandlerScoreBossRankReq extends NetHandler {
.setLastRefreshTime(Nebula.getCurrentTime());
// Get self
var self = session.getPlayer().getScoreBossManager().getRanking();
var self = session.getPlayer().getScoreBossManager().getRankEntry();
if (self != null) {
rsp.setSelf(self.toProto());

View File

@@ -16,7 +16,7 @@ public class HandlerScoreBossSettleReq extends NetHandler {
var req = ScoreBossSettleReq.parseFrom(message);
// Settle
boolean success = session.getPlayer().getScoreBossManager().settle(req.getStar(), req.getScore());
boolean success = session.getPlayer().getScoreBossManager().settle(req.getStar(), req.getScore(), req.getSkillScore());
if (success == false) {
return session.encodeMsg(NetMsgId.score_boss_settle_failed_ack);