HTML5 Canvas 亮度图像滤镜教程
注 意:此滤镜在 Konva 10.0.0 中引入,用以替代 Brighten
滤镜。为了向后兼容,Brighten
滤镜仍可用,但已被弃用,将在未来版本中移除。
新滤镜渲染效果更接近 CSS filter: brightness(0.5);
要对 Konva.Image
应用滤镜,必须先使用 cache()
函数缓存它,然后使用 filters()
函数应用滤镜。
要使用 Konva 调节图像明暗度,可以使用 Konva.Filters.Brightness
滤镜,并通过 brightness
属性设置亮度值。
brightness
属性可以设置从 0 到 2 的任意数字,具体含义:
- 0 会产生完全黑色的图像
- 1 是原始图像(无变化)
- 大于 1 的值会使图像变亮
- 2 会产生非常明亮的图像
说明:拖动滑块调整亮度
所有可用滤镜可查看滤镜文档。
- Vanilla
- React
- Vue
import Konva from 'konva'; const width = window.innerWidth; const height = window.innerHeight; const stage = new Konva.Stage({ container: 'container', width: width, height: height, }); const layer = new Konva.Layer(); stage.add(layer); const imageObj = new Image(); imageObj.onload = () => { const image = new Konva.Image({ x: 50, y: 50, image: imageObj, draggable: true, }); layer.add(image); image.cache(); image.filters([Konva.Filters.Brightness]); image.brightness(1.5); const slider = document.createElement('input'); slider.type = 'range'; slider.min = '0'; slider.max = '2'; slider.step = '0.1'; slider.value = image.brightness(); slider.style.position = 'absolute'; slider.style.top = '20px'; slider.style.left = '20px'; slider.addEventListener('input', (e) => { const value = parseFloat(e.target.value); image.brightness(value); }); document.body.appendChild(slider); }; imageObj.src = 'https://konvajs.org/assets/darth-vader.jpg'; imageObj.crossOrigin = 'anonymous';
import { Stage, Layer, Image } from 'react-konva'; import { useState, useEffect, useRef } from 'react'; import useImage from 'use-image'; const App = () => { const [brightness, setBrightness] = useState(1.5); const [image] = useImage('https://konvajs.org/assets/darth-vader.jpg', 'anonymous'); const imageRef = useRef(null); useEffect(() => { if (image && imageRef.current) { imageRef.current.cache(); } }, [image]); return ( <> <Stage width={window.innerWidth} height={window.innerHeight}> <Layer> <Image ref={imageRef} x={50} y={50} image={image} draggable filters={[Konva.Filters.Brightness]} brightness={brightness} /> </Layer> </Stage> <input type="range" min="0" max="2" step="0.1" value={brightness} onChange={(e) => setBrightness(parseFloat(e.target.value))} style={{ position: 'absolute', top: '20px', left: '20px' }} /> </> ); }; export default App;
<template> <div> <v-stage :config="stageSize"> <v-layer> <v-image ref="imageNode" :config="{ x: 50, y: 50, image: image, draggable: true, filters: [Konva.Filters.Brightness], brightness: brightness, }" /> </v-layer> </v-stage> <input type="range" min="0" max="2" step="0.1" :value="brightness" @input="handleSlider" style="position: absolute; top: 20px; left: 20px" /> </div> </template> <script setup> import { ref, watch, nextTick } from 'vue'; import { useImage } from 'vue-konva'; import Konva from 'konva'; const stageSize = { width: window.innerWidth, height: window.innerHeight, }; const brightness = ref(1.5); const imageNode = ref(null); const [image] = useImage('https://konvajs.org/assets/darth-vader.jpg', 'anonymous'); watch(image, async (newImage) => { if (newImage) { await nextTick(); imageNode.value.getNode().cache(); } }); const handleSlider = (e) => { brightness.value = parseFloat(e.target.value); }; </script>