Categories

Sunday, December 22, 2024
#919814419350 therichposts@gmail.com
ReactjsReactjs TutorialThreejs

Implementing Three.js within a React.js application

Implementing Three.js within a React.js application

Implementing Three.js within a React.js application involves integrating the 3D rendering capabilities of Three.js with the component structure of React. Here’s a step-by-step guide to help you set up a basic scene with Three.js in a React project:

Implementing Three.js within a React.js application
Implementing Three.js within a React.js application

For reactjs new comers, please check the below link:

1. Set Up Your React Project

If you haven’t already created a React application, you can start one using Create React App:

npx create-react-app my-threejs-project
cd my-threejs-project

2. Install Three.js

You need to add Three.js to your project:

npm install three

3. Create a Three.js Component

You can create a Three.js component that handles the setup of the scene, camera, and renderer. Here’s an example of how you might set it up:

import React, { useRef, useEffect } from 'react';
import * as THREE from 'three';

const Scene = () => {
    const mountRef = useRef(null);

    useEffect(() => {
        // Scene
        const scene = new THREE.Scene();
        scene.background = new THREE.Color(0xabcdef);

        // Camera
        const camera = new THREE.PerspectiveCamera(
            75, 
            window.innerWidth / window.innerHeight, 
            0.1, 
            1000
        );
        camera.position.z = 5;

        // Renderer
        const renderer = new THREE.WebGLRenderer();
        renderer.setSize(window.innerWidth, window.innerHeight);
        mountRef.current.appendChild(renderer.domElement);

        // Adding a cube
        const geometry = new THREE.BoxGeometry();
        const material = new THREE.MeshBasicMaterial({ color: 0x00ff00 });
        const cube = new THREE.Mesh(geometry, material);
        scene.add(cube);

        // Animation loop
        const animate = () => {
            requestAnimationFrame(animate);
            cube.rotation.x += 0.01;
            cube.rotation.y += 0.01;
            renderer.render(scene, camera);
        };

        animate();

        // Handle resizing
        const handleResize = () => {
            camera.aspect = window.innerWidth / window.innerHeight;
            camera.updateProjectionMatrix();
            renderer.setSize(window.innerWidth, window.innerHeight);
        };

        window.addEventListener('resize', handleResize);

        return () => {
            window.removeEventListener('resize', handleResize);
            mountRef.current.removeChild(renderer.domElement);
        };
    }, []);

    return <div ref={mountRef} />;
};

export default Scene;

4. Integrate the Three.js Component in Your App

Now, integrate this component into your React application by including it in your main App component:

import React from 'react';
import Scene from './Scene';

function App() {
  return (
    <div className="App">
      <Scene />
    </div>
  );
}

export default App;

5. Run Your Application

Start your application to see the Three.js scene:

npm start

This setup provides a basic Three.js scene with a rotating cube in a React application. You can extend this by adding more complex objects, lights, and shadows to create richer visual effects.

Jaasa

Thanks

therichpost
the authortherichpost
Hello to all. Welcome to therichpost.com. Myself Ajay Malhotra and I am freelance full stack developer. I love coding. I know WordPress, Core php, Angularjs, Angular 19, MedusaJs, Next.js, Bootstrap 5, Nodejs, Laravel, Codeigniter, Shopify, Squarespace, jQuery, Google Map Api, Vuejs, Reactjs, Big commerce etc.

Leave a Reply

This site uses Akismet to reduce spam. Learn how your comment data is processed.