XAML - ट्रिगर

मूल रूप से, एक ट्रिगर आपको संपत्ति के मूल्यों को बदलने या किसी संपत्ति के मूल्य के आधार पर कार्रवाई करने में सक्षम बनाता है। इसलिए, यह मूल रूप से आपको एक नया बनाने के बिना गतिशील रूप से आपके नियंत्रण की उपस्थिति और / या व्यवहार को बदलने की अनुमति देता है।

किसी भी संपत्ति के मूल्य को बदलने के लिए ट्रिगर का उपयोग किया जाता है, जब कुछ शर्तों को संतुष्ट किया जाता है। ट्रिगर आमतौर पर एक शैली में या उस दस्तावेज़ के मूल में परिभाषित किए जाते हैं जो उस विशिष्ट नियंत्रण पर लागू होते हैं। ट्रिगर तीन प्रकार के होते हैं -

  • संपत्ति ट्रिगर
  • डेटा ट्रिगर
  • इवेंट ट्रिगर

संपत्ति ट्रिगर

प्रॉपर्टी ट्रिगर्स में, जब एक प्रॉपर्टी में बदलाव होता है, तो यह या तो किसी अन्य प्रॉपर्टी में तत्काल या एनिमेटेड बदलाव लाएगा। उदाहरण के लिए, आप एक संपत्ति ट्रिगर का उपयोग कर सकते हैं यदि आप माउस के बटन के ऊपर होने पर बटन उपस्थिति को बदलना चाहते हैं।

उदाहरण

निम्नलिखित उदाहरण दर्शाता है कि जब माउस अपने क्षेत्र में प्रवेश करता है तो बटन के अग्रभूमि रंग को कैसे बदलना है।

<Window x:Class = "XAMLPropertyTriggers.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   Title = "MainWindow" Height = "350" Width = "604">
	
   <Window.Resources>
      <Style x:Key = "TriggerStyle" TargetType = "Button">
         <Setter Property = "Foreground" Value = "Blue" />
         <Style.Triggers>
            <Trigger Property = "IsMouseOver" Value = "True">
               <Setter Property = "Foreground" Value = "Green" />
            </Trigger> 
         </Style.Triggers>
      </Style>
   </Window.Resources>
	
   <Grid>
      <Button Width = "100" Height = "70" Style = "{StaticResource TriggerStyle}" 
         Content = "Trigger"/>
   </Grid>
	
</Window>

जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -

जब माउस बटन के क्षेत्र में प्रवेश करता है, तो अग्रभूमि का रंग हरे रंग में बदल जाएगा।

डेटा ट्रिगर

एक डेटा ट्रिगर कुछ कार्रवाई करता है जब बाध्य डेटा कुछ स्थिति को संतुष्ट करता है। आइए निम्नलिखित XAML कोड पर एक नज़र डालें जिसमें कुछ गुणों के साथ एक चेकबॉक्स और एक टेक्स्ट ब्लॉक बनाया जाता है। जब चेकबॉक्स की जाँच की जाती है, तो यह अग्रभूमि रंग को लाल में बदल देगा।

<Window x:Class = "XAMLDataTrigger.MainWindow" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   Title = "Data Trigger" Height = "350" Width = "604">
	
   <StackPanel HorizontalAlignment = "Center">
      <CheckBox x:Name = "redColorCheckBox" Content = "Set red as foreground color" Margin = "20"/>
		
      <TextBlock Name = "txtblock" VerticalAlignment = "Center" 
         Text = "Event Trigger" FontSize = "24" Margin = "20">
         <TextBlock.Style>
            <Style>
               <Style.Triggers>
                  <DataTrigger Binding = "{Binding ElementName = redColorCheckBox, Path = IsChecked}" 
                     Value = "true">
                     <Setter Property = "TextBlock.Foreground" Value = "Red"/>
                     <Setter Property = "TextBlock.Cursor" Value = "Hand" />
                  </DataTrigger>
               </Style.Triggers>
            </Style>
         </TextBlock.Style>
      </TextBlock>
   </StackPanel>
	
</Window>

जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -

जब चेकबॉक्स चेक किया जाता है, तो टेक्स्ट ब्लॉक का अग्रभूमि रंग लाल में बदल जाएगा।

इवेंट ट्रिगर

जब कोई विशिष्ट घटना निकाल दी जाती है तो एक इवेंट ट्रिगर कुछ कार्रवाई करता है। यह आमतौर पर कुछ एनीमेशन को पूरा करने के लिए उपयोग किया जाता है जैसे कि DoubleAnimation, ColorAnimation, आदि। निम्नलिखित कोड ब्लॉक एक साधारण बटन बनाता है। जब क्लिक इवेंट को निकाल दिया जाता है, तो यह बटन की चौड़ाई और ऊंचाई का विस्तार करेगा।

<Window x:Class = "XAMLEventTrigger.MainWindow"
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   Title = "MainWindow" Height = "350" Width = "604">
	
   <Grid>
      <Button Content = "Click Me" Width = "60" Height = "30">
         <Button.Triggers>
            <EventTrigger RoutedEvent = "Button.Click">
               <EventTrigger.Actions>
                  <BeginStoryboard>
                     <Storyboard>
                     
                        <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty = "Width" Duration = "0:0:4">
                           <LinearDoubleKeyFrame Value = "60" KeyTime = "0:0:0"/>
                           <LinearDoubleKeyFrame Value = "120" KeyTime = "0:0:1"/>
                           <LinearDoubleKeyFrame Value = "200" KeyTime = "0:0:2"/>
                           <LinearDoubleKeyFrame Value = "300" KeyTime = "0:0:3"/>
                        </DoubleAnimationUsingKeyFrames>
							
                        <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty = "Height" Duration = "0:0:4">
                           <LinearDoubleKeyFrame Value = "30" KeyTime = "0:0:0"/>
                           <LinearDoubleKeyFrame Value = "40" KeyTime = "0:0:1"/>
                           <LinearDoubleKeyFrame Value = "80" KeyTime = "0:0:2"/>
                           <LinearDoubleKeyFrame Value = "150" KeyTime = "0:0:3"/>
                        </DoubleAnimationUsingKeyFrames>
							
                     </Storyboard>
                  </BeginStoryboard>
               </EventTrigger.Actions>
            </EventTrigger>
         </Button.Triggers>
      </Button>
   </Grid>
</Window>

जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित आउटपुट का उत्पादन करेगा -

अब, बटन पर क्लिक करें और आप देखेंगे कि यह दोनों आयामों में विस्तार करना शुरू कर देगा।