當前位置: 首頁>>代碼示例>>C#>>正文


C# TreeNode.SortChildren方法代碼示例

本文整理匯總了C#中System.Windows.Forms.TreeNode.SortChildren方法的典型用法代碼示例。如果您正苦於以下問題:C# TreeNode.SortChildren方法的具體用法?C# TreeNode.SortChildren怎麽用?C# TreeNode.SortChildren使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Windows.Forms.TreeNode的用法示例。


在下文中一共展示了TreeNode.SortChildren方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: AddSorted

		internal int AddSorted(TreeNode node)
		{
			int pos = 0;
			string text = node.Text;
			if (childCount > 0)
			{
				Globalization.CompareInfo compare = Application.CurrentCulture.CompareInfo;
				// Simple optimization if added in sort order
				if (compare.Compare(children[(childCount - 1)].Text, text) <= 0)
					pos = childCount;
				else
				{
					// Binary Search
					int i = 0;
					int j = childCount;
					while (i < j)
					{
						int mid = (i + j) / 2;
						if (compare.Compare(children[mid].Text, text) <= 0)
							i = mid + 1;
						else
							i = mid;
					}
					pos = i;
				}
			}

			node.SortChildren();
			InsertNodeAt(pos, node);
			if (treeView != null && node == treeView.selectedNode)
			{
				treeView.SelectedNode = node;
			}
			return pos;
		}
開發者ID:jjenki11,項目名稱:blaze-chem-rendering,代碼行數:35,代碼來源:TreeNode.cs

示例2: AddSorted

 internal int AddSorted(TreeNode node)
 {
     int index = 0;
     string text = node.Text;
     System.Windows.Forms.TreeView treeView = this.TreeView;
     if (this.childCount > 0)
     {
         int num2;
         int childCount;
         int num4;
         if (treeView.TreeViewNodeSorter == null)
         {
             CompareInfo compareInfo = Application.CurrentCulture.CompareInfo;
             if (compareInfo.Compare(this.children[this.childCount - 1].Text, text) <= 0)
             {
                 index = this.childCount;
             }
             else
             {
                 num2 = 0;
                 childCount = this.childCount;
                 while (num2 < childCount)
                 {
                     num4 = (num2 + childCount) / 2;
                     if (compareInfo.Compare(this.children[num4].Text, text) <= 0)
                     {
                         num2 = num4 + 1;
                     }
                     else
                     {
                         childCount = num4;
                     }
                 }
                 index = num2;
             }
         }
         else
         {
             IComparer treeViewNodeSorter = treeView.TreeViewNodeSorter;
             num2 = 0;
             childCount = this.childCount;
             while (num2 < childCount)
             {
                 num4 = (num2 + childCount) / 2;
                 if (treeViewNodeSorter.Compare(this.children[num4], node) <= 0)
                 {
                     num2 = num4 + 1;
                 }
                 else
                 {
                     childCount = num4;
                 }
             }
             index = num2;
         }
     }
     node.SortChildren(treeView);
     this.InsertNodeAt(index, node);
     return index;
 }
開發者ID:pritesh-mandowara-sp,項目名稱:DecompliedDotNetLibraries,代碼行數:60,代碼來源:TreeNode.cs

示例3: AddSorted

        /// <include file='doc\TreeNode.uex' path='docs/doc[@for="TreeNode.AddSorted"]/*' />
        /// <devdoc>
        ///     Adds a new child node at the appropriate sorted position
        /// </devdoc>
        /// <internalonly/>
        internal int AddSorted(TreeNode node) {
            int index = 0;
            int iMin, iLim, iT;
            string nodeText = node.Text;
            TreeView parentTreeView = TreeView;
            
            if (childCount > 0) {
                if (parentTreeView.TreeViewNodeSorter == null)
                {
                    CompareInfo compare = Application.CurrentCulture.CompareInfo;

                    // Optimize for the case where they're already sorted
                    if (compare.Compare(children[childCount-1].Text, nodeText) <= 0)
                        index = childCount;
                    else {
                        // Insert at appropriate sorted spot
                        for (iMin = 0, iLim = childCount; iMin < iLim;) {
                            iT = (iMin + iLim) / 2;
                            if (compare.Compare(children[iT].Text, nodeText) <= 0)
                                iMin = iT + 1;
                            else
                                iLim = iT;
                        }
                        index = iMin;
                    }
                }
                else 
                {
                    IComparer sorter = parentTreeView.TreeViewNodeSorter;
                    // Insert at appropriate sorted spot
                    for (iMin = 0, iLim = childCount; iMin < iLim;) {
                        iT = (iMin + iLim) / 2;
                        if (sorter.Compare(children[iT] /*previous*/, node/*current*/) <= 0)
                            iMin = iT + 1;
                        else
                            iLim = iT;
                    }
                    index = iMin;
                }
            }
           
            node.SortChildren(parentTreeView);
            InsertNodeAt(index, node);
            
            return index;
        }
開發者ID:JianwenSun,項目名稱:cc,代碼行數:51,代碼來源:TreeNode.cs


注:本文中的System.Windows.Forms.TreeNode.SortChildren方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。