WPF - टेम्प्लेट
एक टेम्पलेट एक नियंत्रण के समग्र रूप और दृश्य उपस्थिति का वर्णन करता है। प्रत्येक नियंत्रण के लिए, इसके साथ एक डिफ़ॉल्ट टेम्पलेट जुड़ा हुआ है जो नियंत्रण को अपनी उपस्थिति देता है। WPF अनुप्रयोगों में, आप आसानी से अपना स्वयं का टेम्प्लेट बना सकते हैं जब आप दृश्य व्यवहार और नियंत्रण के दृश्य स्वरूप को अनुकूलित करना चाहते हैं।
तर्क और टेम्पलेट के बीच कनेक्टिविटी डेटा बाइंडिंग द्वारा प्राप्त की जा सकती है। के बीच मुख्य अंतरstyles तथा templates नीचे सूचीबद्ध हैं -
शैलियाँ केवल उस नियंत्रण के डिफ़ॉल्ट गुणों के साथ आपके नियंत्रण की उपस्थिति को बदल सकती हैं।
टेम्पलेट्स के साथ, आप शैलियों की तुलना में नियंत्रण के अधिक हिस्सों तक पहुंच सकते हैं। आप एक नियंत्रण के मौजूदा और नए व्यवहार दोनों को भी निर्दिष्ट कर सकते हैं।
दो प्रकार के टेम्प्लेट हैं जो सबसे अधिक उपयोग किए जाते हैं -
- नियंत्रण टेम्पलेट
- डेटा टेम्प्लेट
नियंत्रण टेम्पलेट
नियंत्रण टेम्पलेट नियंत्रण की दृश्य उपस्थिति को परिभाषित करता है। यूआई तत्वों के सभी प्रकार के रूप में अच्छी तरह से व्यवहार है, जैसे, बटन एक उपस्थिति और व्यवहार है। क्लिक इवेंट या माउस हॉवर ईवेंट वे व्यवहार हैं, जो एक क्लिक और होवर के जवाब में निकाल दिए जाते हैं और बटन का डिफ़ॉल्ट रूप भी होता है जिसे नियंत्रण टेम्पलेट द्वारा बदला जा सकता है।
उदाहरण
एक सरल उदाहरण लेते हैं। हम दो बटन बनाएंगे (एक टेम्पलेट के साथ है और दूसरा डिफ़ॉल्ट बटन है) और उन्हें कुछ गुणों के साथ प्रारंभ करें।
<Window x:Class = "TemplateDemo.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>
<ControlTemplate x:Key = "ButtonTemplate" TargetType = "Button">
<Grid>
<Ellipse x:Name = "ButtonEllipse" Height = "100" Width = "150" >
<Ellipse.Fill>
<LinearGradientBrush StartPoint = "0,0.2" EndPoint = "0.2,1.4">
<GradientStop Offset = "0" Color = "Red" />
<GradientStop Offset = "1" Color = "Orange" />
</LinearGradientBrush>
</Ellipse.Fill>
</Ellipse>
<ContentPresenter Content = "{TemplateBinding Content}"
HorizontalAlignment = "Center" VerticalAlignment = "Center" />
</Grid>
<ControlTemplate.Triggers>
<Trigger Property = "IsMouseOver" Value = "True">
<Setter TargetName = "ButtonEllipse" Property = "Fill" >
<Setter.Value>
<LinearGradientBrush StartPoint = "0,0.2" EndPoint = "0.2,1.4">
<GradientStop Offset = "0" Color = "YellowGreen" />
<GradientStop Offset = "1" Color = "Gold" />
</LinearGradientBrush>
</Setter.Value>
</Setter>
</Trigger>
<Trigger Property = "IsPressed" Value = "True">
<Setter Property = "RenderTransform">
<Setter.Value>
<ScaleTransform ScaleX = "0.8" ScaleY = "0.8"
CenterX = "0" CenterY = "0" />
</Setter.Value>
</Setter>
<Setter Property = "RenderTransformOrigin" Value = "0.5,0.5" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Window.Resources>
<StackPanel>
<Button Content = "Round Button!"
Template = "{StaticResource ButtonTemplate}"
Width = "150" Margin = "50" />
<Button Content = "Default Button!" Height = "40"
Width = "150" Margin = "5" />
</StackPanel>
</Window>
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित MainWindow प्रदर्शित करेगा।
जब आप माउस को कस्टम टेम्प्लेट के साथ बटन पर ले जाते हैं, तो यह नीचे दिखाए गए अनुसार अपना रंग बदल देगा।
डेटा टेम्प्लेट
डेटा टेम्प्लेट डेटा के संग्रह की उपस्थिति और संरचना को परिभाषित और निर्दिष्ट करता है। यह किसी भी यूआई तत्व पर डेटा की प्रस्तुति को प्रारूपित करने और परिभाषित करने के लिए लचीलापन प्रदान करता है। इसका उपयोग ज्यादातर डेटा से संबंधित आइटम नियंत्रणों जैसे कि कॉम्बो बॉक्स, लिस्टबॉक्स आदि पर किया जाता है।
उदाहरण
चलो डेटा टेम्पलेट की अवधारणा को समझने के लिए एक सरल उदाहरण लेते हैं। नाम के साथ एक नया WPF प्रोजेक्ट बनाएंWPFDataTemplates।
निम्नलिखित XAML कोड में, हम लेबल और टेक्स्टबॉक्स रखने के लिए संसाधन के रूप में एक डेटा टेम्पलेट बनाएंगे। एक बटन और एक सूची बॉक्स के साथ ही डेटा प्रदर्शित करने के लिए है।
<Window x:Class = "WPFDataTemplates.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006"
xmlns:local = "clr-namespace:WPFDataTemplates"
xmlns:loc = "clr-namespace:WPFDataTemplates"
mc:Ignorable = "d" Title = "MainWindow" Height = "350" Width = "525">
<Window.Resources>
<DataTemplate DataType = "{x:Type loc:Person}">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "Auto" />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width = "Auto" />
<ColumnDefinition Width = "200" />
</Grid.ColumnDefinitions>
<Label Name = "nameLabel" Margin = "10"/>
<TextBox Name = "nameText" Grid.Column = "1" Margin = "10"
Text = "{Binding Name}"/>
<Label Name = "ageLabel" Margin = "10" Grid.Row = "1"/>
<TextBox Name = "ageText" Grid.Column = "1" Grid.Row = "1" Margin = "10"
Text = "{Binding Age}"/>
</Grid>
</DataTemplate>
</Window.Resources>
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height = "Auto" />
<RowDefinition Height = "*" />
</Grid.RowDefinitions>
<ListBox ItemsSource = "{Binding}" />
<StackPanel Grid.Row = "1" >
<Button Content = "_Show..." Click = "Button_Click" Width = "80" HorizontalAlignment = "Left" Margin = "10"/>
</StackPanel>
</Grid>
</Window>
यहाँ है implementation in C# जिसमें व्यक्ति की एक सूची DataContext को सौंपी जाती है, व्यक्ति वर्ग का कार्यान्वयन और बटन क्लिक घटना।
using System.Collections.Generic;
using System.Windows;
namespace WPFDataTemplates {
public partial class MainWindow : Window {
Person src = new Person { Name = "Ali", Age = 27 };
List<Person> people = new List<Person>();
public MainWindow() {
InitializeComponent();
people.Add(src);
people.Add(new Person { Name = "Mike", Age = 62 });
people.Add(new Person { Name = "Brian", Age = 12 });
this.DataContext = people;
}
private void Button_Click(object sender, RoutedEventArgs e) {
string message = src.Name + " is " + src.Age;
MessageBox.Show(message);
}
}
public class Person {
private string nameValue;
public string Name {
get { return nameValue; }
set { nameValue = value; }
}
private double ageValue;
public double Age {
get { return ageValue; }
set {
if (value != ageValue) {
ageValue = value;
}
}
}
}
}
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा। इसमें एक सूची होती है और सूची बॉक्स के अंदर, प्रत्येक सूची बॉक्स आइटम में व्यक्ति वर्ग ऑब्जेक्ट डेटा होता है जो लेबल और टेक्स्ट बॉक्स पर प्रदर्शित होते हैं।