UNPKG

zent

Version:

一套前端设计语言和基于React的实现

35 lines (31 loc) 1.06 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.render = render; exports.get = get; var checkboardCache = {}; function render(c1, c2, size, ServerCanvas) { if (typeof document === 'undefined' && !ServerCanvas) return null; var canvas = ServerCanvas ? new ServerCanvas() : document.createElement('canvas'); // eslint-disable-line canvas.width = size * 2; canvas.height = size * 2; var ctx = canvas.getContext('2d'); if (!ctx) return null; // If no context can be found, return early. ctx.fillStyle = c1; ctx.fillRect(0, 0, canvas.width, canvas.height); ctx.fillStyle = c2; ctx.fillRect(0, 0, size, size); ctx.translate(size, size); ctx.fillRect(0, 0, size, size); return canvas.toDataURL(); } function get(c1, c2, size, serverCanvas) { var key = c1 + '-' + c2 + '-' + size + (serverCanvas ? '-server' : ''); var checkboard = render(c1, c2, size, serverCanvas); if (checkboardCache[key]) { return checkboardCache[key]; } checkboardCache[key] = checkboard; return checkboard; }