How to use the canvas.Image function in canvas

To help you get started, we’ve selected a few canvas examples, based on popular ways it is used in public projects.

Secure your code as it's written. Use Snyk Code to scan source code in minutes - no build needed - and fix issues immediately.

github loretoparisi / tensorflow-node-examples / object_detection / index.js View on Github external
}
        var res = {
            boxes: detectedBoxes,
            names: detectedNames,
            inferenceTime: endTime - startTime
        };
        console.log(res);

        // create canvas and context
        const width=1024
        const height=768
        const canvas = createCanvas(width, height);
        const context = canvas.getContext('2d');

        // create image from buffer
        const img = new Image()
        img.onload = () => {
            // draw image in context
            context.drawImage(img, 0, 0, width, height);
            // draw boxes from model's detection boxes
            for (let i = 0; i < res.boxes.length; i++) {
                const box = res.boxes[i];
                context.fillStyle = 'rgba(255,255,255,0.2';
                context.strokeStyle = 'white';
                context.fillRect(box[1] * width, box[0] * height, width * (box[3] - box[1]),
                    height * (box[2] - box[0]));
                context.font = '15px Arial';
                context.fillStyle = 'white';
                context.fillText(res.names[i], box[1] * width, box[0] * height, box[0] * height);
                context.lineWidth = 2;
                context.strokeRect(box[1] * width, box[0] * height, width * (box[3] - box[1]),
                    height * (box[2] - box[0]));
github luoxuhai / generator-cover / src / index.js View on Github external
const fontScale = 1.2,
    canvas = createCanvas(width, height),
    ctx = canvas.getContext('2d');

  // TODO: 渐变背景
  // const grd=cxt.createLinearGradient(0, 0, width, height);
  // grd.addColorStop(0, "#FF0000");

  if (bgColor) {
    ctx.fillStyle = bgColor;
    ctx.fillRect(0, 0, width, height);
  }

  if (bgImage) {
    let image = new Image();
    if (bgImage.startsWith('http')) {
      image = await loadImage(bgImage);
    } else if (bgImage.startsWith('data:image/')) image.src = bgImage;
    else image.src = await readFile(bgImage);
    ctx.drawImage(image, 0, 0, width, height);
  }

  let fontSize = Number(fontStyle.split(' ')[0].replace('px', ''));
  ctx.font = fontStyle;
  ctx.fillStyle = fontColor;
  if ((fontSize * bookName.length) / height > 0.6) {
    ctx.font = fontStyle.replace(`${fontSize}px`, `${fontSize / fontScale}px`);
    fontSize /= fontScale;
  }

  const fontHeight = fontSize + fontSize / 4;
github jgoralcz / image-microservice / src / workers / canvas / America.js View on Github external
const canvas = createCanvas(imageD, imageD);
      const ctx = canvas.getContext('2d');
      ctx.quality = 'fast';
      ctx.patternQuality = 'fast';

      // resize their image so we don't have to do it each time.
      const ctxResize = canvas.getContext('2d');
      ctxResize.drawImage(theirImage, 0, 0, imageD, imageD);
      const buffer = canvas.toBuffer('image/jpeg', undefined);
      theirImage.src = Buffer.from(buffer);

      // loop over all images.
      const length = (images.length > 65) ? 65 : images.length;
      for (let i = 0; i < length - 1; i += 1) {
        ctx.globalAlpha = 1;
        const background = new Image();
        background.src = Buffer.from(images[i]);
        ctx.drawImage(background, 0, 0, imageD, imageD);

        // get buffer and resize our image to our length
        ctx.globalAlpha = 0.5;
        ctx.drawImage(theirImage, 0, 0, imageD, imageD);
        encoder.addFrame(ctx);
      }
      encoder.finish();

      return await myAccumulator.getBuffer();
    } catch (error) {
      console.error(error);
    }
    return undefined;
  },
github TooTallNate / ansi-canvas / examples / imgcat.js View on Github external
var tc = require('../');
var Canvas = require('canvas');

// create terminal <canvas>
var canvas = tc();
var ctx = canvas.getContext('2d');

var screenWidth = canvas.width;
var maxWidth = parseInt(process.argv[3], 10) || screenWidth;

var imageFile = process.argv[2];
var image = require('fs').readFileSync(imageFile);
var img = new Canvas.Image();
img.src = image;


