30 lines
1.2 KiB
TypeScript
30 lines
1.2 KiB
TypeScript
import { css, render_and_copy, svg_url } from "./common.tsx";
|
|
|
|
const svg = `
|
|
<svg id="filterSource" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg">
|
|
<filter id="displacement" filterUnits="userSpaceOnUse">
|
|
<!-- this is just a base64 encoded PNG with a simple linear gradient -->
|
|
<!-- this may not be exactly what you want, but you can adjust the R and B channels to displace the element however you like. -->
|
|
<feImage href="" result="dispMap" />
|
|
<feDisplacementMap
|
|
in="SourceGraphic"
|
|
in2="dispMap"
|
|
scale="10"
|
|
xChannelSelector="B"
|
|
yChannelSelector="R" />
|
|
</filter>
|
|
</svg>
|
|
`.trim();
|
|
|
|
render_and_copy(
|
|
<div
|
|
style={{
|
|
display: css.inline_block,
|
|
filter: css.url(svg_url(svg) + "#displacement"),
|
|
height: css.rem(10),
|
|
}}
|
|
>
|
|
yo what's up i am a chuckya
|
|
</div>
|
|
);
|