WPF基础五:UI①布局元素StackPanel

目录

StackPanel

StackPanel类

StackPanel.Orientation:指示子元素的堆叠维度

HorizontalAlignment:水平对齐方式

VerticalAlignment:垂直对齐方式

范例:

C#代码

StackPanel 控件的滚动条


StackPanel

 

将子元素排列成水平或垂直的一行。


StackPanel类

名称备注权限
OrientationProperty标识 Orientation 依赖项属性。public

 

名称备注权限
CanHorizontallyScroll获取或设置一个值,该值指示内容能否水平滚动public
CanVerticallyScroll获取或设置一个值,该值指示内容能否垂直滚动public
ExtentHeight获取包含盘区垂直大小的一个值public
ExtentWidth获取包含盘区水平大小的值public
HasLogicalOrientation获取一个值,该值指示此 StackPanel 是水平方向还是垂直方向protected
HorizontalOffse获取一个值,该值包含滚动内容的水平偏移量public
LogicalOrientation获取一个值,该值表示 Orientation 的 StackPanelpublic
Orientation获取或设置一个值,该值指示子元素的堆叠维度public
ScrollOwner获取或设置一个值,该值标识控制此 StackPanel 中的滚动行为的容器public
VerticalOffset获取包含滚动内容的垂直偏移量的值public
ViewportHeight获取包含内容视区垂直大小的值public
ViewportWidth获取包含内容视区水平大小的值public
名称备注权限
ArrangeOverride排列 StackPanel 元素的内容protected
LineDown将内容向下滚动一个逻辑单位public
LineLeft将内容向左滚动一个逻辑单位public
LineRight将内容向右滚动一个逻辑单位public
LineUp将内容向上滚动一个逻辑单位public
MakeVisible滚动到指定坐标并使该 Visual 部分可见public
MeasureOverride测量 StackPanel 的子元素,以便准备在 ArrangeOverride(Size) 处理过程中排列它们protected
MouseWheelDown向下逻辑滚动内容以响应鼠标滚轮按钮的单击操作public
MouseWheelLeft向左逻辑滚动内容以响应鼠标滚轮按钮的单击操作public
MouseWheelRight向右逻辑滚动内容以响应鼠标滚轮按钮的单击操作public
MouseWheelUp向上逻辑滚动内容以响应鼠标滚轮按钮的单击操作public
PageDown将内容向下逻辑滚动一页public
PageLeft将内容向左逻辑滚动一页public
PageRight将内容向右逻辑滚动一页public
PageUp将内容向上逻辑滚动一页public
SetHorizontalOffset设置 HorizontalOffset 属性的值public
SetVerticalOffset设置 VerticalOffset 属性的值public

  • StackPanel包含UIElement对象的集合  ,这些对象位于 Children 属性中。
  • StackPanel中包含内容的HorizontalAlignment 、VerticalAlignment的默认值都是 stretch。
  • 默认情况下,Panel 元素不接收焦点。 若要强制 panel 元素以接收焦点,请将 Focusable 属性设置为 true 。
  • StackPanel 实现 IScrollInfo 接口以支持逻辑滚动。 逻辑滚动用于滚动到逻辑树中的下一个元素。 这与物理滚动相反,后者按给定方向按定义的物理增量滚动内容。 如果需要物理滚动而不是逻辑滚动,请将StackPanel 包含在 ScrollViewer 中,并将其 CanContentScroll 属性设置为 false 。
     

StackPanel.Orientation:指示子元素的堆叠维度

  • Horizontal:水平布置。
  • Vertical:垂直布置。

HorizontalAlignment:水平对齐方式

  • Left
  • Center
  • Right
  • Stretch

VerticalAlignment:垂直对齐方式

  • Top
  • Center
  • Bottom
  • Stretch

 


范例:

<Window x:Class="StackPanelDemo.MainWindow"
        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:StackPanelDemo"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid>
        <StackPanel Orientation="Horizontal">
            <Button Content="Btn1" HorizontalAlignment="Stretch" MaxWidth="500" MinWidth="100" />
            <Button Content="Btn2" HorizontalAlignment="Stretch" MaxWidth="500" MinWidth="100"/>
            <Button Content="Btn3" HorizontalAlignment="Stretch" MaxWidth="500" MinWidth="100"/>
        </StackPanel>
    </Grid>
</Window>

修改 Orientation="Vertical"


C#代码

