(Created page with "MDriven reports are created with open document text (odt) or open document spreadsheet formats (ods). If you need to convert the odt to PDF there are online services availabl...") |
Hans Karlsen (talk | contribs) No edit summary |
||
(6 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
MDriven reports are created with open document text (odt) or open document spreadsheet formats (ods). | MDriven reports are created with open document text (odt) or open document spreadsheet formats (ods). | ||
If you need to convert the odt to PDF there are online services available. If you rather do this | If you need to convert the odt to PDF, there are online services available. If you would rather do this yourself, buy a third-party library that has this ability - for example, [https://www.aspose.com/ Aspose.Words] as used in this example. | ||
'''Please note''' that this solution works well inside IIS, but it's '''not free'''. If you can access Word locally, like the WPF client, | '''Please note''' that this solution works well inside IIS, but it's '''not free'''. If you can access Word locally, like the WPF client, you can use Word instead of paying for a .net component. You can find an example of how to use [[PDF|Word with automation]] here. | ||
Yet another new approach is to [[Use LibreOffice for PDF conversion|use LibreOffice - read more here]] | |||
This example uses a transient class | |||
=== Example === | |||
This example uses a transient class PDF converter to make PDF conversion easy to access from anywhere in the model. | |||
[[File:PDF converter class.png|frameless]] | [[File:PDF converter class.png|frameless]] | ||
This is the C# code for the two functions | This is the C# code for the two functions: | ||
public void ConvertToPDF() | public void ConvertToPDF() | ||
{ | { | ||
Line 25: | Line 27: | ||
this.PDF = dstStream.ToArray(); | this.PDF = dstStream.ToArray(); | ||
} | } | ||
CheckCodeDressingActive is a way of | CheckCodeDressingActive is a way of ensuring that the PDF component has been properly loaded - in this case, with [[CodeDress]]. | ||
public bool CheckCodeDressingActive() | public bool CheckCodeDressingActive() | ||
{ | { | ||
return true; | return true; | ||
} | } | ||
'''Note:''' Include the Aspose license file as an '''Embedded resource''' in the VS project to avoid the error message "the invoked member is not supported in a dynamic assembly." | |||
[[Category:Reports]] | |||
{{Edited|July|12|2024}} |
Latest revision as of 10:01, 3 June 2024
MDriven reports are created with open document text (odt) or open document spreadsheet formats (ods).
If you need to convert the odt to PDF, there are online services available. If you would rather do this yourself, buy a third-party library that has this ability - for example, Aspose.Words as used in this example.
Please note that this solution works well inside IIS, but it's not free. If you can access Word locally, like the WPF client, you can use Word instead of paying for a .net component. You can find an example of how to use Word with automation here.
Yet another new approach is to use LibreOffice - read more here
Example
This example uses a transient class PDF converter to make PDF conversion easy to access from anywhere in the model.
This is the C# code for the two functions:
public void ConvertToPDF() { Aspose.Words.License license = new Aspose.Words.License(); license.SetLicense("Aspose.Words.lic"); MemoryStream srcStream = new MemoryStream(this.Document); Document srcDoc = new Document(srcStream); MemoryStream dstStream = new MemoryStream(); Aspose.Words.Saving.PdfSaveOptions options = new Aspose.Words.Saving.PdfSaveOptions(); options.Compliance = Aspose.Words.Saving.PdfCompliance.PdfA1b; options.MemoryOptimization = true; options.OptimizeOutput = true; srcDoc.Save(dstStream, options); this.PDF = dstStream.ToArray(); }
CheckCodeDressingActive is a way of ensuring that the PDF component has been properly loaded - in this case, with CodeDress.
public bool CheckCodeDressingActive() { return true; }
Note: Include the Aspose license file as an Embedded resource in the VS project to avoid the error message "the invoked member is not supported in a dynamic assembly."