Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

Programmatically printing from Report Viewer c#

Posted on 2011-03-16
11
Medium Priority
?
3,151 Views
Last Modified: 2013-12-17
I have for example a ReportViewer. I have a loop which will go through the report populating it then exporting to pdf and doing the next. I would like to know if anyone knows a way of forcing it to print without a dialogue box?

Cheers
0
Comment
Question by:KazooSoft
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 7
  • 4
11 Comments
 
LVL 4

Expert Comment

by:LeDaouk
ID: 35146958
this code will open the pdf print and close
Dim MyProcess As New Process
        MyProcess.StartInfo.CreateNoWindow = False
        MyProcess.StartInfo.Verb = "print"
        MyProcess.StartInfo.FileName = "C:\file.pdf "
        MyProcess.Start()
        MyProcess.WaitForExit(10000)
        MyProcess.CloseMainWindow()
        MyProcess.Close()

Open in new window

0
 
LVL 4

Author Comment

by:KazooSoft
ID: 35147340
Do you have that in C#? I think I will have to do it that way. Export them all to PDF then print them. Then delete them.
0
 
LVL 4

Expert Comment

by:LeDaouk
ID: 35147382

Process MyProcess = new Process();
MyProcess.StartInfo.CreateNoWindow = false;
MyProcess.StartInfo.Verb = "print";
MyProcess.StartInfo.FileName = "C:\\file.pdf ";
MyProcess.Start();
MyProcess.WaitForExit(10000);
MyProcess.CloseMainWindow();
MyProcess.Close();

Open in new window

0
NEW Veeam Agent for Microsoft Windows

Backup and recover physical and cloud-based servers and workstations, as well as endpoint devices that belong to remote users. Avoid downtime and data loss quickly and easily for Windows-based physical or public cloud-based workloads!

 
LVL 4

Expert Comment

by:LeDaouk
ID: 35147388
and always use this link to convert:
http://www.developerfusion.com/tools/convert/vb-to-csharp/
0
 
LVL 4

Expert Comment

by:LeDaouk
ID: 35147415
use this code in the report viewer form, it will solve your issue
Private Sub frm_ReportViewer_Shown(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Shown
        Dim warnings As Warning() = Nothing
        Dim streamids As String() = Nothing
        Dim mimeType As String = Nothing
        Dim encoding As String = Nothing
        Dim extension As String = Nothing
        Dim bytes As Byte()
        Dim FileName As String

       



        bytes = ReportViewer1.LocalReport.Render("Pdf", _
          Nothing, mimeType, _
            encoding, extension, streamids, warnings)
        FileName = "PrintOut" & Format(Now, "yyyyMMddhhmmss") & ".pdf"
        Dim fs As New FileStream("C:\file.pdf", FileMode.Create)
        fs.Write(bytes, 0, bytes.Length)
        fs.Close()

        Dim MyProcess As New Process
        MyProcess.StartInfo.CreateNoWindow = False
        MyProcess.StartInfo.Verb = "print"
        MyProcess.StartInfo.FileName = "C:\file.pdf"
        MyProcess.Start()
        MyProcess.WaitForExit(10000)
        MyProcess.CloseMainWindow()
        MyProcess.Close()


	 Try

            Dim strFileSize As String = ""
            Dim di As New IO.DirectoryInfo("c:\")
            Dim aryFi As IO.FileInfo() = di.GetFiles("file*.pdf")
            Dim fi As IO.FileInfo


            For Each fi In aryFi
                fi.Delete()
            Next
        Catch
        End Try

        Me.Close()
    End Sub

Open in new window

0
 
LVL 4

Expert Comment

by:LeDaouk
ID: 35147425
as you can see filename in the code is to generate a file everytime you can use it instead of file.pdf
so it wil create printout....pdf and redelete it
0
 
LVL 4

Author Comment

by:KazooSoft
ID: 35147559
Ok I have converted this to C# but how to i suppress the PDF window?

Cheers
0
 
LVL 4

Expert Comment

by:LeDaouk
ID: 35147602
Try

            Dim strFileSize As String = ""
            Dim di As New IO.DirectoryInfo("c:\")
            Dim aryFi As IO.FileInfo() = di.GetFiles("file*.pdf")
            Dim fi As IO.FileInfo


            For Each fi In aryFi
                fi.Delete()
            Next
        Catch
        End Try
 is deleting the file at the end of the sub
0
 
LVL 4

Author Comment

by:KazooSoft
ID: 35147638
That works perfectly. But it keeps spamming the user with a lot of PDF windows until we wait for them to close. Is there a way of getting it to run the chosen PDF reading in the background? out of sight?
0
 
LVL 4

Accepted Solution

by:
LeDaouk earned 2000 total points
ID: 35147814
MyProcess.StartInfo.WindowStyle = ProcessWindowStyle.Hidden
and hide the form
0
 
LVL 4

Author Closing Comment

by:KazooSoft
ID: 35148331
Awesome results thank you for all your help!
0

Featured Post

What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

Question has a verified solution.

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

In my previous two articles we discussed Binary Serialization (http://www.experts-exchange.com/A_4362.html) and XML Serialization (http://www.experts-exchange.com/A_4425.html). In this article we will try to know more about SOAP (Simple Object Acces…
Calculating holidays and working days is a function that is often needed yet it is not one found within the Framework. This article presents one approach to building a working-day calculator for use in .NET.
This course is ideal for IT System Administrators working with VMware vSphere and its associated products in their company infrastructure. This course teaches you how to install and maintain this virtualization technology to store data, prevent vuln…
Add bar graphs to Access queries using Unicode block characters. Graphs appear on every record in the color you want. Give life to numbers. Hopes this gives you ideas on visualizing your data in new ways ~ Create a calculated field in a query: …

661 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