DataGrid.HitTestType-Enumeration
Gibt den Teil des System.Windows.Forms.DataGrid-Steuerelements an, auf den der Benutzer geklickt hat.
Diese Enumeration verfügt über ein FlagsAttribute -Attribut, das die bitweise Kombination der Memberwerte zulässt.
Namespace: System.Windows.Forms
Assembly: System.Windows.Forms (in system.windows.forms.dll)
Syntax
'Declaration
<FlagsAttribute> _
Public Enumeration HitTestType
'Usage
Dim instance As HitTestType
[FlagsAttribute]
public enum HitTestType
[FlagsAttribute]
public enum class HitTestType
/** @attribute FlagsAttribute() */
public enum HitTestType
FlagsAttribute
public enum HitTestType
Member
Membername | Beschreibung | |
---|---|---|
Caption | Die Beschriftung des System.Windows.Forms.DataGrid-Steuerelements. | |
Cell | Eine Zelle im System.Windows.Forms.DataGrid-Steuerelement. | |
ColumnHeader | Ein Spaltenkopf im System.Windows.Forms.DataGrid-Steuerelement. | |
ColumnResize | Der Spaltenrahmen, d. h. die Linie zwischen den Spaltenköpfen. Durch Ziehen dieses Rahmens kann die Breite einer Spalte geändert werden. | |
None | Der Hintergrundbereich, der sichtbar ist, wenn das Steuerelement keine Tabelle bzw. wenige Zeilen enthält, oder wenn in der Tabelle ein Bildlauf bis zum unteren Ende durchgeführt wurde. | |
ParentRows | Der Bereich der übergeordneten Zeile des System.Windows.Forms.DataGrid-Steuerelements. In der übergeordneten Zeile werden Informationen aus oder zu der Tabelle angezeigt, die der momentan angezeigten Tabelle übergeordnet ist, z. B. der Name der übergeordneten Tabelle, Spaltennamen und Werte des übergeordneten Datensatzes. | |
RowHeader | Ein Zeilenkopf im System.Windows.Forms.DataGrid-Steuerelement. | |
RowResize | Der Zeilenrahmen, d. h. die Linie zwischen den Zeilenköpfen der Tabelle. Durch Ziehen dieses Rahmens kann die Höhe einer Zeile geändert werden. |
Hinweise
Sie können mithilfe der Member dieser Enumeration ermitteln, auf welchen Teil der Tabelle geklickt wurde. Die Type-Eigenschaft einer DataGrid.HitTestInfo gibt einen DataGrid.HitTestType zurück. DataGrid.HitTestInfo wird durch Aufrufen der HitTest-Methode eines System.Windows.Forms.DataGridSteuerelements erstellt.
Beispiel
Im folgenden Beispiel wird mithilfe der HitTest-Methode in einem MouseDown-Ereignis die DataGrid.HitTestInfo zurückgegeben. Daraufhin werden die Zeile, die Spalte und ein Teil der Tabelle ausgegeben.
Private Sub dataGrid1_MouseDown(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs)
Dim newLine As String = ControlChars.Cr
Console.WriteLine(newLine)
Dim myHitTest As System.Windows.Forms.DataGrid.HitTestInfo
' Use the DataGrid control's HitTest method with the x and y properties.
myHitTest = dataGrid1.HitTest(e.X, e.Y)
Console.WriteLine(myHitTest)
Console.WriteLine(("Column " & myHitTest.Column))
Console.WriteLine(("Row " & myHitTest.Row))
Console.WriteLine(("Type " & myHitTest.Type))
Console.WriteLine(("ToString " & myHitTest.ToString()))
Console.WriteLine(("Hit " & ReturnHitTest(myHitTest.Type)))
End Sub 'dataGrid1_MouseDown
Private Function ReturnHitTest(hit As System.Windows.Forms.DataGrid.HitTestType) As String
' Use this function to return the part of the grid clicked.
Select Case hit
Case System.Windows.Forms.DataGrid.HitTestType.Cell
Return "Cell"
Case System.Windows.Forms.DataGrid.HitTestType.Caption
Return "Caption"
Case System.Windows.Forms.DataGrid.HitTestType.ColumnHeader
Return "ColumnHeader"
Case System.Windows.Forms.DataGrid.HitTestType.ColumnResize
Return "Resize"
Case System.Windows.Forms.DataGrid.HitTestType.ParentRows
Return "ParentRows"
Case System.Windows.Forms.DataGrid.HitTestType.RowHeader
Return "RowHeader"
Case System.Windows.Forms.DataGrid.HitTestType.RowResize
Return "RowResize"
Case System.Windows.Forms.DataGrid.HitTestType.None
Return "None"
Case Else
Return "Unknown"
End Select
End Function 'ReturnHitTest
private void dataGrid1_MouseDown
(object sender, System.Windows.Forms.MouseEventArgs e)
{
string newLine = "\n";
Console.WriteLine(newLine);
System.Windows.Forms.DataGrid.HitTestInfo myHitTest;
// Use the DataGrid control's HitTest method with the x and y properties.
myHitTest = dataGrid1.HitTest(e.X,e.Y);
Console.WriteLine(myHitTest);
Console.WriteLine("Column " + myHitTest.Column);
Console.WriteLine("Row " + myHitTest.Row);
Console.WriteLine("Type " + myHitTest.Type);
Console.WriteLine("ToString " + myHitTest.ToString());
Console.WriteLine("Hit " + ReturnHitTest(myHitTest.Type ));
}
private string ReturnHitTest(System.Windows.Forms.DataGrid.HitTestType hit ){
// Use this function to return the part of the grid clicked.
switch(hit) {
case(System.Windows.Forms.DataGrid.HitTestType.Cell):
return "Cell";
case(System.Windows.Forms.DataGrid.HitTestType.Caption):
return "Caption";
case(System.Windows.Forms.DataGrid.HitTestType.ColumnHeader):
return "ColumnHeader";
case(System.Windows.Forms.DataGrid.HitTestType.ColumnResize):
return "Resize";
case(System.Windows.Forms.DataGrid.HitTestType.ParentRows):
return "ParentRows";
case(System.Windows.Forms.DataGrid.HitTestType.RowHeader):
return "RowHeader";
case(System.Windows.Forms.DataGrid.HitTestType.RowResize):
return "RowResize";
case(System.Windows.Forms.DataGrid.HitTestType.None):
return "None";
default:return "Unknown";
}
}
private:
void dataGrid1_MouseDown( Object^ /*sender*/,
System::Windows::Forms::MouseEventArgs^ e )
{
String^ newLine = "\n";
Console::WriteLine( newLine );
System::Windows::Forms::DataGrid::HitTestInfo^ myHitTest;
// Use the DataGrid control's HitTest method with the x and y properties.
myHitTest = dataGrid1->HitTest( e->X, e->Y );
Console::WriteLine( myHitTest );
Console::WriteLine( "Column {0}", myHitTest->Column );
Console::WriteLine( "Row {0}", myHitTest->Row );
Console::WriteLine( "Type {0}", myHitTest->Type );
Console::WriteLine( "ToString {0}", myHitTest );
Console::WriteLine( "Hit {0}", ReturnHitTest( myHitTest->Type ) );
}
String^ ReturnHitTest(
System::Windows::Forms::DataGrid::HitTestType hit )
{
// Use this function to return the part of the grid clicked.
switch ( hit )
{
case(System::Windows::Forms::DataGrid::HitTestType::Cell):
return "Cell";
case(System::Windows::Forms::DataGrid::HitTestType::Caption):
return "Caption";
case(System::Windows::Forms::DataGrid::HitTestType::ColumnHeader):
return "ColumnHeader";
case(System::Windows::Forms::DataGrid::HitTestType::ColumnResize):
return "Resize";
case(System::Windows::Forms::DataGrid::HitTestType::ParentRows):
return "ParentRows";
case(System::Windows::Forms::DataGrid::HitTestType::RowHeader):
return "RowHeader";
case(System::Windows::Forms::DataGrid::HitTestType::RowResize):
return "RowResize";
case(System::Windows::Forms::DataGrid::HitTestType::None):
return "None";
default:
return "Unknown";
}
}
Plattformen
Windows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile für Pocket PC, Windows Mobile für Smartphone, Windows Server 2003, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP SP2, Windows XP Starter Edition
.NET Framework unterstützt nicht alle Versionen sämtlicher Plattformen. Eine Liste der unterstützten Versionen finden Sie unter Systemanforderungen.
Versionsinformationen
.NET Framework
Unterstützt in: 2.0, 1.1, 1.0
.NET Compact Framework
Unterstützt in: 2.0, 1.0
Siehe auch
Referenz
System.Windows.Forms-Namespace
DataGrid.HitTestInfo-Klasse
HitTest