Emojis support in the renders

Hey there, I’m trying to put some emojis in the renders that I’m creating using an HTML asset and some text inside with emojis, but the emojis are not being shown :sweat_smile: Am I missing something or it is not supported?

Thanks in advance

Hey @Josue.

The HTML asset doesn’t currently support unicode emoji’s. It does support some ascii emojis. I’ve added unicode emojis to our features request list.

image

{
    "timeline":
    {
        "background": "#000000",
        "tracks":
        [
            {
                "clips":
                [
                    
                    {
                        "asset":
                        {
                            "type": "html",
                            "html": "<p>☺</p>",
                            "css": "p { font-size: 100px; color: #FFFFFF; }"
                        },
                        "start": 0.0,
                        "length": 9.4,
                        "scale": 1
                    }
                ]
            }
        ]
    },
    "output":
    {
        "format": "png",
        "size":
        {
            "width": 500,
            "height": 500
        }
    }
}
1 Like

I just discovered that you can use an inline base64 encoded image in the HTML asset, so something like this will work:

{
    "timeline": {
        "background": "#000000",
        "fonts": [
            {
                "src": "https://shotstack-assets.s3-ap-southeast-2.amazonaws.com/fonts/OpenSans-Regular.ttf"
            }
        ],
        "tracks": [
            {
                "clips": [
                    {
                        "asset": {
                            "type": "html",
                            "html": "<p>This is an emoji <img src='' width='42' height='42' /></p>",
                            "css": "p { font-family: 'Open Sans'; color: #ffffff; font-size: 42px; text-align: center; } b { color: #21bcb9; font-weight: normal; } u { color: #e784ff; text-decoration: none; }",
                            "width": 450,
                            "height": 200
                        },
                        "start": 0,
                        "length": 5
                    }
                ]
            }
        ]
    },
    "output": {
        "format": "mp4",
        "resolution": "hd"
    }
}

You need to specify the width and height for it to display and also would recommend creating the images at the exact size you want - resizing can make the edges go a bit rough. Use a transparent PNG with your emoji and convert the image to base64 using a library or you can quickly use some thing like this: https://www.base64-image.de/.

Use this technique sparingly as the JSON payload could get very large For regular images don’t use the HTML asset, use the image asset and scale and position the image as needed.

An example of using inline images:

{
    "timeline": {
        "tracks": [
            {
                "clips": [
                    {
                        "asset": {
                            "type": "html",
                            "html": "<img src=\"\" width=\"12\" height=\"12\" />"
                        },
                        "length": 1,
                        "start": 0
                    }
                ]
            }
        ]
    },
    "output": {
        "format": "png",
        "resolution": "sd"
    }
}

Any update on supporting unicode emoji? It would be super nice

Well I found a workaround, better than the base64 solution.
Just add an emoji font into your json, then emojis will appear.
I am using this font: Noto Color Emoji - Google Fonts