-
-
Notifications
You must be signed in to change notification settings - Fork 646
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
Entity anchor point is reversed compared to me.Sprite (renamed) #834
Comments
Also, the anchor point is inconsistently applied. Entity applies a positive offset based on the point, while Renderable applies a negative offset. |
Yep, I'd be curious to see if @obiot has a reason for this. While confusing, maybe it's correct? lol. It was done along with the transform changes for melonjs 4. The idea was to keep feature/API parity, but I wouldnt be surprised if a bug or two cropped up. Here's the subtract on sprite: https://github.com/melonjs/melonJS/blob/master/src/renderable/sprite.js#L547 The addition on entity: https://github.com/melonjs/melonJS/blob/master/src/entity/entity.js#L287 |
I did not change the "behavior" of the anchor points, or at least not intentionally, but yes we have to admit that our current design/usage could be improved (not to say fucked up). Personnally i only use the entity anchor point : We had the plan to redesign the entity object, and adress this in the mean time, but this got delayed somehow... but if anyone has any good proposition(s) on how we could better manage these anchor point, it would help ! |
Ah yes sorry, i was more basing on when the code was put there as per the latest commit :) |
small up for this one, as indeed the anchor implementation between Entities and other renderable is not consistent and it's time to clean-it up if we also want to fix related bounds issue (#833, #848) in a clean way : Not to mention that me.Entity does not follow our documentation : |
Speaking of which... It looks like this line belongs in |
indeed, but that's a cheap trick to avoid calculating I had the plan to use an ObservableVector for the anchor point (to manage the bounds issue), so I might actually do it now and pre-compute the offset, so that I can reuse it, and it even then save a few cycle for every single renderable. |
They can be stored in private state variables. I really like the WeakMap setup for private state, but worst case scenario, an extra property on the class isn't terrible. |
I just realised that this is more complex than I thought, because it also needs to then be taken in account when the object bounds size is updated! any comment else on this :
|
@parasyte @agmcleod call me crazy, but looking at this with a well rested eye (i've been travelling too much recently, and that other ticket #854 drove me crazy for a couple of weeks), i just realized that me.Renderable is the wrong one and me.Entity is correct ! based on the documentation we have, an anchor point of [0, 0] corresponds to the top-left part of the image, and an anchor point of [1, 1] the right-bottom part. So me.Entity is correct, but the base me.Renderable object is doing the opposite. Now, this is the opposite of what is doing other frameworks, but we actually already agreed on that. am I correct ? i would appreciate some comment so that we can finally close this one :) |
err.. changing this is leading to crazy result, with both anchor point combined.... i'm really not sure what I/we should do here actually. |
I haven't had a chance to review anything in this ticket. From the initial report to the finding that one-or-the-other things is apparently wrong ... I won't have any more info for you in the short term. :( My only excuse is that I have only slept for a few hours each night for the past week, and spent a few 22-hour days at work; we had a massive service outage starting Thursday morning and ending Saturday afternoon. We had a second service disruption for about 4 hours today during the AWS outages. And a nice little bug in our scheduler topped off the night by slowly leaking disk allocations/reservations, causing one of our capacity alarms to trigger! Anyway, I'm beat. I'll be happy to look into this after I'm rested and can start to think straight. |
ouch... sorry to read that my friend ! Have a welllllll deserved rest then and talk to you later ! |
So I think the original point about 0,0 being object center tends to work if we were using a more standard 3d/opengl coordinate system, instead of pixel screen coordinates. Where 0,0 is the center of the object, Y positive is up instead of down. I think we should keep it consistent with the way the world coordinates work, to help avoid confusion. |
From my POV, origin-center vs origin-top-left has nothing to do with the direction of the y-coordinate or even that we use unit spaces that matches a pixel grid. AFAICT, the issues raised here are inconsistencies with the anchor point direction (both coordinates?) on one of the two objects, but it is unclear which ... even with a different origin location, one of these objects would still be opposite. There might be a good reason for that, or it might just be a confusing artifact of the design. Or just a bug that crept in without test coverage. Who knows? I still haven't looked. Just woke up, and time for work again! :) |
indeed, the issue i was referring to is not that much about our coordinates system, but rather on the fact that the anchor point direction is different between me.Entity and the base me.Renderable object. me.Renderable subtracts the width or height multiplied by the corresponding anchor point value, and me.Entity adds them. |
I know that you are busy on other things (me too, as if you noticed I did not make a single commits since a couple of weeks), but I need your help with this last one, just to be sure we are all aligned and agreeing on this change. the big change is on the entity anchor point, that is now aligned with how renderable normally use it : this leads to some funky scenario with the platformer, like with the enemy entity, where I need now to use negative value to align them : really really appreciate your help here, so that we can finally close all these related anchor tickets we have (once this one done, all the other will fall in line) |
@obiot My only feedback is that this change is surprising. The renderable anchorpoint needs to be changed? IIUC, the anchorpoints should default to |
lol.... Renderable : https://github.com/melonjs/melonJS/blob/master/src/renderable/renderable.js#L368-L377 do you see any differences ? that's what changed there is absolutely no changes to the default anchor point value, still 0.5 |
No, it still doesn't make sense. The change to the coin entity suggests that the coin will be drawn with the sprite's upper-left corner anchored to the entity's center;
Unless I'm mistaken, this is how I'm reading the anchorPoint states for that coin entity. My confusion is from trying to understand how these values lead to the correct behavior.
After all that, the coin sprite is drawn with its upper-left corner at the center of the entity? If the visuals are correct after all this, then that means there is something else inserting an offset somewhere which is what the zero anchorPoint is trying to cancel. The default behavior with renderable anchorPoint at its center, step 3.i (or 3.ii) cancels step 2, which puts the upper-left corner of the renderable at the upper-left corner of the entity. This is the expected behavior. That's why it surprises me, but I could be completely misunderstanding what's actually happening. If you have any insights, please share. |
this conversation is getting nowhere, we keep not understanding each other. All i'm saying is that anchor point are translated to different-opposite direction between entity and renderable. And from the initial discussion this was what we were trying to fix. once again (assuming values are different than 0, 0) :
if now this is the desired behavior, that fine, i give up anyway. But I still don't understand why then all these discussions about the anchor point being inconsistently applied between different object type (me.Entity vs me.Renderable) |
I'm familiar. The "opposite" translation is necessary for Given that it is the current behavior, I'm questioning how the provided values ( I guess it's more a question of lacking unit tests that show expected vs actual behavior. |
see #1008 |
When passing an image to Entity constructor, a child renderable gets created. This results in a strange behavior - the Entity has it's own anchor point, but also the child has a separate anchor point. This leads to situations where setting the point to 0, 0 on the entity causes it to be displayed half of image offset. This is very confusing and also can be related to #833
The text was updated successfully, but these errors were encountered: