Click here to Skip to main content
15,880,543 members
Articles / Programming Languages / Visual Basic
Article

Capture Entire Web Page

Rate me:
Please Sign up or sign in to vote.
4.56/5 (32 votes)
15 Aug 2007 164K   10.6K   122   28
Capture an entire web page and save it as an image.


Screenshot - gui2_animated.gif

Update

- 08.15.2007 - user defined image formats, save path, base file name, text overlay/watermark, and screen res guidelines... and some other ideas to implement.

Introduction

I have seen other articles that describe how to accomplish this, but had no luck in getting any to work with Internet Explorer 7. This is a simple example that captures a webpage, inlcuding elements below the fold, and saves it as an image. Here is what to expect:

Screenshot - httpwwwcodeprojectcom.png
Note that this has been resized, captured images are actual size.

Using the code

This example includes only the basics. Images are saved as PNG's in the same directory as the exe. Saving as a different image format, variable pausing, and given filename should be relatively easy to add.

Private Sub GetImage()
    If WebBrowser1.Document Is Nothing Then
        Return
    End If
    Try
        Dim scrollWidth As Integer
        Dim scrollHeight As Integer
        scrollHeight = WebBrowser1.Document.Body.ScrollRectangle.Height
        scrollWidth = WebBrowser1.Document.Body.ScrollRectangle.Width
        WebBrowser1.Size = New Size(scrollWidth, scrollHeight)
        Dim bm As New Bitmap(scrollWidth, scrollHeight)
        WebBrowser1.DrawToBitmap(bm, New Rectangle(0, 0, bm.Width, bm.Height))
        Dim SaveAsName As String
        SaveAsName = Regex.Replace(textWebURL.Text, "(\\|\/|\:|\*|\?|\""|\<|\>|\|)?", "")
        bm.Save(SaveAsName & ".png", System.Drawing.Imaging.ImageFormat.Png)
        bm.Dispose()
    Catch ex As Exception
        MessageBox.Show(ex.Message, "Exception", MessageBoxButtons.OK, MessageBoxIcon.Error)
    Finally
        '
    End Try
    buttonCapture.Enabled = True
End Sub

Points of Interest

Waiting a second or two after the document has loaded will allow that much more of the client-side animation / js / etc. to be captured. If the web page is saved as a "white" image, try the above.

Environment

Vista / VS2005

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here


Written By
United States United States

Comments and Discussions

 
GeneralMy vote of 5 Pin
S.H.Yadegari6-Sep-13 1:55
S.H.Yadegari6-Sep-13 1:55 
QuestionVERY SKINNY Image created Pin
Ron Mittelman25-Oct-11 9:33
Ron Mittelman25-Oct-11 9:33 
Running both of the projects supplied, without any changes, causes the same effect: I can see the full height of the CodeProject web site, but it is very skinny. You can just about see half of the "W" in "Welcome to the Code Project".

Any idea why the width is so small?

Also, is there a way to capture an existing IE browser window instead of opening a new one and navigating to a site? My project needs that ability. Can anybody suggest code to do that?

Thanks...
AnswerRe: VERY SKINNY Image created Pin
Ron Mittelman25-Oct-11 9:55
Ron Mittelman25-Oct-11 9:55 
GeneralDoesn't seem to work on a page with JScript or ActiveX Pin
Steve Dunn22-Jun-10 7:37
Steve Dunn22-Jun-10 7:37 
GeneralProblem with DrawToBitmap Pin
churchillr22-Apr-10 9:36
churchillr22-Apr-10 9:36 
QuestionMultiple Pages TIFF Pin
damifoo17-Mar-09 20:40
damifoo17-Mar-09 20:40 
QuestionHow can I read the screen text Pin
moreed10-Feb-09 20:30
moreed10-Feb-09 20:30 
QuestionCan i plot this into asp.net web page? Pin
cavinsnipes25-Sep-08 2:01
cavinsnipes25-Sep-08 2:01 
Generaldoesn't convert big file Pin
shob_sp16-Jun-08 1:24
shob_sp16-Jun-08 1:24 
Generalhtml to image Pin
rejaneesh7-May-08 19:45
rejaneesh7-May-08 19:45 
GeneralNot capturing whole page Pin
jfarias6-May-08 5:45
jfarias6-May-08 5:45 
GeneralBeautiful! Pin
Dragon Soldier12-Nov-07 9:17
Dragon Soldier12-Nov-07 9:17 
QuestionUnhandled Exception ? Pin
Madra Beag2-Oct-07 13:30
Madra Beag2-Oct-07 13:30 
AnswerRe: Unhandled Exception ? Pin
Nguyen Thanh Hai9-Nov-07 21:22
Nguyen Thanh Hai9-Nov-07 21:22 
GeneralRe: Unhandled Exception ? Pin
Puddin Tame14-Mar-17 16:18
Puddin Tame14-Mar-17 16:18 
Questionhow can i save source code of web page in word document Pin
skhurams14-Sep-07 21:02
skhurams14-Sep-07 21:02 
GeneralProblem with Popups & Fully loaded pages Pin
guilkerk17-Aug-07 8:34
guilkerk17-Aug-07 8:34 
Questionwhat about web application? Pin
cbattioli16-Aug-07 9:44
cbattioli16-Aug-07 9:44 
GeneralLittle useful code Pin
Irwan Hassan15-Aug-07 17:05
Irwan Hassan15-Aug-07 17:05 
GeneralRe: Little useful code Pin
Irwan Hassan23-Aug-07 2:09
Irwan Hassan23-Aug-07 2:09 
QuestionHow to make it work if pages open within frames ? Pin
Vasanth Kumar14-Aug-07 16:25
Vasanth Kumar14-Aug-07 16:25 
AnswerRe: How to make it work if pages open within frames ? Pin
Irwan Hassan15-Aug-07 17:10
Irwan Hassan15-Aug-07 17:10 
GeneralNice code. Pin
AndrewVos13-Aug-07 22:58
AndrewVos13-Aug-07 22:58 
GeneralI am interested in get page contents (Java) and recognize contents Pin
sanong5-Aug-07 23:29
sanong5-Aug-07 23:29 
GeneralHave a look at Pin
Sacha Barber5-Aug-07 23:02
Sacha Barber5-Aug-07 23:02 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.