I'm wondering if there are any good dead reckoning(I hope I'm using the term right) examples?
I'm currently working on a MMO, and I have no previous experience with this I'm having problems syncing the data properly.
Currently I send 5 updates per second(is this too low?). I run movement on both client and server and try to adjust the client data slightly based on the actual data received from the server although I have problems when character suddenly stops. (I can either have him standing at the wrong position client-side, or I can fix his position which causes him to "glide" to the new position). I'd really like that when he stops he stops pretty much near the actual server position, because I don't notice the gliding in other MMOs(unless under heavy lag).
I've tried searching though many books and tutorials but I can't find anything useful, and I plan on spending the next month to have this working perfectly in my game, so it would be helpful to have a working and tested example. Or any advice?
If you extrapolate, stopping will be a problem no matter what.
An alternative is simply to display every entity based on data that you receive (interpolate between old positions). This will cause some latency in movement to be visible, but that's typically OK when you're doing an RPG.
I do interpolation for the other(non-player) entities(250ms in the past) and that works fairly well.
I implemented and tried your algorithm a while ago although extrapolation just doesn't work too well for me, I guess I just haven't given it a proper try yet since the interpolation works pretty well. (I tried interpolating and switching to extrapolation only when I ran out of updates, which didn't work out too well)
But for the player character I use a different approach since I run the simulation both client and server side. Client sends basically WASD key presses to the server and the server sends a position update every 200ms. If the difference between client and server is too high the client tries to slightly adjust the players movement so that it will be closer to the servers position during the next update. However that doesn't work when stopping...
Problem is with the combat system I'm trying to do(I don't wanna do a WoW-style select&use skill system), but I wanna be able to swing the sword and hit anyone in front of the player. The problem is, when the player goes to attack someone, he stops in front of his enemy although those few ms it takes for the server to update on the server he actually ends up just barely behind his enemy. Therefore when he swings, the server checks if there's anyone in front of him and since there's noone no hit occurs. Although the client clearly sees he's standing in front of his enemy.
I don't know what would be the best way to handle that? Should the target selection happen client-side and then just loosely check if the enemy is range on the server? Although I fear that opens up opportunity for cheating.
Or maybe if the server checked the enemies previous position(when the "sword swing" packet was sent)?