Cannot animate the color property because the object is sealed or frozen
Asked Answered
M

1

3

Ive seen other similiar issues but they alwayse seem to be doing this in XAML, since this is in an event handler I need to figure out the answer in c#. basically I just need the sending menu item to blink red.

ColorAnimation ca = new ColorAnimation()
{
    From = Color.FromRgb(0, 0, 0),
    To = Color.FromRgb(255,0,0),
    AutoReverse = true,
    RepeatBehavior = new RepeatBehavior(3),
    Duration=new Duration(TimeSpan.FromSeconds(.5))
};
(sender as MenuItem).Foreground.BeginAnimation(SolidColorBrush.ColorProperty, ca);
Mcallister answered 1/11, 2016 at 11:10 Comment(0)
L
7

You would have to assign a mutable SolidColorBrush instance to the element's Foreground property before it can be animated, either in XAML or in code behind:

var item = (MenuItem)sender;
item.Foreground = new SolidColorBrush(Colors.Black);
item.Foreground.BeginAnimation(SolidColorBrush.ColorProperty, ca);

If you animate from the current color value (e.g. Black here), you don't have to set the From property of the animation.


Note also that you shouldn't use the as operator without checking whether the result is null. Better use an explicit type cast instead of as, because in case sender is not a MenuItem, you would correctly get an InvalidCastException instead of a NullReferenceException.

Logo answered 1/11, 2016 at 11:29 Comment(3)
The as isnt a concern for me as the event handler is only called from a menu item and not reused for anything else. But your answer where I have to explicitly set the color AGAIN prior to animating worked perfect, any explanation as to why?Mcallister
It is of course sufficient to set the Background once before animating it for the first time. You might probably do that in XAML. It is however important not to use one of the predefined Brushes like Brushes.Black, because these aren't mutable.Logo
ahh, weird, but makes sense I guess.Mcallister

© 2022 - 2024 — McMap. All rights reserved.