Bloom, Depth of Field, এবং Motion Blur Effects

Post-processing এবং Visual Effects - থ্রি.জেএস (Three.js) - Web Development

260

Three.js এবং গ্রাফিক্স এফেক্টস

Three.js হল একটি JavaScript লাইব্রেরি যা ওয়েব ব্রাউজারে 3D গ্রাফিক্স তৈরি এবং পরিচালনা করতে ব্যবহৃত হয়। এটি WebGL এর উপর ভিত্তি করে কাজ করে এবং ডেভেলপারদের সহজে 3D মডেল, সিকোয়েন্স, লাইটিং, শ্যাডো, এবং অন্যান্য 3D গ্রাফিক্স উপাদান তৈরি করতে সহায়তা করে। Three.js এর মাধ্যমে আপনি উন্নত গ্রাফিক্স ইফেক্টস, যেমন Bloom, Depth of Field, এবং Motion Blur প্রয়োগ করতে পারেন, যা 3D দৃশ্যের অনুভূতি এবং বাস্তবতা বৃদ্ধি করে।

এই গাইডে, আমরা Bloom, Depth of Field, এবং Motion Blur এর মত জনপ্রিয় ইফেক্টস ব্যবহারের কৌশল এবং তাদের Three.js-এ প্রয়োগের উপায় আলোচনা করব।


১. Bloom Effect

Bloom হল একটি 3D দৃশ্যের এক ধরনের ইফেক্ট যেখানে উজ্জ্বল অংশগুলি আরো বেশি উজ্জ্বল এবং হার্ড সীমানার বাইরে ছড়িয়ে পড়ে। এটি সাধারণত লাইটিং এফেক্ট হিসেবে ব্যবহৃত হয় এবং দৃশ্যে আরো বাস্তবতাসম্পন্ন অনুভূতি দেয়। Bloom effect-টি একটি ফ্লেয়ার অথবা মৃণাল রেখার মতো দেখতে হয় যা উজ্জ্বল এলাকা থেকে ছড়িয়ে পড়ে।

Three.js এ Bloom Effect প্রয়োগ করা

Three.js এ Bloom ইফেক্ট তৈরির জন্য UnrealBloomPass ব্যবহার করা হয়, যা একটি post-processing ইফেক্ট।

প্রয়োগের উদাহরণ:

import * as THREE from 'three';
import { WebGLRenderer, Scene, PerspectiveCamera, DirectionalLight } from 'three';
import { UnrealBloomPass } from 'three/examples/jsm/postprocessing/UnrealBloomPass';
import { EffectComposer } from 'three/examples/jsm/postprocessing/EffectComposer';
import { RenderPass } from 'three/examples/jsm/postprocessing/RenderPass';

const scene = new Scene();
const camera = new PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
const renderer = new WebGLRenderer();
document.body.appendChild(renderer.domElement);

const light = new DirectionalLight(0xffffff, 1);
scene.add(light);

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

camera.position.z = 5;

// Post-processing setup
const composer = new EffectComposer(renderer);
composer.addPass(new RenderPass(scene, camera));

const bloomPass = new UnrealBloomPass(
  new THREE.Vector2(window.innerWidth, window.innerHeight), 
  1.5, // strength of the bloom
  0.4, // radius
  0.85  // threshold
);
composer.addPass(bloomPass);

// Animation loop
function animate() {
  requestAnimationFrame(animate);
  cube.rotation.x += 0.01;
  cube.rotation.y += 0.01;

  composer.render();
}

animate();

এখানে, UnrealBloomPass ব্যবহৃত হয়েছে EffectComposer এর সাথে, যা 3D দৃশ্যের উজ্জ্বল অংশগুলিকে বৃদ্ধি করে এবং bloom ইফেক্ট প্রযোজ্য করেছে।


২. Depth of Field (DoF) Effect

Depth of Field (DoF) একটি ক্যামেরা ইফেক্ট, যা দৃশ্যের নির্দিষ্ট অংশকে ফোকাসে রেখে বাকি অংশটি ব্লার্ড (blurred) করে। এটি সাধারণত সেলফি বা প্রকৃতির ছবিতে দেখা যায় এবং এটি বাস্তবতাসম্পন্ন অনুভূতি তৈরি করে।

Three.js এ Depth of Field ইফেক্টের জন্য BokehPass ব্যবহৃত হয়, যা post-processing ইফেক্ট হিসেবে কাজ করে।

Three.js এ Depth of Field Effect প্রয়োগ করা

