728x90
반응형
728x170
■ ImageBrush 클래스의 Stretch 속성을 사용해 이미지 종횡비를 유지하는 이미지 브러시를 만드는 방법을 보여준다.
▶ MainWindow.xaml
<Window x:Class="TestProject.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Width="800"
Height="600"
Title="TestProject"
FontFamily="나눔고딕코딩"
FontSize="16">
</Window>
▶ MainWindow.xaml.cs
using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Media.Imaging;
using System.Windows.Media;
using System.Windows.Shapes;
namespace TestProject
{
/// <summary>
/// 메인 윈도우
/// </summary>
public partial class MainWindow : Window
{
//////////////////////////////////////////////////////////////////////////////////////////////////// Constructor
////////////////////////////////////////////////////////////////////////////////////////// Public
#region 생성자 - MainWindow()
/// <summary>
/// 생성자
/// </summary>
public MainWindow()
{
InitializeComponent();
ImageBrush imageBrush1 = new ImageBrush();
imageBrush1.Stretch = Stretch.Uniform;
imageBrush1.ImageSource = new BitmapImage(new Uri("IMAGE\\square.jpg", UriKind.Relative));
imageBrush1.Freeze();
Rectangle rectangle1 = new Rectangle();
rectangle1.Width = 300;
rectangle1.Height = 150;
rectangle1.StrokeThickness = 1.0;
rectangle1.Stroke = Brushes.MediumBlue;
rectangle1.Fill = imageBrush1;
ImageBrush imageBrush2 = new ImageBrush();
imageBrush2.Stretch = Stretch.UniformToFill;
imageBrush2.ImageSource = new BitmapImage(new Uri("IMAGE\\square.jpg", UriKind.Relative));
imageBrush2.Freeze();
Rectangle rectangle2 = new Rectangle();
rectangle2.Margin = new Thickness(0, 10, 0, 0);
rectangle2.Width = 300;
rectangle2.Height = 150;
rectangle2.StrokeThickness = 1.0;
rectangle2.Stroke = Brushes.MediumBlue;
rectangle2.Fill = imageBrush2;
StackPanel stackPanel = new StackPanel();
stackPanel.HorizontalAlignment = HorizontalAlignment.Center;
stackPanel.VerticalAlignment = VerticalAlignment.Center;
stackPanel.Children.Add(rectangle1);
stackPanel.Children.Add(rectangle2);
Content = stackPanel;
}
#endregion
}
}
728x90
반응형
그리드형(광고전용)
'C# > WPF' 카테고리의 다른 글
[C#/WPF] VideoDrawing 엘리먼트 : MediaTimeline/MediaClock 객체를 사용해 무한 반복하는 동영상 재생하기 (0) | 2023.03.25 |
---|---|
[C#/WPF] VideoDrawing 엘리먼트 : 동영상 재생하기 (0) | 2023.03.24 |
[C#/WPF] GeometryDrawing 엘리먼트 사용하기 (0) | 2023.03.24 |
[C#/WPF] ImageBrush 엘리먼트 : Transform/RelativeTransform 속성을 사용해 이미지 브러시 만들기 (0) | 2023.03.24 |
[C#/WPF] DrawingBrush 엘리먼트 : AlignmentX/AlignmentY 속성을 사용해 드로잉 브러시 만들기 (0) | 2023.03.24 |
[C#/WPF] VisualBrush 엘리먼트 : 반사 효과 만들기 (0) | 2023.03.23 |
[C#/WPF] VisualBrush 엘리먼트 : 돋보기 만들기 (0) | 2023.03.23 |
[C#/WPF] VisualBrush 엘리먼트 : Visual 속성에서 MediaElement 객체를 설정해 비디오로 영역 칠하기 (0) | 2023.03.22 |
[C#/WPF] ImageBrush 클래스 : Viewport/TileMode 속성을 사용해 이미지 브러시 만들기 (0) | 2023.03.22 |
[C#/WPF] ImageBrush 클래스 : ImageSource 속성을 사용해 이미지 브러시 만들기 (0) | 2023.03.22 |
댓글을 달아 주세요