ListBox.SelectedIndexCollection クラス

定義

ListBox 内の選ばれた項目へのインデックスを含むコレクションを表します。Represents the collection containing the indexes to the selected items in a ListBox.

public: ref class ListBox::SelectedIndexCollection : System::Collections::IList
public class ListBox.SelectedIndexCollection : System.Collections.IList
type ListBox.SelectedIndexCollection = class
    interface IList
    interface ICollection
    interface IEnumerable
Public Class ListBox.SelectedIndexCollection
Implements IList
継承
ListBox.SelectedIndexCollection
実装

次の例は、メソッドを使用して FindString 、の項目内の検索テキストのすべてのインスタンスを検索する方法を示して ListBox います。The following example demonstrates how to use the FindString method to search for all instances of the search text in the items of the ListBox. この例では、メソッドのバージョンを使用します。これにより、内のすべての項目を連続して検索するための FindString 開始検索インデックスを指定でき ListBox ます。The example uses the version of the FindString method that enables you to specify a starting search index from which to do a continual search of all items in the ListBox. また、この例では、 FindString 再帰的検索を回避するために、リストの一番下に達した後に、メソッドがリストの先頭から検索を開始するタイミングを決定する方法も示しています。The example also demonstrates how to determine when the FindString method begins searching from the top of the list after it reaches the bottom of the list of items to prevent a recursive search. で見つかった項目は、 ListBox メソッドを使用して選択され SetSelected ます。Once items are found in the ListBox, they are selected using the SetSelected method.

private:
   void FindAllOfMyString( String^ searchString )
   {
      // Set the SelectionMode property of the ListBox to select multiple items.
      listBox1->SelectionMode = SelectionMode::MultiExtended;

      // Set our intial index variable to -1.
      int x = -1;

      // If the search string is empty exit.
      if ( searchString->Length != 0 )
      {
         // Loop through and find each item that matches the search string.
         do
         {
            // Retrieve the item based on the previous index found. Starts with -1 which searches start.
            x = listBox1->FindString( searchString, x );

            // If no item is found that matches exit.
            if ( x != -1 )
            {
               // Since the FindString loops infinitely, determine if we found first item again and exit.
               if ( listBox1->SelectedIndices->Count > 0 )
               {
                  if ( x == listBox1->SelectedIndices[ 0 ] )
                                    return;
               }

               // Select the item in the ListBox once it is found.
               listBox1->SetSelected( x, true );
            }
         }
         while ( x != -1 );
      }
   }
private void FindAllOfMyString(string searchString)
{
   // Set the SelectionMode property of the ListBox to select multiple items.
   listBox1.SelectionMode = SelectionMode.MultiExtended;
   
   // Set our intial index variable to -1.
   int x =-1;
   // If the search string is empty exit.
   if (searchString.Length != 0)
   {
      // Loop through and find each item that matches the search string.
      do
      {
         // Retrieve the item based on the previous index found. Starts with -1 which searches start.
         x = listBox1.FindString(searchString, x);
         // If no item is found that matches exit.
         if (x != -1)
         {
            // Since the FindString loops infinitely, determine if we found first item again and exit.
            if (listBox1.SelectedIndices.Count > 0)
            {
               if(x == listBox1.SelectedIndices[0])
                  return;
            }
            // Select the item in the ListBox once it is found.
            listBox1.SetSelected(x,true);
         }
      }while(x != -1);
   }
}
Private Sub FindAllOfMyString(ByVal searchString As String)
   ' Set the SelectionMode property of the ListBox to select multiple items.
   listBox1.SelectionMode = SelectionMode.MultiExtended

   ' Set our intial index variable to -1.
   Dim x As Integer = -1
   ' If the search string is empty exit.
   If searchString.Length <> 0 Then
      ' Loop through and find each item that matches the search string.
      Do
         ' Retrieve the item based on the previous index found. Starts with -1 which searches start.
         x = listBox1.FindString(searchString, x)
         ' If no item is found that matches exit.
         If x <> -1 Then
            ' Since the FindString loops infinitely, determine if we found first item again and exit.
            If ListBox1.SelectedIndices.Count > 0 Then
               If x = ListBox1.SelectedIndices(0) Then
                  Return
               End If
            End If
            ' Select the item in the ListBox once it is found.
            ListBox1.SetSelected(x, True)
         End If
      Loop While x <> -1
   End If
End Sub

注釈

ListBox.SelectedIndexCollectionクラスは、内の選択された項目にインデックスを格納し ListBox ます。The ListBox.SelectedIndexCollection class stores the indexes to the selected items in the ListBox. に格納されているインデックス ListBox.SelectedIndexCollection は、クラス内のインデックス位置です ListBox.ObjectCollectionThe indexes stored in the ListBox.SelectedIndexCollection are index positions within the ListBox.ObjectCollection class. ListBox.ObjectCollectionクラスは、に表示されるすべての項目を格納し ListBox ます。The ListBox.ObjectCollection class stores all items displayed in the ListBox.

次の表に、の項目とその ListBox.ObjectCollection 選択状態を格納する ListBox 例を示し ListBox ます。The following table is an example of how the ListBox.ObjectCollection stores the items of the ListBox as well as their selection states within an example ListBox.

インデックスIndex ItemItem リストボックス内の選択状態Selection state within the ListBox
00 object1object1 未選択Unselected
11 object2object2 SelectedSelected
22 object3object3 未選択Unselected
33 object4object4 SelectedSelected
44 object5object5 SelectedSelected

