Как добавить текст на холсте с помощью библиотеки Reaction и Canvg? - PullRequest
0 голосов
/ 04 мая 2019

Я пытаюсь добавить текст на холсте (внизу справа) с помощью activ и canvg lib

Это то, что я пытаюсь:

DownloadImage = (i) => {
        var _this = this;
        this.modeler.saveSVG(function (err, svg) {
            if (err) console.log(err)
            _this.setState({ datasvg: svg }, function () {
                const canvas = _this.refs.canvasforimage;
                console.log(canvas)

                const options = {
                    log: false,
                    ignoreMouse: true
                };

                canvg(canvas, this.state.datasvg, options);
                    const image = canvas.toDataURL("image/png").replace("image/png", "image/octet-stream");
                    const element = document.createElement("a");
                    element.setAttribute('download', 'diagram.png');
                    element.setAttribute('href', image);
                    element.click();
            })
        })
    }


    render = () => {
        return (
                <canvas  ref="canvasforimage" id="canvasforimage">
                 {/* <div style="position:absolute;right:0;bottom:0">Text</div> */} Not working
                </canvas>
        )

Функция выше работает ... яможно загрузить как изображение, но код при рендеринге, который я прокомментировал, не работает

1 Ответ

0 голосов
/ 04 мая 2019

спасибо за комментарий @Chris G так что я уже решил проблему, добавив код после canvg

canvg(canvas, this.state.datasvg, options);
const ctx = canvas.getContext('2d');
ctx.fillText('Hello world',50, 50);
...