-
Notifications
You must be signed in to change notification settings - Fork 613
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
Add box-based zoom support for interval selections. #4742
Comments
Thanks for posting! The good news is that what you describe is already expressible within Vega. Here is a modified zoomable scatterplot example. You can shift-drag to create a zoom region, and when you release the mouse button the view will snap to the new scale extents. You can also double click to restore the chart to the initial configuration. Note that this works alongside standard drag-pan and scroll-zoom interactions. Or, here is the same example within an Observable notebook: https://observablehq.com/@vega/vega-interactive-scatter-plot The less good news is that I don't think this is currently expressible in Vega-Lite / Altair. However, I could imagine extensions to the interval selection logic that would change that. So, I'm going to rename this issue and transfer it over to the Vega-Lite repo for folks to look at there! |
Oh cool! It's good to know that this is one step closer to being in Altair. Thanks for moving the bug over. |
This feature would be great. |
@allenjlee are you working on this? If not, let's unassign you. |
Is there any alternative to getting interactive zooming of arbitrary regions of a plot working with vega-lite? |
Is there any development on this yet? Thanks! |
No updates yet, unfortunately. Sorry. |
Is there any plan for this? Or is it just in the backlog with no plans at the moment? Thanks! |
It's in the backlog but I think @kanitw wanted to address this issue so it's higher up in the queue. He can comment on the timing. If this is not urgent, we should remove the P1. |
It would be great and I understand many folks are waiting for this feature too. Having the hability to box-zoom is sometimes a must for some data exploration. So yeah, I'm really looking forward to this... |
I'm looking forward to this too, if it's possible with Vega-lite. Thanks ! |
I'm also really looking forward to this feature. If there is any way I can help with this, let me know |
Not quite the real thing, but a workaround is to zoom x- and y-axis independently via Selection projection and event filters depending on whether the shift key is held: (in Altair) selection_x = alt.selection_interval(
bind='scales',
encodings=["x"],
zoom="wheel![!event.shiftKey]",
)
selection_y = alt.selection_interval(
bind='scales',
encodings=["y"],
zoom="wheel![event.shiftKey]",
)
chart = (alt.Chart(...)
...
.add_selection(selection_x)
.add_selection(selection_y)
) (in vega-lite) {
...
"selection": {
"selectorx": {
"bind": "scales",
"encodings": [
"x"
],
"type": "interval",
"zoom": "wheel![!event.shiftKey]"
},
"selectory": {
"bind": "scales",
"encodings": [
"y"
],
"type": "interval",
"zoom": "wheel![event.shiftKey]"
}
},
}
|
This comment has been minimized.
This comment has been minimized.
The lack of this feature is holding Altair back compared to plotly, bokeh, etc |
I agree with @samimia-swks: This is arguably the one feature that holds back @domoritz asked in Feb 1, 2022 whether this is "not urgent". I'd argue that this is currently one of the most urgent features. Would there be any way to prioritize this feature? |
I think @kanitw was also excited about box based zoom. Since most of us are volunteers, the best way to prioritize features is to describe use cases, help design what the feature looks like, prototype (manually) in Vega, or to send pull requests. |
Thanks for the reply! I will try to lay out the use case and see whether I could get something to work in Vega. Really appreciate the effort everyone is putting into these packages! Thanks so much for that! |
So I tried to modify the "Overview and Detail" demo. I discarded the second plot to only have the top plot and turned that into However, now the zoom is broken because as you click to select a rectangular region, the zoom is already applied.
If you remove the demo.movHowever, now nothing happens with the selection. I thought I would just have to change
|
Maybe I'm overthinking this. Could it be as simple as finding the correct way for the
|
Drawing a box can be copied from here: https://vega.github.io/editor/#/examples/vega/brushing-scatter-plots You just then need to link that to a zoom. |
Not sure I fully understand @PBI-David. The brush is linked, I just need to delay the action of updating the interval until I stop clicking the mouse? |
I was showing that a box zoom can be created using the same logic on that Vega example. The first part is drawing a box (the example I showed) and the second is zooming the domain. |
I think I got a very rough first version of this working. I started with the overview and detail example. From that, I removed the lower chart to have everything integrated into one chart. That's this code {
"$schema": "https://vega.github.io/schema/vega-lite/v5.json",
"data": {
"url": "data/sp500.csv"
},
"width": 480,
"mark": "area",
"params": [
{
"name": "brush",
"select": {
"type": "interval",
"encodings": [
"x"
]
}
}
],
"encoding": {
"x": {
"field": "date",
"type": "temporal",
"scale": {
"domain": {
"param": "brush"
}
},
"axis": {
"title": ""
}
},
"y": {
"field": "price",
"type": "quantitative"
}
}
} Now this is broken because as soon as you start selecting a range, the image starts to zoom. I then looked at the compiled Vega code. Here, I substitute {
"events": {
"source": "window",
"type": "pointermove",
"consume": true,
"between": [
{
"source": "scope",
"type": "pointerdown",
"filter": [
"!event.item || event.item.mark.name !== \"brush_brush\""
]
},
{
"source": "window",
"type": "pointerup"
}
]
},
"update": "[brush_x[0], clamp(x(unit), 0, width)]"
}, with {
"events": {
"source": "window",
"type": "pointerup",
"consume": true
},
"update": "[brush_x[0], clamp(x(unit), 0, width)]"
},
to get this example. When you start selecting a range, the box that highlights the reason is not drawn but upon mouse release, you zoom into the right subdomain. |
I spend a lot of time looking at engineering time-series data.
I currently use bokeh for this, but I would love to switch to vega/vega-lite/altair.
However, I'm hesitant to switch because vega appears to be missing a box-zoom feature. This feature is incredibly useful for exploratory time-series plotting/analysis.
As an example, my data often looks like a more complex version of this bokeh example.
There may be many phenomenon of different x/y axis scales which get manifested in time-series data and being able to change the zoom level/aspect ratio is incredibly useful.
Basically, I would love to see Bokeh's BoxZoomTool (as enabled in the box_annotaion example above) in vega/vega-lite/altair.
The text was updated successfully, but these errors were encountered: