wpf - WPF标签水平内容对齐与flexibel宽度
问题描述
我有TabControl
一些TabItems
。
的 HeaderTabItems
由UserControl
alabel
和 a组成button
。为此,我遵循了本教程。
的水平对齐label
不起作用,因为宽度设置为自动。这会导致文本居中,并且buttons
不会一直到它们应该在的正确位置。
但我需要宽度灵活,以免长文本被截断。
这是宽度设置为自动,这是固定宽度。
我希望它看起来像具有固定宽度但具有灵活宽度的图片,具体取决于标签的长度。
编辑:我不使用评论中提出的建议中的主题。
这是我的 XAML 代码:
<UserControl
x:Class="CSM.UserControls.CloseableHeaderUserControl"
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"
mc:Ignorable="d" d:DesignWidth="81" Margin="0" Height="20.5" >
<Grid Margin="0,4,0,0">
<Button Content="X" Name="bClose" FontFamily="Courier" FontWeight="Bold" Style="{StaticResource {x:Static ToolBar.ButtonStyleKey}}" FontStretch="Normal" FontSize="14" ToolTip="Close" Height="20" Width="20" HorizontalAlignment="Right" Margin="0,-4,0,0"/>
<Label Content="TabItem" Name="lTabTitle" FontFamily="Courier" FontSize="12" HorizontalAlignment="Left" HorizontalContentAlignment="Left" Width="auto" Height="24" VerticalAlignment="Top" Margin="0,-4" />
</Grid>
</UserControl>
解决方案
将 DockPanel 与 LastChildFill 一起使用:
<DockPanel LastChildFill="True">
<Button DockPanel.Dock="Right" ... />
<Label DockPanel.Dock="Left" ... />
</DockPanel>
推荐阅读
- python - 无论编码如何,如何在 Python 中解码邮件?
- c# - C# Oracle 数据库对 PL/SQL 游标的引用
- intellij-idea - Micronaut 重新加载源改变了 intellj 的想法
- memory - 在 Linux 中从内核空间访问物理地址
- python-3.x - 在熊猫数据框中获取下一个非 nan 值
- python - What am I doing wrong here? Project Euler Problem 11
- php - 类的PHP声明必须与抽象类兼容
- javascript - 是否可以在 Chrome 中按下鼠标中键时禁用自动滚动?
- visual-studio-code - VSCode 更漂亮的 printWidth 不适用于导入
- flutter - Flutter:嵌套的 ListView 溢出警告