// Create a new workbook Workbook workbook = new Workbook(); IWorksheet ws = workbook.getActiveSheet(); // The base64 string of the image. String base64Img = ""; // Alternative text that describes the image for accessibility. String altText = "altText"; // Customize the image size by using the height and width arguments. // 0 Fit the image in the cell and maintain its aspect ratio. // 1 Fill the cell with the image and ignore its aspect ratio. // 2 Maintain the original image size, which may exceed the cell boundary. // 3 Customize the image size by using the height and width arguments. int sizing = 3; // Custom height of the image in pixels. int height = 60; // Custom width of the image in pixels. int width = 60; // The Y-axis coordinate of the top left corner of the sub-rectangle of the source image to draw into the destination context. int clipY = 0; // The X-axis coordinate of the top left corner of the sub-rectangle of the source image to draw into the destination context. int clipX = 0; // The height of the sub-rectangle of the source image to draw into the destination context. int clipH = 50; // The width of the sub-rectangle of the source image to draw into the destination context. int clipW = 50; // This value indicates the vertical alignment of the image. 0 = top, 1 = center, 2 = bottom. int vAlign = 1; // This value indicates the horizontal alignment of the image. 0 = left, 1 = center, 2 = right. int hAlign = 1; ws.getRange("A1").setValue("Clipped image"); ws.getRange("B1").setValue("Original image"); ws.getRange("A2").setFormula( String.format("=IMAGE(\"%s\",\"%s\",%d,%d,%d,%d,%d,%d,%d,%d,%d)", base64Img, altText, sizing, height, width, clipY, clipX, clipH, clipW, vAlign, hAlign)); ws.getRange("B2").setFormula( String.format("=IMAGE(\"%s\",\"%s\",%d,%d,%d)", base64Img, altText, sizing, height, width)); ws.getRange("A2:B2").setRowHeightInPixel(120); ws.getRange("A2:B2").setColumnWidthInPixel(120); ws.getPageSetup().setPrintGridlines(true); // Save to a pdf file workbook.save("ImageSparkline.pdf");