2014-09-26 2 views
-5

Я хотел бы распечатать несколько файлов (txt, pdf, htm, ...) с помощью C# .Net. Я пробовал разные способы, я использовал ShellExecute, Process, PrintDocument, все без успеха. Существует приложение «http://www.print-conductor.com/download/», которое делает именно то, что мне нужно, кто-нибудь знает, как это работает? Например, он печатает pdf-файлы, не открывая Adobe Reader, даже в менеджере задач adobe, единственное требование - связать его приложение с файлом. Благодарен за любую помощь.Печать нескольких документов с помощью C#

С помощью метода ShellExecute ниже я могу отправить печать, но в случае PDF Adobe Reader открыт, тихо, если он не открыт, и файл должен быть отправлен непосредственно в очередь печати.

[DllImport("shell32.dll", EntryPoint = "ShellExecute")] 
    private static extern IntPtr ShellExecute(IntPtr hwnd, string lpOperation, string lpFile, string lpParameters, 
               string lpDirectory, ShowCommands nShowCmd); 

    public bool Print(string fullPath) 
    { 
     var result = false; 
     try 
     { 
      var resultPrint = ShellExecute(IntPtr.Zero, "Print", fullPath, "", "", ShowCommands.SwShowminimized).ToInt32(); 
      if (resultPrint > 32) result = true; 

     } 
     catch (Exception ex) 
     { 
      throw new Exception(ex.ToString()); 
     } 
     return result; 
    } 

Я извиняюсь за то, что поставил первую часть вопроса, я расстроен за то, чтобы поставить проект я уже 3 недели и ничего, простите меня.

Другой неудачной попытки, файл появится в очереди печати, но он печатает пустой:

public class RawPrinterHelper 
{ 
    // Structure and API declarions: 
    [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)] 
    public class DOCINFOA 
    { 
     [MarshalAs(UnmanagedType.LPStr)] 
     public string pDocName; 
     [MarshalAs(UnmanagedType.LPStr)] 
     public string pOutputFile; 
     [MarshalAs(UnmanagedType.LPStr)] 
     public string pDataType; 
    } 
    [DllImport("winspool.Drv", EntryPoint = "OpenPrinterA", SetLastError = true, CharSet = CharSet.Ansi, ExactSpelling = true, CallingConvention = CallingConvention.StdCall)] 
    public static extern bool OpenPrinter([MarshalAs(UnmanagedType.LPStr)] string szPrinter, out IntPtr hPrinter, IntPtr pd); 

    [DllImport("winspool.Drv", EntryPoint = "ClosePrinter", SetLastError = true, ExactSpelling = true, CallingConvention = CallingConvention.StdCall)] 
    public static extern bool ClosePrinter(IntPtr hPrinter); 

    [DllImport("winspool.Drv", EntryPoint = "StartDocPrinterA", SetLastError = true, CharSet = CharSet.Ansi, ExactSpelling = true, CallingConvention = CallingConvention.StdCall)] 
    public static extern bool StartDocPrinter(IntPtr hPrinter, Int32 level, [In, MarshalAs(UnmanagedType.LPStruct)] DOCINFOA di); 

    [DllImport("winspool.Drv", EntryPoint = "EndDocPrinter", SetLastError = true, ExactSpelling = true, CallingConvention = CallingConvention.StdCall)] 
    public static extern bool EndDocPrinter(IntPtr hPrinter); 

    [DllImport("winspool.Drv", EntryPoint = "StartPagePrinter", SetLastError = true, ExactSpelling = true, CallingConvention = CallingConvention.StdCall)] 
    public static extern bool StartPagePrinter(IntPtr hPrinter); 

    [DllImport("winspool.Drv", EntryPoint = "EndPagePrinter", SetLastError = true, ExactSpelling = true, CallingConvention = CallingConvention.StdCall)] 
    public static extern bool EndPagePrinter(IntPtr hPrinter); 

    [DllImport("winspool.Drv", EntryPoint = "WritePrinter", SetLastError = true, ExactSpelling = true, CallingConvention = CallingConvention.StdCall)] 
    public static extern bool WritePrinter(IntPtr hPrinter, IntPtr pBytes, Int32 dwCount, out Int32 dwWritten); 

    // SendBytesToPrinter() 
    // When the function is given a printer name and an unmanaged array 
    // of bytes, the function sends those bytes to the print queue. 
    // Returns true on success, false on failure. 
    public static bool SendBytesToPrinter(string szPrinterName, IntPtr pBytes, Int32 dwCount) 
    { 
     Int32 dwError = 0, dwWritten = 0; 
     IntPtr hPrinter = new IntPtr(0); 
     DOCINFOA di = new DOCINFOA(); 
     bool bSuccess = false; // Assume failure unless you specifically succeed. 

     di.pDocName = "My C#.NET RAW Document"; 
     di.pDataType = "RAW"; 

     // Open the printer. 
     if (OpenPrinter(szPrinterName.Normalize(), out hPrinter, IntPtr.Zero)) 
     { 
      // Start a document. 
      if (StartDocPrinter(hPrinter, 1, di)) 
      { 
       // Start a page. 
       if (StartPagePrinter(hPrinter)) 
       { 
        // Write your bytes. 
        bSuccess = WritePrinter(hPrinter, pBytes, dwCount, out dwWritten); 
        EndPagePrinter(hPrinter); 
       } 
       EndDocPrinter(hPrinter); 
      } 
      ClosePrinter(hPrinter); 
     } 
     // If you did not succeed, GetLastError may give more information 
     // about why not. 
     if (bSuccess == false) 
     { 
      dwError = Marshal.GetLastWin32Error(); 
     } 
     return bSuccess; 
    } 

    public static bool SendFileToPrinter(string szPrinterName, string szFileName) 
    { 
     // Open the file. 
     FileStream fs = new FileStream(szFileName, FileMode.Open); 
     // Create a BinaryReader on the file. 
     BinaryReader br = new BinaryReader(fs); 
     // Dim an array of bytes big enough to hold the file's contents. 
     Byte[] bytes = new Byte[fs.Length]; 
     bool bSuccess = false; 
     // Your unmanaged pointer. 
     IntPtr pUnmanagedBytes = new IntPtr(0); 
     int nLength; 

     nLength = Convert.ToInt32(fs.Length); 
     // Read the contents of the file into the array. 
     bytes = br.ReadBytes(nLength); 
     // Allocate some unmanaged memory for those bytes. 
     pUnmanagedBytes = Marshal.AllocCoTaskMem(nLength); 
     // Copy the managed byte array into the unmanaged array. 
     Marshal.Copy(bytes, 0, pUnmanagedBytes, nLength); 
     // Send the unmanaged bytes to the printer. 
     bSuccess = SendBytesToPrinter(szPrinterName, pUnmanagedBytes, nLength); 
     // Free the unmanaged memory that you allocated earlier. 
     Marshal.FreeCoTaskMem(pUnmanagedBytes); 
     return bSuccess; 
    } 
    public static bool SendStringToPrinter(string szPrinterName, string szString) 
    { 
     IntPtr pBytes; 
     Int32 dwCount; 
     // How many characters are in the string? 
     dwCount = szString.Length; 
     // Assume that the printer is expecting ANSI text, and then convert 
     // the string to ANSI text. 
     pBytes = Marshal.StringToCoTaskMemAnsi(szString); 
     // Send the converted ANSI string to the printer. 
     SendBytesToPrinter(szPrinterName, pBytes, dwCount); 
     Marshal.FreeCoTaskMem(pBytes); 
     return true; 
    } 
} 

