Silverlight - Baskı
Baskı, belirli türden uygulamalar için önemli bir özelliktir. Bu bölümde Silverlight'taki ilgili tesislere bakacağız.
Yazdırma API'leri ve yazdırmak istiyorlarsa tüm Silverlight uygulamalarının gerçekleştirmesi gereken temel adımlar. Su baskısını seçmek için çeşitli seçenekler.
En basit olanı, ekranda zaten bulunan kullanıcı arabirimi öğelerinin bir kopyasını yazdırmaktır.
Çoğu uygulama bundan biraz daha gelişmiş olmak ve özellikle baskıya uyarlanmış içerik oluşturmak isteyecektir ve bazı durumlarda, içeriği birden çok sayfaya bölmek gerekecektir.
Yazdırma Adımları
İster bir anlık görüntüyü veya halihazırda ekranda olan bir şeyi yazdırıyor olun, ister tamamen özelleştirilmiş bir çok sayfalı baskı çıktısı almak için aynı temel adımlar gereklidir.
Yazdırma API'sinin merkezinde PrintDocument sınıfı bulunur.
Bunlardan birini oluşturarak başlarsınız ve bunun Yazdırma yöntemini çağırdığınızda, bir yazdırma işini başlatmak için standart kullanıcı arayüzünü gösterir.
Kullanıcı bir yazıcı seçebilir ve her zamanki gibi ayarları yapılandırabilir. Kullanıcı daha sonra tıklayarak devam etmeye karar verirsePrint, PrintDocument hemen yükseltecek PrintPage olay ve bu olay için işleyiciniz yazdırılacak içeriği sağlar.
Olay argümanı bir PageVisual bu amaç için mülk.
Bunu, ekranda görünen herhangi bir Silverlight kullanıcı arabirimi öğesine veya özellikle yazdırma için oluşturduğunuz yeni bir öğeye ayarlayabilirsiniz.
Mevcut Öğeleri Yazdırma
Öğeler En basit seçenek, Silverlight uygulamanızda zaten ekranda bulunan içeriği yazdırmaktır. BeriPrintPage olay argümanları PageVisual, herhangi bir kullanıcı arayüzü elemanını kabul ederse, kullanıcı arayüzünüzden istediğinizi seçebilir ve yazdırabilirsiniz.
Bir ekran görüntüsü almak için PrintScreen tuşunu kullanmaktan sadece küçük bir adımdır. Bundan marjinal olarak daha iyidir çünkü kullanıcının ekran görüntüsünü kırpmak ve yazdırmak için başka bir programa manuel olarak yapıştırması gerekmez. Hala sadece küçük bir gelişme.
Zaten ekranda olan içeriğin yazdırılması sorunludur.
Her şeyden önce, ekranda çalışan bir düzenin kağıt için iyi çalışacağının garantisi yoktur.
Basit bir örneğe bakalım. ScrollViewerekrana uyarlanmış bazı UI öğeleri ve düzenini içerir. Tarayıcı pencere boyutuna göre yeniden boyutlandırılır ve sığmasa bile her şeyin erişilebilir olmasını sağlamak için kaydırma çubukları sunar.
Aşağıda verilen XAML kodudur.
<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>
İşte Print button tıklama-olay uygulaması, ScrollViewer ve görünür verileri.
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;
}
}
}
Gördüğünüz gibi Print button click event o PrintDocument nesne oluşturulursa, PrintPage olayına bir işleyici ekleriz.
Sen ayarlayabilirsiniz PageVisual başvurulacak mülk ScrollViewer.
Sonra Print methoddenir. Bu, yazdırma kuyruğunda iş adı olarak görünecek bir dizeyi alır.
Yukarıdaki kod derlendiğinde ve çalıştırıldığında, aşağıdaki çıktıyı göreceksiniz.
Tıkladığınızda Print düğmesi, standart Yazdır iletişim kutusunu göreceksiniz.
Şimdi varsayılan yazıcıyı seçin. Gösteri amacıyla seçelimOneNote ve tıklayın Printbuton. Bunu göreceksinScrollViewer basılmıştır.
Kaydırma çubuklarının hala ekranda göründüğüne dikkat edin. ScrollViewer.
Özel Kullanıcı Arayüzü Ağacı
Zaten ekranda olan içeriği yazdırmak yerine, özellikle yazdırma için bir kullanıcı arabirimi öğeleri ağacı oluşturmak genellikle daha mantıklıdır. Bu şekilde, kağıt üzerinde yalnızca etkileşimli olmayan öğeleri kullandığınızdan emin olabilir ve kağıt şekline ve boyutuna daha uygun özel bir düzen oluşturabilirsiniz. Yalnızca yazdırmak için bir UserControl oluşturabilirsiniz.
Bir Silverlight projesi oluşturarak basit bir örneğe bakalım ve UserControl aranan PrintLayout.
Tasarım zamanı genişliğini ve yüksekliğini yaklaşık olarak kağıt şeklinde olacak şekilde ayarlayın. Aşağıda verilen XAML koduPrintLayout.xaml dosya.
<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>
Aşağıda verilen kod, MainPage.xaml içeren bir dosya Print sadece düğme.
<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>
İşte Click event baskı düğmesi için uygulama.
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;
}
}
}
Yukarıdaki kod derlenip çalıştırıldığında, web sayfasında aşağıdaki çıktıyı göreceksiniz.
Tıklayın Print ve seçin OneNotedüzeni yazdırmak için. Düzenin yazdırıldığını göreceksiniz.
Mevcut alanı doldurduğunu görebilirsiniz. Daha iyi anlamak için yukarıdaki örnekleri uygulamanızı tavsiye ederiz.