繁体   English   中英

如何刷新UserControl中的嵌套控件属性

[英]How to refresh nested control property in UserControl

我们制作了一个WPF用户控件,该控件由一个Label和一个嵌套的Textblock作为Content组成(用于文本包装)。 因为我们像这样拖放用户控件,所以在XAML定义中不使用任何名称,因为创建用户控件的副本存在问题。 因此,我们改用视图模型。 文本块的DependencyProperties(如FontSize)绑定到祖先(UserControl)的属性。

例如:

        <TextBlock Text="{Binding Path=Text, Mode=TwoWay, NotifyOnSourceUpdated=True, UpdateSourceTrigger=PropertyChanged}"
                   FontSize="{Binding RelativeSource Mode=FindAncestor, AncestorType={x:Type UserControl}}, Path=FontSize}"

在UserControl的CS文件中,我们覆盖了UserControl的FontSize属性,以便我们可以获取和设置它:

    public new double FontSize
    {
        get { return base.FontSize; }
        set { base.FontSize = value; }
    }

现在的问题是,我们希望有可能在拖放到WPF窗口后编辑usercontrols属性。

为此,我们在放置事件后打开一个对话框,并将UserControl作为FrameworkElement提供给它。 然后,在该对话框中,我们可以更改FontSize。 调用上面FontSize属性的设置方法,并更改base.FontSize。 当我们在调试器中查看给定元素的属性时,FontSize被更改。 但是我们用户控件中TextBlock的可视FontSize仍然相同。

我们如何刷新?

提前致谢!

PS:在第二个WPF窗口上放置UserControl时,我们通过XAML序列化和-deserialization复制控件。 在第一步(序列化)之后,我们得到一个类似于Label-UserControl的字符串:

<ControlLabel Text="Label1" ControlFontSize="12" ControlFontWeight="Normal" ControlFontStyle="Normal" ControlHorizontalContentAlignment="Left" ControlVerticalContentAlignment="Top" BorderBrush="#FF00FFFF" BorderThickness="1,1,1,1" av:Canvas.Left="103" av:Canvas.Top="214" xmlns="clr-namespace:WpfDesignerControlLibrary;assembly=WpfDesignerControlLibrary" xmlns:assembly="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:av="http://schemas.microsoft.com/winfx/2006/xaml/presentation">
  <ControlLabel.TextDecorations>
    <assembly:Null />
  </ControlLabel.TextDecorations>
  <av:Grid>
    <av:Grid.ColumnDefinitions>
      <av:ColumnDefinition />
    </av:Grid.ColumnDefinitions>
    <av:Grid.RowDefinitions>
      <av:RowDefinition Height="*" />
    </av:Grid.RowDefinitions>
    <av:Border BorderThickness="0,0,0,0" BorderBrush="{assembly:Null}">
      <av:Border.Style>
        <av:Style TargetType="av:IFrameworkInputElement">
          <av:Style.Resources>
            <av:ResourceDictionary />
          </av:Style.Resources>
          <av:Setter Property="av:Border.BorderBrush">
            <av:Setter.Value>
              <av:SolidColorBrush>#FF4169E1</av:SolidColorBrush>
            </av:Setter.Value>
          </av:Setter>
          <av:Setter Property="av:Border.BorderThickness">
            <av:Setter.Value>
              <av:Thickness>1,1,1,1</av:Thickness>
            </av:Setter.Value>
          </av:Setter>
          <av:Setter Property="av:FrameworkElement.HorizontalAlignment">
            <av:Setter.Value>
              <assembly:Static Member="av:HorizontalAlignment.Stretch" />
            </av:Setter.Value>
          </av:Setter>
          <av:Setter Property="av:FrameworkElement.VerticalAlignment">
            <av:Setter.Value>
              <assembly:Static Member="av:VerticalAlignment.Stretch" />
            </av:Setter.Value>
          </av:Setter>
        </av:Style>
      </av:Border.Style>
      <av:Label HorizontalContentAlignment="Left" VerticalContentAlignment="Top" Margin="2,2,2,2">
        <av:TextBlock Text="Label1" FontStyle="Normal" FontWeight="Normal" FontSize="12" TextAlignment="Left" TextWrapping="Wrap">
          <av:TextBlock.TextDecorations>
            <assembly:Null />
          </av:TextBlock.TextDecorations>
        </av:TextBlock>
      </av:Label>
    </av:Border>
  </av:Grid>
</ControlLabel>

可能是序列化对控件造成了一些损害吗? 正如我上面所说的,setter可以工作并且属性会更改,但是控件中的文本保持不变。

问题是串行化会删除绑定。 通过创建拖动控件的新实例,而不是通过XAML序列化和反序列化来复制它,可以避免这种情况。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM