Solved

How can I tell if clipboard contents can be pasted as Enhanced Metafile

Posted on 2007-12-01
4
226 Views
Last Modified: 2012-05-05
I am developing an add-in for Word in VB.NET. One of the functions is to Paste clipboard contents as an Enhanced Metafile (my company frequently copy charts and tables from Excel to Word in this format).

I would like to test that the contents of the clipboard can be pasted as enhanced metafile. Currently I just trap the error if it cannot but if I can find out in advance I can then disable the menu item (or change its name) to be clearer to the user.

Code for this test would be much appreciated.
0
Comment
Question by:CarlPritchard
  • 2
4 Comments
 
LVL 10

Expert Comment

by:athapa
ID: 20389242
Use ClipBoard.GetDataPresent to figure out if the format you want is available in the clipboard. You can also enumerate all of the formats available in the clipboard.

HTH,
AT
0
 
LVL 6

Author Comment

by:CarlPritchard
ID: 20389333
Please could you give a code example that shows if there is data that can be pasted as enhanced metafile (ie is compatible data) including any required namespaces/imports.
0
 
LVL 62

Accepted Solution

by:
Fernando Soto earned 250 total points
ID: 20389501
Hi CarlPritchard;

Here is sample code to show you how to see if the clipboard has the correct data. No special imports needed.

Fernando
        If Clipboard.ContainsData(DataFormats.EnhancedMetafile) Then

            ' Then the Clipboard contains data in the EnhancedMetafile format

        Else

            ' The Clipboard DOES NOT contain data in the EnhancedMetafile

        End If

Open in new window

0
 
LVL 10

Expert Comment

by:athapa
ID: 20389509
the only required name space is
System.Windows.Form
which should be already there if your app is windows form app.

imports System.Windows.Form

Private Const FormatName As String = "EnhancedMetafile" 'Enhanced Meta-File Picture

'Call this function anytime you want to see if EnhancedMetaFile is in the clipboard
Private Function IsEnhancedMetaAvailableInClipboard() As Boolean
        Dim clip As IDataObject = Clipboard.GetDataObject()
        Dim AvailableFormats As String() = clip.GetFormats()

        Return (System.Array.IndexOf(AvailableFormats, FormatName) > -1)

End Function

I used the following test code to figure out what other formats are available in clipboard as well as to test the function above

    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click

        Debug.WriteLine(IsEnhancedMetaAvailableInClipboard())

        For Each ClipboardFormat As String In Clipboard.GetDataObject().GetFormats()
            System.Diagnostics.Debug.WriteLine(ClipboardFormat)
        Next

    End Sub
0

Featured Post

3 Use Cases for Connected Systems

Our Dev teams are like yours. They’re continually cranking out code for new features/bugs fixes, testing, deploying, testing some more, responding to production monitoring events and more. It’s complex. So, we thought you’d like to see what’s working for us.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This document covers how to connect to SQL Server and browse its contents.  It is meant for those new to Visual Studio and/or working with Microsoft SQL Server.  It is not a guide to building SQL Server database connections in your code.  This is mo…
A long time ago (May 2011), I have written an article showing you how to create a DLL using Visual Studio 2005 to be hosted in SQL Server 2005. That was valid at that time and it is still valid if you are still using these versions. You can still re…
This Micro Tutorial demonstrates using Microsoft Excel pivot tables, how to reverse engineer competitors' marketing strategies through backlinks.
Internet Business Fax to Email Made Easy - With  eFax Corporate (http://www.enterprise.efax.com), you'll receive a dedicated online fax number, which is used the same way as a typical analog fax number. You'll receive secure faxes in your email, f…

863 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

20 Experts available now in Live!

Get 1:1 Help Now