要在 Konva.Node
上应用滤镜,我们首先必须使用 cache()
函数进行缓存。然后使用 filters()
函数应用滤镜。
要使用 Konva 改变图像的对比度,我们可以使用 Konva.Filters.Contrast
。
说明:滑动控制条以更改对比度值。
有关所有可用滤镜,请访问 滤镜文档。
Konva 对比度图像演示view raw<!DOCTYPE html> <html> <head> <script src="https://unpkg.com/konva@9.3.18/konva.min.js"></script> <meta charset="utf-8" /> <title>Konva Contrast Image Demo</title> <style> body { margin: 0; padding: 0; overflow: hidden; background-color: #f0f0f0; }
#controls { position: absolute; top: 20px; left: 20px; } </style> </head>
<body> <div id="container"></div> <div id="controls"> contrast: <input id="contrast" type="range" min="-100" max="100" step="1" value="0" /> </div> <script> Konva.Image.fromURL('../../../assets/lion.png', function (lion) { var stage = new Konva.Stage({ container: 'container', width: window.innerWidth, height: window.innerHeight, });
var layer = new Konva.Layer();
lion.position({ x: 50, y: 50, }); lion.cache(); lion.filters([Konva.Filters.Contrast]); layer.add(lion); stage.add(layer);
var sliders = ['contrast']; sliders.forEach(function (attr) { var slider = document.getElementById(attr); function update() { lion[attr](parseFloat(slider.value)); } slider.oninput = update; update(); }); }); </script> </body> </html>
|