var width = maxWidth;
var scaleW = img.width &gt; width ? width / img.width : 1;
var w = Math.floor(img.width * scaleW);
var h = Math.floor(img.height * scaleW);

ctx.drawImage(img, 0, 0, w, h);

canvas.render();
</canvas>
github iobroker-community-adapters / ioBroker.mihome-vacuum / lib / mapCreator.js View on Github external
let COLOR_WALLS = "#2b2e30";
let COLOR_PATH = "white";

const robot = "";
const robot1 = "";
const charger = "";
const tank = ""
const spaceship = "";

var canvasimg = new Canvas();
//var ctximg = canvasimg.getContext('2d');

var img = new Image(); // Create a new Image
img.src = robot1;

const img_charger = new Image();
img_charger.src = charger;



const MapCreator = function () {};

MapCreator.CanvasMap = function (Mapdata, options) {
    let that = this;

    if(options){
        COLOR_FLOOR = options.FLOORCOLOR;
        COLOR_WALLS = options.WALLCOLOR;
        COLOR_PATH = options.PATHCOLOR;
        if(options.ROBOT=== 'robot'){
            img.src = robot
        }
github lifechurch / melos / nodejs / snapshot-image-2018.js View on Github external
drawProfileImage() {
		const text20 = '20';
		const text18 = '18';
		const startAngle = 0;
		const endAngle = Math.PI * 2;
		const circleRadius = this.relativeCircleSize(0.17);
		const imageSize = circleRadius * 2;
		const halfImageSize = imageSize / 2;
		const x = this.relativeX(0.50, this.widthLeftPane);
		const y = this.relativeY(0.28);
		const textY = this.relativeY(0.295);
		const ctx = this.ctx;


		// Draw avatar inside circle
		const img = new Image();
		img.src = this.avatarData;

		ctx.save();
		ctx.beginPath();
		ctx.arc(
			x,
			y,
			circleRadius,
			startAngle,
			endAngle,
			true
		);
		ctx.clip();
		ctx.drawImage(
			img,
			x - halfImageSize,
github WebPlatformForEmbedded / Lightning / src / node / NodeAdapter.js View on Github external
parseImage(data, cb) {
        let Canvas = require('canvas');
        let img = new Canvas.Image();
        img.src = data;
        let buf = img.rawData;
        cb(null, {source: buf, w: img.width, h: img.height, premultiplyAlpha: false, flipBlueRed: true});
    }
github lifechurch / melos / nodejs / snapshot-image-2018.js View on Github external
drawRightPane() {
		const ctx = this.ctx;
		const rightGradient = ctx.createLinearGradient(this.widthLeftPane, 0, this.widthLeftPane, this.height);
		rightGradient.addColorStop(0, 'rgba(23, 218, 214, 0.75)');
		rightGradient.addColorStop(0.5, 'rgba(33, 136, 179, 0.75)');
		rightGradient.addColorStop(1, 'rgba(43, 56, 144, 0.75)');

		const picture = new Image(this.width, this.height);
		picture.src = this.avatarData;

		const imageCanvas = createCanvas(this.width, this.height);
		const ictx = imageCanvas.getContext('2d');

		ictx.drawImage(picture, this.width * 0.3, 0, this.width, this.height);

		StackBlur.canvasRGB(imageCanvas, 0, 0, this.width, this.height, 20);
		ctx.drawImage(imageCanvas, 0, 0, this.width, this.height);

		ctx.fillStyle = rightGradient;
		ctx.fillRect(this.widthLeftPane, 0, this.widthRightPane, this.canvas.height);
	}
github uhop / grunt-tight-sprite / tasks / tight_sprite.js View on Github external
rectangles.forEach(function(rect){
					var image = new (Canvas.Image)();
					image.src = rect.name;
					ctx.drawImage(image, rect.x, rect.y);
				});
github stanford-oval / almond-cloud / routes / friendhub.js View on Github external
function loadImage(imageFilename) {
    let img = new Canvas.Image();
    img.src = imageFilename;
    const canvas = new Canvas();
    canvas.width = img.width;
    canvas.height = img.height;
    const ctx = canvas.getContext('2d');
    ctx.drawImage(img, 0, 0, img.width, img.height);
    return ctx;
}