WPF实现可视化控件打印及打印预览

打印预览XAML代码:

<controls:WindowEx x:Class="SunCreate.Vipf.Client.UI.MapPrintPreview"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
             xmlns:controls="clr-namespace:SunCreate.Common.Controls;assembly=SunCreate.Common.Controls"
             mc:Ignorable="d" 
             d:DesignHeight="700" d:DesignWidth="1000" Loaded="WindowEx_Loaded">
    <Window.Resources>
        <ResourceDictionary>
            <!-- 文字按钮 -->
            <Style x:Key="stlTxtBtn" TargetType="{x:Type Button}">
                <Setter Property="Template">
                    <Setter.Value>
                        <ControlTemplate TargetType="{x:Type Button}">
                            <Border Background="Transparent">
                                <Border x:Name="bd" Background="{TemplateBinding Background}" CornerRadius="2" Padding="{TemplateBinding Padding}">
                                    <TextBlock x:Name="txt" VerticalAlignment="Center" HorizontalAlignment="Center" Margin="5 2 5 2"  Foreground="White" ><InlineUIContainer>
                                            <ContentPresenter />
                                        </InlineUIContainer></TextBlock>
                                </Border>
                            </Border>
                            <ControlTemplate.Triggers>
                                <Trigger Property="IsMouseOver" Value="true">
                                    <Setter TargetName="bd" Property="Background" Value="#33c4f5"/>
                                </Trigger>
                                <Trigger Property="IsPressed" Value="true">
                                    <Setter TargetName="txt" Property="FontSize" Value="11"/>
                                </Trigger>
                            </ControlTemplate.Triggers>
                        </ControlTemplate>
                    </Setter.Value>
                </Setter>
            </Style>
        </ResourceDictionary>
    </Window.Resources>
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="38"></RowDefinition>
            <RowDefinition></RowDefinition>
        </Grid.RowDefinitions>
        <Border Background="#f0f0f0">
            <Button x:Name="btnPrint" Margin="10 0 0 0" Background="#1aa4f5" Width="60" Height="28" HorizontalAlignment="Left" FontSize="12" Style="{StaticResource stlTxtBtn}" Click="btnPrint_Click" Content="打印"></Button>
        </Border>
        <Border Grid.Row="1" Background="#a0a0a0">
            <ScrollViewer HorizontalScrollBarVisibility="Auto" VerticalScrollBarVisibility="Auto">
                <!-- 该Border设置成固定A4纸大小 -->
                <Border Background="#fff" Margin="10" Width="842" Height="595">
                    <!-- 该Border可缩放至打印纸 -->
                    <Border x:Name="border">
                        <Image x:Name="img" Margin="10" Stretch="Uniform" Source="{Binding Image}" HorizontalAlignment="Left" VerticalAlignment="Top" ></Image>
                    </Border>
                </Border>
            </ScrollViewer>
        </Border>
    </Grid>
</controls:WindowEx>
View Code

打印预览后台代码(注意:打印的是Border不是Image):

using SunCreate.Common.Controls;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Printing;
using System.Text;
using System.Threading.Tasks;
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 SunCreate.Vipf.Client.UI
{
    /// <summary>
    /// 地图打印预览
    /// </summary>
    public partial class MapPrintPreview : WindowEx
    {
        /// <summary>
        /// 需要打印预览的控件
        /// </summary>
        private FrameworkElement _element;

        private BitmapImage _Image;
        public BitmapImage Image
        {
            get
            {
                return _Image;
            }
            set
            {
                _Image = value;
                OnPropertyChanged("Image");
            }
        }

        public MapPrintPreview(FrameworkElement element)
        {
            InitializeComponent();
            this.DataContext = this;
            _element = element;
        }

        private void WindowEx_Loaded(object sender, RoutedEventArgs e)
        {
            int width = (int)_element.ActualWidth;
            int height = (int)_element.ActualHeight;
            RenderTargetBitmap renderTargetBitmap = new RenderTargetBitmap(width, height, 96, 96, PixelFormats.Pbgra32);
            renderTargetBitmap.Render(_element);
            BmpBitmapEncoder bmpBitmapEncoder = new BmpBitmapEncoder();
            bmpBitmapEncoder.Frames.Add(BitmapFrame.Create(renderTargetBitmap));
            MemoryStream memoryStream = new MemoryStream();
            bmpBitmapEncoder.Save(memoryStream);
            memoryStream.Position = 0;
            BitmapImage bitmapImage = new BitmapImage();
            bitmapImage.BeginInit();
            bitmapImage.StreamSource = memoryStream;
            bitmapImage.EndInit();
            Image = bitmapImage;
        }

        private void btnPrint_Click(object sender, RoutedEventArgs e)
        {
            PrintDialog printDialog = new PrintDialog();
            printDialog.PrintTicket.PageOrientation = PageOrientation.Landscape;
            if (printDialog.ShowDialog() == true)
            {
                printDialog.PrintVisual(border, "打印地图");
            }
        }

    }
}
View Code

打印预览效果图(说明:地图没数据所以都是空白;地图下面空白,是因为地图尺寸长宽比例和A4纸比例不同,缩放到A4纸):

 

点击“打印”弹出系统的打印对话框。这个功能做的不是很理想,只是简单实现了预览与打印,没有达到我想要的效果。

 

转载于:https://www.cnblogs.com/s0611163/p/10147705.html

如果你想在 WPF打印窗口中只打印部分内容,你可以使用 `PrintDialog` 类和 `PrintVisual` 方法结合其他可视化控件实现。下面是一个示例代码,演示如何在 WPF 中只打印部分内容: ```csharp using System.Printing; using System.Windows; using System.Windows.Controls; private void ShowPrintPreview() { PrintDialog printDialog = new PrintDialog(); // 检查是否支持打印 if (printDialog.ShowDialog() == true) { // 创建一个 StackPanel,并将部分内容添加到其中 StackPanel stackPanel = new StackPanel(); stackPanel.Children.Add(new TextBlock() { Text = "打印的部分内容" }); stackPanel.Children.Add(new Button() { Content = "Print Me" }); // 设置打印的尺寸和边距 stackPanel.Measure(new Size(printDialog.PrintableAreaWidth, printDialog.PrintableAreaHeight)); stackPanel.Arrange(new Rect(new Point(0, 0), stackPanel.DesiredSize)); // 打印预览 printDialog.PrintVisual(stackPanel, "打印预览"); } } ``` 在上面的示例代码中,首先创建了一个 `PrintDialog` 对象,并通过 `ShowDialog` 方法显示打印对话框。如果用户选择了打印选项并点击了确定按钮,就会进入下一步。 然后,创建一个 `StackPanel` 对象,并将要打印的部分内容添加到其中(在示例中是一个 `TextBlock` 和一个 `Button`)。你可以根据需要自定义内容。 接着,使用 `Measure` 和 `Arrange` 方法来设置打印的尺寸和边距。 最后,调用 `PrintVisual` 方法将 `StackPanel` 对象传递给 `PrintDialog`,并指定打印作业的名称(在示例中是 "打印预览")。 这样就可以实现WPF打印窗口中只打印部分内容了。请根据你的具体需求修改示例代码中的内容,并确保在调用 `PrintVisual` 方法之前进行正确的测量和布局操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值