Ask a questionAsk a question
 

AnswerExecuting Commands from *any* event

  • Friday, August 04, 2006 1:37 PMwpf michelle Users MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     

    I understand that commands can be triggered off certain events of certain controls.   For example, specifying  a Command for a Button will trigger it off the Click event.  But what if I wanted to trigger a command off of a different event -- like a Load event?  Is there a way to do this at all?  If so, can I do it from XAML only?

Answers

  • Wednesday, August 09, 2006 3:27 PMwpf michelle Users MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     Answer

    I looked into this further, and it doesn't seem that deriving from TriggerAction will work, since TriggerAction class is "public abstract" but it has 2 "internal abstract" methods [2 overloads for Invoke].  

    Any plans from MS to change this?   This could be really useful...

  • Monday, April 06, 2009 9:45 PMBrownie PointsMVP, ModeratorUsers MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     Answer

    Almost 3 years later we have a solution. The new blend behaviors api allows for custom trigger actions. I blogged about my ExecuteCommandAction here.


    Keep your head in the Clouds as you're coding .NET http://azurecoding.net

All Replies

  • Friday, August 04, 2006 6:11 PMBrownie PointsMVP, ModeratorUsers MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     

    Create a handler for the event and call RoutedCommand.Execute within your handler. I'm not sure if you should call CanExecute first or if Execute will check for you. (To err on the safe side call CanExecute first.)

    If you want this to be done strictly through XAML, you would need to derive a class from TriggerAction that fires a command and add it to an EventTrigger within XAML. If people think this utility would be useful, I could add it as a WorkItem for the WPF Toolbelt project.

  • Friday, August 04, 2006 7:57 PMlukemelia Users MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     
    If you want this to be done strictly through XAML, you would need to derive a class from TriggerAction that fires a command and add it to an EventTrigger within XAML. If people think this utility would be useful, I could add it as a WorkItem for the WPF Toolbelt project.

    I would find this useful...
  • Monday, August 07, 2006 1:58 PMwpf michelle Users MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     

    Yes, that would be a very useful utility.   Thanks Mike! 

  • Monday, August 07, 2006 3:04 PMBrownie PointsMVP, ModeratorUsers MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     
    Done, the tool is scheduled for the WPF Toolbelt CTP 2 release scheduled for the end of August. If the class is available prior to the official release date (through a code commit) I will let you know here. If you'd like to follow the project, you can go here
  • Wednesday, August 09, 2006 3:27 PMwpf michelle Users MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     Answer

    I looked into this further, and it doesn't seem that deriving from TriggerAction will work, since TriggerAction class is "public abstract" but it has 2 "internal abstract" methods [2 overloads for Invoke].  

    Any plans from MS to change this?   This could be really useful...

  • Wednesday, August 09, 2006 6:30 PMBrownie PointsMVP, ModeratorUsers MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     
    Well that's not fair. And looking at the implementation of its derived classes, you can't override behavior with them either.
  • Wednesday, August 09, 2006 6:46 PMBrownie PointsMVP, ModeratorUsers MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     
    I just logged a feature request on the feedback site. Go here to vote and add a comment. Hopefully this is something that can be added in time for the final version.
  • Thursday, August 10, 2006 2:42 PMwpf michelle Users MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     
    I agree.  Thanks Mike!
  • Thursday, August 17, 2006 7:50 PMBrownie PointsMVP, ModeratorUsers MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     

    This is the feedback from Msft on the issue

     Microsoft wrote:
    This is by design for this version. We do understand that this is a valuable feature and are considering it for future versions.

    Thanks for the feedback!

    Looks like we won't get it with V1

  • Monday, April 06, 2009 9:45 PMBrownie PointsMVP, ModeratorUsers MedalsUsers MedalsUsers MedalsUsers MedalsUsers Medals
     Answer

    Almost 3 years later we have a solution. The new blend behaviors api allows for custom trigger actions. I blogged about my ExecuteCommandAction here.


    Keep your head in the Clouds as you're coding .NET http://azurecoding.net