Frontend Forever App
We have a mobile app for you to download and use. And you can unlock many features in the app.
Get it nowIntall Later
We have a mobile app for you to download and use. And you can unlock many features in the app.
Get it nowHello reader, I am sebastian-piskaty. Nice to meet you again in this free code sharing website. In this post I am going to explain about Text Particles. If you are new to this website, we recommend you to subscribe to our youtube channel and watch the videos. Ok lets dive into the code.
These are the output images of the code. You can click on the image to enlarge it. also you can click the try it button to see the output.
If you are a visual learner and want to learn how to use this code, you can watch the video below.
and also this video contains the clear step by step explanation and the output of the code.
This is the source code of the code. You can copy and paste the code to your editor.
xxxxxxxxxx
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div>
<canvas></canvas>
</div>
</body>
</html>
xxxxxxxxxx
@charset "UTF-8";
@import url(https://fonts.googleapis.com/css?family=Nunito+Sans:300,400,600,700,800);
*,
:after,
:before {
box-sizing: border-box;
padding: 0;
margin: 0;
}
body {
display: grid;
place-items: center;
height: 100dvh;
background: #222;
}
canvas {
position: fixed;
inset: 0;
width: 100%;
height: 100%;
}
xxxxxxxxxx
const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height).data;
console.log("Event Fired")
const canvas = document.querySelector("canvas");
const ctx = canvas.getContext("2d");
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
const particles = [];
const particleCount = 1200;
const textArray = ["Design.", "Code.", "Coffee."];
let currentTextIndex = 0;
let nextTextTimeout;
let textCoordinates = [];
const mouse = {
x: -500,
y: -500,
radius: 50
};
class Particle {
constructor(x, y) {
this.x = x;
this.y = y;
this.size = 1;
this.baseX = x;
this.baseY = y;
this.density = Math.random() * 30 + 1;
this.color = "white";
this.history = [];
}
update() {
let dx = mouse.x - this.x;
let dy = mouse.y - this.y;
let distance = Math.sqrt(dx * dx + dy * dy);
if (distance < mouse.radius) {
let forceDirectionX = dx / distance;
let forceDirectionY = dy / distance;
let maxDistance = mouse.radius;
let force = (maxDistance - distance) / maxDistance;
let directionX = forceDirectionX * force * this.density;
let directionY = forceDirectionY * force * this.density;
And also you can click the try it button to see the output of the code in our web Code Playground.
You can also download the code to the zip format by clicking the download button. The download process is little bit complex, you need ti await for 10 seconds. after that you can download the code by clicking the generated download link.
Leave a Comment
You need to login first to comment.