class Program 
{ 
    private static void Main(string[] args) 
    { 

     var defaultPrintQueue = LocalPrintServer.GetDefaultPrintQueue(); 
     RawPrinterHelper.SendFileToPrinter(defaultPrintQueue.FullName, @"C:\Temp\Teste.pdf"); 

    } 
} 

С помощью опции ниже Adobe Reader также открывается и остается открытым:

public void Print(string fullPath, string printerName) 
    { 
     Process process = new Process 
           { 
            StartInfo = 
             { 
              FileName = fullPath, 
              UseShellExecute = true, 
              Verb = "printto", 
              Arguments = "\"" + printerName + "\"" 
             } 
           }; 

     process.Start(); 
    } 
  • Визуальный Studio 2013, C#, Windows 8.1
+1

Вы говорите, что вы пробовали разные способы, но вы не объяснили, как они не работают. Как мы должны знать, что вы сделали неправильно? И что означает «печатать молчание»? –

+0

Вопросы, которые являются просто требованиями без каких-либо усилий, обычно не воспринимаются при переполнении стека. Вместо этого покажите (в коде), что было предпринято для решения проблемы и какие проблемы в настоящее время встречаются вместе с конкретным, ответным, объективным вопросом. – tnw

+0

Да, покажите свой код, тогда только мы сможем понять, какую логику вы использовали и где это не удалось – Kira

ответ

2

Если вы посмотрите на печать C Ссылка «Как это работает» на катушке индуктора говорит:

«Специальная способность Дирижера - автоматическая отправка документов в другие программы для печати.

....

Adobe Reader или Adobe Acrobat требуется для печати PDF-файлов.»

Так ведь это делает открытой Acrobat (или, по крайней мере, приложение, связанное с PDF-файлами) чтобы печатать их. Я боюсь, что для печати произвольных типов документов вам необходимо приложение, которое понимает, как читать документ и как его отображать.

Некоторые типы документов понимаются операционной системой (например, Windows и файлы XPS) и могут быть напечатаны без дополнительного программного обеспечения но в общем случае такого решения нет.

+0

Кен спасибо за ответ, у меня это программное обеспечение установлено на моей машине, я провел несколько тестов. Я заметил, что он запрашивает соответствующее приложение, но, как я уже упоминал, он распечатал файл pdf без открытия Adobe Reader, документ переходит в прямую печать в очереди. –

+0

Если честно, если разработчик программного обеспечения говорит, что для печати требуется Acrobat, я склонен им поверить ... – KenS

+0

Я согласен с вами и с ними, но имею некоторое представление о том, как они могут отправить это впечатление без открытия Adobe Reader? –

Смежные вопросы