-
-
Notifications
You must be signed in to change notification settings - Fork 21.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[4.3beta3] Sprite pivot changed since 4.3beta2 #94298
Comments
Bisected to 6b17d51 |
The issue is with rounding of the sprite offset for both In 4.2 and earlier, this snapping used #93740 aimed to address the inconsistent behaviour of snapping the halfway values of canvas items, but at the same time it also changed the snapping of the sprite offset. This changed the snapping of -0.5, which is what caused this issue. (Side note, #93712 is another issue caused by inconsistent snapping of halfway values.) Consider the simpler case with no scaling: Say we have a 3x3 sprite at the origin, with the default centre offset by -1.5,-1.5, how do we want the sprite to be snapped? Edit: Oh no, apparently I mixed up the two screenshots for the first case... |
@alvinhochun I'm off work today so I'll look at this a little too. I'd first like to get a good grasp of how this is reproduced. The MRP is very specific and has a lot of odd project settings for this, with the specific scene scaled 20x and offset. I'm going to make a cleaner MRP because I suspect all of this isn't necessary to reproduce. I'll then test it against 4.2 and 4.3 and your fix against 4.2 and 4.3 for the pixel snap tests to make sure there's no regressions. |
Okay, the MRP is actually very simple to make. I just made a 1x1 sprite from a If you run this in 4.2, you'll see that half values round down (actually all values round down in 4.2, but for the sake of the issue...), and in 4.3 half values round up. This is more apparent when you take a 1x1 pixel sprite and scale it 20x and then offset it like in the images in the issue description, but that's a very specific case. You can see this also just as clear by changing the placeholder texture from 1x1 to 2x2 or 3x3 etc and turning the centering on and off. It's hard for me to say that this is a regression any more than the fact that 0.6 rounds up instead of down now, because it's an arbitrary tie-breaking rule for exact half values. This is expected behavior and one of the problems the pixel snapping changes intended to fix. In most cases in the wild you'll see round() methods round up for half values. Another common one is "banker's rounding" which rounds to the nearest even number which also may be a good choice for centering, but I'm not sure. Either way, it sounds like Godot's internal rounding oddly rounds down for half values? We could change all floors to ceils but the intent of #87297 was to change how snapping works to be more consistent and just personally I think rounding up is the more common tie-breaker for 0.5. It doesn't seem like any of this is critical, but if Godot's internal EDIT: I checked how GDScript and Godot internally handles half value rounding and it looks like they both round up, so this would be the odd one out if we change it to round down. EDIT2: Actually it's round away from zero, so either way it's inconsistent. |
Discussed the other day and agreed this is expected behavior with the intentional changes to snapping for 4.3. 4.2 and before with pixel snapping:
4.3 before
4.3 after fix:
|
After some discussions and considerations I do incline to consider this not a bug, because the previous changes intentionally fixed some inconsistent behaviour. This can be worked around by disabling "centered" and manually setting an offset with integer values. |
Hmm, for cases where numbers cause offsets in reverse (like pivots), should we replace |
This is what #94305 tried to do. The problem is that the offset is not setting the pivot point with respect to the top-left corner of the sprite, but actually moving the top-left corner of the sprite with respect to the node origin. Changing how it is rounded makes the offset rounding inconsistent with the canvas item position rounding. |
After noticing that all the 2D team agree on this issue, I'm closing this issue as "as intended". We deeply refactored (and fixed) "Snap 2D Transforms to Pixel", so these kind of issues are expected. To me, the new behavior is behaving correctly. The old behavior was a bug. |
Tested versions
System information
Godot v4.3.beta3 - Windows 10.0.19045 - GLES3 (Compatibility) - NVIDIA GeForce RTX 3070 (NVIDIA; 31.0.15.3619) - 11th Gen Intel(R) Core(TM) i7-11700K @ 3.60GHz (16 Threads)
Issue description
Since upgrading to 4.3.beta3 a lot of the sprites in the game I've been working on have been visually offset. The data for the sprite has not changed or corrupted, you can freely switch between 4.3.beta2 and 4.3.beta3 to see the sprite offset.
Below is what this looks like in 4.3.beta2 (and in 4.2.1-stable):
And below is how it looks in 4.3.beta3, note that it is no longer centred on the xy axis.
Steps to reproduce
Minimal reproduction project (MRP)
Sprite Pivot Bug.zip
The text was updated successfully, but these errors were encountered: