diff --git a/readme.md b/readme.md index 527abcb..3673fa3 100644 --- a/readme.md +++ b/readme.md @@ -115,10 +115,10 @@ The cursor won't display if the user's system accessibility settings have [prefe ### trailingCursor -You can change the number of trail steps in `trailingCursor` with the `particles` option (a number) +You can change the number of trail steps in `trailingCursor` with the `particles` option (a number), the rate of the trail with the `rate` option (a number between 0 and 1, default is `0.4`), and the trailing cursor image with the `baseImageSrc` option (a URL or base64 string) ```js -new cursoreffects.trailingCursor({ particles: 15 }); +new cursoreffects.trailingCursor({particles: 15, rate: 0.8, baseImageSrc: "..."}); ``` You can change the color of the following dot in `followingDotCursor` with the `color` option (hex) diff --git a/src/trailingCursor.js b/src/trailingCursor.js index cb24b7a..be7024b 100644 --- a/src/trailingCursor.js +++ b/src/trailingCursor.js @@ -12,11 +12,12 @@ export function trailingCursor(options) { let canvas, context, animationFrame; const totalParticles = options?.particles || 15; + const rate = options?.rate || 0.4; + const baseImageSrc = options?.baseImageSrc || ""; let cursorsInitted = false; let baseImage = new Image(); - baseImage.src = - ""; + baseImage.src = baseImageSrc; const prefersReducedMotion = window.matchMedia( "(prefers-reduced-motion: reduce)" @@ -115,8 +116,8 @@ export function trailingCursor(options) { particle.position.x = x; particle.position.y = y; particle.move(context); - x += (nextParticle.position.x - particle.position.x) * 0.4; - y += (nextParticle.position.y - particle.position.y) * 0.4; + x += (nextParticle.position.x - particle.position.x) * rate; + y += (nextParticle.position.y - particle.position.y) * rate; }); }