Adjust output image size
When CAD drawings are rendered, the size of the render result is adjusted by API automatically, the biggest side (width or height depending on which one is bigger) is set 2000 px, another side is set value based on width-to-length ratio. You may adjust the size of resulting document by setting CadOptions as show in example.
Viewer viewer = new Viewer("sample.dwg"); HtmlViewOptions viewOptions = HtmlViewOptions.forEmbeddedResources(); viewOptions.setCadOptions(CadOptions.forRenderingByScaleFactor(0.3f)); viewer.view(viewOptions); viewer.close();
When rendering CAD drawings GroupDocs.Viewer provides following options:
1.When rendering by width or height (forRenderingByWidth(…) or forRenderingByHeight(…)) - value of another side will be calculated from ratio in original document.
2. When rendering by width and height (forRenderingByWidthAndHeigh(…)) - the resulting image will have the same size in pixels.
3. When rendering by scale factory (forRenderingByScaleFactor(…)) - the accepted value
scaleFactor type is float, values higher than 1 will enlarge resulting image and values between 0 and 1 will make image smaller. If the render result image size is equal to 200 px to 200 px, when
scaleFactor is equal to 1, then setting this value to 0.1 will provide image with 20 px to 20 px dimension.
How sizing works for Sheets and Layouts
DWF drawing format consists of sheets, that may have different sizes, DWG and DXF drawing formats consists of the Model and Layouts. Refer to Adjust output image size article that describes layouts rendering. Sizing rules described above, work for the drawings that consist of a one sheet or rendered without layouts and provide only one page as an output. In this section we will review how sizing works when the output consist of several pages. Later in this article, for convenience, we will refer to Model and layouts as sheets.
By default, when we render DWF format with several sheets, or DWG and DXF formats with layouts, each sheet is rendered into separate page, that has it’s own size.
If only one of
Width is set, value of another side for every sheet will be calculated from the ratio in size of that sheet. For example if
Height is set as 600 and the ratio of the height to width in first sheet is 6 to 5 and second sheet is 6 to 4, then the width of the resulting pages will be 500px and 400px respectively.
Height are set, we will get the same size for every page, and this may provide invalid results for documents that have differently sized sheets. When you want to set both
Height options for documents with sheets that have different sizes, it is better to render each page separately by specifying LayoutName property and setting individual size.
ScaleFactor option is set, it will be used to form resulting page sizes and will provide consistent size for every page.
You may easily run the code above and see the feature in action in our GitHub examples:
- GroupDocs.Viewer for Java examples, plugins, and showcase
- Document Viewer for .NET App WebForms UI Modern Example
- Document Viewer for Java App Dropwizard UI Modern Example
- Document Viewer for Java Spring UI Example
- GroupDocs.Viewer for .NET samples, plugins and showcase
- Document Viewer for .NET MVC UI Example
Free Online App
Along with full-featured Java library we provide simple but powerful free Apps. You are welcome to view Word, PDF, Excel, PowerPoint documents with free to use online GroupDocs Viewer App.