当前位置:   article > 正文

一点一滴掌握WPF应用系列 - 之二:画刷使用 ImageBrush_wpf imagebrush

wpf imagebrush

        ImageBrush 使用ImageSource 绘制一个区域。 与ImageBrush 一起使用的ImageSource 的最常见类型是BitmapImage,它描述一个位图图形。 使用Drawing 对象时,您可以使用DrawingImage 进行绘制,但是使用DrawingBrush 会更简单。 若要使用ImageBrush 进行绘制,请创建一个 BitmapImage 并用它来加载位图内容。 然后,使用BitmapImage 来设置 ImageBrush 的 ImageSource 属性。 最后,将ImageBrush 应用到想要绘制的对象。 在XAML中,还可以将 ImageBrush 的 ImageSource 属性仅设置为要加载的图像的路径。与所有 Brush 对象一样,ImageBrush 可用于绘制诸如形状、面板、控件和文本之类的对象。

         默认情况下,ImageBrush 会将其图像拉伸以完全充满要绘制的区域,如果绘制的区域和该图像的长宽比不同,则可能会扭曲该图像。 您可以通过将 Stretch 属性从默认值 Fill 更改为 None、Uniform 或 UniformToFill 来更改此行为。 由于 ImageBrush 是 TileBrush 的一种类型,因此您可以准确指定图像画笔如何填充输出区域,甚至创建图案。

以下示例使用 ImageBrush 绘制 Canvas 的 Background。

前端代码实现(XAML):

  1. <Window x:Class="WpfApplication1.MainWindow"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4. Title="MainWindow" Height="350" Width="525">
  5. <Grid>
  6. <StackPanel>
  7. <Canvas Height="200"
  8. Width="300">
  9. <Canvas.Background>
  10. <ImageBrush ImageSource="mydog.png" />
  11. </Canvas.Background>
  12. </Canvas>
  13. </StackPanel>
  14. </Grid>
  15. </Window>


后端代码实现:

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Windows;
  6. using System.Windows.Controls;
  7. using System.Windows.Data;
  8. using System.Windows.Documents;
  9. using System.Windows.Input;
  10. using System.Windows.Media;
  11. using System.Windows.Media.Imaging;
  12. using System.Windows.Navigation;
  13. using System.Windows.Shapes;
  14. namespace WpfApplication1
  15. {
  16. /// <summary>
  17. /// MainWindow.xaml 的交互逻辑
  18. /// </summary>
  19. public partial class MainWindow : Window
  20. {
  21. public MainWindow()
  22. {
  23. InitializeComponent();
  24. var mainPanel = new StackPanel();
  25. canvasBackgroundExample(mainPanel);
  26. this.Content = mainPanel;
  27. }
  28. private void canvasBackgroundExample(Panel mainPanel)
  29. {
  30. var bitmapImage = new BitmapImage(new Uri("mydog.png", UriKind.Relative));
  31. var myImageBrush = new ImageBrush(bitmapImage);
  32. Canvas myCanvas = new Canvas();
  33. myCanvas.Width = 300;
  34. myCanvas.Height = 200;
  35. myCanvas.Background = myImageBrush;
  36. mainPanel.Children.Add(myCanvas);
  37. }
  38. }
  39. }


-----------------------------------------------------------------------------------------------------------------------------------------------------

感谢阅读,希能对你有益。

2015年10月14日

Kevin.Chen     蘇州.娄城

O(∩_∩)O~

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小蓝xlanll/article/detail/264540
推荐阅读
  

闽ICP备14008679号