Cursor Classe
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Représente l'image utilisée pour peindre le pointeur de souris.
public ref class Cursor sealed : IDisposable, System::Runtime::Serialization::ISerializable
[System.ComponentModel.TypeConverter(typeof(System.Windows.Forms.CursorConverter))]
[System.Serializable]
public sealed class Cursor : IDisposable, System.Runtime.Serialization.ISerializable
[System.ComponentModel.TypeConverter(typeof(System.Windows.Forms.CursorConverter))]
public sealed class Cursor : IDisposable, System.Runtime.Serialization.ISerializable
[<System.ComponentModel.TypeConverter(typeof(System.Windows.Forms.CursorConverter))>]
[<System.Serializable>]
type Cursor = class
interface IDisposable
interface ISerializable
[<System.ComponentModel.TypeConverter(typeof(System.Windows.Forms.CursorConverter))>]
type Cursor = class
interface IDisposable
interface ISerializable
Public NotInheritable Class Cursor
Implements IDisposable, ISerializable
- Héritage
-
Cursor
- Attributs
- Implémente
Exemples
L’exemple de code suivant affiche un formulaire qui illustre l’utilisation d’un curseur personnalisé. Le personnalisé Cursor est incorporé dans le fichier de ressources de l’application. L’exemple nécessite un curseur contenu dans un fichier de curseur nommé MyCursor.cur
. Pour compiler cet exemple à l’aide de la ligne de commande, incluez l’indicateur suivant : /res:MyCursor.Cur, CustomCursor.MyCursor.Cur
using System;
using System.Drawing;
using System.Windows.Forms;
namespace CustomCursor
{
public class Form1 : System.Windows.Forms.Form
{
[STAThread]
static void Main()
{
Application.Run(new Form1());
}
public Form1()
{
this.ClientSize = new System.Drawing.Size(292, 266);
this.Text = "Cursor Example";
// The following generates a cursor from an embedded resource.
// To add a custom cursor, create a bitmap
// 1. Add a new cursor file to your project:
// Project->Add New Item->General->Cursor File
// --- To make the custom cursor an embedded resource ---
// In Visual Studio:
// 1. Select the cursor file in the Solution Explorer
// 2. Choose View->Properties.
// 3. In the properties window switch "Build Action" to "Embedded Resources"
// On the command line:
// Add the following flag:
// /res:CursorFileName.cur,Namespace.CursorFileName.cur
//
// Where "Namespace" is the namespace in which you want to use the cursor
// and "CursorFileName.cur" is the cursor filename.
// The following line uses the namespace from the passed-in type
// and looks for CustomCursor.MyCursor.Cur in the assemblies manifest.
// NOTE: The cursor name is acase sensitive.
this.Cursor = new Cursor(GetType(), "MyCursor.cur");
}
}
}
Imports System.Drawing
Imports System.Windows.Forms
Namespace CustomCursor
Public Class Form1
Inherits System.Windows.Forms.Form
<System.STAThread()> _
Public Shared Sub Main()
System.Windows.Forms.Application.Run(New Form1())
End Sub
Public Sub New()
Me.ClientSize = New System.Drawing.Size(292, 266)
Me.Text = "Cursor Example"
' The following generates a cursor from an embedded resource.
'To add a custom cursor, create a bitmap
' 1. Add a new cursor file to your project:
' Project->Add New Item->General->Cursor File
'--- To make the custom cursor an embedded resource ---
'In Visual Studio:
' 1. Select the cursor file in the Solution Explorer
' 2. Choose View->Properties.
' 3. In the properties window switch "Build Action" to "Embedded Resources"
'On the command line:
' Add the following flag:
' /res:CursorFileName.cur,Namespace.CursorFileName.cur
' Where "Namespace" is the namespace in which you want to use the cursor
' and "CursorFileName.cur" is the cursor filename.
'The following line uses the namespace from the passed-in type
'and looks for CustomCursor.MyCursor.cur in the assemblies manifest.
'NOTE: The cursor name is acase sensitive.
Me.Cursor = New Cursor(Me.GetType(), "MyCursor.cur")
End Sub
End Class
End Namespace 'CustomCursor
L’exemple de code suivant affiche les informations client dans un TreeView contrôle. Les nœuds d’arborescence racine affichent les noms des clients, et les nœuds d’arborescence enfants affichent les numéros de commande attribués à chaque client. Dans cet exemple, 1 000 clients sont affichés avec 15 commandes chacun. Le repeint du est supprimé à l’aide TreeView des BeginUpdate méthodes et EndUpdate , et une attente Cursor s’affiche pendant que le TreeView crée et peint les TreeNode objets. Cet exemple nécessite que vous disposiez d’un fichier de curseur nommé MyWait.cur
dans le répertoire de l’application. Il nécessite également un Customer
objet qui peut contenir une collection d’objets Order
et que vous ayez créé une instance d’un TreeView contrôle sur un Form.
// The basic Customer class.
ref class Customer: public System::Object
{
private:
String^ custName;
protected:
ArrayList^ custOrders;
public:
Customer( String^ customername )
{
custName = "";
custOrders = gcnew ArrayList;
this->custName = customername;
}
property String^ CustomerName
{
String^ get()
{
return this->custName;
}
void set( String^ value )
{
this->custName = value;
}
}
property ArrayList^ CustomerOrders
{
ArrayList^ get()
{
return this->custOrders;
}
}
};
// End Customer class
// The basic customer Order class.
ref class Order: public System::Object
{
private:
String^ ordID;
public:
Order( String^ orderid )
{
ordID = "";
this->ordID = orderid;
}
property String^ OrderID
{
String^ get()
{
return this->ordID;
}
void set( String^ value )
{
this->ordID = value;
}
}
};
// End Order class
void FillMyTreeView()
{
// Add customers to the ArrayList of Customer objects.
for ( int x = 0; x < 1000; x++ )
{
customerArray->Add( gcnew Customer( "Customer " + x ) );
}
// Add orders to each Customer object in the ArrayList.
IEnumerator^ myEnum = customerArray->GetEnumerator();
while ( myEnum->MoveNext() )
{
Customer^ customer1 = safe_cast<Customer^>(myEnum->Current);
for ( int y = 0; y < 15; y++ )
{
customer1->CustomerOrders->Add( gcnew Order( "Order " + y ) );
}
}
// Display a wait cursor while the TreeNodes are being created.
::Cursor::Current = gcnew System::Windows::Forms::Cursor( "MyWait.cur" );
// Suppress repainting the TreeView until all the objects have been created.
treeView1->BeginUpdate();
// Clear the TreeView each time the method is called.
treeView1->Nodes->Clear();
// Add a root TreeNode for each Customer object in the ArrayList.
myEnum = customerArray->GetEnumerator();
while ( myEnum->MoveNext() )
{
Customer^ customer2 = safe_cast<Customer^>(myEnum->Current);
treeView1->Nodes->Add( gcnew TreeNode( customer2->CustomerName ) );
// Add a child treenode for each Order object in the current Customer object.
IEnumerator^ myEnum = customer2->CustomerOrders->GetEnumerator();
while ( myEnum->MoveNext() )
{
Order^ order1 = safe_cast<Order^>(myEnum->Current);
treeView1->Nodes[ customerArray->IndexOf( customer2 ) ]->Nodes->Add( gcnew TreeNode( customer2->CustomerName + "." + order1->OrderID ) );
}
}
// Reset the cursor to the default for all controls.
::Cursor::Current = Cursors::Default;
// Begin repainting the TreeView.
treeView1->EndUpdate();
}
// The basic Customer class.
public class Customer : System.Object
{
private string custName = "";
protected ArrayList custOrders = new ArrayList();
public Customer(string customername)
{
this.custName = customername;
}
public string CustomerName
{
get{return this.custName;}
set{this.custName = value;}
}
public ArrayList CustomerOrders
{
get{return this.custOrders;}
}
} // End Customer class
// The basic customer Order class.
public class Order : System.Object
{
private string ordID = "";
public Order(string orderid)
{
this.ordID = orderid;
}
public string OrderID
{
get{return this.ordID;}
set{this.ordID = value;}
}
} // End Order class
// Create a new ArrayList to hold the Customer objects.
private ArrayList customerArray = new ArrayList();
private void FillMyTreeView()
{
// Add customers to the ArrayList of Customer objects.
for(int x=0; x<1000; x++)
{
customerArray.Add(new Customer("Customer" + x.ToString()));
}
// Add orders to each Customer object in the ArrayList.
foreach(Customer customer1 in customerArray)
{
for(int y=0; y<15; y++)
{
customer1.CustomerOrders.Add(new Order("Order" + y.ToString()));
}
}
// Display a wait cursor while the TreeNodes are being created.
Cursor.Current = new Cursor("MyWait.cur");
// Suppress repainting the TreeView until all the objects have been created.
treeView1.BeginUpdate();
// Clear the TreeView each time the method is called.
treeView1.Nodes.Clear();
// Add a root TreeNode for each Customer object in the ArrayList.
foreach(Customer customer2 in customerArray)
{
treeView1.Nodes.Add(new TreeNode(customer2.CustomerName));
// Add a child treenode for each Order object in the current Customer object.
foreach(Order order1 in customer2.CustomerOrders)
{
treeView1.Nodes[customerArray.IndexOf(customer2)].Nodes.Add(
new TreeNode(customer2.CustomerName + "." + order1.OrderID));
}
}
// Reset the cursor to the default for all controls.
Cursor.Current = Cursors.Default;
// Begin repainting the TreeView.
treeView1.EndUpdate();
}
Public Class Customer
Inherits [Object]
Private custName As String = ""
Friend custOrders As New ArrayList()
Public Sub New(ByVal customername As String)
Me.custName = customername
End Sub
Public Property CustomerName() As String
Get
Return Me.custName
End Get
Set(ByVal Value As String)
Me.custName = Value
End Set
End Property
Public ReadOnly Property CustomerOrders() As ArrayList
Get
Return Me.custOrders
End Get
End Property
End Class
Public Class Order
Inherits [Object]
Private ordID As String
Public Sub New(ByVal orderid As String)
Me.ordID = orderid
End Sub
Public Property OrderID() As String
Get
Return Me.ordID
End Get
Set(ByVal Value As String)
Me.ordID = Value
End Set
End Property
End Class
' Create a new ArrayList to hold the Customer objects.
Private customerArray As New ArrayList()
Private Sub FillMyTreeView()
' Add customers to the ArrayList of Customer objects.
Dim x As Integer
For x = 0 To 999
customerArray.Add(New Customer("Customer" + x.ToString()))
Next x
' Add orders to each Customer object in the ArrayList.
Dim customer1 As Customer
For Each customer1 In customerArray
Dim y As Integer
For y = 0 To 14
customer1.CustomerOrders.Add(New Order("Order" + y.ToString()))
Next y
Next customer1
' Display a wait cursor while the TreeNodes are being created.
Cursor.Current = New Cursor("MyWait.cur")
' Suppress repainting the TreeView until all the objects have been created.
treeView1.BeginUpdate()
' Clear the TreeView each time the method is called.
treeView1.Nodes.Clear()
' Add a root TreeNode for each Customer object in the ArrayList.
Dim customer2 As Customer
For Each customer2 In customerArray
treeView1.Nodes.Add(New TreeNode(customer2.CustomerName))
' Add a child TreeNode for each Order object in the current Customer object.
Dim order1 As Order
For Each order1 In customer2.CustomerOrders
treeView1.Nodes(customerArray.IndexOf(customer2)).Nodes.Add( _
New TreeNode(customer2.CustomerName + "." + order1.OrderID))
Next order1
Next customer2
' Reset the cursor to the default for all controls.
Cursor.Current = System.Windows.Forms.Cursors.Default
' Begin repainting the TreeView.
treeView1.EndUpdate()
End Sub
Remarques
Un curseur est une petite image dont l’emplacement à l’écran est contrôlé par un appareil pointant, tel qu’une souris, un stylet ou un trackball. Lorsque l’utilisateur déplace l’appareil pointant, le système d’exploitation déplace le curseur en conséquence.
Différentes formes de curseur sont utilisées pour informer l’utilisateur de l’opération de la souris. Par exemple, lors de la modification ou de la sélection de texte, un Cursors.IBeam curseur s’affiche généralement. Un curseur d’attente est couramment utilisé pour informer l’utilisateur qu’un processus est en cours d’exécution. Les exemples de processus que l’utilisateur peut attendre sont l’ouverture d’un fichier, l’enregistrement d’un fichier ou le remplissage d’un contrôle tel qu’un DataGridou ListBoxTreeView avec une grande quantité de données.
Tous les contrôles qui dérivent de la Control classe ont une Cursor propriété. Pour modifier le curseur affiché par le pointeur de la souris lorsqu’il se trouve dans les limites du contrôle, affectez un Cursor à la Cursor propriété du contrôle. Vous pouvez également afficher des curseurs au niveau de l’application en affectant un Cursor à la Current propriété . Par exemple, si l’objectif de votre application est de modifier un fichier texte, vous pouvez définir la Current propriété sur pour afficher un curseur d’attente Cursors.WaitCursor sur l’application pendant le chargement ou l’enregistrement du fichier pour empêcher le traitement des événements de souris. Une fois le processus terminé, définissez la Current propriété Cursors.Default sur pour que l’application affiche le curseur approprié sur chaque type de contrôle.
Notes
Si vous appelez Application.DoEvents avant de réinitialiser la Current propriété au Cursors.Default curseur, l’application reprend l’écoute des événements de souris et reprend l’affichage du approprié Cursor pour chaque contrôle dans l’application.
Les objets curseur peuvent être créés à partir de plusieurs sources, telles que le handle d’un fichier standardCursor, d’une ressource ou d’un flux de données existantCursor.
Notes
La Cursor classe ne prend pas en charge les curseurs animés (fichiers .ani) ou les curseurs avec des couleurs autres que le noir et le blanc.
Si l’image que vous utilisez comme curseur est trop petite, vous pouvez utiliser la DrawStretched méthode pour forcer l’image à remplir les limites du curseur. Vous pouvez masquer temporairement le curseur en appelant la méthode et la Hide restaurer en appelant la Show méthode.
À compter de .NET Framework 4.5.2, le Cursor sera redimensionné en fonction du paramètre DPI système lorsque le fichier app.config contient l’entrée suivante :
<appSettings>
<add key="EnableWindowsFormsHighDpiAutoResizing" value="true" />
</appSettings>
Constructeurs
Cursor(IntPtr) |
Initialise une nouvelle instance de la classe Cursor à partir du handle Windows spécifié. |
Cursor(Stream) |
Initialise une nouvelle instance de la classe Cursor à partir du flux de données spécifié. |
Cursor(String) |
Initialise une nouvelle instance de la classe Cursor à partir du fichier spécifié. |
Cursor(Type, String) |
Initialise une nouvelle instance de la classe Cursor à partir de la ressource spécifiée avec le type de ressource spécifié. |
Propriétés
Clip |
Obtient ou définit les limites qui représentent le rectangle de découpage du curseur. |
Current |
Obtient ou définit un objet curseur qui représente le curseur de souris. |
Handle |
Obtient le handle du curseur. |
HotSpot |
Obtient la zone réactive du curseur. |
Position |
Obtient ou définit la position du curseur. |
Size |
Obtient la taille de l'objet curseur. |
Tag |
Obtient ou définit l'objet qui contient les données relatives au Cursor. |
Méthodes
CopyHandle() |
Copie le handle de ce Cursor. |
Dispose() |
Libère toutes les ressources utilisées par Cursor. |
Draw(Graphics, Rectangle) |
Dessine le curseur sur la surface spécifiée dans les limites spécifiées. |
DrawStretched(Graphics, Rectangle) |
Dessine le curseur dans un format agrandi sur la surface spécifiée dans les limites spécifiées. |
Equals(Object) |
Retourne une valeur indiquant si le curseur est égal au Cursor spécifié. |
Finalize() |
Autorise un objet à tenter de libérer des ressources et à exécuter d'autres opérations de nettoyage avant qu'il ne soit récupéré par une opération garbage collection. |
GetHashCode() |
Récupère le code de hachage pour le Cursor actuel. |
GetType() |
Obtient le Type de l'instance actuelle. (Hérité de Object) |
Hide() |
Masque le curseur. |
MemberwiseClone() |
Crée une copie superficielle du Object actuel. (Hérité de Object) |
Show() |
Affiche le curseur. |
ToString() |
Récupère une chaîne lisible par l'utilisateur représentant ce Cursor. |
Opérateurs
Equality(Cursor, Cursor) |
Retourne une valeur indiquant si deux instances de la classe Cursor sont égales. |
Inequality(Cursor, Cursor) |
Retourne une valeur indiquant si deux instances de la classe Cursor ne sont pas égales. |
Implémentations d’interfaces explicites
ISerializable.GetObjectData(SerializationInfo, StreamingContext) |
Sérialise l'objet. |