-
Notifications
You must be signed in to change notification settings - Fork 115
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
Inquiry about Manual Control of Zoom and Persistent Configuration in Your Open Source Framework #274
Comments
hi there, answering inline:
I do believe it's possible, given instance.canvas.merge(window.instance.canvas.enter)
.call(
instance.meta.zoomBehavior.transform,
d3.zoomIdentity.translate(1000, 1000)
) That would move the graph as expected but it you zoom or pan it goes back to its original location, I'm not sure why that's happening, I think there might be a bug in this codebase.
Yes, I believe the current zoom should be stored in |
Thank you for your response. I have tried the methods you provided, and indeed, I can translate and scale, but whenever I use the mouse to move or scale the graph again, it resets the state. I attempted to simulate button clicks for manual zoom events, simulate reset events, and persistently store zoom and pan events by recalculating xDomain and yDomain settings. Persistent storage of zoom and pan is effective and achieves the desired results. However, the first two conflict with mouse zoom and pan. I wonder if I should destroy the original function-plot before the operation and then redraw it with the new domain? Would this solve the problem? I noticed you added a destroy method two months ago, but I couldn't find this method in the latest npm version 1.24.0. I am a developer from China, using ChatGPT to translate my question. If there are any translation issues, please forgive me! reset() { zoomIn() { this.instance?.on('all:zoom', (event) => { |
Yes this is what I saw too, what I remember doing is overriding the default zoom behavior so that zoom works across multiple instances of function plot (done with these lines) so it's unfortunately not implemented the same way as the zoom example from the d3 docs.
Interesting idea, calling destroy removes the SVG node from the page and all listener associated with it, however I believe for every pan/zoom you'd redraw from scratch and that's a little bit expensive. It's also true that it's in the master branch and not released yet and hopefully |
Hello, and thank you very much for your open-source framework, which is very user-friendly! Currently, I have two questions I would like to ask:
Is it possible to manually control zooming, for example, having zoom in and zoom out buttons on the touchscreen, where clicking the buttons can control zoom similar to a scroll wheel? Are there any relevant APIs for this, or if not, are there other ways to achieve this? I've seen others ask this question in historical issues, but there hasn't been a resolution.
After zooming and panning, is it possible to persist the configuration? For example, saving the configuration of this zoom locally and automatically applying this zoom and pan the next time it opens.
The text was updated successfully, but these errors were encountered: