Quiero usar vba para tomar una captura de pantalla (que luego se enviará como un archivo adjunto de correo electrónico). Idealmente, me gustaría tomar una captura de pantalla de solo el formulario activo. ¿Hay alguna manera de hacer esto?¿Hay alguna manera de tomar una captura de pantalla en MS-Access con vba?
Respuesta
Tienes que usar las llamadas a la API de Windows para hacer esto. El siguiente código funciona en MS Access 2007. Guardará los archivos BMP.
Option Compare Database
Option Explicit
Private Declare Sub keybd_event Lib "user32" (ByVal bVk As Byte, ByVal _
bScan As Byte, ByVal dwFlags As Long, ByVal dwExtraInfo As Long)
Private Const VK_SNAPSHOT = &H2C
Private Declare Function OpenClipboard Lib "user32" (ByVal hwnd As Long) As Long
Private Declare Function GetClipboardData Lib "user32" (ByVal wFormat As Integer) As Long
Private Declare Function CloseClipboard Lib "user32"() As Long
Private Declare Function OleCreatePictureIndirect Lib "olepro32.dll" _
(PicDesc As uPicDesc, RefIID As GUID, ByVal fPictureOwnsHandle As Long, _
IPic As IPicture) As Long
'\\ Declare a UDT to store a GUID for the IPicture OLE Interface
Private Type GUID
Data1 As Long
Data2 As Integer
Data3 As Integer
Data4(0 To 7) As Byte
End Type
'\\ Declare a UDT to store the bitmap information
Private Type uPicDesc
Size As Long
Type As Long
hPic As Long
hPal As Long
End Type
Private Const CF_BITMAP = 2
Private Const PICTYPE_BITMAP = 1
Sub PrintScreen()
keybd_event VK_SNAPSHOT, 1, 0, 0
End Sub
Public Sub MyPrintScreen(FilePathName As String)
Call PrintScreen
Dim IID_IDispatch As GUID
Dim uPicinfo As uPicDesc
Dim IPic As IPicture
Dim hPtr As Long
OpenClipboard 0
hPtr = GetClipboardData(CF_BITMAP)
CloseClipboard
'\\ Create the interface GUID for the picture
With IID_IDispatch
.Data1 = &H7BF80980
.Data2 = &HBF32
.Data3 = &H101A
.Data4(0) = &H8B
.Data4(1) = &HBB
.Data4(2) = &H0
.Data4(3) = &HAA
.Data4(4) = &H0
.Data4(5) = &H30
.Data4(6) = &HC
.Data4(7) = &HAB
End With
'\\ Fill uPicInfo with necessary parts.
With uPicinfo
.Size = Len(uPicinfo) '\\ Length of structure.
.Type = PICTYPE_BITMAP '\\ Type of Picture
.hPic = hPtr '\\ Handle to image.
.hPal = 0 '\\ Handle to palette (if bitmap).
End With
'\\ Create the Range Picture Object
OleCreatePictureIndirect uPicinfo, IID_IDispatch, True, IPic
'\\ Save Picture Object
stdole.SavePicture IPic, FilePathName
End Sub
Hay un Knowledge Base article que profundiza más. ejemplo
Lamento plantear esto de la muerte, pero ¿esto también funciona para Access 2003? Si no, ¿puedo hacer que funcione en eso? – Magisch
Acabo de revisar el código ... No puedo ver por qué no funcionará en Access 2003, siempre y cuando las DLL estén presentes. ¿Has probado? –
La implementación funciona ... aproximadamente. No hay ningún control allí si el contenido del portapapeles es en realidad una pantalla de impresión, pero eso está bien ya que lo llamas directamente. El principal problema que me queda ahora es que los archivos de imagen generados por esto son grandes ... alrededor de 6 mb para una pantalla de impresión completa. Según lo que veo para Access 2003, no hay formas integradas de convertir una imagen IP en .png y comprimirla, ¿la conoce? – Magisch
Uso de Raj para conseguir la imagen y luego esto para salvar
Dim oPic
On Error Resume Next
Set oPic = Clipboard.GetData
On Error GoTo 0
If oPic Is Nothing Then
'no image in clipboard'
Else
SavePicture oPic, "c:\temp\pic.bmp"
end if
¿Qué es 'PastePicture'? –
era una lib externa, he editado mi publicación original – bugtussle
- 1. ¿Hay alguna manera de tomar una captura de pantalla del escritorio de Windows del usuario?
- 2. ¿Hay alguna manera de tomar automáticamente una captura de pantalla de un sitio web a través de una URL?
- 3. Tomar una captura de pantalla con Pyglet [Fix'd]
- 4. Cómo tomar una captura de pantalla con FireMonkey (multiplataformas)
- 5. ¿Cómo tomar una captura de pantalla con unidad HTML?
- 6. Sin iPhone, ¿cómo tomar una captura de pantalla con XCode?
- 7. Tomar una captura de pantalla parcial en el iPad
- 8. ¿Hay alguna forma de tomar una captura de pantalla con Java y guardarla en algún tipo de imagen?
- 9. Tomar captura de pantalla de una página web (remota) programáticamente
- 10. ¿Cómo tomar una captura de pantalla de una página web?
- 11. ¿Cómo tomar la captura de pantalla programáticamente?
- 12. Tomar una captura de pantalla de área específica
- 13. VBA captura de pantalla completa WebBrowser
- 14. Cómo tomar una captura de pantalla en OpenGL
- 15. C# ¿Cuál es la manera más rápida de tomar una captura de pantalla?
- 16. cómo tomar una captura de pantalla del iPhone programáticamente?
- 17. La forma más rápida de tomar una captura de pantalla con Python en Windows
- 18. C#: cómo tomar una captura de pantalla de una parte de la pantalla
- 19. ¿Hay alguna otra manera que no sea el método de miniaturas para tomar una captura de pantalla de un video en Iphone?
- 20. ¿Hay alguna manera de saber si hay fallas en mi caso de prueba PHPUnit de tearDown()?
- 21. ¿Cómo puedo tomar una captura de pantalla de un sitio web con .NET?
- 22. ¿La mejor manera de tomar capturas de pantalla de pruebas en Selenium 2?
- 23. ¿Cómo puedo tomar una captura de pantalla en una aplicación de Windows?
- 24. Cómo tomar la captura de pantalla de una parte de Google Maps use JavaScript
- 25. Tomando una captura de pantalla con C \ GTK
- 26. Captura de pantalla de la segunda pantalla
- 27. ¿Cómo tomar una captura de pantalla de iPhone de toda la vista, incluidas las partes fuera de la pantalla?
- 28. ¿Cómo tomar una captura de pantalla de la ventana activa en Delphi?
- 29. ¿Cuál es la mejor manera de tomar capturas de pantalla de una ventana con C++ en Windows?
- 30. Captura de pantalla en Haskell?
¿Es necesario que esto sea automatizado? ¿Es por eso que no puedes usar Alt + PrintScreen? –
Sí, tiene que ser automático. Quiero ponerlo en el código para que cuando un usuario realice una determinada acción, se tome una captura de pantalla y se envíe por correo electrónico a un administrador. – dmr
O la instantánea podría guardarse en una tabla de mensajes de error como un bmp. Junto con otra información como el nombre de las formas activas, el número de la estación de trabajo, el ID de usuario, la fecha/hora, etc. –