Принятие той Системы. Гуид. NewGuid использует CoCreateGuid, это не случайно вообще. Исторически, алгоритм, используемый для создания гуидов, должен был включить MAC-адрес от сетевого адаптера, в дополнение к некоторым другим вещам как время. Я не уверен, изменился ли алгоритм. В то время как это, конечно, не случайно, это, как гарантируют, будет уникально.
Style s = new Style();
s.Setters.Add(new Setter(UIElement.VisibilityProperty, Visibility.Collapsed));
tabControl.ItemContainerStyle = s;
Что ж, есть несколько способов сделать это.
Самый уродливый способ: используйте 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));
}
}
}
}