ExcelBanter

ExcelBanter (https://www.excelbanter.com/)
-   Excel Programming (https://www.excelbanter.com/excel-programming/)
-   -   Is there an easy Copy/Paste of a Userform ? (Entire Userform Including tx & cbx's) (https://www.excelbanter.com/excel-programming/380804-there-easy-copy-paste-userform-entire-userform-including-tx-cbxs.html)

Corey

Is there an easy Copy/Paste of a Userform ? (Entire Userform Including tx & cbx's)
 



Tom Ogilvy

Is there an easy Copy/Paste of a Userform ? (Entire Userform Including tx & cbx's)
 
Modification of code originally posted by
"Orlando Magalhães Filho"

Modified to capture just the userform (not the whole window).

' Placed at the top of a general module above any other code:
Declare Sub keybd_event Lib "user32" (ByVal bVk As Byte, _
ByVal bScan As Byte, ByVal dwFlags As Long, ByVal dwExtraInfo As Long)

'Public Const VK_SNAPSHOT = &H2C

Public Const VK_SNAPSHOT = 44
Public Const VK_LMENU = 164
Public Const KEYEVENTF_KEYUP = 2
Public Const KEYEVENTF_EXTENDEDKEY = 1


Sub Test()
UserForm1.Show
End Sub


In the userform module:




Private Sub CommandButton1_Click() '<== change to the Commandbutton you use
or trigger some other way
' keybd_event VK_SNAPSHOT, 0, 0, 0
DoEvents
keybd_event VK_LMENU, 0, KEYEVENTF_EXTENDEDKEY, 0 ' key down
keybd_event VK_SNAPSHOT, 0, KEYEVENTF_EXTENDEDKEY, 0
keybd_event VK_SNAPSHOT, 0, KEYEVENTF_EXTENDEDKEY + KEYEVENTF_KEYUP, 0
keybd_event VK_LMENU, 0, KEYEVENTF_EXTENDEDKEY + KEYEVENTF_KEYUP, 0
DoEvents
Workbooks.Add
Application.Wait Now + TimeValue("00:00:01")
ActiveSheet.PasteSpecial Format:="Bitmap", Link:=False,
DisplayAsIcon:=False
End Sub



--
Regards,
Tom Ogilvy

"Corey" wrote in message
...





Jon Peltier

Is there an easy Copy/Paste of a Userform ? (Entire Userform Including tx & cbx's)
 
Tom's answer assumes you want a picture of the userform. I read your
question to mean you wanted a second copy of the form.

One way: Export the form, change the name of the existing form, and import
the original.

Another way: Drag the form into another VB Project (just create a new
temporary workbook for this), change the name of either form, and drag the
form beck into the original project.

- Jon
-------
Jon Peltier, Microsoft Excel MVP
Tutorials and Custom Solutions
http://PeltierTech.com
_______


"Corey" wrote in message
...






All times are GMT +1. The time now is 01:16 PM.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
ExcelBanter.com