Скройте заголовок TabControl

Принятие той Системы. Гуид. NewGuid использует CoCreateGuid, это не случайно вообще. Исторически, алгоритм, используемый для создания гуидов, должен был включить MAC-адрес от сетевого адаптера, в дополнение к некоторым другим вещам как время. Я не уверен, изменился ли алгоритм. В то время как это, конечно, не случайно, это, как гарантируют, будет уникально.

34
задан Community 23 May 2017 в 10:31
поделиться

2 ответа

Style s = new Style();
s.Setters.Add(new Setter(UIElement.VisibilityProperty, Visibility.Collapsed));
tabControl.ItemContainerStyle = s;
43
ответ дан 27 November 2019 в 15:55
поделиться

Что ж, есть несколько способов сделать это.

Самый уродливый способ: используйте VisualTreeHelper, чтобы найти TabPanel (или любую другую панель, которую вы используете для размещения элементов), и установите для ее свойства Visibility значение Visibility.Collapsed. Почему некрасиво? Здесь легко создать несколько надоедливых ошибок или сломать этот подход с помощью «безобидного» обновления стиля, если вы не были достаточно осторожны ...

Я предпочитаю использовать комбинацию Xaml и кода. Вы связываете либо видимость TabItem для просмотра свойства модели, либо видимость TabPanel для просмотра свойства модели. В обоих случаях вам нужно переопределить стиль (стиль ItemContainer или стиль всего TabControl). В обоих случаях у вас есть модель просмотра. Теперь, чтобы переключить видимость заголовка вкладки, вы просто обновляете свойство в модели представления. Вот пример с TabItems:

XAML

<Window x:Class="WpfApplication5.Window1"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:local="clr-namespace:WpfApplication5"
        Title="Tab Settings"
        Height="300"
        Width="300">
  <Window.Resources>
    <local:TabControlViewModel x:Key="tabVM" />
    <BooleanToVisibilityConverter x:Key="booleanToVisibilityConverter" />
  </Window.Resources>
  <Grid>
    <TabControl DataContext="{StaticResource tabVM}">
      <TabControl.ItemContainerStyle>
        <Style TargetType="{x:Type TabItem}">
          <Setter Property="Visibility"
                  Value="{Binding TabHeaderVisible, Converter={StaticResource booleanToVisibilityConverter}}" />
        </Style>
      </TabControl.ItemContainerStyle>
      <TabItem Header="Tab 1">
        <StackPanel>
          <TextBlock Text="Content" />
          <Button Content="Toggle Header"
                  Click="ToggleHeaderClick" />
        </StackPanel>
      </TabItem>
      <TabItem Header="Tab 2 Header">
        <TextBlock Text="Tab 2 Content" />
      </TabItem>
    </TabControl>
  </Grid>
</Window>

C #

using System.ComponentModel;
using System.Windows;
using System.Windows.Input;

namespace WpfApplication5
{
  public partial class Window1 : Window
  {
    public Window1()
    {
      InitializeComponent();
    }

    private void ToggleHeaderClick(object sender, RoutedEventArgs e)
    {
      var tabControlVM =
        ((FrameworkElement)sender).DataContext as TabControlViewModel;
      if (tabControlVM != null)
      {
        tabControlVM.TabHeaderVisible = !tabControlVM.TabHeaderVisible;
      }
    }
  }

  public class TabControlViewModel : INotifyPropertyChanged
  {
    private bool _tabHeaderVisible = true;

    public ICommand ToggleHeader
    {
      get; private set;
    }

    public bool TabHeaderVisible
    {
      get { return _tabHeaderVisible; }
      set
      {
        _tabHeaderVisible = value;
        OnPropertyChanged("TabHeaderVisible");
      }
    }

    public event PropertyChangedEventHandler PropertyChanged;

    private void OnPropertyChanged(string name)
    {
      var changed = PropertyChanged;
      if (changed != null)
      {
        changed(this, new PropertyChangedEventArgs(name));
      }
    }
  }
}
8
ответ дан 27 November 2019 в 15:55
поделиться
Другие вопросы по тегам:

Похожие вопросы: