Assembly : mscorlib (dans mscorlib.dll)
SyntaxePublic Delegate Function Converter(Of TInput, TOutput) ( _ input As TInput _ ) As TOutput
Dim instance As New Converter(Of TInput, TOutput)(AddressOf HandlerMethod)
public delegate TOutput Converter<TInput,TOutput> (
TInput input
)
generic<typename TInput, typename TOutput>
public delegate TOutput Converter (
TInput input
)
J# prend en charge l'utilisation de types et de méthodes génériques mais pas la déclaration de nouveaux types et de méthodes génériques.
JScript ne prend pas en charge les types et les méthodes génériques.
Paramètres de type
- TInput
Type de l'objet à convertir.
- TOutput
Type en lequel l'objet d'entrée doit être converti.
Paramètres
- input
Objet à convertir.
Valeur de retour
TOutput représentant l'objet TInput converti.
NotesCe délégué est utilisé par la méthode ConvertAll de la classe Array et la méthode ConvertAll de la classe List pour convertir chaque élément de la collection d'un type en un autre.
ExempleCette section comprend deux exemples de code. Le premier exemple présente le délégué Converter avec la méthode ConvertAll de la classe Array et le deuxième exemple présente le délégué avec la méthode ConvertAll de la classe générique List.
Exemple 1
L'exemple de code suivant définit une méthode nommée PointFToPoint qui convertit une structure PointF en une structure Point. L'exemple crée ensuite un tableau de structures PointF, crée un délégué Converter<PointF, Point> (Converter(Of PointF, Point) en Visual Basic) pour représenter la méthode PointFToPoint, puis passe le délégué à la méthode ConvertAll. La méthode ConvertAll passe chaque élément de la liste d'entrée à la méthode PointFToPoint et met les éléments convertis dans une nouvelle liste de structures Point. Les deux listes sont affichées.
Imports System Imports System.Drawing Imports System.Collections.Generic Public Class Example Public Shared Sub Main() Dim apf() As PointF = { _ New PointF(27.8, 32.62), _ New PointF(99.3, 147.273), _ New PointF(7.5, 1412.2) } Console.WriteLine() For Each p As PointF In apf Console.WriteLine(p) Next Dim ap() As Point = Array.ConvertAll(apf, _ New Converter(Of PointF, Point)(AddressOf PointFToPoint)) Console.WriteLine() For Each p As Point In ap Console.WriteLine(p) Next End Sub Public Shared Function PointFToPoint(ByVal pf As PointF) _ As Point Return New Point(CInt(pf.X), CInt(pf.Y)) End Function End Class ' This code example produces the following output: ' '{X=27.8, Y=32.62} '{X=99.3, Y=147.273} '{X=7.5, Y=1412.2} ' '{X=28,Y=33} '{X=99,Y=147} '{X=8,Y=1412}
using System; using System.Drawing; using System.Collections.Generic; public class Example { public static void Main() { PointF[] apf = { new PointF(27.8F, 32.62F), new PointF(99.3F, 147.273F), new PointF(7.5F, 1412.2F) }; Console.WriteLine(); foreach( PointF p in apf ) { Console.WriteLine(p); } Point[] ap = Array.ConvertAll(apf, new Converter<PointF, Point>(PointFToPoint)); Console.WriteLine(); foreach( Point p in ap ) { Console.WriteLine(p); } } public static Point PointFToPoint(PointF pf) { return new Point(((int) pf.X), ((int) pf.Y)); } } /* This code example produces the following output: {X=27.8, Y=32.62} {X=99.3, Y=147.273} {X=7.5, Y=1412.2} {X=27,Y=32} {X=99,Y=147} {X=7,Y=1412} */
Exemple 2
L'exemple de code suivant définit une méthode nommée PointFToPoint qui convertit une structure PointF en une structure Point. L'exemple crée ensuite un List des structures PointF, crée un délégué Converter<PointF, Point> (Converter(Of PointF, Point) en Visual Basic) pour représenter la méthode PointFToPoint et passe le délégué à la méthode ConvertAll. La méthode ConvertAll passe chaque élément de la liste d'entrée à la méthode PointFToPoint et met les éléments convertis dans une nouvelle liste de structures Point. Les deux listes sont affichées.
Imports System Imports System.Drawing Imports System.Collections.Generic Public Class Example Public Shared Sub Main() Dim lpf As New List(Of PointF) lpf.Add(New PointF(27.8, 32.62)) lpf.Add(New PointF(99.3, 147.273)) lpf.Add(New PointF(7.5, 1412.2)) Console.WriteLine() For Each p As PointF In lpf Console.WriteLine(p) Next Dim lp As List(Of Point) = lpf.ConvertAll( _ New Converter(Of PointF, Point)(AddressOf PointFToPoint)) Console.WriteLine() For Each p As Point In lp Console.WriteLine(p) Next End Sub Public Shared Function PointFToPoint(ByVal pf As PointF) _ As Point Return New Point(CInt(pf.X), CInt(pf.Y)) End Function End Class ' This code example produces the following output: ' '{X=27.8, Y=32.62} '{X=99.3, Y=147.273} '{X=7.5, Y=1412.2} ' '{X=28,Y=33} '{X=99,Y=147} '{X=8,Y=1412}
using System; using System.Drawing; using System.Collections.Generic; public class Example { public static void Main() { List<PointF> lpf = new List<PointF>(); lpf.Add(new PointF(27.8F, 32.62F)); lpf.Add(new PointF(99.3F, 147.273F)); lpf.Add(new PointF(7.5F, 1412.2F)); Console.WriteLine(); foreach( PointF p in lpf ) { Console.WriteLine(p); } List<Point> lp = lpf.ConvertAll( new Converter<PointF, Point>(PointFToPoint)); Console.WriteLine(); foreach( Point p in lp ) { Console.WriteLine(p); } } public static Point PointFToPoint(PointF pf) { return new Point(((int) pf.X), ((int) pf.Y)); } } /* This code example produces the following output: {X=27.8, Y=32.62} {X=99.3, Y=147.273} {X=7.5, Y=1412.2} {X=27,Y=32} {X=99,Y=147} {X=7,Y=1412} */
#using <System.Drawing.dll> using namespace System; using namespace System::Drawing; using namespace System::Collections::Generic; Point PointFToPoint(PointF pf) { return Point((int) pf.X, (int) pf.Y); }; void main() { List<PointF>^ lpf = gcnew List<PointF>(); lpf->Add(PointF(27.8F, 32.62F)); lpf->Add(PointF(99.3F, 147.273F)); lpf->Add(PointF(7.5F, 1412.2F)); Console::WriteLine(); for each(PointF p in lpf) { Console::WriteLine(p); } List<Point>^ lp = lpf->ConvertAll<Point>( gcnew Converter<PointF, Point>(PointFToPoint) ); Console::WriteLine(); for each(Point p in lp) { Console::WriteLine(p); } } /* This code example produces the following output: {X=27.8, Y=32.62} {X=99.3, Y=147.273} {X=7.5, Y=1412.2} {X=27,Y=32} {X=99,Y=147} {X=7,Y=1412} */
Plates-formesWindows 98, Windows 2000 SP4, Windows CE, Windows Millennium Edition, Windows Mobile pour Pocket PC, Windows Mobile pour Smartphone, Windows Server 2003, Windows XP Édition Media Center, Windows XP Professionnel Édition x64, Windows XP SP2, Windows XP Starter Edition
Le .NET Framework ne prend pas en charge toutes les versions de chaque plate-forme. Pour obtenir la liste des versions prises en charge, consultez Configuration requise.
Informations de version
Outils (masquer)
S'enregistrer
Liste des Membres
Qui est en ligne?
FAQ