सिल्वरलाइट - प्रिंटिंग

कुछ प्रकार के अनुप्रयोगों के लिए मुद्रण एक महत्वपूर्ण क्षमता है। इस अध्याय में, हम सिल्वरलाइट में संबंधित सुविधाओं को देखेंगे।

  • मुद्रण एपीआई, और मूल कदम है कि सभी सिल्वरलाइट अनुप्रयोगों प्रदर्शन करना चाहिए अगर वे मुद्रित करना चाहते हैं। वाटर प्रिंट चुनने के लिए विभिन्न विकल्प।

  • सबसे सरल उपयोगकर्ता इंटरफ़ेस तत्वों की एक प्रति प्रिंट करना है जो पहले से ही स्क्रीन पर हैं।

  • अधिकांश अनुप्रयोग इस से थोड़ा अधिक उन्नत प्राप्त करना चाहते हैं, और विशेष रूप से मुद्रण के लिए अनुकूलित सामग्री उत्पन्न करते हैं, और कुछ मामलों में, सामग्री को कई पृष्ठों में विभाजित करना आवश्यक होगा।

मुद्रण के लिए कदम

चाहे आप एक स्नैपशॉट प्रिंट कर रहे हों या स्क्रीन पर कुछ पहले से ही, या पूरी तरह से अनुकूलित मल्टी-पेज प्रिंट आउटपुट के लिए जा रहे हों, उसी मूल चरणों की आवश्यकता है।

  • मुद्रण एपीआई के दिल में PrintDocument वर्ग है।

  • आप इनमें से किसी एक का निर्माण शुरू करते हैं, और जब आप इसकी प्रिंट विधि कहते हैं, तो यह प्रिंट कार्य शुरू करने के लिए मानक उपयोगकर्ता इंटरफ़ेस दिखाता है।

  • उपयोगकर्ता एक प्रिंटर का चयन कर सकता है और हमेशा की तरह सेटिंग्स को कॉन्फ़िगर कर सकता है। यदि उपयोगकर्ता क्लिक करके आगे बढ़ने का फैसला करता हैPrint, को PrintDocument तुरंत उसका पालन-पोषण करेंगे PrintPage घटना, और उस घटना के लिए आपका हैंडलर मुद्रित होने वाली सामग्री की आपूर्ति करता है।

  • घटना तर्क एक प्रदान करता है PageVisual इस उद्देश्य के लिए संपत्ति।

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

मौजूदा तत्वों की छपाई

तत्व सबसे आसान विकल्प उस सामग्री को प्रिंट करना है जो आपके सिल्वरलाइट एप्लिकेशन में स्क्रीन पर पहले से मौजूद है। के बाद सेPrintPage घटना के तर्क PageVisualकिसी भी उपयोगकर्ता इंटरफ़ेस तत्वों को स्वीकार करता है, आप अपने उपयोगकर्ता इंटरफ़ेस में कुछ भी चुन सकते हैं, और इसे प्रिंट कर सकते हैं।

  • स्क्रीनशॉट हथियाने के लिए PrintScreen कुंजी का उपयोग करने से यह केवल एक छोटा कदम है। यह उससे थोड़ा बेहतर है क्योंकि उपयोगकर्ता को इसे क्रॉप करने और प्रिंट करने के लिए किसी अन्य प्रोग्राम में स्क्रीनशॉट को मैन्युअल रूप से पेस्ट करने की आवश्यकता नहीं है। यह अभी भी केवल एक मामूली सुधार है।

  • मुद्रण सामग्री जो पहले से ही स्क्रीन पर है वह समस्याग्रस्त है।

  • सबसे पहले, कोई गारंटी नहीं है कि स्क्रीन पर काम करने वाला एक लेआउट कागज के लिए अच्छी तरह से काम करेगा।

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

नीचे XAML कोड दिया गया है।

<UserControl 
   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:sdk = "http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk" 
   x:Class = "SilverlightPrinting.MainPage" 
   mc:Ignorable = "d" 
   d:DesignHeight = "300" d:DesignWidth = "500">
	
   <Grid x:Name = "LayoutRoot" Background = "White">
	
      <Button x:Name = "print" Content = "Print" Click = "print_Click" Width = "60" 
         Height = "20" Margin = "10,10,430,270"/>
			
      <ScrollViewer x:Name = "myScrollViewer" 
         HorizontalScrollBarVisibility = "Auto" 
         VerticalScrollBarVisibility = "Auto" 
         Width = "400" Margin = "90,0,10,0">
			
         <StackPanel>
            <Rectangle Fill = "Gray" Width = "100" Height = "100" /> 
            <Button x:Name = "button" Content = "Button" Width = "75"/> 
            <sdk:Calendar Height = "169" Width = "230"/> 
            <Rectangle Fill = "AliceBlue" Width = "475" Height = "100" /> 
         </StackPanel> 
				
      </ScrollViewer> 
		
   </Grid> 
	
</UserControl>

यहाँ है Print button क्लिक-इवेंट कार्यान्वयन, जो प्रिंट करेगा ScrollViewer और इसके दृश्यमान डेटा।

using System; 
using System.Windows; 
using System.Windows.Controls; 
using System.Windows.Printing; 
 
namespace SilverlightPrinting { 

   public partial class MainPage : UserControl { 
	
      public MainPage() { 
         InitializeComponent(); 
      }
	  
      private void print_Click(object sender, RoutedEventArgs e) { 
         PrintDocument pd = new PrintDocument(); 
         pd.PrintPage += new System.EventHandler<PrintPageEventArgs>(pd_PrintPage);  
         pd.Print("Print Screen Content"); 
      }
	  
