✅ Responsive ScrollViewer AvaloniaUI
Hi, I'm having trouble setting up a ScrollViewer in my project. I want it to be responsive for a DataGrid, but when I set the second row definition in the Grid to "*", the scroll doesn't work. It only works if I assign a fixed value, but that makes it non-responsive. How can I make it responsive while ensuring the scroll works properly?
data:image/s3,"s3://crabby-images/ec71c/ec71cea2b887507fcfe2a35ae4957b775657531d" alt="No description"
data:image/s3,"s3://crabby-images/988a3/988a322b5c3940aae28adbfb7132373309ea032d" alt="No description"
7 Replies
DataGrid should already come with a scroll.
What if not? In my case when I'm resizing window i can't scroll items on list
Here’s an example: when I minimize the window, I can't scroll, and some of the data is missing.
data:image/s3,"s3://crabby-images/73f51/73f5183d4f77921ba02448071eedae2441a93a57" alt="No description"
data:image/s3,"s3://crabby-images/0ed66/0ed661e9d55102b22596f08b984d2629858bdac1" alt="No description"
press F12 on the running app (debug) and make sure nothing is outside the bounds
As far as I'm aware it's not permanently visible. It will only become visible if you hover the rightmost area
I don't see anything suspicious. The DataGrid is nested inside a ScrollViewer.
data:image/s3,"s3://crabby-images/a0efc/a0efc9407ace40e4df9abdcb3afd30d2030b1e3d" alt="No description"
What I've noticed in the dev tools is that when I change the window size, the LargeChange property of the ScrollViewer (for the width) updates correctly. However, when I adjust the height, the LargeChange property for the height stays the same.
data:image/s3,"s3://crabby-images/18325/18325de4fa7618c7c22cf16f4479ded5b0156332" alt="No description"
data:image/s3,"s3://crabby-images/a4a2b/a4a2b9df930bf51b9da7b0888d65ad33e20c3b4f" alt="No description"
The height of the ScrollViewer in the dev tools is set to "None," which is why it's not working. My question is how to set up a responsive height that is bound to the window height.
Okay, I’m stupid, but it works well—only if I reload the view after resizing the window.