WPF - डिबगिंग
यह कोड के एक टुकड़े में बग या दोषों की पहचान करने और उन्हें ठीक करने का एक व्यवस्थित तंत्र है, जो आपसे अपेक्षा के अनुरूप व्यवहार नहीं कर रहे हैं। एक जटिल एप्लिकेशन को डिबग करना जहां सबसिस्टम कसकर युग्मित हैं, यह इतना आसान नहीं है, क्योंकि एक सबसिस्टम में बग को ठीक करने से दूसरे सबसिस्टम में बग बन सकते हैं।
सी # में डिबगिंग
WPF अनुप्रयोगों में, प्रोग्रामर दो भाषाओं जैसे C # और XAML से निपटते हैं। यदि आप किसी प्रक्रियात्मक भाषा जैसे C # या C / C ++ में डिबगिंग से परिचित हैं और आपको ब्रेक पॉइंट के उपयोग का भी पता है, तो आप अपने एप्लिकेशन के C # भाग को आसानी से डीबग कर सकते हैं।
आइए एक सरल उदाहरण लेते हैं कि C # कोड डिबग कैसे करें। नाम के साथ एक नया WPF प्रोजेक्ट बनाएंWPFDebuggingDemo। टूलबॉक्स से चार लेबल, तीन टेक्स्टबॉक्स और एक बटन खींचें। निम्नलिखित XAML कोड पर एक नज़र डालें।
<Window x:Class = "WPFDebuggingDemo.Window1"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Title = "Window1" Height = "400" Width = "604">
<Grid>
<TextBox Height = "23" Margin = "0,44,169,0" Name = "textBox1"
VerticalAlignment = "Top" HorizontalAlignment = "Right" Width = "120" />
<TextBox Height = "23" Margin = "0,99,169,0" Name = "textBox2"
VerticalAlignment = "Top" HorizontalAlignment = "Right" Width = "120" />
<TextBox HorizontalAlignment = "Right" Margin = "0,153,169,0"
Name = "textBox3" Width = "120" Height = "23" VerticalAlignment = "Top" />
<Label Height = "28" Margin = "117,42,0,0" Name = "label1"
VerticalAlignment = "Top" HorizontalAlignment = "Left" Width = "120">
Item 1</Label>
<Label Height = "28" HorizontalAlignment = "Left"
Margin = "117,99,0,0" Name = "label2" VerticalAlignment = "Top" Width = "120">
Item 2</Label>
<Label HorizontalAlignment = "Left" Margin = "117,153,0,181"
Name = "label3" Width = "120">Item 3</Label>
<Button Height = "23" HorizontalAlignment = "Right" Margin = "0,0,214,127"
Name = "button1" VerticalAlignment = "Bottom" Width = "75"
Click = "button1_Click">Total</Button>
<Label Height = "28" HorizontalAlignment = "Right"
Margin = "0,0,169,66" Name = "label4" VerticalAlignment = "Bottom" Width = "120"/>
</Grid>
</Window>
नीचे दिया गया C # कोड है जिसमें एक बटन क्लिक इवेंट लागू किया गया है।
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
namespace WPFDebuggingDemo {
/// <summary>
/// Interaction logic for Window1.xaml
/// </summary>
public partial class Window1 : Window {
public Window1() {
InitializeComponent();
}
private void button1_Click(object sender, RoutedEventArgs e) {
if (textBox1.Text.Length > 0 && textBox2.Text.Length > 0 && textBox2.Text.Length > 0) {
double total = Convert.ToDouble(textBox1.Text) +
Convert.ToDouble(textBox2.Text) + Convert.ToDouble(textBox3.Text);
label4.Content = total.ToString();
}
else {
MessageBox.Show("Enter the value in all field.");
}
}
}
}
जब आप उपरोक्त कोड को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित विंडो का उत्पादन करेगा। अब टेक्स्टबॉक्स में मान दर्ज करें और कुल बटन दबाएं। टेक्स्टबॉक्स में दर्ज सभी मानों के योग के बाद आपको कुल मूल्य मिलेगा।
यदि आप वास्तविक मूल्यों के अलावा अन्य मूल्यों को दर्ज करने का प्रयास करते हैं, तो उपरोक्त एप्लिकेशन क्रैश हो जाएगा। समस्या को खोजने और हल करने के लिए (यह दुर्घटनाग्रस्त क्यों है), आप बटन क्लिक घटना में ब्रेक पॉइंट सम्मिलित कर सकते हैं।
नीचे दिए गए अनुसार आइटम 1 में "एबीसी" लिखें।
कुल बटन पर क्लिक करने पर, आप देखेंगे कि कार्यक्रम विराम बिंदु पर बंद हो जाता है।
अब textbox1.Text की ओर कर्सर ले जाएँ और आप देखेंगे कि प्रोग्राम जोड़ने की कोशिश कर रहा है abc अन्य मानों के कारण जो प्रोग्राम क्रैश कर रहा है।
XAML में डिबगिंग
यदि आप XAML में उसी तरह के डिबगिंग की उम्मीद कर रहे हैं, तो आपको यह जानकर आश्चर्य होगा कि XAML कोड को डीबग करना अभी तक संभव नहीं है, जैसे किसी अन्य प्रक्रियात्मक भाषा कोड को डीबग करना। जब आप XAML कोड में डिबगिंग शब्द सुनते हैं, तो इसका मतलब है कि प्रयास करें और एक त्रुटि ढूंढें।
डेटा बाइंडिंग में, आपका डेटा स्क्रीन पर दिखाई नहीं देता है और आपको पता नहीं है कि क्यों
या एक समस्या जटिल लेआउट से संबंधित है।
या सूची बॉक्स और कॉम्बो बॉक्स जैसे कुछ व्यापक टेम्पलेट्स के साथ मार्जिन रंग, ओवरले आदि में एक संरेखण मुद्दा या मुद्दे।
XAML प्रोग्राम को डिबग करना कुछ ऐसा है जो आप आमतौर पर यह जांचने के लिए करते हैं कि क्या आपके बाइंडिंग काम करते हैं; और अगर यह काम नहीं कर रहा है, तो यह जांचने के लिए कि क्या गलत है। दुर्भाग्य से XAML बाइंडिंग में ब्रेकप्वाइंट सेट करना सिल्वरलाइट को छोड़कर संभव नहीं है, लेकिन हम डेटा बाइंडिंग त्रुटियों की जांच के लिए आउटपुट विंडो का उपयोग कर सकते हैं। डेटा बाइंडिंग में त्रुटि को खोजने के लिए निम्नलिखित XAML कोड पर एक नज़र डालते हैं।
<Window x:Class = "DataBindingOneWay.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>
<StackPanel Name = "Display">
<StackPanel Orientation = "Horizontal" Margin = "50, 50, 0, 0">
<TextBlock Text = "Name: " Margin = "10" Width = "100"/>
<TextBlock Margin = "10" Width = "100" Text = "{Binding FirstName}"/>
</StackPanel>
<StackPanel Orientation = "Horizontal" Margin = "50,0,50,0">
<TextBlock Text = "Title: " Margin = "10" Width = "100"/>
<TextBlock Margin = "10" Width = "100" Text = "{Binding Title}" />
</StackPanel>
</StackPanel>
</Grid>
</Window>
दो टेक्स्ट ब्लॉक की टेक्स्ट प्रॉपर्टीज़ को "नाम" और "शीर्षक" को स्टेटिक रूप से सेट किया जाता है, जबकि अन्य दो टेक्स्ट ब्लॉक टेक्स्ट प्रॉपर्टीज़ को "फर्स्टनाम" और "टाइटल" से बाँधते हैं, लेकिन क्लास वेरिएबल एंप्लॉयी क्लास में नाम और शीर्षक होते हैं जो नीचे दिखाया गया है।
हमने जानबूझकर एक गलत चर नाम लिखा है, ताकि यह समझने के लिए कि वांछित आउटपुट न दिखाए जाने पर हम इस प्रकार की गलती कहां पा सकते हैं।
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DataBindingOneWay {
public class Employee {
public string Name { get; set; }
public string Title { get; set; }
public static Employee GetEmployee() {
var emp = new Employee() {
Name = "Ali Ahmed", Title = "Developer"
};
return emp;
}
}
}
यहाँ C # कोड में MainWindow क्लास का कार्यान्वयन है।
using System;
using System.Windows;
using System.Windows.Controls;
namespace DataBindingOneWay {
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
DataContext = Employee.GetEmployee();
}
}
}
चलिए इस एप्लिकेशन को चलाते हैं और आप तुरंत हमारे मेनविंडो में देख सकते हैं कि हम सफलतापूर्वक उस कर्मचारी के शीर्षक से बंध गए हैं लेकिन नाम बाध्य नहीं है।
नाम के साथ क्या हुआ, यह जांचने के लिए, आइए आउटपुट विंडो में देखें, जहां बहुत अधिक लॉग जेनरेट होता है।
एक त्रुटि खोजने के लिए आसान बस त्रुटि की खोज करना है और आपको निम्नलिखित त्रुटि मिलेगी जो कहती है "बाइंडिंगप्रेशन पथ त्रुटि: 'FirstName' गुण 'ऑब्जेक्ट' 'Employe" पर नहीं मिला
System.Windows.Data Error: 40 : BindingExpression path error: 'FirstName'
property not found on 'object' ''Employee' (HashCode=11611730)'.
BindingExpression:Path = FirstName; DataItem = 'Employee' (HashCode = 11611730);
target element is 'TextBlock' (Name=''); target property is 'Text' (type 'String')
जो स्पष्ट रूप से इंगित करता है कि फर्स्टनाम कर्मचारी वर्ग का सदस्य नहीं है, इसलिए यह आपके आवेदन में इस प्रकार के मुद्दों को ठीक करने में मदद करता है।
जब आप FirstName को फिर से नाम में बदलते हैं, तो आप वांछित आउटपुट देखेंगे।
XAML के लिए UI डिबगिंग टूल
रन टाइम पर XAML कोड का निरीक्षण करने के लिए विजुअल स्टूडियो 2015 के साथ XAML के लिए UI डिबगिंग टूल पेश किए गए थे। इन उपकरणों की मदद से, XAML कोड आपके चल रहे WPF एप्लिकेशन के विज़ुअल ट्री के रूप में प्रस्तुत किया गया है और पेड़ में विभिन्न UI तत्व गुण भी हैं। इन उपकरणों को सक्षम करने के लिए, नीचे दिए गए चरणों का पालन करें।
- टूल मेनू पर जाएं और टूल मेनू से विकल्प चुनें।
- यह निम्नलिखित डायलॉग बॉक्स खोलेगा।
- बाईं ओर आइटम डीबगिंग के अंतर्गत सामान्य विकल्प पर जाएं।
- हाइलाइट किए गए विकल्प पर टिक करें, अर्थात, "XAML के लिए UI डिबगिंग उपकरण सक्षम करें" और ठीक बटन पर क्लिक करें।
अब कोई भी XAML एप्लिकेशन चलाएं या निम्नलिखित XAML कोड का उपयोग करें।
<Window x:Class = "XAMLTestBinding.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">
<StackPanel>
<ComboBox Name = "comboBox" Margin = "50" Width = "100">
<ComboBoxItem Content = "Green" />
<ComboBoxItem Content = "Yellow" IsSelected = "True" />
<ComboBoxItem Content = "Orange" />
</ComboBox>
<TextBox Name = "textBox" Margin = "50" Width = "100" Height = "23"
VerticalAlignment = "Top" Text =
"{Binding ElementName = comboBox, Path = SelectedItem.Content, Mode = TwoWay, UpdateSourceTrigger = PropertyChanged}"
Background = "{Binding ElementName = comboBox, Path = SelectedItem.Content}">
</TextBox>
</StackPanel>
</Window>
जब आप एप्लिकेशन निष्पादित करते हैं, तो यह लाइव विजुअल ट्री दिखाएगा जहां सभी तत्व एक पेड़ में दिखाए गए हैं।
यह लाइव विज़ुअल ट्री यह समझने के लिए पूरा लेआउट संरचना दिखाता है कि यूआई तत्व कहां स्थित हैं। लेकिन यह विकल्प केवल Visual Studio 2015 में उपलब्ध है। यदि आप Visual Studio के पुराने विकल्प का उपयोग कर रहे हैं, तो आप इस टूल का उपयोग नहीं कर सकते हैं, हालाँकि एक और उपकरण है जिसे Visual Studio जैसे XAML Spy for Visual Studio के साथ एकीकृत किया जा सकता है। । आप इसे xamlspy से डाउनलोड कर सकते हैं