繁体   English   中英

如何从后面的代码中以编程方式更改选定的 tabItem 标题颜色

[英]How to programmatically change selected tabItem Header colour from code behind

我有一个程序,我必须在启动时加载颜色。 然后我必须添加一个带有选项卡项的选项卡控件:

TabControl tabc = m_Executer.GetTabControl();<---- from outside
if (tabc != null)
{
    TabItem tbi = new TabItem();
    tbi.Header.Background = Brushes.Transparent;
    tbi.Header.Content = "End manager";
    tabc.Items.Add(tbi);
    tabc.SelectionChanged += (sender2, args) =>
    {
        ((TabItem)(tabc.SelectedItem)).Background = Brushes.Red;
        tabc.UpdateLayout();
    };
}

这个想法是在触发 selectionchanged 事件时改变背景,但这不起作用。

TabItem 的默认控件模板包含两个名为“mainBorder”和一个“innerBorder”的 Border 元素。 您可以更改后一个的背景:

tabc.SelectionChanged += (sender2, args) =>
{
    if(args.AddedItems != null && args.AddedItems.Count > 0)
    {
        TabItem ti = args.AddedItems[0] as TabItem;
        if(ti != null && VisualTreeHelper.GetChildrenCount(ti) > 0)
        {
            Grid grid = VisualTreeHelper.GetChild(ti, 0) as Grid;
            if (grid != null)
            {
                Border mainBorder = grid.Children[0] as Border;
                if (mainBorder != null)
                {
                    Border innerBorder = mainBorder.Child as Border;
                    if(innerBorder != null)
                        innerBorder.Background = Brushes.Red;
                }
            }
       }
   }
};

上述代码适用于 Windows 10。不同版本的 Windows 之间的模板可能不同。

如果你想改变未选择的TabItem的背景下,只需要替换AddedItemsRemovedItems并设置的背景属性mainBorder

您可以使用文本块来更改颜色:

TabItem tbi = new TabItem();
tbi.Header = Brushes.Transparent;
TextBlock tbk = new TextBlock() { Text="End manager" };
tbi.Header = tbk;
    tabc.Items.Add(tbi);

然后更改事件上的文本块

tabc.SelectionChanged += (sender2, args) =>
{

    ((TabItem)(tabc.SelectedItem)).Foreground = Brushes.Red;
    tabc.UpdateLayout();

};

编辑您最好取消突出显示未选择的项目:

tabc.SelectionChanged += (sender2, args) =>
{
    foreach (var item in tabc.Items)
    {
        if (item == ((TabItem)(tabc.SelectedItem)))
            ((TabItem)item).Foreground = Brushes.Red;
        else
        ((TabItem)item).Foreground = Brushes.Black;
    }                   
};

您必须将Content设置为TextBlock而不是字符串:

XAML:

<TabControl>
    <TabControl.Items>
        <TabItem >
            <TabItem.Header>
                <TextBlock Background="Red" Text="Foo"/>
            </TabItem.Header>
        </TabItem>
        <TabItem Header="Bar" />
    </TabControl.Items>
</TabControl>

或背后的代码(无论出于何种原因......)

TabItem tbi = new TabItem();
TextBlock headerElement = new TextBlock();
headerElement.Text = "End manager";
headerElement.Background = Brushes.Red;
tbi.Header = headerElement;

我还建议您深入研究 MVVM 模式。 在 98% 的情况下,最佳做法是用 XAML 编写 UI 并绑定到 ViewModel。

顺便说一句:您的代码甚至无法编译,因为Headerobject类型...

暂无
暂无

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

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