次の表は、前の表の例に基づいて ListBox.ObjectCollection 、がどのように表示されるかを示して ListBox.SelectedIndexCollection います。Based on the ListBox.ObjectCollection example in the previous table, the following table demonstrates how the ListBox.SelectedIndexCollection would appear.

インデックスIndex ObjectCollection 内の選択された項目のインデックスIndex of selected item in ObjectCollection
00 11
11 33
22 44

このクラスのプロパティとメソッドを使用して、コレクションに対してさまざまなタスクを実行できます。You can use the properties and methods of this class to perform a variety of tasks with the collection. Containsメソッドを使用すると、クラスのインデックス位置 ListBox.ObjectCollection が、に格納されている選択されたインデックスのメンバーであるかどうかを判断でき ListBox.SelectedIndexCollection ます。The Contains method enables you to determine whether an index position from the ListBox.ObjectCollection class is a member of the selected indexes stored in the ListBox.SelectedIndexCollection. コレクション内に項目があることを確認したら、メソッドを使用して、の IndexOf 内の特定のインデックス位置が格納されている場所を確認でき ListBox.ObjectCollection ListBox ます。Once you know that the item is located within the collection, you can use the IndexOf method to determine where a specific index position within the ListBox.ObjectCollection for the ListBox is stored.

コンストラクター

ListBox.SelectedIndexCollection(ListBox)

ListBox.SelectedIndexCollection クラスの新しいインスタンスを初期化します。Initializes a new instance of the ListBox.SelectedIndexCollection class.

プロパティ

Count

コレクション内の項目の数を取得します。Gets the number of items in the collection.

IsReadOnly

コレクションが読み取り専用かどうかを示す値を取得します。Gets a value indicating whether the collection is read-only.

Item[Int32]

コレクション内の指定したインデックスにあるインデックス値を取得します。Gets the index value at the specified index within this collection.

メソッド

Add(Int32)

指定したインデックス位置に ListBox を追加します。Adds the ListBox at the specified index location.

Clear()

コレクションからすべてのコントロールを削除します。Removes all controls from the collection.

Contains(Int32)

指定したインデックスがコレクション内にあるかどうかを確認します。Determines whether the specified index is located within the collection.

CopyTo(Array, Int32)

コレクション全体を既存の配列内の指定した位置にコピーします。Copies the entire collection into an existing array at a specified location within the array.

Equals(Object)

指定されたオブジェクトが現在のオブジェクトと等しいかどうかを判断します。Determines whether the specified object is equal to the current object.

(継承元 Object)
GetEnumerator()

選択されているインデックス コレクションを反復処理するために使用する列挙子を返します。Returns an enumerator to use to iterate through the selected indexes collection.

GetHashCode()

既定のハッシュ関数として機能します。Serves as the default hash function.

(継承元 Object)
GetType()

現在のインスタンスの Type を取得します。Gets the Type of the current instance.

(継承元 Object)
IndexOf(Int32)

ListBox.SelectedIndexCollectionListBox.ObjectCollection 内で指定されたインデックスについて、ListBox 内におけるインデックスを返します。Returns the index within the ListBox.SelectedIndexCollection of the specified index from the ListBox.ObjectCollection of the ListBox.

MemberwiseClone()

現在の Object の簡易コピーを作成します。Creates a shallow copy of the current Object.

(継承元 Object)
Remove(Int32)

指定したコントロールをコレクションから削除します。Removes the specified control from the collection.

ToString()

現在のオブジェクトを表す文字列を返します。Returns a string that represents the current object.

(継承元 Object)

明示的なインターフェイスの実装

ICollection.IsSynchronized

このメンバーの詳細については、「IsSynchronized」をご覧ください。For a description of this member, see IsSynchronized.

ICollection.SyncRoot

このメンバーの詳細については、「SyncRoot」をご覧ください。For a description of this member, see SyncRoot.

IList.Add(Object)

このメンバーの詳細については、「Add(Object)」をご覧ください。For a description of this member, see Add(Object).

IList.Clear()

このメンバーの詳細については、「Clear()」をご覧ください。For a description of this member, see Clear().

IList.Contains(Object)

このメンバーの詳細については、「Contains(Object)」をご覧ください。For a description of this member, see Contains(Object).

IList.IndexOf(Object)

このメンバーの詳細については、「IndexOf(Object)」をご覧ください。For a description of this member, see IndexOf(Object).

IList.Insert(Int32, Object)

このメンバーの詳細については、「Insert(Int32, Object)」をご覧ください。For a description of this member, see Insert(Int32, Object).

IList.IsFixedSize

このメンバーの詳細については、「IsFixedSize」をご覧ください。For a description of this member, see IsFixedSize.

IList.Item[Int32]

このメンバーの詳細については、「Item[Int32]」をご覧ください。For a description of this member, see Item[Int32].

IList.Remove(Object)

このメンバーの詳細については、「Remove(Object)」をご覧ください。For a description of this member, see Remove(Object).

IList.RemoveAt(Int32)

このメンバーの詳細については、「RemoveAt(Int32)」をご覧ください。For a description of this member, see RemoveAt(Int32).

拡張メソッド

Cast<TResult>(IEnumerable)

IEnumerable の要素を、指定した型にキャストします。Casts the elements of an IEnumerable to the specified type.

OfType<TResult>(IEnumerable)

指定された型に基づいて IEnumerable の要素をフィルター処理します。Filters the elements of an IEnumerable based on a specified type.

AsParallel(IEnumerable)

クエリの並列化を有効にします。Enables parallelization of a query.

AsQueryable(IEnumerable)

IEnumerableIQueryable に変換します。Converts an IEnumerable to an IQueryable.

適用対象