I have a ListView that is set up with a MinHeight and a MaxHeight. The final height is determined by the number of items inside the list.
At the moment, when a list is added to the ItemsSource property of the ListView, the height jumps to the final height. Is there a way to animate this change in height, so that it’s smooth?
Here’s an example of something that does what you want (as I understand it). I’ll call this “quick and dirty” and don’t claim to have put a whole lot of thought into it.
UPDATE: You should be able to copy this into .cs and .xaml files and run it as an example application. To summarize what I’m doing: Set the MaxHeight property to something artificially low, in my case I just set it to the same value as the MinHeight. Then you can create a storyboard that animates the MaxHeight to its real value, which gives you the smooth transition effect. The trick is indicating when to start the animation, I use a dependency property in a subclassed ListView just because that seemed to be the easiest option to implement in a hurry. I just have to bind the dependency property to a value in my ViewModel and I can trigger the animation by changing that value (since I don’t know of an easy way to trigger an animation based on a change to a ListView ItemsSource off the top of my head).