-
-
Notifications
You must be signed in to change notification settings - Fork 867
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
Improve tile handling #1356
Improve tile handling #1356
Conversation
0ed34e2
to
e126ef8
Compare
@JosefWN |
One reason I kept the animation controller is that we allow for this: animationController?.forward(from: from); So you can choose to play the animation from, say, 50% to 100%. I don't know why this is necessary, but we have exposed the option to the users as well ( |
I see. I guess it depends on how much things can or cannot be simplified, and how often it's used. I'd say if it's not used in the example app, then we can probably get rid of it: although this will be a breaking change. @ibrierley @moonag @TesteurManiak What do you guys think? |
IMO we can replace with a |
I'm a bit hesitant to do breaking changes atm (we've had quite a lot of late), but no problems with these type of changes implemented in a future version where there's several breaking changes if that makes sense. |
Yeah, I would agree with that. I think leaving an at least 2-3 month gap between breaking releases is the minimum. In this case, @JosefWN can you explore how much you can simplify things with this option - and any similar options you think fall under the same bracket - and maybe we merge this into a separate branch 'delayed-breaking-changes', which we can merge into main and release at a later date. Thanks :) |
I can have a look in the coming days! |
I know the tile layer stuff is all kinda spaghetti together and hard to keep separate, but we could look at making this the migration to a new tile layer system. Give it a new name, RasterTileLayer, WMSTileLayer, VectorTileLayer, etc.... And then deprecate the old stuff. This would allow for non-breaking changes and allow us to basically rewrite the entire tiling system. I don't think this change has to be breaking for end users. One thing I would like to see be worked on, I don't have the time right now, but support wrapping on the map left and right; and an extension of that would be to extend the system to support rendering on a sphere. |
I'm not sure, if you deprecate something in 1.2, and replace it in 1.3, is that OK with SemVer? Or would you need to move it 2.0? Are we even sticking with SemVer (we are atm, and it seems kind of sensible to remain doing so)? But yes, I would like to see that rewrite and separation as well. This might even pave the way for #1337. But alas, I don't have the time (or much knowledge) to do so either at the moment. Should we be making this aim more formal? Ie. use a Discussion, Discord channel, and/or Git branch.
I think someone had a crack at 3D rendering, but I think they ran out of time. |
Hey, thanks for the ping. I'm pretty busy with other things at the moment, unfortunately I don't have any spare cycles to chip in.
Improvements are great, but any breaking change is a pain for users and for plug-in maintainers. Unless there's substantial benefit, we should try to avoid it as much as possible. I know that might sound like a drag, but it's a big deal. For example, going to 3.0.0 was a lot of work. For the VectorTileLayer I had to understand the nature of the change and then get it working. It cost me about a full day, and although the code is a little cleaner on the consumer side, it's an incremental benefit. I'm not sure that it's worth it to break the API for such a minor improvement. I'm not sure what's planned for the new tile layer system. There is quite a lot of logic in vector_map_tiles related to loading tiles of different sizes, depending on the data that's available and to optimize the frame rate. It would be great if we could avoid breaking that. |
Thanks anyway @greensopinion :) Yeah, understood with the breaking changes. For me, I don't mind them so much, but I can see & understand they are a pain for a lot of people, especially when the changes are as big as last time. Those greater tile system changes probably won't be coming any time soon, so no need to worry about them for now. |
@JosefWN I've converted to a draft just for now, so we can differentiate between needs-review/in-progress/ready. If you are ready to merge, let me know. |
Hi @JosefWN, is this ready for review? If not, no pressure! |
I propose we just work on new tile layer stuff from the ground up, give it a new widget (ideally plural with different behaviors) with new logic. That is realistically the best way to improve the tile handling at this point. The current system is not extensible, has too many edge cases, and way too many options. |
@moonag I agree with this, however I'm not sure when this would get finished? |
Hey @moonag, is there any chance of that rewrite happening any time soon? If not, we should probably get round to merging this. |
not right now unfortunately unless someone else wants to take it on |
Ok. @ibrierley When you're back, do you want to review this for merge? I'll do the same. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm a little out of touch with the tile handler recently, but I like the visible difference. My acid "feel" test is to open Animated MapController example in Web release, and repeatedly animate from London <-> Paris. It certainly feels better to me with this change (mainly less slight outer grey on animation).
Regarding the code itself, I'm fairly easy and can't initially spot any issues, but it's hard with the tile handler as it's typically been a mess to follow, but maybe that's just me:D. I'm happy with this.
Thanks for the work on this!
@ibrierley I can't seem to find where this is a breaking change? |
Good question, I'm not actually sure if this is or not now...there was mention of the fadeInStart I think... |
Ok, @ibrierley I haven't tested, but I can't see any issues or why this would be a breaking change. You can merge this if you want. |
A suggestion to simplify the tile handling a bit:
AnimatedTile
into formerTileWidget
(no need for state, the tiles are managed by theTileManager
), theAnimationBuilder
does the heavy lifting for usAnimationController
for every animationHaven't gotten rid of the opacity widget yet, I think we'd need to crossfade between old and new tile on zoom