c# - UWP 用户控件 + 内容控件

标签 c# xaml uwp uwp-xaml

我试图了解内容控件如何工作以及如何将内容控件放置在我正在构建的用户控件中。据我了解,我的用户控件应该有一个对象依赖属性,然后我应该能够向我的用户控件添加内容控件并将其绑定(bind)到依赖属性。

我尝试了用户控件 XAML 的变体,包括绕过 ScrollViewer 元素并将 ContentControl 放置在用户控件XAML

如何将此图像放置在此控件内?更广泛地说,如何将任何 XAML 放入用户控件中?

用户控制CS

namespace CoreProject.UserControls
{
public sealed partial class ZoomControl : UserControl
{
    public ZoomControl()
    {
        this.InitializeComponent();
    }

    #region Properties
    public static readonly DependencyProperty ZoomContentProperty =
    DependencyProperty.Register("ZoomContent", typeof(object), typeof(ZoomControl), new PropertyMetadata(null));
    public object ZoomContent
    {
        get { return (object)GetValue(ZoomContentProperty); }
        set { SetValue(ZoomContentProperty, value); }
    }
    #endregion

    public void UnZoom()
    {
        // unzoom
        ImageScrollViewer.Visibility = Visibility.Visible;
        var period = TimeSpan.FromMilliseconds(10);
        Windows.System.Threading.ThreadPoolTimer.CreateTimer(async (source) =>
        {
            await Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
            {
                ImageScrollViewer.ChangeView(0.0, 0.0, 0.8F, true);
                ImageScrollViewer.Visibility = Visibility.Collapsed;
            });
        }, period);
    }

    public void ZoomToPosition(double zoomOriginX, double zoomOriginY, float zoomFactor, bool disableAnimations)
    {
        ImageScrollViewer.Visibility = Visibility.Visible;
        var period = TimeSpan.FromMilliseconds(10);
        Windows.System.Threading.ThreadPoolTimer.CreateTimer(async (source) =>
        {
            await Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.Normal, () =>
            {
                ImageScrollViewer.ChangeView(zoomOriginX, zoomOriginY, 1.2F, disableAnimations);
            });
        }, period);
    }
}

}

用户控制 Xaml

<Grid>
    <ScrollViewer x:Name="ImageScrollViewer" 
                  ZoomMode="Enabled" 
                  Visibility="Collapsed" 
                  HorizontalContentAlignment="Center" 
                  VerticalContentAlignment="Center" 
                  Background="Transparent" 
                  HorizontalScrollMode="Enabled"
                  VerticalScrollMode="Enabled"
                  HorizontalScrollBarVisibility="Hidden"
                  VerticalScrollBarVisibility="Hidden">
        <Grid>
            <!-- HERE IS WHERE I WANT TO PLACE MY CONTENT -->
            <ContentControl Content="{Binding ZoomContent, ElementName=zoomContent}" />
        </Grid>
    </ScrollViewer>
</Grid>

用户控制使用

<usercontrols:ZoomControl x:Name="ZoomControl">
    <usercontrols:ZoomControl.ZoomContent>
        <!-- THIS IS HOW I WANT TO ADD MY CONTENT, SIMPLY PLACE XAML ELEMENT -->
        <Image Source="/Assets/colocationDataCenterData.jpg" />
    </usercontrols:ZoomControl.ZoomContent>
</usercontrols:ZoomControl>

最佳答案

 <Grid>
     <!-- HERE IS WHERE I WANT TO PLACE MY CONTENT -->
     <ContentControl Content="{x:Bind ZoomContent, Mode=OneWay}" />
 </Grid>

您还可以使用 x:Bind 来代替 - 它将 Binding 上下文作为类本身(您的 UserControl),因此您可以直接绑定(bind)。

如果您希望经典绑定(bind)起作用,您需要在用户控件本身内部命名和 userControl。 (顺便说一句,通常您会将其作为模板控件来执行并使用模板绑定(bind))

<UserControl x:Name="zoomContent">
    <Grid>
         <ScrollViewer x:Name="ImageScrollViewer" 
              ZoomMode="Enabled" 
              Visibility="Collapsed" 
              HorizontalContentAlignment="Center" 
              VerticalContentAlignment="Center" 
              Background="Transparent" 
              HorizontalScrollMode="Enabled"
              VerticalScrollMode="Enabled"
              HorizontalScrollBarVisibility="Hidden"
              VerticalScrollBarVisibility="Hidden">
         <Grid>
             <!-- HERE IS WHERE I WANT TO PLACE MY CONTENT -->
             <ContentControl Content="{Binding ZoomContent, ElementName=zoomContent}" />
         </Grid>
     </ScrollViewer>
  </Grid>
</UserControl>

关于c# - UWP 用户控件 + 内容控件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44952022/

相关文章:

c# - 尝试使用 .net 4.0 在 XP sp3 上运行 TLS1.2

c# - DataBinding 集合和更改集合元素

c# - 如何在 Xamarin.Forms 中强制使用灯光模式?

WPF 使用自定义 RoutedUICommands 还是简单的事件处理程序?

c# - 使用 Win2D 绘制可编辑和可选择的形状?

c# - 使用模板 10 在 UWP 用户控件中进行数据绑定(bind)

c# - 如何更改网格中所有文本框的字体大小,windows app uwp

c# - 在 C# 中从 resx 文件名中提取文化信息的最有效方法是什么?

c# - 无法监视 Azure 中的自定义性能计数器

c# - 如何在asp.net中拖动文本框时调整其大小?