您的位置:首页 > 房产 > 建筑 > 网页游戏大全网_优惠好券省钱必逛 查看详情 prime会员甄选 查看详情_长春百度网站优化_东莞seo网站排名优化

网页游戏大全网_优惠好券省钱必逛 查看详情 prime会员甄选 查看详情_长春百度网站优化_东莞seo网站排名优化

2025/1/10 22:37:09 来源:https://blog.csdn.net/weixin_44177600/article/details/144962709  浏览:    关键词:网页游戏大全网_优惠好券省钱必逛 查看详情 prime会员甄选 查看详情_长春百度网站优化_东莞seo网站排名优化
网页游戏大全网_优惠好券省钱必逛 查看详情 prime会员甄选 查看详情_长春百度网站优化_东莞seo网站排名优化

一 功能描述:

扩展的 TabControl 可保存显示的项目,这样切换选项卡时就不会因卸载和重新加载 VisualTree 而影响性能

 [TemplatePart(Name = "PART_ItemsHolder", Type = typeof(Panel))]public class TabControlEx : HandyControl.Controls.TabControl{private Panel _itemsHolderPanel;public TabControlEx(){// This is necessary so that we get the initial databound selected itemItemContainerGenerator.StatusChanged += ItemContainerGeneratorStatusChanged;}/// <summary>/// If containers are done, generate the selected item/// </summary>/// <param name="sender">The sender.</param>/// <param name="e">The <see cref="EventArgs"/> instance containing the event data.</param>private void ItemContainerGeneratorStatusChanged(object sender, EventArgs e){if (ItemContainerGenerator.Status == GeneratorStatus.ContainersGenerated){ItemContainerGenerator.StatusChanged -= ItemContainerGeneratorStatusChanged;UpdateSelectedItem();}}/// <summary>/// Get the ItemsHolder and generate any children/// </summary>public override void OnApplyTemplate(){base.OnApplyTemplate();_itemsHolderPanel = GetTemplateChild("PART_ItemsHolder") as Panel;UpdateSelectedItem();}/// <summary>/// When the items change we remove any generated panel children and add any new ones as necessary/// </summary>/// <param name="e">The <see cref="NotifyCollectionChangedEventArgs"/> instance containing the event data.</param>protected override void OnItemsChanged(NotifyCollectionChangedEventArgs e){base.OnItemsChanged(e);if (_itemsHolderPanel == null){return;}switch (e.Action){case NotifyCollectionChangedAction.Reset:_itemsHolderPanel.Children.Clear();break;case NotifyCollectionChangedAction.Add:case NotifyCollectionChangedAction.Remove:if (e.OldItems != null){foreach (var item in e.OldItems){var cp = FindChildContentPresenter(item);if (cp != null){_itemsHolderPanel.Children.Remove(cp);}}}// Don't do anything with new items because we don't want to// create visuals that aren't being shownUpdateSelectedItem();break;case NotifyCollectionChangedAction.Replace:throw new NotImplementedException("Replace not implemented yet");}}protected override void OnSelectionChanged(SelectionChangedEventArgs e){base.OnSelectionChanged(e);UpdateSelectedItem();}private void UpdateSelectedItem(){if (_itemsHolderPanel == null){return;}// Generate a ContentPresenter if necessaryvar item = GetSelectedTabItem();if (item != null){CreateChildContentPresenter(item);}// show the right childforeach (ContentPresenter child in _itemsHolderPanel.Children){child.Visibility = ((child.Tag as HandyControl.Controls.TabItem).IsSelected) ? Visibility.Visible : Visibility.Collapsed;}}private ContentPresenter CreateChildContentPresenter(object item){if (item == null){return null;}var cp = FindChildContentPresenter(item);if (cp != null){return cp;}var tabItem = item as HandyControl.Controls.TabItem;cp = new ContentPresenter{Content = (tabItem != null) ? tabItem.Content : item,ContentTemplate = this.SelectedContentTemplate,ContentTemplateSelector = this.SelectedContentTemplateSelector,ContentStringFormat = this.SelectedContentStringFormat,Visibility = Visibility.Collapsed,Tag = tabItem ?? (this.ItemContainerGenerator.ContainerFromItem(item))};_itemsHolderPanel.Children.Add(cp);return cp;}private ContentPresenter FindChildContentPresenter(object data){if (data is HandyControl.Controls.TabItem){data = (data as HandyControl.Controls.TabItem).Content;}if (data == null){return null;}if (_itemsHolderPanel == null){return null;}foreach (ContentPresenter cp in _itemsHolderPanel.Children){if (cp.Content == data){return cp;}}return null;}protected HandyControl.Controls.TabItem GetSelectedTabItem(){var selectedItem = SelectedItem;if (selectedItem == null)return null;return selectedItem as HandyControl.Controls.TabItem ?? ItemContainerGenerator.ContainerFromIndex(SelectedIndex) as HandyControl.Controls.TabItem;}protected override AutomationPeer OnCreateAutomationPeer(){return new TabControlAutomationPeer(this);}}

二 使用示例:

注意注释地方和系统样式不一样!
修改内容:系统样式使用ContentPresenter 作为承载容器,切换标签页使会重新加载并且标签页内容会互相影响。这里使用Grid x:Name="PART_ItemsHolder"作为承载容器,内容通过Visibility控制显示!

 <control:TabControlEx ItemsSource="{Binding TabItems, Mode=TwoWay}"SelectedItem="{Binding SelectedTab, Mode=TwoWay}"><control:TabControlEx.Style><Style TargetType="control:TabControlEx"><Setter Property="Template"><Setter.Value><ControlTemplate TargetType="control:TabControlEx"><Border BorderBrush="{TemplateBinding BorderBrush}"CornerRadius="{TemplateBinding hc:BorderElement.CornerRadius}"BorderThickness="{TemplateBinding BorderThickness}"Background="{DynamicResource Background2}"><Grid Name="templateRoot"ClipToBounds="true"SnapsToDevicePixels="true"><Grid.ColumnDefinitions><ColumnDefinition Width="*"x:Name="column1" /><ColumnDefinition Width="auto" /></Grid.ColumnDefinitions><Grid.RowDefinitions><RowDefinition Height="60" /><RowDefinition Height="*" /></Grid.RowDefinitions><TabPanel Name="PART_HeaderPanel"IsItemsHost="true"ZIndex="1" /><Border x:Name="contentPanel"Background="{DynamicResource WhiteBackground}"Grid.Column="0"Grid.ColumnSpan="2"Grid.Row="1"><Grid x:Name="PART_ItemsHolder"SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}">	<!--<ContentPresenter Name="PART_SelectedContentHost"ContentSource="SelectedContent"Margin="{TemplateBinding Padding}"SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" />--></Grid></Border></Grid></Border></ControlTemplate></Setter.Value></Setter></Style></control:TabControlEx.Style>
</control:TabControlEx>

三 原文连接:stackoverflow

四 TabControl 扩展(模板选择器)

本教程基于Prism + HandyControl + .Net Framework 4.8
要手动添加标签页,并且每个标签页不同,可使用模板选择器实现,示例:
这里每个标签页有自己的后台处理逻辑,即FrontPageView.xaml的后台是FrontPageViewModel.cs

注意点:由于标签页有自己的处理逻辑,并且是嵌入在TabControl中,所以
不能在标签页中开启Prism的自动查找功能 即xmlns:prism="http://prismlibrary.com/" prism:ViewModelLocator.AutoWireViewModel="False" 或者 不写这两行代码

<UserControl.Resources><!-- 首页模板 --><DataTemplate x:Key="FrontPageTemplate"DataType="{x:Type pageview:FrontPageViewModel}"><pageview:FrontPageView /></DataTemplate><!-- 其他页面模板 --><DataTemplate x:Key="WebPageTemplate"DataType="{x:Type pageview:WebPageViewModel}"><pageview:WebPageView /></DataTemplate><!-- 模板选择器 --><helper:TabContentTemplateSelector x:Key="TabContentTemplateSelector"FrontPageTemplate="{StaticResource FrontPageTemplate}"WebPageTemplate="{StaticResource WebPageTemplate}" />
</UserControl.Resources><control:TabControlEx ItemsSource="{Binding TabItems, Mode=TwoWay}"SelectedItem="{Binding SelectedTab, Mode=TwoWay}"ContentTemplateSelector="{StaticResource TabContentTemplateSelector}">
</control:TabControlEx>
  internal class TabContentTemplateSelector : DataTemplateSelector{public DataTemplate FrontPageTemplate { get; set; }public DataTemplate WebPageTemplate { get; set; }public override DataTemplate SelectTemplate(object item, DependencyObject container){if (item is FrontPageViewModel)return FrontPageTemplate;if (item is WebPageViewModel)return WebPageTemplate;return base.SelectTemplate(item, container);}}

TabControlEx 的后台代码:

private ObservableCollection<object> _allTabItems;
public ObservableCollection<object> TabItems
{get { return _allTabItems; }set { SetProperty(ref _allTabItems, value); }
}private object _selectedTab;
public object SelectedTab
{get { return _selectedTab; }set { SetProperty(ref _selectedTab, value); }
}//添加标签页
private void OnAddTabCommand()
{WebPageViewModel webPage = new WebPageViewModel();//TODO:TabItems.Add(webPage);
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com