HTML5 Canvas Grayscale Image Filter Tutorial

Get last news, demos, posts from Konva

To apply filter to an Konva.Image, we have to cache it first with cache() function. Then apply filter with filter() function.

To invert the colors of an image with Konva, we can use the
Konva.Filters.Grayscale filter.

For all available filters go to Filters Documentation.

Konva Grayscale Image Demoview raw
<!DOCTYPE html>
<script src="[email protected]/konva.min.js"></script>
<meta charset="utf-8" />
<title>Konva Grayscale Image Demo</title>
body {
margin: 0;
padding: 0;
overflow: hidden;
background-color: #f0f0f0;

<div id="container"></div>
function loadImages(sources, callback) {
var images = {};
var loadedImages = 0;
var numImages = 0;
for (var src in sources) {
for (var src in sources) {
images[src] = new Image();
images[src].onload = function() {
if (++loadedImages >= numImages) {
images[src].src = sources[src];
function buildStage(images) {
var stage = new Konva.Stage({
container: 'container',
width: window.innerWidth,
height: window.innerHeight

var layer = new Konva.Layer();

var lion = new Konva.Image({
image: images.lion,
x: 80,
y: 30,
draggable: true


var sources = {
lion: '/assets/lion.png'

loadImages(sources, buildStage);