mirror of
https://github.com/genxium/DelayNoMore
synced 2025-01-13 14:31:36 +00:00
Temp broken commit during frontend refactoring.
This commit is contained in:
parent
f97ce22cef
commit
3f4e49656a
@ -1191,11 +1191,11 @@ func (pR *Room) applyInputFrameDownsyncDynamics(fromRenderFrameId int32, toRende
|
|||||||
if nil == tmp {
|
if nil == tmp {
|
||||||
panic(fmt.Sprintf("delayedInputFrameId=%v doesn't exist for roomId=%v, this is abnormal because it's to be used for applying dynamics to [fromRenderFrameId:%v, toRenderFrameId:%v) @ collisionSysRenderFrameId=%v! InputsBuffer=%v", delayedInputFrameId, pR.Id, fromRenderFrameId, toRenderFrameId, collisionSysRenderFrameId, pR.InputsBufferString(false)))
|
panic(fmt.Sprintf("delayedInputFrameId=%v doesn't exist for roomId=%v, this is abnormal because it's to be used for applying dynamics to [fromRenderFrameId:%v, toRenderFrameId:%v) @ collisionSysRenderFrameId=%v! InputsBuffer=%v", delayedInputFrameId, pR.Id, fromRenderFrameId, toRenderFrameId, collisionSysRenderFrameId, pR.InputsBufferString(false)))
|
||||||
}
|
}
|
||||||
delayedInputFrame := tmp.(*InputFrameDownsync)
|
delayedInputFrame = tmp.(*InputFrameDownsync)
|
||||||
// [WARNING] It's possible that by now "allConfirmedMask != delayedInputFrame.ConfirmedList && delayedInputFrameId <= pR.LastAllConfirmedInputFrameId", we trust "pR.LastAllConfirmedInputFrameId" as the TOP AUTHORITY.
|
// [WARNING] It's possible that by now "allConfirmedMask != delayedInputFrame.ConfirmedList && delayedInputFrameId <= pR.LastAllConfirmedInputFrameId", we trust "pR.LastAllConfirmedInputFrameId" as the TOP AUTHORITY.
|
||||||
atomic.StoreUint64(&(delayedInputFrame.ConfirmedList), allConfirmedMask)
|
atomic.StoreUint64(&(delayedInputFrame.ConfirmedList), allConfirmedMask)
|
||||||
}
|
}
|
||||||
|
|
||||||
nextRenderFrame := pR.applyInputFrameDownsyncDynamicsOnSingleRenderFrame(delayedInputFrame, currRenderFrame, pR.CollisionSysMap)
|
nextRenderFrame := pR.applyInputFrameDownsyncDynamicsOnSingleRenderFrame(delayedInputFrame, currRenderFrame, pR.CollisionSysMap)
|
||||||
// Update in the latest player pointers
|
// Update in the latest player pointers
|
||||||
for playerId, playerDownsync := range nextRenderFrame.Players {
|
for playerId, playerDownsync := range nextRenderFrame.Players {
|
||||||
@ -1245,6 +1245,9 @@ func (pR *Room) applyInputFrameDownsyncDynamicsOnSingleRenderFrame(delayedInputF
|
|||||||
playerId := player.Id
|
playerId := player.Id
|
||||||
currPlayerDownsync := currRenderFrame.Players[playerId]
|
currPlayerDownsync := currRenderFrame.Players[playerId]
|
||||||
encodedInput := inputList[joinIndex-1]
|
encodedInput := inputList[joinIndex-1]
|
||||||
|
if 0 == encodedInput {
|
||||||
|
continue
|
||||||
|
}
|
||||||
decodedInput := DIRECTION_DECODER[encodedInput]
|
decodedInput := DIRECTION_DECODER[encodedInput]
|
||||||
newVx := (currPlayerDownsync.VirtualGridX + (decodedInput[0] + decodedInput[0]*currPlayerDownsync.Speed))
|
newVx := (currPlayerDownsync.VirtualGridX + (decodedInput[0] + decodedInput[0]*currPlayerDownsync.Speed))
|
||||||
newVy := (currPlayerDownsync.VirtualGridY + (decodedInput[1] + decodedInput[1]*currPlayerDownsync.Speed))
|
newVy := (currPlayerDownsync.VirtualGridY + (decodedInput[1] + decodedInput[1]*currPlayerDownsync.Speed))
|
||||||
@ -1288,6 +1291,8 @@ func (pR *Room) applyInputFrameDownsyncDynamicsOnSingleRenderFrame(delayedInputF
|
|||||||
nextRenderFramePlayers[playerId].VirtualGridX = newVx
|
nextRenderFramePlayers[playerId].VirtualGridX = newVx
|
||||||
nextRenderFramePlayers[playerId].VirtualGridY = newVy
|
nextRenderFramePlayers[playerId].VirtualGridY = newVy
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Logger.Debug(fmt.Sprintf("After applyInputFrameDownsyncDynamicsOnSingleRenderFrame: currRenderFrame.Id=%v, inputList=%v, currRenderFrame.Players=%v, nextRenderFramePlayers=%v, toRet.Players=%v", currRenderFrame.Id, inputList, currRenderFrame.Players, nextRenderFramePlayers, toRet.Players))
|
||||||
}
|
}
|
||||||
|
|
||||||
return toRet
|
return toRet
|
||||||
|
@ -440,7 +440,7 @@
|
|||||||
"array": [
|
"array": [
|
||||||
0,
|
0,
|
||||||
0,
|
0,
|
||||||
372.39092362730867,
|
344.6705889248102,
|
||||||
0,
|
0,
|
||||||
0,
|
0,
|
||||||
0,
|
0,
|
||||||
|
@ -382,7 +382,8 @@ cc.Class({
|
|||||||
window.clearBoundRoomIdInBothVolatileAndPersistentStorage();
|
window.clearBoundRoomIdInBothVolatileAndPersistentStorage();
|
||||||
window.initPersistentSessionClient(self.initAfterWSConnected, null /* Deliberately NOT passing in any `expectedRoomId`. -- YFLu */ );
|
window.initPersistentSessionClient(self.initAfterWSConnected, null /* Deliberately NOT passing in any `expectedRoomId`. -- YFLu */ );
|
||||||
};
|
};
|
||||||
resultPanelScriptIns.onCloseDelegate = () => {};
|
resultPanelScriptIns.onCloseDelegate = () => {
|
||||||
|
};
|
||||||
|
|
||||||
self.gameRuleNode = cc.instantiate(self.gameRulePrefab);
|
self.gameRuleNode = cc.instantiate(self.gameRulePrefab);
|
||||||
self.gameRuleNode.width = self.canvasNode.width;
|
self.gameRuleNode.width = self.canvasNode.width;
|
||||||
@ -585,7 +586,7 @@ cc.Class({
|
|||||||
if (window.MAGIC_ROOM_DOWNSYNC_FRAME_ID.BATTLE_START < rdf.id && window.RING_BUFF_CONSECUTIVE_SET == dumpRenderCacheRet) {
|
if (window.MAGIC_ROOM_DOWNSYNC_FRAME_ID.BATTLE_START < rdf.id && window.RING_BUFF_CONSECUTIVE_SET == dumpRenderCacheRet) {
|
||||||
/*
|
/*
|
||||||
Don't change
|
Don't change
|
||||||
- lastAllConfirmedRenderFrameId, it's updated only in "rollbackAndChase > _createOrUpdateRoomDownsyncFrameLocally" (except for when RING_BUFF_NON_CONSECUTIVE_SET)
|
- lastAllConfirmedRenderFrameId, it's updated only in "rollbackAndChase" (except for when RING_BUFF_NON_CONSECUTIVE_SET)
|
||||||
- chaserRenderFrameId, it's updated only in "onInputFrameDownsyncBatch" (except for when RING_BUFF_NON_CONSECUTIVE_SET)
|
- chaserRenderFrameId, it's updated only in "onInputFrameDownsyncBatch" (except for when RING_BUFF_NON_CONSECUTIVE_SET)
|
||||||
*/
|
*/
|
||||||
return dumpRenderCacheRet;
|
return dumpRenderCacheRet;
|
||||||
@ -945,62 +946,6 @@ cc.Class({
|
|||||||
}, 1500);
|
}, 1500);
|
||||||
},
|
},
|
||||||
|
|
||||||
_createOrUpdateRoomDownsyncFrameLocally(renderFrameId, collisionSys, collisionSysMap) {
|
|
||||||
const self = this;
|
|
||||||
const prevRenderFrameId = renderFrameId - 1;
|
|
||||||
const inputFrameAppliedOnPrevRenderFrame = (
|
|
||||||
0 > prevRenderFrameId
|
|
||||||
?
|
|
||||||
null
|
|
||||||
:
|
|
||||||
self.getCachedInputFrameDownsyncWithPrediction(self._convertToInputFrameId(prevRenderFrameId, self.inputDelayFrames))
|
|
||||||
);
|
|
||||||
|
|
||||||
// TODO: Find a better way to assign speeds instead of using "speedRefRenderFrameId".
|
|
||||||
const speedRefRenderFrameId = prevRenderFrameId;
|
|
||||||
const speedRefRenderFrame = (
|
|
||||||
0 > speedRefRenderFrameId
|
|
||||||
?
|
|
||||||
null
|
|
||||||
:
|
|
||||||
self.recentRenderCache.getByFrameId(speedRefRenderFrameId)
|
|
||||||
);
|
|
||||||
|
|
||||||
const rdf = {
|
|
||||||
id: renderFrameId,
|
|
||||||
refFrameId: renderFrameId,
|
|
||||||
players: {}
|
|
||||||
};
|
|
||||||
self.playerRichInfoDict.forEach((playerRichInfo, playerId) => {
|
|
||||||
const joinIndex = playerRichInfo.joinIndex;
|
|
||||||
const collisionPlayerIndex = self.collisionPlayerIndexPrefix + joinIndex;
|
|
||||||
const playerCollider = collisionSysMap.get(collisionPlayerIndex);
|
|
||||||
const vpos = self.playerColliderAnchorToVirtualGridPos(playerCollider.x, playerCollider.y, playerRichInfo);
|
|
||||||
rdf.players[playerRichInfo.id] = {
|
|
||||||
id: playerRichInfo.id,
|
|
||||||
virtualGridX: vpos[0],
|
|
||||||
virtualGridY: vpos[1],
|
|
||||||
dir: self.ctrl.decodeDirection(null == inputFrameAppliedOnPrevRenderFrame ? 0 : inputFrameAppliedOnPrevRenderFrame.inputList[joinIndex - 1]),
|
|
||||||
speed: (null == speedRefRenderFrame ? playerRichInfo.speed : speedRefRenderFrame.players[playerRichInfo.id].speed),
|
|
||||||
joinIndex: joinIndex
|
|
||||||
};
|
|
||||||
});
|
|
||||||
if (
|
|
||||||
null != inputFrameAppliedOnPrevRenderFrame && self._allConfirmed(inputFrameAppliedOnPrevRenderFrame.confirmedList)
|
|
||||||
&&
|
|
||||||
rdf.id > self.lastAllConfirmedRenderFrameId
|
|
||||||
) {
|
|
||||||
// We got a more up-to-date "all-confirmed-render-frame".
|
|
||||||
self.lastAllConfirmedRenderFrameId = rdf.id;
|
|
||||||
if (rdf.id > self.chaserRenderFrameId) {
|
|
||||||
// it must be true that "chaserRenderFrameId >= lastAllConfirmedRenderFrameId"
|
|
||||||
self.chaserRenderFrameId = rdf.id;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
self.dumpToRenderCache(rdf);
|
|
||||||
return rdf;
|
|
||||||
},
|
|
||||||
|
|
||||||
applyRoomDownsyncFrameDynamics(rdf) {
|
applyRoomDownsyncFrameDynamics(rdf) {
|
||||||
const self = this;
|
const self = this;
|
||||||
|
|
||||||
@ -1034,28 +979,34 @@ cc.Class({
|
|||||||
return inputFrameDownsync;
|
return inputFrameDownsync;
|
||||||
},
|
},
|
||||||
|
|
||||||
rollbackAndChase(renderFrameIdSt, renderFrameIdEd, collisionSys, collisionSysMap) {
|
// TODO: Write unit-test for this function to compare with its backend counter part
|
||||||
const self = this;
|
applyInputFrameDownsyncDynamicsOnSingleRenderFrame(delayedInputFrame, currRenderFrame, collisionSys, collisionSysMap) {
|
||||||
let latestRdf = self.recentRenderCache.getByFrameId(renderFrameIdSt); // typed "RoomDownsyncFrame"
|
const nextRenderFramePlayers = {}
|
||||||
if (null == latestRdf) {
|
for (let playerId in currRenderFrame.players) {
|
||||||
console.error("Couldn't find renderFrameId=", renderFrameIdSt, " to rollback, lastAllConfirmedRenderFrameId=", self.lastAllConfirmedRenderFrameId, ", lastAllConfirmedInputFrameId=", self.lastAllConfirmedInputFrameId, ", recentRenderCache=", self._stringifyRecentRenderCache(false), ", recentInputCache=", self._stringifyRecentInputCache(false));
|
const currPlayerDownsync = currRenderFrame.players[playerId];
|
||||||
|
nextRenderFramePlayers[playerId] = {
|
||||||
|
id: playerId,
|
||||||
|
virtualGridX: currPlayerDownsync.virtualGridX,
|
||||||
|
virtualGridY: currPlayerDownsync.virtualGridY,
|
||||||
|
dir: {
|
||||||
|
dx: currPlayerDownsync.dir.dx,
|
||||||
|
dy: currPlayerDownsync.dir.dy,
|
||||||
|
},
|
||||||
|
speed: currPlayerDownsync.speed,
|
||||||
|
battleState: currPlayerDownsync.battleState,
|
||||||
|
score: currPlayerDownsync.score,
|
||||||
|
removed: currPlayerDownsync.removed,
|
||||||
|
joinIndex: currPlayerDownsync.joinIndex,
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
if (renderFrameIdSt >= renderFrameIdEd) {
|
const toRet = {
|
||||||
return latestRdf;
|
id: currRenderFrame.id,
|
||||||
}
|
players: nextRenderFramePlayers,
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
if (null != delayedInputFrame) {
|
||||||
This function eventually calculates a "RoomDownsyncFrame" where "RoomDownsyncFrame.id == renderFrameIdEd".
|
const inputList = delayedInputFrame.inputList;
|
||||||
*/
|
|
||||||
for (let i = renderFrameIdSt; i < renderFrameIdEd; ++i) {
|
|
||||||
const renderFrame = self.recentRenderCache.getByFrameId(i); // typed "RoomDownsyncFrame"
|
|
||||||
const j = self._convertToInputFrameId(i, self.inputDelayFrames);
|
|
||||||
const inputFrameDownsync = self.getCachedInputFrameDownsyncWithPrediction(j);
|
|
||||||
if (null == inputFrameDownsync) {
|
|
||||||
console.error("Failed to get cached inputFrameDownsync for renderFrameId=", i, ", inputFrameId=", j, "lastAllConfirmedRenderFrameId=", self.lastAllConfirmedRenderFrameId, ", lastAllConfirmedInputFrameId=", self.lastAllConfirmedInputFrameId, ", recentRenderCache=", self._stringifyRecentRenderCache(false), ", recentInputCache=", self._stringifyRecentInputCache(false));
|
|
||||||
}
|
|
||||||
const inputList = inputFrameDownsync.inputList;
|
|
||||||
// [WARNING] Traverse in the order of joinIndices to guarantee determinism.
|
// [WARNING] Traverse in the order of joinIndices to guarantee determinism.
|
||||||
for (let j in self.playerRichInfoArr) {
|
for (let j in self.playerRichInfoArr) {
|
||||||
const joinIndex = parseInt(j) + 1;
|
const joinIndex = parseInt(j) + 1;
|
||||||
@ -1083,8 +1034,9 @@ cc.Class({
|
|||||||
collisionSys.update();
|
collisionSys.update();
|
||||||
const result = collisionSys.createResult(); // Can I reuse a "self.latestCollisionSysResult" object throughout the whole battle?
|
const result = collisionSys.createResult(); // Can I reuse a "self.latestCollisionSysResult" object throughout the whole battle?
|
||||||
|
|
||||||
for (let i in self.playerRichInfoArr) {
|
for (let j in self.playerRichInfoArr) {
|
||||||
const joinIndex = parseInt(i) + 1;
|
const joinIndex = parseInt(j) + 1;
|
||||||
|
const playerId = self.playerRichInfoArr[j].id;
|
||||||
const collisionPlayerIndex = self.collisionPlayerIndexPrefix + joinIndex;
|
const collisionPlayerIndex = self.collisionPlayerIndexPrefix + joinIndex;
|
||||||
const playerCollider = collisionSysMap.get(collisionPlayerIndex);
|
const playerCollider = collisionSysMap.get(collisionPlayerIndex);
|
||||||
const potentials = playerCollider.potentials();
|
const potentials = playerCollider.potentials();
|
||||||
@ -1095,9 +1047,55 @@ cc.Class({
|
|||||||
playerCollider.x -= result.overlap * result.overlap_x;
|
playerCollider.x -= result.overlap * result.overlap_x;
|
||||||
playerCollider.y -= result.overlap * result.overlap_y;
|
playerCollider.y -= result.overlap * result.overlap_y;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const newVpos = self.playerColliderAnchorToVirtualGridPos(playerCollider.x, playerCollider.y, self.playerRichInfoArr[j]);
|
||||||
|
nextRenderFramePlayers[playerId].virtualGridX = newVpos[0];
|
||||||
|
nextRenderFramePlayers[playerId].virtualGridY = newVpos[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return toRet;
|
||||||
|
},
|
||||||
|
|
||||||
|
rollbackAndChase(renderFrameIdSt, renderFrameIdEd, collisionSys, collisionSysMap) {
|
||||||
|
/*
|
||||||
|
This function eventually calculates a "RoomDownsyncFrame" where "RoomDownsyncFrame.id == renderFrameIdEd".
|
||||||
|
*/
|
||||||
|
const self = this;
|
||||||
|
let latestRdf = self.recentRenderCache.getByFrameId(renderFrameIdSt); // typed "RoomDownsyncFrame"
|
||||||
|
if (null == latestRdf) {
|
||||||
|
console.error("Couldn't find renderFrameId=", renderFrameIdSt, " to rollback, lastAllConfirmedRenderFrameId=", self.lastAllConfirmedRenderFrameId, ", lastAllConfirmedInputFrameId=", self.lastAllConfirmedInputFrameId, ", recentRenderCache=", self._stringifyRecentRenderCache(false), ", recentInputCache=", self._stringifyRecentInputCache(false));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (renderFrameIdSt >= renderFrameIdEd) {
|
||||||
|
return latestRdf;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (let i = renderFrameIdSt; i < renderFrameIdEd; ++i) {
|
||||||
|
const currRenderFrame = self.recentRenderCache.getByFrameId(i); // typed "RoomDownsyncFrame"; FIXME: onRoomDownsyncFrame(rdf) might get called asynchronously and thus made this line return "null"!
|
||||||
|
if (null == currRenderFrame) {
|
||||||
|
console.error("Couldn't find renderFrameId=", i, " to rollback, lastAllConfirmedRenderFrameId=", self.lastAllConfirmedRenderFrameId, ", lastAllConfirmedInputFrameId=", self.lastAllConfirmedInputFrameId, ", recentRenderCache=", self._stringifyRecentRenderCache(false), ", recentInputCache=", self._stringifyRecentInputCache(false));
|
||||||
|
}
|
||||||
|
const j = self._convertToInputFrameId(i, self.inputDelayFrames);
|
||||||
|
const delayedInputFrame = self.getCachedInputFrameDownsyncWithPrediction(j);
|
||||||
|
if (null == delayedInputFrame) {
|
||||||
|
console.error("Failed to get cached delayedInputFrame for renderFrameId=", i, ", inputFrameId=", j, "lastAllConfirmedRenderFrameId=", self.lastAllConfirmedRenderFrameId, ", lastAllConfirmedInputFrameId=", self.lastAllConfirmedInputFrameId, ", recentRenderCache=", self._stringifyRecentRenderCache(false), ", recentInputCache=", self._stringifyRecentInputCache(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
latestRdf = self._createOrUpdateRoomDownsyncFrameLocally(i + 1, collisionSys, collisionSysMap);
|
latestRdf = self.applyInputFrameDownsyncDynamicsOnSingleRenderFrame(delayedInputFrame, currRenderFrame, collisionSys, collisionSysMap);
|
||||||
|
if (
|
||||||
|
self._allConfirmed(delayedInputFrame.confirmedList)
|
||||||
|
&&
|
||||||
|
latestRdf.id > self.lastAllConfirmedRenderFrameId
|
||||||
|
) {
|
||||||
|
// We got a more up-to-date "all-confirmed-render-frame".
|
||||||
|
self.lastAllConfirmedRenderFrameId = latestRdf.id;
|
||||||
|
if (latestRdf.id > self.chaserRenderFrameId) {
|
||||||
|
// it must be true that "chaserRenderFrameId >= lastAllConfirmedRenderFrameId"
|
||||||
|
self.chaserRenderFrameId = latestRdf.id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
self.dumpToRenderCache(latestRdf);
|
||||||
}
|
}
|
||||||
|
|
||||||
return latestRdf;
|
return latestRdf;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user