WPF编程基础-学习笔记-20220303

本文介绍了WPF中Viewport和TileMode的概念。Viewport用于定义VisualBrush的视口区域,其坐标相对于包围盒,例如Viewport=0,0,0.5,0.2表示占据对象一半宽度和五分之一高度的区域。而TileMode则决定了背景如何平铺,如Tile、FlipX、FlipY等选项,用于创建不同的重复效果。示例中,Rectangle的Fill使用VisualBrush,平铺了WrapPanel的顶部部分。

1、实例中,Viewport,表示视窗。ViewportUnits默认RelativeToBoundingBox,也就是相对坐标。前两位表示开始坐标,后两位表示结束坐标。归一化为1。

Viewport="0, 0, 0.5, 0.2",表示,开始坐标(0,0),结束坐标(0.5,0.2),0.5表示占据对象X轴长度一半,0.2表示占据对象Y轴长度的五分之一。

<Window x:Class="KarliCards.Gui.Window1"
        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:local="clr-namespace:KarliCards.Gui"
        mc:Ignorable="d"
        Title="Window1" Height="350" Width="525">
    <Window.Resources>
        <SolidColorBrush x:Key="bg" Color="Yellow"/>
    </Window.Resources>
    <DockPanel>
        <WrapPanel x:Name="wp" DockPanel.Dock="Top">
            <Button Background="{StaticResource bg}">A first Button</Button>
            <Button Background="{StaticResource bg}">A second Button</Button>
            <TextBox x:Name="txt" Text="I am a TextBox"/>
            <TextBlock Text="{Binding ElementName=txt, Path=Text}"></TextBlock>
        </WrapPanel>
        <Rectangle Margin="5">
            <Rectangle.Fill>
                <VisualBrush Visual="{Binding ElementName=wp}"
                             Viewport="0, 0, 0.5, 0.2" ViewportUnits="RelativeToBoundingBox"
                             TileMode="Tile"/> 
            </Rectangle.Fill>
        </Rectangle>
    </DockPanel>
</Window>

2、TileMode,表示平铺模式。有多种选择。

 TileMode="Tile"

 TileMode="FlipX"

 

 TileMode="FlipY"

 

TileMode="FlipXY"

 

TileMode="None"

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值