2012-11-13 15 views
6

Próbowałem wydrukować zawartość RichTextBox i jest zbyt wiele błędów, jeśli drukuję do drukarki. Ale kiedy drukuję do pliku XPS (przez XPS-drukarki w Windows), a następnie drukowanie tego pliku do drukarki wszystko jest w porządku.Wydrukuj do pliku XPS, a następnie wydrukuj go na drukarce.

Czy mogę więc programować wszystkie te rzeczy?

Oto moja metoda druku:

public int PrintRotate(bool rotate, PrintPageEventArgs e, int charFrom, int charTo) 
    { 
     //Calculate the area to render and print 
     RECT rectToPrint; 
     rectToPrint.Top = (int)(e.MarginBounds.Top * anInch); 
     rectToPrint.Bottom = (int)(e.MarginBounds.Bottom * anInch); 
     rectToPrint.Left = (int)(e.MarginBounds.Left * anInch); 
     rectToPrint.Right = (int)(e.MarginBounds.Right * anInch); 

     //Calculate the size of the page 
     RECT rectPage; 
     rectPage.Top = (int)(e.PageBounds.Top * anInch); 
     rectPage.Bottom = (int)(e.PageBounds.Bottom * anInch); 
     rectPage.Left = (int)(e.PageBounds.Left * anInch); 
     rectPage.Right = (int)(e.PageBounds.Right * anInch); 

     IntPtr hdc = e.Graphics.GetHdc(); 

     FORMATRANGE fmtRange; 
     fmtRange.chrg.cpMax = charTo;    //Indicate character from to character to 
     fmtRange.chrg.cpMin = charFrom; 
     fmtRange.hdc = hdc;     //Use the same DC for measuring and rendering 
     fmtRange.hdcTarget = hdc;    //Point at printer hDC 
     fmtRange.rc = rectToPrint;    //Indicate the area on page to print 
     fmtRange.rcPage = rectPage;   //Indicate size of page 


     SetGraphicsMode(fmtRange.hdc, GM_ADVANCED); 

     XFORM par = new XFORM(); 

     par = new XFORM(); 
     par.eM11 = 1; 
     par.eM12 = 0; 
     par.eM21 = 0; 
     par.eM22 = 1; 
     par.eDx = -e.PageSettings.Margins.Left/100 * e.PageSettings.PrinterResolution.X; 
     par.eDy = -e.PageSettings.Margins.Top/100 * e.PageSettings.PrinterResolution.Y; 
     ModifyWorldTransform(fmtRange.hdc, ref par, MWT_LEFTMULTIPLY); 

     IntPtr res = IntPtr.Zero; 

     IntPtr wparam = IntPtr.Zero; 
     wparam = new IntPtr(1); 

     //Get the pointer to the FORMATRANGE structure in memory 
     IntPtr lparam = IntPtr.Zero; 
     lparam = Marshal.AllocCoTaskMem(Marshal.SizeOf(fmtRange)); 
     Marshal.StructureToPtr(fmtRange, lparam, false); 

     //Send the rendered data for printing 
     res = SendMessage(Handle, EM_FORMATRANGE, wparam, lparam); 

     //Free the block of memory allocated 
     Marshal.FreeCoTaskMem(lparam); 

     //Release the device context handle obtained by a previous call 
     e.Graphics.ReleaseHdc(hdc); 

     //Return last + 1 character printer 
     return res.ToInt32(); 
    } 
+1

Czy kiedykolwiek znalazłeś rozwiązanie tego problemu? Zamierzam zrobić to samo. –

+0

Niestety nie. Zadanie to ma teraz dla mnie niski priorytet. –

+0

Chciałbym również rozwiązać ten problem. – Jeff

Odpowiedz

1

miałem problemu takiego, a zakończył się tworzenia pliku .xps a następnie wysyłając że do drukarki.

Z twojego pytania wynika, że ​​masz już proces "drukowania" do pliku xps, co jest dobre, ponieważ nie wiem nic o procesie drukowania pola tekstowego do pliku xps. W mojej scenariuszu musiałem wydrukować dokument bez korzystania z pakietu MS Office, więc skończyłem tworzyć plik XPS, edytować go w kodzie, a następnie wysłać go do drukarki.

Jest to kod używam wysłać XPS plik bezpośrednio do drukarki:

LocalPrintServer localPrintServer = new LocalPrintServer(); 
var queue = localPrintServer.GetPrintQueue("NameOfPrinter"); 
PrintSystemJobInfo xpsPrintJob = queue.AddJob("name of print job", "my/xps/path.xps",false); 

Należy również pamiętać, że dla tego kodu do pracy trzeba dodać referencje do System.Printing I „ReachFramework”. Zajęło mi to dłużej, niż pamiętam, aby dowiedzieć się, dlaczego nie mogłem uzyskać dostępu do tego robota.

Większość drukarek powinna obsługiwać to z mojego doświadczenia. Typowe i działa nawet na dziwnej "drukarce kodów kreskowych" w naszym magazynie.