Using canvas layer in function

Before starting to use the canvas layer, it is required to have the layer deployed through AWS Serverless Application Repository or AWS Lambda console, you may refer setup information for details. Then, you may create your Lambda function using:

  • AWS Lambda console editor; or
  • Local tool in your machine; or
  • Any way you may prefer

Following is an example where a Lambda function uses the canvas layer to generate PNG graphic with colored text and circle rendered. There is no environment variable setting is required in this example.

Function structure

The setup of the function may look like the following structure. For font file, you may use any supported font file you like, in this example, we are going to use DejaVu Sans1 which could be originally found in Amazon Linux 2 EC2 instance.

/var/task/
    .
    ├── fonts/
        ├── DejaVuSans.ttf
        ├── fonts.conf
    ├── index.js

Font configuration using fonts.config

Since AWS Lambda does not appear to support even the basic fonts on its own, so we create the fonts directory at the root directory for our Lambda function with following font configuration file2.

<?xml version="1.0"?>
<!DOCTYPE fontconfig SYSTEM "fonts.dtd">
<fontconfig>
    <dir>/var/task/fonts</dir>
    <cachedir>/tmp/fonts-cache/</cachedir>
    <config></config>
</fontconfig>

Build function code in index.js

Once the setup is ready, we may put following function code and test it in AWS Lambda console.

let { registerFont, createCanvas } = require('canvas');

exports.handler = async (event) => {
    registerFont(__dirname.concat('/fonts/DejaVuSans.ttf'), { family: 'DejaVu Sans' });

    let canvas = createCanvas(300, 300);
    var ctxCircle = canvas.getContext('2d');
    var X = canvas.width / 2;
    var Y = canvas.height / 2;
    var R = 45;
    ctxCircle.beginPath();
    ctxCircle.arc(X, Y, R, 0, 2 * Math.PI, false);
    ctxCircle.lineWidth = 3;
    ctxCircle.strokeStyle = '#FF9900';
    ctxCircle.stroke();

    var ctxText = canvas.getContext('2d');
    ctxText.font = '40px "DejaVu Sans"';
    ctxText.fillStyle = '#146EB4';
    ctxText.fillText('DejaVu Sans', 15, 120);

    const response = {
        statusCode: 200,
        body: JSON.stringify(canvas.toDataURL()),
    };

    return response;
};

Following is the sample response from the above example function code.

{
  "statusCode": 200,
  "body": "\"\""
}

As a result, the generated PNG graphic with colored text and circle rendered may look like as follow.