using System;
using System.Collections.Generic;
using System.Linq;
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 StackPanelDemo
{
    /// <summary>
    /// MainWindow.xaml 的交互逻辑
    /// </summary>
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();

            StackPanel stackPanel = new StackPanel();
            stackPanel.Orientation = Orientation.Vertical;

            Button button1 = new Button();
            Button button2 = new Button();
            Button button3 = new Button();

            button1.Height = 200;
            button1.MinWidth = 100;
            button1.MaxWidth = 500;
            button1.HorizontalAlignment = HorizontalAlignment.Stretch;
            button1.Content = "Btn1";

            button2.Height = 200;
            button2.MinWidth = 100;
            button2.MaxWidth = 500;
            button2.HorizontalAlignment = HorizontalAlignment.Stretch;
            button2.Content = "Btn2";

            button3.Height = 200;
            button3.MinWidth = 100;
            button3.MaxWidth = 500;
            button3.HorizontalAlignment = HorizontalAlignment.Stretch;
            button3.Content = "Btn3";

            stackPanel.Children.Add(button1);
            stackPanel.Children.Add(button2);
            stackPanel.Children.Add(button3);

            ((this as Window).Content as Grid).Children.Add(stackPanel);

        }
    }
}

StackPanel 控件的滚动条

<Window
    x:Class="StackPanelDemo.MainWindow"
    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:local="clr-namespace:StackPanelDemo"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    Title="MainWindow"
    Width="800"
    Height="450"
    mc:Ignorable="d">
    <Grid>
        <ScrollViewer HorizontalScrollBarVisibility="Auto" VerticalScrollBarVisibility="Auto">
            <StackPanel x:Name="sp1"  Orientation="Vertical">
                <Button
                    Height="200"
                    MinWidth="100"
                    MaxWidth="500"
                    HorizontalAlignment="Stretch"
                    Content="Btn1" />
                <Button
                    Height="200"
                    MinWidth="100"
                    MaxWidth="500"
                    HorizontalAlignment="Stretch"
                    Content="Btn2" />
                <Button
                    Height="200"
                    MinWidth="100"
                    MaxWidth="500"
                    HorizontalAlignment="Stretch"
                    Content="Btn3" />
            </StackPanel>
        </ScrollViewer>
    </Grid>
</Window>

