Not
Åtkomst till den här sidan kräver auktorisering. Du kan prova att logga in eller ändra kataloger.
Åtkomst till den här sidan kräver auktorisering. Du kan prova att ändra kataloger.
Klassen Clipboard innehåller metoder som du kan använda för att interagera med urklippsfunktionen i Windows-operativsystemet. Många program använder Urklipp som en tillfällig lagringsplats för data. Ordbehandlare använder till exempel Urklipp under åtgärderna klipp ut och klistra in. Urklipp är också användbart för att överföra information från ett program till ett annat.
Anmärkning
Alla Windows-program delar systemets urklipp. Innehållet kan därför ändras när du byter till ett annat program.
Klassen Clipboard kan endast användas i trådar som är inställda på sta-läge (single thread apartment). Om du vill använda den här klassen kontrollerar du att din Main-metod har markerats med attributet STAThreadAttribute.
Vissa program lagrar data i Urklipp i flera format för att öka antalet andra program som potentiellt kan använda data. Ett Urklippsformat är en sträng som identifierar formatet. Ett program som använder det identifierade formatet kan hämta associerade data i Urklipp. Klassen DataFormats innehåller fördefinierade formatnamn för din användning. Du kan också använda egna formatnamn eller använda ett objekts typ som format. Information om hur du lägger till data i Urklipp finns i Så här lägger du till data i Urklipp.
Om du vill avgöra om Urklipp innehåller data i ett visst format använder du någon av Contains. Om du vill hämta data från Urklipp använder du någon av GetTryGetData eller metoden för anpassade format.
Anmärkning
I .NET Framework använder GetData du metoden i stället för TryGetData, och GetDataObject metoden används ofta för scenarier med flera format.
Hämta i ett enda format
Använd metoden GetAudioStream, GetFileDropList, GetImageeller GetText. Du kan också använda motsvarande ContainsFormat metoder först för att avgöra om data är tillgängliga i ett visst format.
För anpassade dataformat använder du TryGetData metoden i stället för den föråldrade GetData metoden. Metoden GetData returnerar data i de flesta fall, men när BinaryFormatter krävs för deserialisering och inte är aktiverad, returnerar den en NotSupportedException instans som anger att BinaryFormatter behövs. För anpassade dataformat rekommenderar vi att du använder JSON-baserade metoder (SetDataAsJson<T>() och TryGetData<T>()) för bättre typsäkerhet och för att undvika BinaryFormatter beroenden.
Anmärkning
I .NET Framework är samma Getformatmetoder tillgängliga, men du använder GetData i stället TryGetData för för anpassade format.
// Demonstrates TryGetData methods for common formats.
// These methods are preferred over the older Get* methods.
public Stream? SwapClipboardAudio(Stream replacementAudioStream)
{
Stream? returnAudioStream = null;
if (Clipboard.ContainsAudio())
{
returnAudioStream = Clipboard.GetAudioStream();
Clipboard.SetAudio(replacementAudioStream);
}
return returnAudioStream;
}
// Demonstrates TryGetData for file drop lists
public StringCollection? SwapClipboardFileDropList(StringCollection replacementList)
{
StringCollection? returnList = null;
if (Clipboard.ContainsFileDropList())
{
returnList = Clipboard.GetFileDropList();
Clipboard.SetFileDropList(replacementList);
}
return returnList;
}
// Demonstrates TryGetData for images
public Image? SwapClipboardImage(Image replacementImage)
{
Image? returnImage = null;
if (Clipboard.ContainsImage())
{
returnImage = Clipboard.GetImage();
Clipboard.SetImage(replacementImage);
}
return returnImage;
}
// Demonstrates TryGetData for text in HTML format
public string? SwapClipboardHtmlText(string replacementHtmlText)
{
string? returnHtmlText = null;
if (Clipboard.ContainsText(TextDataFormat.Html))
{
returnHtmlText = Clipboard.GetText(TextDataFormat.Html);
Clipboard.SetText(replacementHtmlText, TextDataFormat.Html);
}
return returnHtmlText;
}
// Example of using TryGetData for custom string-based data
public string? GetCustomStringData(string format)
{
if (Clipboard.TryGetData(format, out object? data))
{
return data as string;
}
return null;
}
' Demonstrates TryGetData methods for common formats.
' These methods are preferred over the older Get* methods.
Public Function SwapClipboardAudio(ByVal replacementAudioStream As System.IO.Stream) As System.IO.Stream
Dim returnAudioStream As System.IO.Stream = Nothing
If Clipboard.ContainsAudio() Then
returnAudioStream = Clipboard.GetAudioStream()
Clipboard.SetAudio(replacementAudioStream)
End If
Return returnAudioStream
End Function
' Demonstrates TryGetData for file drop lists
Public Function SwapClipboardFileDropList(ByVal replacementList As StringCollection) As StringCollection
Dim returnList As StringCollection = Nothing
If Clipboard.ContainsFileDropList() Then
returnList = Clipboard.GetFileDropList()
Clipboard.SetFileDropList(replacementList)
End If
Return returnList
End Function
' Demonstrates TryGetData for images
Public Function SwapClipboardImage(ByVal replacementImage As Image) As Image
Dim returnImage As Image = Nothing
If Clipboard.ContainsImage() Then
returnImage = Clipboard.GetImage()
Clipboard.SetImage(replacementImage)
End If
Return returnImage
End Function
' Demonstrates TryGetData for text in HTML format
Public Function SwapClipboardHtmlText(ByVal replacementHtmlText As String) As String
Dim returnHtmlText As String = Nothing
If Clipboard.ContainsText(TextDataFormat.Html) Then
returnHtmlText = Clipboard.GetText(TextDataFormat.Html)
Clipboard.SetText(replacementHtmlText, TextDataFormat.Html)
End If
Return returnHtmlText
End Function
' Example of using TryGetData for custom string-based data
Public Function GetCustomStringData(ByVal format As String) As String
Dim data As Object = Nothing
If Clipboard.TryGetData(format, data) Then
Return TryCast(data, String)
End If
Return Nothing
End Function
Hämta i anpassat format
Använd metoden TryGetData med ett anpassat formatnamn. Den här metoden ersätter den föråldrade GetData metoden i moderna .NET-versioner.
Du kan också använda fördefinierade formatnamn med den här metoden. Mer information finns i DataFormats.
Viktigt!
I .NET 10 och senare SetData fungerar inte längre med typer som kräver BinaryFormatter serialisering. Metoden GetData returnerar data i de flesta fall, men när BinaryFormatter krävs för deserialisering och inte är aktiverad returnerar den en NotSupportedException instans som indikerar att BinaryFormatter behövs. Exemplen nedan visar hur du hämtar data som kan ha angetts av andra program eller tidigare .NET-versioner.
Anmärkning
I .NET Framework använder GetData du metoden i stället för TryGetData, och objektserialisering via SetData stöds fullt ut.
// Demonstrates TryGetData using a custom format name and a business object.
// Note: In .NET 10, SetData for objects is no longer supported,
// so this example shows how to retrieve data that might have been
// set by other applications or earlier .NET versions.
public Customer? TestCustomFormat
{
get
{
// For demonstration, we'll use string data instead of objects
// since SetData for objects is no longer supported in .NET 10
if (Clipboard.TryGetData("CustomerFormat", out object? data))
{
return data as Customer;
}
return null;
}
}
' Demonstrates TryGetData using a custom format name and a business object.
' Note: In .NET 10, SetData for objects is no longer supported,
' so this example shows how to retrieve data that might have been
' set by other applications or earlier .NET versions.
Public ReadOnly Property TestCustomFormat() As Customer
Get
Dim data As Object = Nothing
' For demonstration, we'll use string data instead of objects
' since SetData for objects is no longer supported in .NET 10
If Clipboard.TryGetData("CustomerFormat", data) Then
Return TryCast(data, Customer)
End If
Return Nothing
End Get
End Property
Klassen Customer som användes i föregående kodfragment:
[Serializable]
public class Customer
{
private string nameValue = string.Empty;
public Customer(string name)
{
nameValue = name;
}
public string Name
{
get { return nameValue; }
set { nameValue = value; }
}
}
<Serializable()>
Public Class Customer
Private nameValue As String = String.Empty
Public Sub New(ByVal name As String)
nameValue = name
End Sub
Public Property Name() As String
Get
Return nameValue
End Get
Set(ByVal value As String)
nameValue = value
End Set
End Property
End Class
Hämta i flera format
Använd metoden GetDataObject för att få en IDataObject, använd sedan TryGetData för att hämta data i specifika format.
Den här metoden rekommenderas för moderna .NET-program eftersom den använder de nyare, säkrare API:erna.
Anmärkning
I .NET Framework använder du vanligtvis metoden GetDataObject och arbetar direkt med det returnerade IDataObject, och använder dess metoder som GetData i stället för den nyare metoden TryGetData.
// Demonstrates how to retrieve data from the Clipboard in multiple formats
// using TryGetData instead of the obsoleted GetData method.
public void TestClipboardMultipleFormats()
{
IDataObject? dataObject = Clipboard.GetDataObject();
if (dataObject != null)
{
// Check for custom format
if (dataObject.GetDataPresent("CustomFormat"))
{
if (Clipboard.TryGetData("CustomFormat", out object? customData))
{
if (customData is ListViewItem item)
{
MessageBox.Show(item.Text);
}
else if (customData is string stringData)
{
MessageBox.Show(stringData);
}
}
}
// Check for Customer type - note that object serialization
// through SetData is no longer supported in .NET 10
if (dataObject.GetDataPresent(typeof(Customer)))
{
if (Clipboard.TryGetData(typeof(Customer).FullName!, out object? customerData))
{
if (customerData is Customer customer)
{
MessageBox.Show(customer.Name);
}
}
}
// For modern .NET 10 applications, prefer using standard formats
if (Clipboard.ContainsText())
{
string text = Clipboard.GetText();
MessageBox.Show($"Text data: {text}");
}
}
}
' Demonstrates how to retrieve data from the Clipboard in multiple formats
' using TryGetData instead of the obsoleted GetData method.
Public Sub TestClipboardMultipleFormats()
Dim dataObject As IDataObject = Clipboard.GetDataObject()
If dataObject IsNot Nothing Then
' Check for custom format
If dataObject.GetDataPresent("CustomFormat") Then
Dim customData As Object = Nothing
If Clipboard.TryGetData("CustomFormat", customData) Then
Dim item As ListViewItem = TryCast(customData, ListViewItem)
If item IsNot Nothing Then
MessageBox.Show(item.Text)
ElseIf TypeOf customData Is String Then
MessageBox.Show(CStr(customData))
End If
End If
End If
' Check for Customer type - note that object serialization
' through SetData is no longer supported in .NET 10
If dataObject.GetDataPresent(GetType(Customer)) Then
Dim customerData As Object = Nothing
If Clipboard.TryGetData(GetType(Customer).FullName, customerData) Then
Dim customer As Customer = TryCast(customerData, Customer)
If customer IsNot Nothing Then
MessageBox.Show(customer.Name)
End If
End If
End If
' For modern .NET 10 applications, prefer using standard formats
If Clipboard.ContainsText() Then
Dim text As String = Clipboard.GetText()
MessageBox.Show($"Text data: {text}")
End If
End If
End Sub
[Serializable]
public class Customer
{
private string nameValue = string.Empty;
public Customer(string name)
{
nameValue = name;
}
public string Name
{
get { return nameValue; }
set { nameValue = value; }
}
}
<Serializable()>
Public Class Customer
Private nameValue As String = String.Empty
Public Sub New(ByVal name As String)
nameValue = name
End Sub
Public Property Name() As String
Get
Return nameValue
End Get
Set(ByVal value As String)
nameValue = value
End Set
End Property
End Class
Se även
.NET Desktop feedback