- 桌面新建文件夹:cromePointerEffect-plugin
- 新建:manifest.json
- 粘贴以下代码:
{
"name": "custom-cursor",
"version": "2.1",
"description": "cool pointer.",
"permissions": [
"storage"
],
"icons": {
},
"content_scripts": [
{
"matches": [
"*://*/*"
],
"js": [
"cursorSpecialEffects.js"
],
"css": ["custom-cursor.css"]
}
],
"manifest_version": 3
}
html, body, body select, body .custom-cursor-default-hover { cursor: url() 0 2, auto !important; }
body button, body [type='button'], body input[type='reset'], body input[type='submit'], body [role="button"], ::-webkit-search-cancel-button, ::-webkit-search-decoration, ::-webkit-scrollbar-button, ::-webkit-file-upload-button, [role^=button], .cc_pointer, [type="search"]::-webkit-search-cancel-button, a, select, [type="search"]::-webkit-search-decoration, .paper-button, .ytp-progress-bar-container, input[type=submit], :link, :visited, a > *, img, .ogdlpmhglpejoiomcodnpjnfgcpmgale_pointer, ::-webkit-file-upload-button, .ytp-volume-panel, #myogdlpmhglpejoiomcodnpjnfgcpmgale .icon, body .custom-cursor-on-hover { cursor: url() 1 2, pointer !important; }
- 新建:custom-cursor.css
- 粘贴以下代码:
```js
- 新建:cursorSpecialEffects.js
- 粘贴以下代码:
```js
class Circle {
constructor({ origin, speed, color, angle, context }) {
this.origin = origin
this.position = { ...this.origin }
this.color = color
this.speed = speed
this.angle = angle
this.context = context
this.renderCount = 0
}
draw() {
this.context.fillStyle = this.color
this.context.beginPath()
this.context.arc(this.position.x, this.position.y, 2, 0, Math.PI * 2)
this.context.fill()
}
move() {
this.position.x = (Math.sin(this.angle) * this.speed) + this.position.x
this.position.y = (Math.cos(this.angle) * this.speed) + this.position.y + (this.renderCount * 0.3)
this.renderCount++
}
}
class Boom {
constructor({ origin, context, circleCount = 10, area }) {
this.origin = origin
this.context = context
this.circleCount = circleCount
this.area = area
this.stop = false
this.circles = []
}
randomArray(range) {
const length = range.length
const randomIndex = Math.floor(length * Math.random())
return range[randomIndex]
}
randomColor() {
const range = ['1','2', '3', '4', '5', '6', '7','8', '9', 'A', 'B', 'C', 'D', 'E', 'F']
return '#' + this.randomArray(range) + this.randomArray(range) + this.randomArray(range) + this.randomArray(range) + this.randomArray(range) + this.randomArray(range)
}
randomRange(start, end) {
return (end - start) * Math.random() + start
}
init() {
for (let i = 0; i < this.circleCount; i++) {
const circle = new Circle({
context: this.context,
origin: this.origin,
color: this.randomColor(),
angle: this.randomRange(Math.PI - 1, Math.PI + 1),
speed: this.randomRange(1, 6)
})
this.circles.push(circle)
}
}
move() {
this.circles.forEach((circle, index) => {
if (circle.position.x > this.area.width || circle.position.y > this.area.height) {
return this.circles.splice(index, 1)
}
circle.move()
})
if (this.circles.length == 0) {
this.stop = true
}
}
draw() {
this.circles.forEach(circle => circle.draw())
}
}
class CursorSpecialEffects {
constructor() {
this.computerCanvas = document.createElement('canvas')
this.renderCanvas = document.createElement('canvas')
this.computerContext = this.computerCanvas.getContext('2d')
this.renderContext = this.renderCanvas.getContext('2d')
this.globalWidth = window.innerWidth
this.globalHeight = window.innerHeight
this.booms = []
this.running = false
}
handleMouseDown(e) {
const boom = new Boom({
origin: { x: e.clientX, y: e.clientY },
context: this.computerContext,
area: {
width: this.globalWidth,
height: this.globalHeight
}
})
boom.init()
this.booms.push(boom)
this.running || this.run()
}
handlePageHide() {
this.booms = []
this.running = false
}
init() {
const style = this.renderCanvas.style
style.position = 'fixed'
style.top = style.left = 0
style.zIndex = '999999999999999999999999999999999999999999'
style.pointerEvents = 'none'
style.width = this.renderCanvas.width = this.computerCanvas.width = this.globalWidth
style.height = this.renderCanvas.height = this.computerCanvas.height = this.globalHeight
document.body.append(this.renderCanvas)
window.addEventListener('mousedown', this.handleMouseDown.bind(this))
window.addEventListener('pagehide', this.handlePageHide.bind(this))
}
run() {
this.running = true
if (this.booms.length == 0) {
return this.running = false
}
requestAnimationFrame(this.run.bind(this))
this.computerContext.clearRect(0, 0, this.globalWidth, this.globalHeight)
this.renderContext.clearRect(0, 0, this.globalWidth, this.globalHeight)
this.booms.forEach((boom, index) => {
if (boom.stop) {
return this.booms.splice(index, 1)
}
boom.move()
boom.draw()
})
this.renderContext.drawImage(this.computerCanvas, 0, 0, this.globalWidth, this.globalHeight)
}
}
const cursorSpecialEffects = new CursorSpecialEffects()
cursorSpecialEffects.init()
// chrome.runtime.onInstalled.addListener(details => {
// if (details.reason === 'install') {
// // install
// alert("The pointer is cool");
// }
// if (details.reason === 'update') {
// alert("The cool pointer has updated");
// }
// })
function fairyDustCursor(){
var possibleColors = ["#D61C59", "#E7D84B", "#1B8798"];
var width = window.innerWidth;
var height = window.innerHeight;
var cursor = { x: width / 2, y: width / 2 };
var particles = [];
var particleBox = null;
function init() {
particleBox = document.createElement("div");
particleBox.style.position = "fixed";
particleBox.style.top = "0";
particleBox.style.left = "0";
particleBox.style.width = "100%";
particleBox.style.height = "100%";
particleBox.style.pointerEvents = "none";
particleBox.classList.add("fairy-dust-cursor");
document.body.appendChild(particleBox);
bindEvents();
loop()
}
function bindEvents() {
document.addEventListener("mousemove", onMouseMove);
window.addEventListener("resize", onWindowResize)
}
function onWindowResize(e) {
width = window.innerWidth;
height = window.innerHeight
}
function onMouseMove(e) {
cursor.x = e.clientX; cursor.y = e.clientY;
addParticle(cursor.x, cursor.y, possibleColors[Math.floor(Math.random() * possibleColors.length)])
}
function addParticle(x, y, color) {
var particle = new Particle();
particle.init(x, y, color);
particles.push(particle)
}
function updateParticles() {
for (var i = 0; i < particles.length; i++) {
particles[i].update()
}
for (var i = particles.length - 1; i >= 0; i--) {
if (particles[i].lifeSpan < 0) {
particles[i].die(); particles.splice(i, 1)
}
}
}
function loop() {
requestAnimationFrame(loop); updateParticles()
}
function Particle() {
this.character = "*";
this.lifeSpan = 120;
this.initialStyles = {
"position": "fixed",
"display": "inline-block",
"top": "0px",
"left": "0px",
"pointerEvents": "none",
"touch-action": "none",
"z-index": "10000000",
"fontSize": "25px",
"will-change": "transform"
};
this.init = function (x, y, color) {
this.velocity = {
x: (Math.random() < 0.5 ? -1 : 3) * (Math.random() / 2), y: 1
};
this.position = {
x: x + 10,
y: y + 10
};
this.initialStyles.color = color;
this.element = document.createElement("span");
this.element.innerHTML = this.character;
applyProperties(this.element, this.initialStyles);
this.update();
particleBox.appendChild(this.element)
};
this.update = function () {
this.position.x += this.velocity.x;
this.position.y += this.velocity.y;
this.lifeSpan-=3;
this.element.style.transform = "translate3d(" + this.position.x + "px," + this.position.y + "px, 0) scale(" + (this.lifeSpan / 120) + ")"
};
this.die = function () {
particleBox.removeChild(this.element)
}
}
function applyProperties(target, properties) {
for (var key in properties) {
target.style[key] = properties[key]
}
}
if (!("ontouchstart" in window || navigator.msMaxTouchPoints)) {
init()
}
}
// fairyDustCursor()
- 谷歌浏览器地址栏贴入:
chrome://extensions/
回车 - 右侧开启开发者模式 点击 加载已解压的扩展程序 选择 脚本文件夹 cromePointerEffect-plugin 确定即可
此时进入任何一个标签页面点击 会有惊喜哦!
至此:一个简单的浏览器用户扩展程序制作完成