      private void pd_PrintPage(object sender, PrintPageEventArgs e) { 
         e.PageVisual = myScrollViewer; 
      } 
   } 
}
  • जैसा कि आप देख सकते हैं, में Print button click event उस PrintDocument ऑब्जेक्ट बनाया जाता है, हम एक हैंडलर को उसके PrintPage इवेंट में संलग्न करते हैं।

  • आप सेट कर सकते हैं PageVisual संपत्ति को संदर्भित करने के लिए ScrollViewer

  • फिर Print methodकहा जाता है। यह एक स्ट्रिंग लेता है, जो प्रिंट कतार में काम के नाम के रूप में दिखाई देगा।

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

जब आप क्लिक करें Print बटन, आपको मानक प्रिंट संवाद दिखाई देगा।

अब, डिफ़ॉल्ट प्रिंटर का चयन करें। प्रदर्शन के उद्देश्य के लिए, हमें चुनेंOneNote और क्लिक करें Printबटन। आप देखेंगे किScrollViewer छपा है।

ध्यान दें कि स्क्रॉल बार अभी भी दिखाई दे रहे हैं ScrollViewer

कस्टम यूआई ट्री

मुद्रण सामग्री के बजाय जो पहले से ही ऑनस्क्रीन है, यह आमतौर पर उपयोगकर्ता इंटरफ़ेस तत्वों का एक पेड़ बनाने के लिए अधिक समझ में आता है विशेष रूप से मुद्रण के लिए। इस तरह, आप यह सुनिश्चित कर सकते हैं कि आप कागज पर केवल गैर-संवादात्मक तत्वों का उपयोग करें, और आप एक विशेष लेआउट बना सकते हैं जो कागज के आकार और आकार के लिए बेहतर है। आप केवल मुद्रण के लिए एक UserControl बना सकते हैं।

चलिए सिल्वरलाइट प्रोजेक्ट बनाकर एक सरल उदाहरण देखते हैं UserControl बुलाया PrintLayout

लगभग समय के आकार का होने के लिए डिज़ाइन समय की चौड़ाई और ऊंचाई निर्धारित करें। नीचे दिया गया XAML कोड हैPrintLayout.xaml फ़ाइल।

<UserControl x:Class = "PrintCustomUI.PrintLayout" 
   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" 
   mc:Ignorable = "d" 
   d:DesignHeight = "768" d:DesignWidth = "960">
   
   <Grid x:Name = "LayoutRoot" Background = "White"> 
	
      <Grid.RowDefinitions> 
         <RowDefinition Height = "Auto" /> 
         <RowDefinition /> 
         <RowDefinition Height = "Auto" /> 
      </Grid.RowDefinitions> 
		
      <TextBlock Text = "Silverlight" HorizontalAlignment = "Center"
         FontSize = "60" FontWeight = "Bold" FontFamily = "Georgia" />
				
      <TextBlock Grid.Row = "2" Text = "Print Testing" 
         HorizontalAlignment = "Center" FontFamily = "Georgia" 
         FontSize = "24" Margin = "0,10"/> 
				
      <Rectangle Grid.Row = "2" Height = "1" Fill = "Black" 
         VerticalAlignment = "Top"/> 
				
      <Ellipse Grid.Row = "1" Stroke = "Black" StrokeThickness = "10" Margin = "10">
				
         <Ellipse.Fill>
			
            <RadialGradientBrush 
               GradientOrigin = "0.2,0.2" 
               Center = "0.4,0.4"> 
               <GradientStop Color = "Aqua" Offset = "0.006" /> 
               <GradientStop Color = "AntiqueWhite" Offset = "1" /> 
            </RadialGradientBrush>
				
         </Ellipse.Fill>
			
      </Ellipse> 
		
   </Grid> 
	
</UserControl>

नीचे दिए गए कोड में है MainPage.xaml फ़ाइल, जिसमें ए Print केवल बटन।

<UserControl x:Class = "PrintCustomUI.MainPage" 
   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" 
   mc:Ignorable = "d" 
   d:DesignHeight = "300" d:DesignWidth = "400">
   
   <Grid x:Name = "LayoutRoot" Background = "White"> 
	
      <Button Content = "Print..." Height = "23" HorizontalAlignment = "Left"  
         Margin = "12,28,0,0" Name = "printButton"  
         VerticalAlignment = "Top" Width = "75"  
         Click = "printButton_Click" />
			
   </Grid> 
	
</UserControl>

यहाँ है Click event प्रिंट बटन के लिए कार्यान्वयन।

using System; 
using System.Collections.Generic; 
using System; 

using System.Windows; 
using System.Windows.Controls; 
using System.Windows.Printing;
  
namespace PrintCustomUI { 

   public partial class MainPage : UserControl { 
	
      public MainPage() { 
         InitializeComponent(); 
      }
	  
      private void printButton_Click(object sender, RoutedEventArgs e) { 
         PrintDocument pd = new PrintDocument(); 
         pd.PrintPage += new EventHandler<PrintPageEventArgs>(pd_PrintPage);
         pd.Print("Custom"); 
      }
	  
      void pd_PrintPage(object sender, PrintPageEventArgs e) { 
         var pl = new PrintLayout(); 
         pl.Width = e.PrintableArea.Width; 
         pl.Height = e.PrintableArea.Height; 
         e.PageVisual = pl; 
      } 
   } 
}

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

क्लिक Print और चुनें OneNoteलेआउट मुद्रित करने के लिए। आप देखेंगे कि लेआउट मुद्रित है।

आप देख सकते हैं कि इसने उपलब्ध स्थान को भर दिया है। हम आपको बेहतर समझ के लिए उपरोक्त उदाहरणों को निष्पादित करने की सलाह देते हैं।