Skip to content

Commit

Permalink
Merge pull request #45 from sylturner/syl/trail-rate
Browse files Browse the repository at this point in the history
Trailing Cursor: Options to change the rate and image
  • Loading branch information
tholman authored Jan 29, 2023
2 parents 1560849 + 251a3fe commit 4c1881f
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 6 deletions.
4 changes: 2 additions & 2 deletions readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -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)
Expand Down
9 changes: 5 additions & 4 deletions src/trailingCursor.js
Original file line number Diff line number Diff line change
Expand Up @@ -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)"
Expand Down Expand Up @@ -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;
});
}

Expand Down

0 comments on commit 4c1881f

Please sign in to comment.