Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / System / Windows / Controls / ListView.cs / 1305600 / ListView.cs
//---------------------------------------------------------------------------- // // Copyright (C) Microsoft Corporation. All rights reserved. // //--------------------------------------------------------------------------- using System.Collections.Specialized; using System.Windows.Automation.Peers; // OnCreateAutomationPeer namespace System.Windows.Controls { ////// A general purpose control for data presentation as part of the set of common controls provided with Avalon. /// Drop a control into a layout; /// Enable application developers to display data efficiently; /// Allow the presentation of data to be styled, including the layout and the item visuals; /// No type-specific functionality. /// /// ListView is a control which has /// A data collection; /// A set of predefined operations to manipulate the data/view. /// Also, ListView is a control for the most convenient browsing of data. /// #if OLD_AUTOMATION [Automation(AccessibilityControlType = "List")] #endif [StyleTypedProperty(Property = "ItemContainerStyle", StyleTargetType = typeof(ListViewItem))] public class ListView : ListBox { //------------------------------------------------------------------- // // Constructors // //------------------------------------------------------------------- #region Constructors static ListView() { SelectionModeProperty.OverrideMetadata(typeof(ListView), new FrameworkPropertyMetadata(SelectionMode.Extended)); } #endregion Constructors //-------------------------------------------------------------------- // // Public Methods // //------------------------------------------------------------------- //-------------------------------------------------------------------- // // Public Properties // //-------------------------------------------------------------------- #region Public Properties ////// View DependencyProperty /// public static readonly DependencyProperty ViewProperty = DependencyProperty.Register( "View", typeof(ViewBase), typeof(ListView), new PropertyMetadata( new PropertyChangedCallback(OnViewChanged)) ); ////// descriptor of the whole view. Include chrome/layout/item/... /// public ViewBase View { get { return (ViewBase)GetValue(ViewProperty); } set { SetValue(ViewProperty, value); } } private static void OnViewChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) { ListView listView = (ListView)d; ViewBase oldView = (ViewBase)e.OldValue; ViewBase newView = (ViewBase)e.NewValue; if (newView != null) { if (newView.IsUsed) { throw new InvalidOperationException(SR.Get(SRID.ListView_ViewCannotBeShared)); } newView.IsUsed = true; } // In ApplyNewView ListView.ClearContainerForItemOverride will be called for each item. // Should use old view to do clear item. listView._previousView = oldView; listView.ApplyNewView(); // After ApplyNewView, if item is removed, ListView.ClearContainerForItemOverride will be called. // Then should use new view to do clear item. listView._previousView = newView; //Switch ViewAutomationPeer in ListViewAutomationPeer ListViewAutomationPeer lvPeer = UIElementAutomationPeer.FromElement(listView) as ListViewAutomationPeer; if (lvPeer != null) { if (lvPeer.ViewAutomationPeer != null) { lvPeer.ViewAutomationPeer.ViewDetached(); } if (newView != null) { lvPeer.ViewAutomationPeer = newView.GetAutomationPeer(listView); } else { lvPeer.ViewAutomationPeer = null; } //Invalidate the ListView automation tree because the view has been changed lvPeer.InvalidatePeer(); } if (oldView != null) { oldView.IsUsed = false; } } #endregion //------------------------------------------------------------------- // // Protected Methods // //-------------------------------------------------------------------- #region Protected Methods ////// Prepare the element to display the item. Override the default style /// if new view is a GridView and no ItemContainerStyle provided. /// Will call View.PrepareItem() to allow view do preparison for item. /// protected override void PrepareContainerForItemOverride(DependencyObject element, object item) { base.PrepareContainerForItemOverride(element, item); ListViewItem lvi = element as ListViewItem; if (lvi != null) { ViewBase view = View; if (view != null) { // update default style key lvi.SetDefaultStyleKey(view.ItemContainerDefaultStyleKey); view.PrepareItem(lvi); } else { lvi.ClearDefaultStyleKey(); } } } ////// Clear the element to display the item. /// protected override void ClearContainerForItemOverride(DependencyObject element, object item) { // This method no longer does the work it used to (bug 1445288). // It is called when a container is removed from the tree; such a // container will be GC'd soon, so there's no point in changing // its properties. base.ClearContainerForItemOverride(element, item); } ///Return true if the item is (or is eligible to be) its own ItemContainer protected override bool IsItemItsOwnContainerOverride(object item) { return (item is ListViewItem); } ///Create or identify the element used to display the given item. protected override DependencyObject GetContainerForItemOverride() { return new ListViewItem(); } ////// /// /// protected override void OnItemsChanged(NotifyCollectionChangedEventArgs e) { base.OnItemsChanged(e); ListViewAutomationPeer lvPeer = UIElementAutomationPeer.FromElement(this) as ListViewAutomationPeer; if (lvPeer != null && lvPeer.ViewAutomationPeer != null) { lvPeer.ViewAutomationPeer.ItemsChanged(e); } } #endregion // Protected Methods //------------------------------------------------------------------- // // Accessibility // //------------------------------------------------------------------- #region Accessibility ////// Creates AutomationPeer ( protected override AutomationPeer OnCreateAutomationPeer() { ListViewAutomationPeer lvPeer = new ListViewAutomationPeer(this); if (lvPeer != null && View != null) { lvPeer.ViewAutomationPeer = View.GetAutomationPeer(this); } return lvPeer; } #endregion //------------------------------------------------------------------- // // Private Methods // //-------------------------------------------------------------------- #region Private Methods // apply styles described in View. private void ApplyNewView() { ViewBase newView = View; if (newView != null) { // update default style key of ListView DefaultStyleKey = newView.DefaultStyleKey; } else { ClearValue(DefaultStyleKeyProperty); } // Encounter a new view after loaded means user is switching view. // Force to regenerate all containers. if (IsLoaded) { ItemContainerGenerator.Refresh(); } } // Invalidate resources on the view header if the header isn't // reachable via the visual/logical tree internal override void OnThemeChanged() { // If the ListView does not have a template generated tree then its // View.Header is not reachable via a tree walk. if (!HasTemplateGeneratedSubTree && View != null) { View.OnThemeChanged(); } } #endregion Private Methods //------------------------------------------------------------------- // // Private Fields // //-------------------------------------------------------------------- private ViewBase _previousView; } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //---------------------------------------------------------------------------- // // Copyright (C) Microsoft Corporation. All rights reserved. // //--------------------------------------------------------------------------- using System.Collections.Specialized; using System.Windows.Automation.Peers; // OnCreateAutomationPeer namespace System.Windows.Controls { ///) /// /// A general purpose control for data presentation as part of the set of common controls provided with Avalon. /// Drop a control into a layout; /// Enable application developers to display data efficiently; /// Allow the presentation of data to be styled, including the layout and the item visuals; /// No type-specific functionality. /// /// ListView is a control which has /// A data collection; /// A set of predefined operations to manipulate the data/view. /// Also, ListView is a control for the most convenient browsing of data. /// #if OLD_AUTOMATION [Automation(AccessibilityControlType = "List")] #endif [StyleTypedProperty(Property = "ItemContainerStyle", StyleTargetType = typeof(ListViewItem))] public class ListView : ListBox { //------------------------------------------------------------------- // // Constructors // //------------------------------------------------------------------- #region Constructors static ListView() { SelectionModeProperty.OverrideMetadata(typeof(ListView), new FrameworkPropertyMetadata(SelectionMode.Extended)); } #endregion Constructors //-------------------------------------------------------------------- // // Public Methods // //------------------------------------------------------------------- //-------------------------------------------------------------------- // // Public Properties // //-------------------------------------------------------------------- #region Public Properties ////// View DependencyProperty /// public static readonly DependencyProperty ViewProperty = DependencyProperty.Register( "View", typeof(ViewBase), typeof(ListView), new PropertyMetadata( new PropertyChangedCallback(OnViewChanged)) ); ////// descriptor of the whole view. Include chrome/layout/item/... /// public ViewBase View { get { return (ViewBase)GetValue(ViewProperty); } set { SetValue(ViewProperty, value); } } private static void OnViewChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) { ListView listView = (ListView)d; ViewBase oldView = (ViewBase)e.OldValue; ViewBase newView = (ViewBase)e.NewValue; if (newView != null) { if (newView.IsUsed) { throw new InvalidOperationException(SR.Get(SRID.ListView_ViewCannotBeShared)); } newView.IsUsed = true; } // In ApplyNewView ListView.ClearContainerForItemOverride will be called for each item. // Should use old view to do clear item. listView._previousView = oldView; listView.ApplyNewView(); // After ApplyNewView, if item is removed, ListView.ClearContainerForItemOverride will be called. // Then should use new view to do clear item. listView._previousView = newView; //Switch ViewAutomationPeer in ListViewAutomationPeer ListViewAutomationPeer lvPeer = UIElementAutomationPeer.FromElement(listView) as ListViewAutomationPeer; if (lvPeer != null) { if (lvPeer.ViewAutomationPeer != null) { lvPeer.ViewAutomationPeer.ViewDetached(); } if (newView != null) { lvPeer.ViewAutomationPeer = newView.GetAutomationPeer(listView); } else { lvPeer.ViewAutomationPeer = null; } //Invalidate the ListView automation tree because the view has been changed lvPeer.InvalidatePeer(); } if (oldView != null) { oldView.IsUsed = false; } } #endregion //------------------------------------------------------------------- // // Protected Methods // //-------------------------------------------------------------------- #region Protected Methods ////// Prepare the element to display the item. Override the default style /// if new view is a GridView and no ItemContainerStyle provided. /// Will call View.PrepareItem() to allow view do preparison for item. /// protected override void PrepareContainerForItemOverride(DependencyObject element, object item) { base.PrepareContainerForItemOverride(element, item); ListViewItem lvi = element as ListViewItem; if (lvi != null) { ViewBase view = View; if (view != null) { // update default style key lvi.SetDefaultStyleKey(view.ItemContainerDefaultStyleKey); view.PrepareItem(lvi); } else { lvi.ClearDefaultStyleKey(); } } } ////// Clear the element to display the item. /// protected override void ClearContainerForItemOverride(DependencyObject element, object item) { // This method no longer does the work it used to (bug 1445288). // It is called when a container is removed from the tree; such a // container will be GC'd soon, so there's no point in changing // its properties. base.ClearContainerForItemOverride(element, item); } ///Return true if the item is (or is eligible to be) its own ItemContainer protected override bool IsItemItsOwnContainerOverride(object item) { return (item is ListViewItem); } ///Create or identify the element used to display the given item. protected override DependencyObject GetContainerForItemOverride() { return new ListViewItem(); } ////// /// /// protected override void OnItemsChanged(NotifyCollectionChangedEventArgs e) { base.OnItemsChanged(e); ListViewAutomationPeer lvPeer = UIElementAutomationPeer.FromElement(this) as ListViewAutomationPeer; if (lvPeer != null && lvPeer.ViewAutomationPeer != null) { lvPeer.ViewAutomationPeer.ItemsChanged(e); } } #endregion // Protected Methods //------------------------------------------------------------------- // // Accessibility // //------------------------------------------------------------------- #region Accessibility ////// Creates AutomationPeer ( protected override AutomationPeer OnCreateAutomationPeer() { ListViewAutomationPeer lvPeer = new ListViewAutomationPeer(this); if (lvPeer != null && View != null) { lvPeer.ViewAutomationPeer = View.GetAutomationPeer(this); } return lvPeer; } #endregion //------------------------------------------------------------------- // // Private Methods // //-------------------------------------------------------------------- #region Private Methods // apply styles described in View. private void ApplyNewView() { ViewBase newView = View; if (newView != null) { // update default style key of ListView DefaultStyleKey = newView.DefaultStyleKey; } else { ClearValue(DefaultStyleKeyProperty); } // Encounter a new view after loaded means user is switching view. // Force to regenerate all containers. if (IsLoaded) { ItemContainerGenerator.Refresh(); } } // Invalidate resources on the view header if the header isn't // reachable via the visual/logical tree internal override void OnThemeChanged() { // If the ListView does not have a template generated tree then its // View.Header is not reachable via a tree walk. if (!HasTemplateGeneratedSubTree && View != null) { View.OnThemeChanged(); } } #endregion Private Methods //------------------------------------------------------------------- // // Private Fields // //-------------------------------------------------------------------- private ViewBase _previousView; } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.) ///
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- WebPartConnectionsConfigureVerb.cs
- FilterQueryOptionExpression.cs
- XPathNode.cs
- TableStyle.cs
- ObjectDesignerDataSourceView.cs
- RowUpdatingEventArgs.cs
- SHA256Managed.cs
- SqlRowUpdatingEvent.cs
- ElapsedEventArgs.cs
- TrimSurroundingWhitespaceAttribute.cs
- FullTextLine.cs
- CommandHelper.cs
- XmlDataSource.cs
- ReferenceAssemblyAttribute.cs
- XmlSerializerAssemblyAttribute.cs
- PriorityItem.cs
- XmlCharCheckingReader.cs
- XmlSecureResolver.cs
- PropertyChange.cs
- EdmFunction.cs
- BuildProviderAppliesToAttribute.cs
- NavigationExpr.cs
- CompositeFontFamily.cs
- DebugView.cs
- ISAPIApplicationHost.cs
- Rotation3DAnimation.cs
- DictionaryManager.cs
- WindowsListView.cs
- MetadataProperty.cs
- HyperLinkColumn.cs
- ServicesSection.cs
- CatalogPartCollection.cs
- ResizeGrip.cs
- ExtractorMetadata.cs
- Authorization.cs
- ListItemConverter.cs
- VBIdentifierName.cs
- TableCell.cs
- WebRequestModulesSection.cs
- RuntimeResourceSet.cs
- PeerCollaboration.cs
- AssemblyResourceLoader.cs
- ButtonChrome.cs
- GlyphingCache.cs
- WebEventCodes.cs
- PrePrepareMethodAttribute.cs
- TokenizerHelper.cs
- PointHitTestParameters.cs
- StateBag.cs
- GroupByQueryOperator.cs
- OleDbMetaDataFactory.cs
- ToolStripProfessionalLowResolutionRenderer.cs
- LocalIdKeyIdentifierClause.cs
- DataRecordObjectView.cs
- ToolStripLabel.cs
- ScaleTransform.cs
- WebConfigurationHostFileChange.cs
- KeyGesture.cs
- InkCanvasInnerCanvas.cs
- XmlCharacterData.cs
- ExceptionRoutedEventArgs.cs
- ItemCollectionEditor.cs
- ConfigDefinitionUpdates.cs
- formatter.cs
- HealthMonitoringSection.cs
- IgnoreDeviceFilterElement.cs
- OdbcUtils.cs
- IndexedString.cs
- NestPullup.cs
- SqlEnums.cs
- SoapSchemaImporter.cs
- _LocalDataStoreMgr.cs
- SelectionPattern.cs
- Int16Animation.cs
- CheckBoxList.cs
- VoiceChangeEventArgs.cs
- WorkerRequest.cs
- XmlArrayItemAttribute.cs
- HtmlInputCheckBox.cs
- DataGridViewCellEventArgs.cs
- RelationshipEnd.cs
- ImportOptions.cs
- IPHostEntry.cs
- FilteredXmlReader.cs
- CellIdBoolean.cs
- ResourceDefaultValueAttribute.cs
- DataGridViewControlCollection.cs
- ImmutableObjectAttribute.cs
- SelectingProviderEventArgs.cs
- CryptoApi.cs
- HttpListenerContext.cs
- WindowsListViewItemStartMenu.cs
- ToolStripItemImageRenderEventArgs.cs
- BypassElementCollection.cs
- StringAttributeCollection.cs
- DataAccessor.cs
- TraceHandlerErrorFormatter.cs
- AsyncCodeActivityContext.cs
- DataGridViewCheckBoxCell.cs
- HtmlPanelAdapter.cs