Solved

print screen

Posted on 2001-08-15
7
325 Views
Last Modified: 2013-11-26
how do you make a program that automatically prints the screen(copies it to the clipboard) then pastes it into an image box?
0
Comment
Question by:short_fat_n_black
7 Comments
 
LVL 20

Expert Comment

by:hes
ID: 6389801
0
 
LVL 20

Expert Comment

by:hes
ID: 6389822
If you want the code to do a print screen, capture just the form, just the client area of the form let me know and I will post it.
0
 
LVL 2

Expert Comment

by:JanusFury
ID: 6390419
Here's something off the top of my head: (It'll require some API declarations from the API viewer.)

deskWnd = GetDesktopWindow
deskDC = GetDC(deskWnd)
BitBlt Picture1.hDC, 0, 0, Screen.Width \ Screen.TwipsPerPixelX, Screen.Height \ TwipsPerPixelY, deskDC, 0, 0, vbSrcCopy
ReleaseDC deskWnd, deskDC
deskDC = 0
deskWnd = 0

I'll make a full ver of the code when I get home.
0
Salesforce Has Never Been Easier

Improve and reinforce salesforce training & adoption using WalkMe's digital adoption platform. Start saving on costly employee training by creating fast intuitive Walk-Thrus for Salesforce. Claim your Free Account Now

 
LVL 14

Expert Comment

by:wsh2
ID: 6390613
<ping>
0
 
LVL 20

Expert Comment

by:hes
ID: 6390764
a ping from wsh2, havn't seen you on lately (until this week) :)
0
 
LVL 8

Accepted Solution

by:
glass_cookie earned 50 total points
ID: 6391093
Hi!

Here's a file for you over the net:

Download...
http://www.vb-helper.com/HowTo/formimg.zip

Descirption: Capture an image of a form in a PictureBox (2K)

I suppose you can change the picture box to tht of an image box.

That's it!

glass cookie : )
0
 
LVL 51

Expert Comment

by:Ryan Chong
ID: 6391300
Hi short_fat_n_black ,
   
To mimic the printscreen / take a snapshot of desktop:

http://www.mvps.org/vbnet/code/bitmap/printscreen.htm 

Here is another version that Calling the Windows PrintScreen Function Using keybd_event:

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 TheScreen = 0
Private Const TheForm = 1

Private Sub Command1_Click()
 'call the Windows keybd_event sub, passing the built-in
 'VB keyboard constant vbKeySnapshot (44) to the sub.

 'The four parameters for keybd_event are:
 'BYTE bVk           'virtual-key code
 'BYTE bScan         'hardware scan code
 'DWORD dwFlags      'flags specifying various function options
 'DWORD dwExtraInfo  'additional data associated with keystroke

 'The bScan parameter value determines what
 'to copy... passing 0 (TheScreen) copies
 'the screen, passing 1 (TheForm) copies the
 'active form.
  keybd_event vbKeySnapshot, TheForm, 0&, 0&
 
 'pause to let Windows update the clipboard
  DoEvents
 
 'retrieve the clipboard bitmap to the control (vbCFBitmap = 2)
  Image1.Picture = Clipboard.GetData(vbCFBitmap)

End Sub


Original Source: http://www.mvps.org/vbnet/code/bitmap/printscreenapi.htm

'Hope will help.
0

Featured Post

Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

Question has a verified solution.

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

Suggested Solutions

When trying to find the cause of a problem in VBA or VB6 it's often valuable to know what procedures were executed prior to the error. You can use the Call Stack for that but it is often inadequate because it may show procedures you aren't intereste…
If you need to start windows update installation remotely or as a scheduled task you will find this very helpful.
Get people started with the process of using Access VBA to control Excel using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Excel. Using automation, an Access application can laun…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

726 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