Создание файла XPS с помощью Microsoft XPS Document Writer программным способом

Я исследую решение для пакетной печати.

Файлы для печати будут в различных (типичных) форматах, например, PDF, Word, Excel и т. Д. Из того, что я собрал (и проверил), печать файлов XPS - это путь для платформы Windows.

Однако мне совершенно неясно, как на самом деле создать файл XPS - без глубоких знаний о рассматриваемом формате входного файла (то есть программно).

Я надеялся, что смогу распечатать на локальном «принтере» Microsoft XPS Document Writer, а затем физически распечатать его вывод (то есть файл XPS).

Я не могу сделать это программно. Я пробовал использовать управляемый код System.Printing, неуправляемый код Winspool API.

Я могу успешно открыть принтер и записать на него необработанные данные, но никогда не получаю выходной файл XPS. Как создать файлы XPS? Я просмотрел XPSDocumentWriter API, но он кажется очень сложным и, по-видимому, уже реализован Microsoft XPS Document Writer и / или существующими приложениями.


person Publius    schedule 24.10.2012    source источник


Ответы (1)


Я нашел один способ сделать это - начать с приложения, создавшего документ, т.е. Word, Excel и т. Д. И распечатать их. Этот фрагмент кода принимает строку в документ, который нужно преобразовать, создает файл xps в папке users% tmp% и возвращает строку в документ. Он выполняет свою работу, но не быстро:

    private readonly string TEMP = Environment.ExpandEnvironmentVariables("%tmp%");
    private  object nullObject = Type.Missing;

    private string ConvertWordtoXps(string wordDocName)
    {
        Microsoft.Office.Interop.Word.Application wordApp = new Microsoft.Office.Interop.Word.Application();
        wordApp.Documents.Open(wordDocName, ConfirmConversions: false, ReadOnly: true);
        string xpsFileName = String.Concat(TEMP, "\\", Path.GetFileNameWithoutExtension(wordDocName), ".xps");

        try
        {
            wordApp.ActiveDocument.SaveAs2(xpsFileName, FileFormat: WdSaveFormat.wdFormatXPS);
            return xpsFileName;
        }
        catch (Exception e)
        {
            MessageBox.Show(e.Message);
        }
        finally
        {
            ((Microsoft.Office.Interop.Word._Application)wordApp).Quit(SaveChanges: false, OriginalFormat: nullObject, RouteDocument: nullObject);
        }
        return null;

    }

    private string ConvertExceltoXps(string excelWorkbookName)
    {
        Microsoft.Office.Interop.Excel.Application excelApp = new Microsoft.Office.Interop.Excel.Application();
        excelApp.Workbooks.Add(excelWorkbookName);
        Workbook excelWorkbook = excelApp.ActiveWorkbook;
        string xpsFileName = String.Concat(TEMP, "\\", Path.GetFileNameWithoutExtension(excelWorkbookName), ".xps");

        try
        {
            excelWorkbook.ExportAsFixedFormat(
                XlFixedFormatType.xlTypeXPS,
                xpsFileName,  
                Quality: XlFixedFormatQuality.xlQualityMinimum,
                IncludeDocProperties: false,
                IgnorePrintAreas: false,
                From: nullObject,
                To: nullObject,
                OpenAfterPublish: false,
                FixedFormatExtClassPtr: nullObject
            );

            return xpsFileName;
        }
        catch (Exception e)
        {
            MessageBox.Show(e.Message);
        }
        finally
        {
            excelWorkbook.Close(XlSaveAction.xlDoNotSaveChanges, Filename: nullObject, RouteWorkbook: nullObject); 
            ((Microsoft.Office.Interop.Excel._Application)excelApp).Quit();
        }
        return null;
    }

    private string ConvertPowerPointtoXps(string pptFile)
    {
        Microsoft.Office.Interop.PowerPoint.Application pptApp = new Microsoft.Office.Interop.PowerPoint.Application();
        Microsoft.Office.Interop.PowerPoint.Presentations pptSet = pptApp.Presentations;
        Microsoft.Office.Interop.PowerPoint.Presentation pptPresentation = pptSet.Open(pptFile, ReadOnly: MsoTriState.msoTrue, Untitled: MsoTriState.msoTrue, WithWindow: MsoTriState.msoFalse);
        string xpsFileName = String.Concat(TEMP, "\\", Path.GetFileNameWithoutExtension(pptFile), ".xps");

        try
        {
            pptPresentation.ExportAsFixedFormat(
                xpsFileName,
                PpFixedFormatType.ppFixedFormatTypeXPS,
                PpFixedFormatIntent.ppFixedFormatIntentScreen,
                FrameSlides: MsoTriState.msoFalse,
                HandoutOrder: PpPrintHandoutOrder.ppPrintHandoutVerticalFirst,
                OutputType: PpPrintOutputType.ppPrintOutputFourSlideHandouts,
                PrintHiddenSlides: MsoTriState.msoFalse,
                RangeType: PpPrintRangeType.ppPrintAll,
                SlideShowName: "",
                IncludeDocProperties: false,
                KeepIRMSettings: true,
                DocStructureTags: true,
                BitmapMissingFonts: true,
                UseISO19005_1: false,
                ExternalExporter: nullObject
            );
            return xpsFileName;
        }
        catch (Exception e)
        {
            MessageBox.Show(e.Message);
        }
        finally
        {
            ((_Presentation)pptPresentation).Close();
            ((Microsoft.Office.Interop.PowerPoint._Application)pptApp).Quit();
        }
        return null;
    }
person Jakob    schedule 28.11.2012