Open ds300 opened 2 weeks ago
The latest updates on your projects. Learn more about Vercel for Git ↗︎
Name | Status | Preview | Updated (UTC) |
---|---|---|---|
examples | ✅ Ready (Inspect) | Visit Preview | May 8, 2024 1:10pm |
@TodePond I've heavily refactored the viewport following code in this PR, mind doing a little QA to make sure I haven't broken any features/behaviour I wasn't aware of?
This revives the old 'derived camera' idea to prevent cursor wobbling during viewport following.
Before this PR we updated the camera on a tick during viewport following, but the shapes and cursors were not moving on the same tick (we tried that during the perf work and it was all kinds of problematic). Frankly I've forgotten how we ever managed to eliminate wobble here in the first place?
Anyway after this PR we derive the camera based on whether or not we are following a user. When you follow a user it makes it so that your viewport contains their viewport. If your viewport is not already very close to their viewport it will animate the initial position, after which it will 'lock' in place and the derived value will be used from then on.
This exposed a minor issue in our sync engine: the fact that we send presence updates in separate websocket messages from document updates. We get into situations like this
So to fix this I made it so that we can (and do) send presence updates in the same websocket messages as document updates so the server can handle them atomically.
Change Type
sdk
— Changes the tldraw SDKbugfix
— Bug fixTest Plan
Release Notes