mirror of
https://github.com/Melledy/Nebula.git
synced 2025-12-13 12:54:36 +01:00
Implement disc limit break (crescendo)
This commit is contained in:
@@ -190,6 +190,34 @@ public class GameDisc implements GameDatabaseObject {
|
|||||||
return changes.setSuccess(true);
|
return changes.setSuccess(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public PlayerChangeInfo limitBreak(int count) {
|
||||||
|
// Sanity check
|
||||||
|
if (count <= 0) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create params with limit break items
|
||||||
|
var materials = new ItemParamMap();
|
||||||
|
materials.add(this.getData().getTransformItemId(), count);
|
||||||
|
|
||||||
|
// Verify that the player has the items
|
||||||
|
if (!this.getPlayer().getInventory().verifyItems(materials)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Remove items
|
||||||
|
var changes = this.getPlayer().getInventory().removeItems(materials, null);
|
||||||
|
|
||||||
|
// Add phase level
|
||||||
|
this.star = Math.max(this.star + count, 4);
|
||||||
|
|
||||||
|
// Save to database
|
||||||
|
this.save();
|
||||||
|
|
||||||
|
// Success
|
||||||
|
return changes.setSuccess(true);
|
||||||
|
}
|
||||||
|
|
||||||
// Proto
|
// Proto
|
||||||
|
|
||||||
public Disc toProto() {
|
public Disc toProto() {
|
||||||
|
|||||||
@@ -0,0 +1,40 @@
|
|||||||
|
package emu.nebula.server.handlers;
|
||||||
|
|
||||||
|
import emu.nebula.net.NetHandler;
|
||||||
|
import emu.nebula.net.NetMsgId;
|
||||||
|
import emu.nebula.proto.DiscLimitBreak.DiscLimitBreakReq;
|
||||||
|
import emu.nebula.proto.DiscLimitBreak.DiscLimitBreakResp;
|
||||||
|
import emu.nebula.net.HandlerId;
|
||||||
|
import emu.nebula.net.GameSession;
|
||||||
|
|
||||||
|
@HandlerId(NetMsgId.disc_limit_break_req)
|
||||||
|
public class HandlerDiscLimitBreakReq extends NetHandler {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public byte[] handle(GameSession session, byte[] message) throws Exception {
|
||||||
|
// Parse request
|
||||||
|
var req = DiscLimitBreakReq.parseFrom(message);
|
||||||
|
|
||||||
|
// Get character
|
||||||
|
var disc = session.getPlayer().getCharacters().getDiscById(req.getId());
|
||||||
|
|
||||||
|
if (disc == null) {
|
||||||
|
return this.encodeMsg(NetMsgId.disc_limit_break_failed_ack);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Limit break
|
||||||
|
var change = disc.limitBreak(req.getQty());
|
||||||
|
|
||||||
|
if (change == null) {
|
||||||
|
return this.encodeMsg(NetMsgId.disc_limit_break_failed_ack);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create response
|
||||||
|
var rsp = DiscLimitBreakResp.newInstance()
|
||||||
|
.setStar(disc.getStar())
|
||||||
|
.setChange(null);
|
||||||
|
|
||||||
|
return this.encodeMsg(NetMsgId.disc_limit_break_succeed_ack, rsp);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -23,7 +23,7 @@ public class HandlerDiscStrengthenReq extends NetHandler {
|
|||||||
return this.encodeMsg(NetMsgId.disc_strengthen_failed_ack);
|
return this.encodeMsg(NetMsgId.disc_strengthen_failed_ack);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Upgrade character
|
// Level up disc
|
||||||
var params = ItemParamMap.fromItemInfos(req.getItems());
|
var params = ItemParamMap.fromItemInfos(req.getItems());
|
||||||
var change = disc.upgrade(params);
|
var change = disc.upgrade(params);
|
||||||
|
|
||||||
@@ -33,9 +33,9 @@ public class HandlerDiscStrengthenReq extends NetHandler {
|
|||||||
|
|
||||||
// Create response
|
// Create response
|
||||||
var rsp = DiscStrengthenResp.newInstance()
|
var rsp = DiscStrengthenResp.newInstance()
|
||||||
.setChange(change.toProto())
|
|
||||||
.setLevel(disc.getLevel())
|
.setLevel(disc.getLevel())
|
||||||
.setExp(disc.getExp());
|
.setExp(disc.getExp())
|
||||||
|
.setChange(change.toProto());
|
||||||
|
|
||||||
return this.encodeMsg(NetMsgId.disc_strengthen_succeed_ack, rsp);
|
return this.encodeMsg(NetMsgId.disc_strengthen_succeed_ack, rsp);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user