import * as THREE from 'three';
import { WebGLRenderer, Scene, PerspectiveCamera } from 'three';
import { EffectComposer } from 'three/examples/jsm/postprocessing/EffectComposer';
import { RenderPass } from 'three/examples/jsm/postprocessing/RenderPass';
import { BokehPass } from 'three/examples/jsm/postprocessing/BokehPass';

const scene = new Scene();
const camera = new PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
const renderer = new WebGLRenderer();
document.body.appendChild(renderer.domElement);

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

camera.position.z = 5;

// Post-processing setup
const composer = new EffectComposer(renderer);
composer.addPass(new RenderPass(scene, camera));

const bokehPass = new BokehPass(scene, camera, {
  focus: 1.0,
  aperture: 0.025,
  maxblur: 0.01,
  width: window.innerWidth,
  height: window.innerHeight
});
composer.addPass(bokehPass);

// Animation loop
function animate() {
  requestAnimationFrame(animate);
  cube.rotation.x += 0.01;
  cube.rotation.y += 0.01;

  composer.render();
}

animate();

এখানে, BokehPass ব্যবহার করা হয়েছে, যার মাধ্যমে একটি Depth of Field ইফেক্ট তৈরি করা হয়েছে। এটি ক্যামেরার ফোকাস পরিবর্তন করে এবং অন্যান্য অংশ ব্লার্ড করে দেয়।


৩. Motion Blur Effect

Motion Blur হল একটি গ্রাফিক্স এফেক্ট যা দ্রুত চলমান অবজেক্টের পিছনে ঝাপসা দাগ তৈরি করে, যা বাস্তব বিশ্বের ক্যামেরা ফটোগ্রাফির মতো। এই ইফেক্টটি 3D অ্যানিমেশন বা গেমে অধিক বাস্তব অনুভূতি তৈরি করতে ব্যবহৃত হয়।

Three.js এ Motion Blur তৈরি করতে ShaderPass এবং FXAAShader বা ConvolutionShader ব্যবহার করা হয়।

Three.js এ Motion Blur Effect প্রয়োগ করা

import * as THREE from 'three';
import { WebGLRenderer, Scene, PerspectiveCamera } from 'three';
import { EffectComposer } from 'three/examples/jsm/postprocessing/EffectComposer';
import { RenderPass } from 'three/examples/jsm/postprocessing/RenderPass';
import { ShaderPass } from 'three/examples/jsm/postprocessing/ShaderPass';
import { FXAAShader } from 'three/examples/jsm/shaders/FXAAShader';

const scene = new Scene();
const camera = new PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
const renderer = new WebGLRenderer();
document.body.appendChild(renderer.domElement);

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

camera.position.z = 5;

// Post-processing setup
const composer = new EffectComposer(renderer);
composer.addPass(new RenderPass(scene, camera));

// Apply Motion Blur using ShaderPass
const fxaaPass = new ShaderPass(FXAAShader);
composer.addPass(fxaaPass);

// Animation loop
function animate() {
  requestAnimationFrame(animate);
  cube.rotation.x += 0.01;
  cube.rotation.y += 0.01;

  composer.render();
}

animate();

এখানে, ShaderPass ব্যবহার করে FXAAShader এর মাধ্যমে Motion Blur প্রয়োগ করা হয়েছে। এটি গতিশীল অবজেক্টে ব্লার ইফেক্ট তৈরি করবে।


সারাংশ

Three.js-এ Bloom, Depth of Field, এবং Motion Blur ইফেক্টগুলি 3D দৃশ্যের বাস্তবতা এবং অভিজ্ঞতা উন্নত করতে ব্যবহৃত হয়। এই এফেক্টসগুলি ব্যবহার করে আপনি আপনার ওয়েব গ্রাফিক্সকে আরও আকর্ষণীয় এবং ইন্টারেক্টিভ করে তুলতে পারেন। Bloom এলাকা গুলোকে উজ্জ্বল করে, Depth of Field ফোকাস এবং ব্লার নিয়ে কাজ করে, এবং Motion Blur গতিশীল অবজেক্টের পিছনে ঝাপসা তৈরি করে, যা বাস্তব পৃথিবীর অভিজ্ঞতা অনুকরণ করে। Three.js ব্যবহার করে আপনি এই এফেক্টগুলি খুব সহজেই প্রয়োগ করতে পারেন এবং আপনার 3D প্রজেক্টে শক্তিশালী গ্রাফিক্স ফিচার যোগ করতে পারেন।

Content added By
Promotion

Are you sure to start over?

Loading...