Create custom receipts with CloverConnector
If your integration requires receipt features beyond those provided by Clover, you can turn off the default receipts Per-transaction settings and print your own using the Clover device printer. It is your responsibility to make sure that custom receipts comply with local laws and regulations. For more information, see Clover Help.
Note
When your default receipt selection screen does not appear during the payment flow, your app should launch a Custom Activity if customer input is required.
Get the device printer
Before you can use the print()
method, you must:
- Retrieve information about the available printer for the device. Your app can retrieve this information after the connection is established and the device is ready for subsequent requests. The following are samples from the Remote Pay Android Example POS on how to get the printer information from the connected device.
public static List<Printer> printers;
private Printer printer;
public void onDeviceReady(final MerchantInfo merchantInfo) {
runOnUiThread(new Runnable() {
public void run() {
showMessage("Ready!", Toast.LENGTH_SHORT);
}
});
RetrievePrintersRequest rpr = new RetrievePrintersRequest();
cloverConnector.retrievePrinters(rpr);
}
- Create a listener to handle the response to the
RetrievePrinters()
call and set theprinter
for the currently connected device. Use this to confirm that theprinter
is available before making a print request.
@Override
public void onRetrievePrintersResponse(RetrievePrintersResponse response) {
printers = response.getPrinters();
if(printers != null){
printer = printers.get(0);
}
}
Print a custom receipt
To send an image to the device printer, use the CloverConnector.print(PrintRequest)
. The first parameter of the PrintRequest
can take one of three forms—a bitmap image, the URL (link) of an image, or an array of text strings. The following are samples from the Remote Pay Android Example POS for each type of PrintRequest
:
- Print image
public void printImage(String imgDecodableString){
Bitmap bitmap = BitmapFactory.decodeFile(imgDecodableString);
if(this.printer != null){
PrintRequest pr = new PrintRequest(bitmap);
lastPrintRequestId = String.valueOf(getNextPrintRequestId());
pr.setPrintRequestId(lastPrintRequestId);
pr = new PrintRequest(bitmap, lastPrintRequestId, printer.getId());
cloverConnector.print(pr);
}
}
- Print an image from a URL (link)
public void printImageURLClick(View view) {
String URL = ((TextView) findViewById(R.id.PrintImageURLText)).getText().toString();
if(printer != null){
PrintRequest pr = new PrintRequest(URL);
lastPrintRequestId = String.valueOf(getNextPrintRequestId());
pr.setPrintRequestId(lastPrintRequestId);
pr = new PrintRequest(URL, lastPrintRequestId, printer.getId());
cloverConnector.print(pr);
}
}
- Print text on the receipt
public void printTextClick(View view) {
String[] textLines = ((TextView) findViewById(R.id.PrintTextText)).getText().toString().split("\n");
List<String> lines = Arrays.asList(textLines);
if(printer != null){
PrintRequest pr = new PrintRequest(lines);
lastPrintRequestId = String.valueOf(getNextPrintRequestId());
pr.setPrintRequestId(lastPrintRequestId);
pr = new PrintRequest(lines, lastPrintRequestId, printer.getId());
cloverConnector.print(pr);
}
Guidelines for receipt images
For the best printing performance, Clover recommends the following when constructing a print receipt bitmap:
- Pre-scale the image to a maximum width of 576 pixels.
- Use a black-and-white image where the saturation value is zero (0). A gray-scaled image processes more slowly because the device evaluates each pixel.
Updated 6 days ago