Main Process থেকে Renderer Process এ মেসেজ পাঠানো

Main এবং Renderer Process এর মধ্যে যোগাযোগ - ইলেকট্রন  (Electron) - Web Development

291

Electron এ Main Process এবং Renderer Process এর মধ্যে মেসেজ পাঠানোর জন্য IPC (Inter-Process Communication) ব্যবহৃত হয়। এটি ipcMain এবং ipcRenderer মডিউল ব্যবহার করে করা হয়।

এখানে Main Process থেকে Renderer Process এ মেসেজ পাঠানোর প্রক্রিয়া বিস্তারিতভাবে দেখানো হচ্ছে।


১. Main Process থেকে Renderer Process এ মেসেজ পাঠানো

Main Process থেকে Renderer Process এ মেসেজ পাঠানোর জন্য ipcMain মডিউল ব্যবহার করা হয়। Main Process কোনো ইভেন্টে বা যেকোনো কাজের পর Renderer Process এ ডেটা পাঠাতে পারে।

উদাহরণ: Main Process (main.js)

const { app, BrowserWindow, ipcMain } = require('electron');

let mainWindow;

app.on('ready', () => {
  mainWindow = new BrowserWindow({
    width: 800,
    height: 600,
    webPreferences: {
      nodeIntegration: true,
    },
  });

  mainWindow.loadFile('index.html');

  // Main Process থেকে Renderer Process এ মেসেজ পাঠানো
  mainWindow.webContents.on('did-finish-load', () => {
    mainWindow.webContents.send('message-from-main', 'Hello from Main Process!');
  });

  // Renderer থেকে আসা মেসেজ গ্রহণ (এটি শুধু উদাহরণের জন্য)
  ipcMain.on('message-from-renderer', (event, arg) => {
    console.log('Renderer থেকে বার্তা:', arg);
  });
});

app.on('window-all-closed', () => {
  if (process.platform !== 'darwin') {
    app.quit();
  }
});

২. Renderer Process (index.html)

Renderer Process থেকে মেসেজ গ্রহণ এবং Main Process এ মেসেজ পাঠানোর জন্য ipcRenderer মডিউল ব্যবহৃত হয়।

উদাহরণ: Renderer Process (index.html)

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Renderer Process</title>
</head>
<body>
  <h1>Renderer Process থেকে Main Process এ মেসেজ পাঠানো</h1>
  <button id="sendMessageBtn">Main Process থেকে মেসেজ গ্রহণ</button>

  <script>
    const { ipcRenderer } = require('electron');

    // Main Process থেকে মেসেজ গ্রহণ
    ipcRenderer.on('message-from-main', (event, message) => {
      console.log('Main Process থেকে বার্তা:', message);
      alert(message);  // Main Process থেকে পাওয়া বার্তা UI তে দেখানো
    });

    document.getElementById('sendMessageBtn').addEventListener('click', () => {
      // Main Process এ মেসেজ পাঠানো
      ipcRenderer.send('message-from-renderer', 'Hello from Renderer!');
    });
  </script>
</body>
</html>

৩. ব্যবহার

  1. Main Process থেকে মেসেজ পাঠানো:
    • mainWindow.webContents.send('message-from-main', 'Hello from Main Process!'); — এটি Main Process থেকে Renderer Process এ মেসেজ পাঠানোর জন্য ব্যবহৃত হয়।
    • মেসেজটি message-from-main নামে একটি ইভেন্টে পাঠানো হয়।
  2. Renderer Process থেকে মেসেজ গ্রহণ:
    • ipcRenderer.on('message-from-main', (event, message) => { ... }); — এটি Renderer ProcessMain Process থেকে আসা মেসেজ গ্রহণ করতে ব্যবহৃত হয়।
  3. Renderer Process থেকে মেসেজ পাঠানো:
    • ipcRenderer.send('message-from-renderer', 'Hello from Renderer!'); — এটি Renderer Process থেকে Main Process এ মেসেজ পাঠানোর জন্য ব্যবহৃত হয়।
    • মেসেজটি message-from-renderer নামে একটি ইভেন্টে পাঠানো হয়।

সারাংশ

  • Main Process থেকে Renderer Process এ মেসেজ পাঠাতে webContents.send() ব্যবহৃত হয়।
  • Renderer Process এ মেসেজ গ্রহণ করতে ipcRenderer.on() ব্যবহার করা হয় এবং মেসেজ পাঠাতে ipcRenderer.send() ব্যবহার করা হয়।
  • এই প্রক্রিয়ার মাধ্যমে, Main Process এবং Renderer Process এর মধ্যে সহজে তথ্য আদান-প্রদান করা সম্ভব হয়।
Content added By
Promotion

Are you sure to start over?

Loading...