首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如果文本不适合TextBlock,则WPF显示省略。

如果文本不适合TextBlock,则WPF显示省略。
EN

Stack Overflow用户
提问于 2016-05-26 16:20:42
回答 2查看 4.4K关注 0票数 5

如果我的文件名和路径不适合TextBlock,我想显示省略号。

例如,如果我的文件名和路径类似于:

代码语言:javascript
运行
复制
C:\examples\example\folderA\folderB\folderC\myfilename.txt

我想在我的TextBlock中这样展示它:

代码语言:javascript
运行
复制
C:\examples...myfilename.txt

更新:,我知道我可以使用TextTrimming在末尾设置省略号。但我需要一种方法把省略号放在中间的某个地方。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-05-26 21:26:38

好的,我感兴趣的是,这是否可以用基本的XAML来完成,而不是在测量或绘图上乱搞,所以就开始乱搞。我今天没有时间完成这件事,但我想,如果你想把它拿出来,把它清理掉,我想把它作为一个起点。

到目前为止,XAML看起来是这样的:

代码语言:javascript
运行
复制
<Window.Resources>
    <local:FileNameConverter x:Key="FileNameConverter" />
    <local:FilePathConverter x:Key="FilePathConverter" />

    <Style x:Key="CustomFileText" TargetType="{x:Type TextBox}">
        <Style.Triggers>
            <DataTrigger Binding="{Binding IsKeyboardFocused, RelativeSource={RelativeSource Self}}" Value="false">
                <Setter Property="Template">
                    <Setter.Value>
                        <ControlTemplate TargetType="TextBox">
                            <Grid>
                                <TextBox IsHitTestVisible="False" /> <!-- for Border -->
                                <DockPanel>
                                    <TextBlock Text="{TemplateBinding Text, Converter={StaticResource FileNameConverter}}" DockPanel.Dock="Right" Margin="-3,3,4,3" />
                                    <TextBlock Text="{TemplateBinding Text, Converter={StaticResource FilePathConverter}}" TextTrimming="CharacterEllipsis" Margin="4,3,0,3" />
                                </DockPanel>
                            </Grid>
                        </ControlTemplate>
                    </Setter.Value>
                </Setter>
            </DataTrigger>
        </Style.Triggers>
    </Style>
</Window.Resources>

<StackPanel Margin="10">
    <TextBox Text="C:\Program Files\Some Directory\SomeFile.txt" Style="{StaticResource CustomFileText}"/>
    <TextBox Margin="0,10" />
</StackPanel>

最终的结果是,如果TextBox具有编辑焦点,它将显示为一个普通的TextBox:

但是一旦用户将焦点转移到表单的其他地方,它就会分成两个单独的TextBlocks,使用转换器解析目录和FileName。TextTrimming在目录中被用来给出您在问题中描述的效果:

这方面的主要问题是调整大小时,在两个文本框之间添加额外的空间。

我可以在这里想到两种选择:

  1. 使模板基于某种类型的触发器,即“仅在TextBox.DesiredSize.Width > TextBox.ActualWidth__时使用此模板”。
  2. 更改模板中的XAML,使名称TextBox以某种方式表示“占用您所需的所有空间作为最小大小。如果有额外的空间,也将其分配到此框中”,而目录TextBox则表示“占用所有可能的空间,但不要增长超过内容的空间”。我不确定做这件事的最佳方法,但我认为这与另一个面板、TextBox上的一些我现在无法想到的属性、或者一些限制大小的自定义转换器/绑定有关。

我猜#1会更容易实现,但我现在没有时间解决它。希望这给你一个好的起点,并祝你好运!:)

哦,而转换器只是非常基本的。您可能希望添加更多的安全措施,但下面是我用于测试的内容:

代码语言:javascript
运行
复制
public class FileNameConverter : IValueConverter
{
    public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
    {
        if (value != null && value is string)
            return System.IO.Path.GetFileName((string)value);

        return null;
    }

    public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
    {
        throw new NotImplementedException();
    }
}

public class FilePathConverter : IValueConverter
{
    public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
    {
        if (value != null && value is string)
            return System.IO.Path.GetDirectoryName((string)value);

        return null;
    }

    public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
    {
        throw new NotImplementedException();
    }
}
票数 7
EN

Stack Overflow用户

发布于 2017-09-19 21:15:48

我修改了Rachel提供的XAML,以修复窗口大小上出现的路径中的额外空间。

代码语言:javascript
运行
复制
    <Window.Resources>
    <local:FileNameConverter x:Key="FileNameConverter" />
    <local:FilePathConverter x:Key="FilePathConverter" />

    <Style x:Key="CustomFileText" TargetType="{x:Type TextBox}">
        <Style.Triggers>
            <DataTrigger Binding="{Binding IsKeyboardFocused, RelativeSource={RelativeSource Self}}" Value="false">
                <Setter Property="Template">
                    <Setter.Value>
                        <ControlTemplate TargetType="TextBox">
                            <Grid>
                                <TextBox Grid.ColumnSpan="2" IsHitTestVisible="False"/>
                                <Grid>
                                    <Grid.ColumnDefinitions>
                                        <ColumnDefinition MaxWidth="{Binding ActualWidth, ElementName=PART_DirMaxWidth}"/>
                                        <ColumnDefinition Width="Auto"/>
                                    </Grid.ColumnDefinitions>
                                    <Canvas x:Name="PART_Canvas">
                                        <TextBlock x:Name="PART_DirMaxWidth" Margin="0" Padding="0" Text="{TemplateBinding Text, Converter={StaticResource FilePathConverter}}" Visibility="Hidden"/>
                                        <TextBlock Width="{Binding ActualWidth, ElementName=PART_Canvas}" Margin="0" Padding="0" Text="{TemplateBinding Text, Converter={StaticResource FilePathConverter}}" TextTrimming="CharacterEllipsis" Background="Transparent"/>
                                    </Canvas>
                                    <StackPanel Grid.Column="1" Orientation="Horizontal">
                                        <TextBlock Margin="0" Padding="0" Text="\" Background="Transparent"/>
                                        <TextBlock Margin="0" Padding="0" Text="{TemplateBinding Text, Converter={StaticResource FileNameConverter}}" Background="Transparent"/>
                                    </StackPanel>
                                </Grid>
                            </Grid>
                        </ControlTemplate>
                    </Setter.Value>
                </Setter>
            </DataTrigger>
        </Style.Triggers>
    </Style>
</Window.Resources>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37466240

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档