Coder Social home page Coder Social logo

rat.js's Introduction

Rat.js

Small canvas object-oriented library

Init

var ctx = element.getContext('2d');
var rat = new Rat(ctx);

Paths

var path = rat.path([
  ['moveTo', 10, 10],
  ['lineTo', 100, 100],
  ['lineTo', 10, 100],
  ['closePath']
], {
 fillStyle: 'red',
 strokeStyle: 'green',
 lineWidth: 4
});

Image

var img = new Image;
img.src = "image.jpg";
img.onload = function(){
  rat.image(img, {
    rotate: 45 * Math.PI / 180,
    origin: [100, 100]
    // crop, width, height parameters for images
  });
}

Text

var text = rat.text("Hello, world!", {
  fillStyle: 'blue',
  translate: [0, 100]
  // maxWidth parameter for text
});

Animation

function draw(){
  path.style.rotate += Math.PI / 180;
  rat.clear();
  rat.draw([path, image, text]);
  requestAnimationFrame(draw);
}
draw();

Transformations

With origin:

  • rotate (angle in radians)
  • scale (array, [x,y])

Without origin:

  • translate (array, [x,y])
  • transform (array, [m11,m21,m12,m22,dx,dy])

rat.js's People

Contributors

keyten avatar flubbex avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.