3

コンテンツ コントロールをデータ テンプレート セレクターにバインドし、変数をそのコンテンツ コントロールにバインドしてから、変数の内容に応じて別のテンプレートを表示したいと考えています。

TelerikDataTemplateSelectorに必要なことをさせることができましたが、バインドするコントロールが見つかりませんDataTemplateSelector

私が見つけたすべてのコントロールは、DataTemplateSelectorrequireItemsSourceをコレクションとして使用できるようにします。単一のオブジェクトを渡すと、例外がスローされます。

私が渡しているアイテムは、コレクションではなく単一のアイテムです。コンテンツ コントロールが必要なようですが、それにバインドできませんDataTemplateSelector

DataTemplateSelector をバインドできるContent Controlに似た Telerik コントロールはありますか? または、 Content ControlDataTemplateSelectorにバインドできるに似たものがありますか。

どんな助けでも大歓迎です。

4

1 に答える 1

3

Telerik のクラスを避けることを検討する必要があると思います (私の意見では、この場合は少し複雑になります)。

標準DataTemplateSelector実装はどうですか?自分で実装するのはとても簡単です!

まず、抽象クラスの「クラシック」実装を宣言しますDataTemplateSelector

public abstract class DataTemplateSelector : ContentControl
{
    public virtual DataTemplate SelectTemplate(object item, DependencyObject container)
    {
        return null;
    }

    protected override void OnContentChanged(object oldContent, object newContent)
    {
        base.OnContentChanged(oldContent, newContent);

        ContentTemplate = SelectTemplate(newContent, this);
    }
}

次に、カスタムを書くことができますDataTemplateSelector...

public class myTemplateSelector : DataTemplateSelector
{
    public DataTemplate Template1 { get; set; }

    public DataTemplate Template2 { get; set; }


    public override DataTemplate SelectTemplate(object item, DependencyObject container)
    {
        // No template...
        if (item == null)
            return null;

        // Enumeration discriminant:
        if (item is BoundTemplateDiscriminantType)
            switch ((BoundTemplateDiscriminantType)item)
            {
                case BoundTemplateDiscriminantType.Type1:
                    return Template1;
                case BoundTemplateDiscriminantType.Type2:
                    return Template2;
                // Not implemented...
                default:
                    throw new NotImplementedException();
            }
        // Integer discriminant:
        else if (item is int)
        {
            return (int)item > 0 ? Template1 : Template2;
        }
        // Other discriminants...
        else
            // Not yet implemented...
            throw new NotImplementedException();
    }
}

...そして最後に XAML の設計 (通常のListBoxItemではなく、この場合はスクロール可能なコンテンツ):

<ScrollViewer>
    <ScrollViewer.ContentTemplate>
        <DataTemplate>
            <utilities:myTemplateSelector Content="{Binding Path=BoundDiscriminant, Mode=OneWay}">
                <!--Content of first template...-->
                <utils:myTemplateSelector.Template1>
                    <DataTemplate>
                          <TextBlock Text={Binding Path=BoundDescription, Mode=OneWay} />              
                    </DataTemplate>
                </utils:myTemplateSelector.Template1>
                <!--Content of second template...-->
                <utils:myTemplateSelector.Template2>
                    <DataTemplate>

                    </DataTemplate>
                </utils:myTemplateSelector.Template2>
                ... and so on...
            </utilities:myTemplateSelector>
        </DataTemplate>
    </ScrollViewer.ContentTemplate>
</ScrollViewer>
于 2013-04-30T10:43:30.430 に答える