其他一些方法如LineUp()等,必须实现System.Windows.Controls.Primitives.IScrollInfo接口

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本书所附光盘范例 第4章(\C04) 示例描述:本章介绍LINQ的基本语法和使用。 UseQueryExpression 演示LINQ表达式语法的使用。 UseMethodSynax 演示LINQ方法语法的使用。 第5章(\C05) 示例描述:本章介绍LINQ to ADO.NET相关技术和使用。 QueryOneTable 演示用LINQ查询单个DataTable的数据。 QueryMultiTable 演示用LINQ查询多个DataTable的数据。 UseCopyToTable 演示通过LINQ查询在DataTable之间拷贝数据。 UseORDesigner 演示对象关系设计器(OR Designer)的使用。 UseDataContextLINQ 演示通过DataContext进行数据绑定和访问。 UseDataView 演示通过LINQ实现DataView的数据查询和绑定。 第6章(\C06) 示例描述:本章介绍LINQ to XML相关技术和使用。 CreateSimpleXMLTree 演示通过XElement创建简单的XML树。 CreateAttributeElement 演示通过XElement创建具有属性的XML元素。 CreateSubElement 演示通过XElement创建具有子元素的XML元素。 CreateXMLTree 演示通过XElement创建复杂的完整的XML树。 QeuryAttributesElement 演示通过XElement查询XML元素的属性。 QueryInContent 演示通过XElement查询XML元素的具体内容。 QueryOrderElement 演示通过XElement对XML元素进行排序。 QuerySubElement 演示通过XElement查询XML元素的子元素。 LoadXMLTree 演示通过XElement加载XML树。 第7章(\C07) 示例描述:本章介绍了WPF的基本概念和架构,并举了一个简单的示例演示WPF程序的开发。 HelloWPF 第一个用WPF示例应用程序。 第8章(\C08) 示例描述:本章介绍了XAML的语法,包括原理、使用方法以及事件处理等等。 AttachedProperty 使用XAML中的附加属性。 CodebehindDemo 使用XAML中的后置代码文件编写程序代码。 LooseXaml 松散XAML示例。 NamespaceDemo1 在XAML中使用系统命名空间。 OtherNamespace 在XAML中使用其他项目中的命名空间。 PropertyandTypeConvert 使用属性和类型转换器 PropertyElementSyntax 使用XAML的属性元素语法。 UnderstandXAMLDemo1 理解XAML的简单示例。 UnderstandXAMLDemo2 使用程序代码创建UI元素。 XAMLEvents 在XAML中使用事件。 XamlReaderDemo 动态加载和编译XAML示例。 第9章(\C09) 示例描述:本章详细介绍WPF中的全局应用程序类Application。 AccessingCurrentApplication 访问当前的全局应用程序类实例。 ApplicationEventDemo 应用程序类事件演示。 CreateApplicationByHand 手动创建应用程序类实例。 HandleCommandLineDemo 处理命令行参数。 SingleInstanceApplication 单实例应用程序。 SingleInstanceWithCommunication 在单实例应用程序实例之间通信。 VS2008Application 在VS2008中创建自定义的Application类。 第10章(\C10) 示例描述:本章学习WPF提供的布局特性。 CanvasDemo 使用Canvas进行布局。 DockPanelDemo 使用DockPanel进行布局。 GridDemo 使用Grid进行布局。 InkCanvasDemo 使用InkCanvas的示例。 SimpleDiagDox 简单对话框示例程序。 SimpleStackPanelDemo 使用StackPanel进行布局。 WrapPanelDemo 使用WrapPanelDemo进行布局。 第11章(\C11) 示例描述:本章学习WPF中的内容控件的概念以及特性。 BorderDemo 使用Border控件。 ContentDemo Content属性的使用示例。 ControlControlDemo 内容控件层次结构。 HeaderedContentControlDemo HeaderedContentControl使用示例。 ScrollViewer 使用ScrollViewer控件。 ViewboxDemo 使用Viewbox控件。 第12章(\C12) 示例描述:本章介绍WPF中的依赖属性和事件路由特性。 AttachedEvents 使用WPF的附加事件。 CaptureMouseDemo 捕捉鼠标示例。 CreateWPFDependencyProperty 创建WF中的依赖属性。 CustomRoutedEvent 自定义路由事件。 DragandDropLabel 拖动编程示例。 DragandDropSimpleDemo 文件拖放示例。 GetFocus 获取控件焦点。 KeyInputDemo 处理键盘事件示例。 LatBox 依赖属性示例。 LogicalTree 逻辑树示例。 MouseClickEventArgsDemo 鼠标单击事件示例。 MouseInputInfo 获取鼠标输入信息。 ProgramLoopTree 编程遍历逻辑树和视觉树。 RegisterAttached 注册附加属性。 RoutingStrategyDemo 演示如何使用路由策略。 SharedDP 共享依赖属性示例。 StackPanelLoadedDemo WPF元素的生命周期事件演示。 UnderstandingDP 理解依赖属性。 UnderstandRoutedEvent 理解路由事件。 第13章(\C13) 示例描述:本章学习使用WPF的标准控件。 AnimationPopup 动画Popup弹出窗口。 BackgroundLinearGradientBrushDemo 使用渐变画刷填充背景示例。 BindingSliderDemo 使用Silder滑动条控件。 ButtonBaseDemo 使用Button控件的ButtonBase基类。 ChangeCursorDemo 更改鼠标光标示例。 CursorSimpleDemo 使用鼠标光标的简单示例。 FontFamilyDemo 字体使用示例。 LabelDemo 使用Label标签控件。 ListBoxDemo 使用ListBox控件。 MultiLineTextBox 多行文本框控件的演示。 MultiSelectedListBox ListBox中的多选示例。 OpacityDemo Opacity属性的使用方法。 PasswordBoxDemo 使用PasswordBox示例。 Popup Popup控件使用示例。 ProgressBarDemo ProgressBar控件使用示例 RadioButtonCheckBox RadioButton使用示例。 RepeatToggleButton RepeatToggleButton使用示例。 SimpleComboBox示例 使用ComboBox的简单示例。 SliderDemo Slider控件使用示例 TextBlockDemo TextBlock控件使用示例 ToolTip ToolTip控件使用示例 第14章(\C14) 示例描述:本章学习WPF的窗口和导航窗口的使用方法。 AddAndRemoveEntry 添加和移除导航记录的功能。 CommonDialogDemo WPF中的通用对话框示例。 DialogModalDemo WPF中的模式窗口示例。 DrawShapeWindow 绘制图形窗口示例。 FirstNavigateApp 第一个导航窗口应用程序示例。 FrameInPage 在导航窗口中使用Frame示例。 FrameNavigationDemo 框架导航示例程序。 Hyperlinkdemo 在导航窗口中使用超级链接。 MessageBoxDemo 消息框使用示例。 NavigationEventDemo 理解和使用导航事件。 NavigationServiceDemo 导航服务示例。 NavigationWindowDemo 使用WPF中的导航窗口进行导航。 PageFunctionDemo 使用PageFunction功能返回数据示例。 SaveandRestoreWindowState 保存和恢复窗口状态示例。 SharpedWindow 图形窗口示例 ShowingaWindow 显示窗口。 WindowDemo 简单窗口示例 WindowIcon 获取和设置Window图标示例。 WindowLifetime 窗口的生命周期事件。 XBAPDemo1 XBAP应用程序示例。 第15章(\C15) 示例描述:本章学习WPF资源、样式和控件模板。 AssemblyResourceDemo1 使用程序集资源。 BaseOnStyle 样式的继承使用示例。 DataTriggerDemo 数据触发器使用示例。 EventSetterDemo 绑定事件处理器示例。 EventTriggerDemo 事件触发器使用示例。 FontSizeResourceDemo 使用WPF资源示例。 MultiDataTriggerDemo 多个数据触发器的使用示例。 MultiTriggerDemo 多事件触发器示例。 SimpleButtonTemplate 简单的按钮模板示例。 StyleOrResourceDemo 样式或资源使用示例。 SystemResourceDemo 系统资源使用示例。 TargetTypeStyleDemo 为样式指定TargetType示例。 TemplateTriggerDemo 模板触发器示例。 TriggerDemo 触发器示例。 WindowResourceDemo 窗口资源使用示例 第16章(\C16) 示例描述:本章演示如何使用WPF的形状、变换和画刷来绘制图形。 BitmapEffectsDemo 位图效果使用示例。 DashLine 虚线绘制示例。 ImageBrushDemo1 图像画刷使用示例。 LineCapDemo WPF线帽示例。 LineDem 绘制直线。 LineGradientBrushDemo1 线性渐变画刷使用示例。 OpacityMaskDemo 透明遮罩使用示例。 RadialGradientBrushDemo 径向渐变示例。 RectangleDemo 矩形绘制示例。 ReflectionEffectDemo 反射效果示例。 SizePlacementDemo 图像位置示例。 TileModeDemo TileMode枚举示例。 TransformDemo 变换使用示例。 VisualBrushDemo1 可视化画刷示例。 第17章(\C17) 示例描述:本章演示如何使用WPF的几何图形、图像和可视化层。 DrawingVisualDemo 绘制可视化层示例。 GeometryDrawingDemo 几何图形绘制示例。 MiniLanguageDemo 迷你几何语言使用示例。 PathGeometriesDemo1 路径几何图形的演示。 第18章(\C18) 示例描述:本章演示如何使用WPF数据绑定基础。 BindingToElementDemo 绑定到元素属性的示例。 BindingToObject 绑定到对象的示例。 DataBindingToTable 绑定到数据表示例。 第19章(\C19) 示例描述:本章演示如何使用WF进行编程入门。 AnswerToRiddleNormal 使用传统语法的猜迷游戏示例。 AnswerToRiddleWF 使用WF的猜迷游戏示例。 ApprovalOrder 订单批核WF示例程序。 SimpleStateMachine 简单的状态机示例程序。 WorkflowruntimeEvent 工作流运行时引擎事件。 第20章(\C20) 示例描述:本章介绍WF的标准活动。 CAGDemo ConditionedActivityGroup活动使用示例。 EventHandlingScopeActivityDemo 使用EventHandlingScopeActivity活动示例。 InvokeWorkflowDemo 使用InvokeWorkflowActivity活动执行其他工作流实例。 ParallelActivityDemo ParallelActivity活动使用示例。 ParallelReplicatorDemo ParallelActivity和ReplicatorActivity活动示例。 ReplicatorActivityDemo ReplicatorActivity活动使用示例。 RuleConditionDemo 活动的规则条件示例。 SuspendAndTerminate 挂起和终止活动示例。 UsingEventDrivenActivity EvenDrivenActivity使用示例。 VotingServicesDemo 一个投票服务示例程序。 WhileActivityDemo WhileActivity活动使用示例 第21章(\C21) 示例描述:本章介绍WF的基本服务。 PersistenceDemo 持久化服务使用示例。 SimpleTrackingSample 简单的追踪服务示例。 第22章(\C22) 示例描述:本章详细分析了一个基于WF的工作流批核系统。 WorkflowApprovalDemo 城市电力和照明工作任务批核系统示例代码。 第23章(\第23章) 示例描述:本章演示基本的WCF开发。 HelloWorld 第一个WCF程序。 第24章(\第24章) 示例描述:本章介绍WCF中有关通道和绑定的编程和配置。 basicHttpBinding绑定设置 basicHttpBinding的配置演示。 Datagram 演示了数据报传输模式的机制。 Duplex 演示了双工传输模式的机制。 msmqIntegrationBinding绑定设置 msmqIntegrationBinding的配置演示。 netMsmqBinding绑定设置 netMsmqBinding的配置演示。 netNamedPipeBinding绑定设置 netNamedPipeBinding的配置演示。 netTcpBinding绑定设置 netTcpBinding的配置演示。 Request-Reply 演示了请求-响应传输模式的机制。 wsDualHttpBinding绑定设置 wsDualHttpBinding的配置演示。 wsHttpBinding绑定设置 wsHttpBinding的配置演示。 绑定的设置 使用代码对绑定进行设置 状态改变事件 演示了如何响应状态改变事件 第25章(\第25章) 示例描述:本章演示了WCF中的契约编程。 WCF事件机制的实现 演示了WCF中事件的实现。 捕获异常示例 演示了WCF中异常的捕获。 操作契约的重载 服务契约的重载问题。 单程操作示例 演示了单程操作。 服务契约的WSDL 服务契约WSDL的示例。 集合数据契约 演示了集合数据契约的使用。 强类型消息契约 演示了强类型消息契约的使用。 弱类型消息契约 演示了弱类型消息契约的使用。 使用FaultCode和FaultReason示例 使用FaultCode和FaultReason的示例。 使用错误契约示例 使用错误契约示例。 使用具有继承结构的数据契约 演示了具有继承结构的数据契约。 数据契约的XSD 数据契约的XSD示例。 数据契约缺失成员 演示了数据契约缺失成员时的情况。 双程操作示例 双程操作的示例。 未捕获异常示例 未捕获异常示例。 序列化顺序 数据契约的序列化顺序。 第26章(\第26章) 示例描述:本章演示了WCF中的行为编程。 并行管理Multiple Multiple并发模式的示例。 并行管理Reentrant Reentrant并发模式的示例。 并行管理Single Single并发模式的示例。 代码添加元数据行为 演示使用代码添加元数据的行为。 单服务事务 单服务事务的示例 分布式事务 分布式事务的示例。 实例管理PerCall PerCall实例管理的示例。 实例管理PerSession PerSession实例管理的示例。 实例管理Single Single实例管理的示例。 显式使用事务类型 显示使用事务类型的示例。 第27章(\第27章) 示例描述:本章演示了WCF中和安全有关的配置和编程。 局域网内Windows平台系统的安全性 局域网内Windows平台系统的安全性编程。 配置宿主证书 演示了宿主证书的配置。 配置验证方法 验证方法的配置。 配置MembershipProvider 演示了MembershipProvider的配置。 配置角色提供程序 演示了角色提供程序的配置。 安全机制的跟踪配置 演示了安全机制的跟踪的配置。 第28章(\第28章) 示例描述:本章演示了一个实际WCF系统的编程。 自动化点滴管理系统 用WCF架构自动化点滴管理系统。
WPF是一种用于构建应用程序用户界面的框架,UI布局是其中的一个重要部分。在WPF中,UI布局的源码是指定义和排列UI元素的代码。 WPFUI布局源码主要包括XAML和C#代码两部分。XAML是一种标记语言,用于描述和创建UI元素的层次结构。可以使用XAML代码来定义UI元素的属性,例如大小、位置、样式等。XAML代码通常位于.xaml文件中,可以在Visual Studio等开发工具中编辑和查看。 除了XAML之外,还可以使用C#代码来动态地创建、修改和排列UI元素。通过C#代码,可以通过调用WPF框架提供的布局控件和方法,通过代码逻辑来定义和控制UI元素的排列方式。 在WPF中,有多种布局控件可供选择,例如Grid、StackPanel、WrapPanel、DockPanel等。每个布局控件都有自己的特点和使用方法,在设计UI布局时,可以根据具体需求选择适合的布局控件。 此外,WPF还提供了一些布局特性,例如布局容器、布局管理器和面板容器等,用于更细致地控制UI元素的排列和布局方式。 总之,WPFUI布局源码包括XAML和C#代码,通过这些代码可以定义和排列UI元素,选择合适的布局方式,并通过代码逻辑来控制UI的显示效果和交互行为。这些源码是构建WPF应用程序用户界面的基础,开发人员可以根据具体需求和设计来编写和修改UI布局代码,以实现丰富多样的用户界面体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值