Web Development Bar Chart: গাইড ও নোট

192

বার চার্ট (Bar Chart) হলো একটি জনপ্রিয় চার্ট টাইপ যা তুলনামূলক ডেটা প্রদর্শনের জন্য ব্যবহৃত হয়। এটি সাধারণত একাধিক ক্যাটেগরি বা গ্রুপের মধ্যে ডেটা তুলনা করতে ব্যবহৃত হয়। Chart.js এর মাধ্যমে বার চার্ট তৈরি করা খুবই সহজ এবং এটি ভিন্ন ভিন্ন গ্রুপের মান বা পরিমাণে তুলনা প্রদর্শন করতে সাহায্য করে।


Bar Chart এর ব্যবহার

বার চার্ট সাধারণত নিম্নলিখিত ক্ষেত্রে ব্যবহার করা হয়:

  • সেলস রিপোর্ট এবং আর্থিক বিশ্লেষণ।
  • জনসংখ্যার ডেটা বিশ্লেষণ।
  • মার্কেট শেয়ার এবং অন্যান্য তুলনামূলক ডেটা প্রদর্শন।
  • গ্রাহক বা কর্মচারীর পারফরম্যান্স বিশ্লেষণ।

Bar Chart এর বেসিক কনফিগারেশন

Chart.js এর মাধ্যমে একটি সাধারণ বার চার্ট তৈরি করতে কিছু কনফিগারেশন সেট করতে হয়। এই কনফিগারেশনের মধ্যে চার্টের ধরন, ডেটাসেট, এবং কাস্টমাইজেশন অপশন থাকবে।

কোড উদাহরণ:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Chart.js Bar Chart Example</title>
</head>
<body>
    <h1>Sales Data (Bar Chart)</h1>
    <!-- Chart.js Canvas -->
    <canvas id="myBarChart" width="400" height="200"></canvas>

    <!-- Chart.js Library -->
    <script src="https://cdn.jsdelivr.net/npm/chart.js"></script>

    <!-- Custom Script for Bar Chart -->
    <script>
        const ctx = document.getElementById('myBarChart').getContext('2d');
        
        const myBarChart = new Chart(ctx, {
            type: 'bar', // Chart type: Bar
            data: {
                labels: ['January', 'February', 'March', 'April', 'May'], // X-axis labels
                datasets: [{
                    label: 'Sales', // Dataset label
                    data: [30, 45, 60, 25, 50], // Y-axis data values
                    backgroundColor: [
                        'rgba(255, 99, 132, 0.2)',
                        'rgba(54, 162, 235, 0.2)',
                        'rgba(255, 206, 86, 0.2)',
                        'rgba(75, 192, 192, 0.2)',
                        'rgba(153, 102, 255, 0.2)'
                    ],
                    borderColor: [
                        'rgba(255, 99, 132, 1)',
                        'rgba(54, 162, 235, 1)',
                        'rgba(255, 206, 86, 1)',
                        'rgba(75, 192, 192, 1)',
                        'rgba(153, 102, 255, 1)'
                    ],
                    borderWidth: 1 // Bar border width
                }]
            },
            options: {
                responsive: true, // Responsive chart
                scales: {
                    y: {
                        beginAtZero: true // Y-axis starts from zero
                    }
                }
            }
        });
    </script>
</body>
</html>

Bar Chart কনফিগারেশন বিশ্লেষণ

  1. type: 'bar': এটি Chart.js এর টাইপ কনফিগারেশন, যেখানে আমরা 'bar' টাইপ ব্যবহার করেছি, যা বার চার্ট তৈরি করবে।
  2. data: ডেটা সেট এবং লেবেলসমূহ এখানে সংজ্ঞায়িত করা হয়:
    • labels: এক্স-অক্ষের লেবেল (এখানে মাসের নাম: January, February, March, ইত্যাদি)।
    • datasets: ডেটাসেটের জন্য ডেটা পয়েন্ট এবং স্টাইল সেট করা হয়:
      • label: ডেটাসেটের নাম (যেমন Sales)।
      • data: Y-অক্ষের জন্য ডেটার মান (যেমন সেলস ডেটা)।
      • backgroundColor: বারগুলোর ব্যাকগ্রাউন্ড কালার।
      • borderColor: বারগুলোর বর্ডার কালার।
      • borderWidth: বারগুলোর বর্ডারের প্রস্থ।
  3. options: চার্টের কাস্টমাইজেশন অপশন:
    • responsive: true: এটি নিশ্চিত করে যে চার্টটি রেসপন্সিভ হবে, অর্থাৎ বিভিন্ন স্ক্রীন সাইজের সাথে মানিয়ে চলবে।
    • scales: এটি চার্টের অক্ষের স্কেল কনফিগারেশন। Y-অক্ষের জন্য beginAtZero: true সেট করা হয়েছে যাতে Y-অক্ষ শূন্য থেকে শুরু হয়।

আরও কাস্টমাইজেশন

Chart.js এর বার চার্টের কাস্টমাইজেশন আরও বাড়ানো যেতে পারে যেমন:

  • বার গ্যাপ: বারগুলোর মধ্যে ফাঁকা জায়গা কাস্টমাইজ করা।
  • এনিমেশন: চার্টের লোডিং বা আপডেটিংয়ে এনিমেশন যোগ করা।
  • লেজেন্ড ও টুলটিপস: চার্টের লেজেন্ড এবং টুলটিপস কাস্টমাইজ করা।

উদাহরণ: বার গ্যাপ কাস্টমাইজেশন:

options: {
    scales: {
        x: {
            barPercentage: 0.5, // বারগুলোর সাইজ কমানো
        }
    }
}

সারাংশ

Chart.js এর মাধ্যমে বার চার্ট তৈরি করা খুবই সহজ এবং এর মাধ্যমে আপনি ডেটার তুলনামূলক বিশ্লেষণ করতে পারবেন। এটি খুবই কাস্টমাইজেবল, এবং আপনি আপনার প্রয়োজন অনুসারে বার চার্টের রঙ, আকার, অক্ষ এবং অন্যান্য বৈশিষ্ট্য পরিবর্তন করতে পারেন। এটি সেলস ডেটা, জনসংখ্যা পরিসংখ্যান, বা যে কোনো তুলনামূলক ডেটার জন্য আদর্শ।

Content added By

Horizontal এবং Vertical Bar Chart তৈরি

211

Chart.js একটি শক্তিশালী লাইব্রেরি যা বিভিন্ন ধরনের চার্ট তৈরি করতে সহায়ক। আজ আমরা দেখব কিভাবে Horizontal Bar Chart এবং Vertical Bar Chart তৈরি করা যায়। এই দুটি চার্ট বিভিন্ন ডেটা প্রদর্শনের জন্য উপকারী, এবং এগুলো bar টাইপের চার্টের মধ্যে পড়ে।


১. Vertical Bar Chart

Vertical Bar Chart হল সবচেয়ে সাধারণ ধরনের বার চার্ট যেখানে বারগুলো এক্স-অক্ষের সাথে মিলিয়ে দাঁড়িয়ে থাকে। এটি তুলনামূলক ডেটা প্রদর্শনের জন্য ব্যবহৃত হয়।

Vertical Bar Chart উদাহরণ

HTML:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Vertical Bar Chart</title>
    <script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
</head>
<body>
    <h1>Vertical Bar Chart Example</h1>
    <canvas id="verticalBarChart" width="400" height="200"></canvas>
    <script src="script.js"></script>
</body>
</html>

JavaScript (script.js):

const ctx = document.getElementById('verticalBarChart').getContext('2d');
const verticalBarChart = new Chart(ctx, {
    type: 'bar', // Bar chart type
    data: {
        labels: ['January', 'February', 'March', 'April', 'May'], // X-axis labels
        datasets: [{
            label: 'Sales', // Dataset label
            data: [10, 25, 15, 30, 40], // Data for Y-axis
            backgroundColor: 'rgba(75, 192, 192, 0.2)', // Bar color
            borderColor: 'rgba(75, 192, 192, 1)', // Bar border color
            borderWidth: 1
        }]
    },
    options: {
        responsive: true, // Make the chart responsive
        scales: {
            y: {
                beginAtZero: true // Start the Y-axis at zero
            }
        }
    }
});

বর্ণনা:

  • type: 'bar': এটি বারের চার্ট হিসেবে সেট করা হয়েছে।
  • labels: X-axis এর জন্য মাসের নাম দেওয়া হয়েছে।
  • data: Y-axis এর জন্য বিক্রয়ের ডেটা দেওয়া হয়েছে।
  • backgroundColor: বারগুলির রং নির্ধারণ করা হয়েছে।
  • borderColor: বারগুলির বর্ডারের রং নির্ধারণ করা হয়েছে।
  • borderWidth: বর্ডারের প্রস্থ নির্ধারণ করা হয়েছে।

২. Horizontal Bar Chart

Horizontal Bar Chart হল একটি চার্ট যেখানে বারগুলো অনুভূমিকভাবে (Horizontal) প্রদর্শিত হয়। এটি কিছু বিশেষ ক্ষেত্রে তুলনামূলক ডেটা প্রদর্শনের জন্য ব্যবহৃত হয়, বিশেষ করে যেখানে বিভাগগুলোর নাম অনেক বড় হয়।

Horizontal Bar Chart উদাহরণ

HTML:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Horizontal Bar Chart</title>
    <script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
</head>
<body>
    <h1>Horizontal Bar Chart Example</h1>
    <canvas id="horizontalBarChart" width="400" height="200"></canvas>
    <script src="script.js"></script>
</body>
</html>

JavaScript (script.js):

const ctx = document.getElementById('horizontalBarChart').getContext('2d');
const horizontalBarChart = new Chart(ctx, {
    type: 'bar', // Bar chart type
    data: {
        labels: ['Red', 'Blue', 'Yellow', 'Green', 'Purple'], // Y-axis labels
        datasets: [{
            label: 'Votes', // Dataset label
            data: [12, 19, 3, 5, 2], // Data for X-axis
            backgroundColor: 'rgba(255, 99, 132, 0.2)', // Bar color
            borderColor: 'rgba(255, 99, 132, 1)', // Bar border color
            borderWidth: 1
        }]
    },
    options: {
        responsive: true, // Make the chart responsive
        indexAxis: 'y', // Set axis to horizontal (y-axis will be the index axis)
        scales: {
            x: {
                beginAtZero: true // Start the X-axis at zero
            }
        }
    }
});

বর্ণনা:

  • type: 'bar': এটি বারের চার্ট হিসেবে সেট করা হয়েছে, কিন্তু এখানে আমরা এটি অনুভূমিকভাবে (horizontal) কনফিগার করেছি।
  • indexAxis: 'y': y নির্ধারণ করলে চার্টটি অনুভূমিকভাবে (horizontal) প্রদর্শিত হবে, অর্থাৎ X-axis এবং Y-axis এর অবস্থান পাল্টে যাবে।
  • labels: Y-axis এর জন্য ব্যাখ্যাগুলি দেওয়া হয়েছে।
  • data: X-axis এর জন্য ডেটা নির্ধারণ করা হয়েছে।

সারাংশ

  • Vertical Bar Chart: এটি সাধারণত ডেটার তুলনা করার জন্য ব্যবহৃত হয়, যেখানে বারগুলি উল্লম্বভাবে প্রদর্শিত হয়।
  • Horizontal Bar Chart: এই চার্টটি তুলনামূলক ডেটা প্রদর্শনের জন্য ব্যবহার করা হয়, তবে বারগুলি অনুভূমিকভাবে (horizontal) প্রদর্শিত হয়।

উপরে দেওয়া উদাহরণগুলো Chart.js এর মাধ্যমে Vertical এবং Horizontal Bar Chart তৈরি করার প্রাথমিক পদক্ষেপগুলো দেখিয়েছে, যা সহজেই আপনার প্রজেক্টে ব্যবহার করা যাবে।

Content added By

Bar Chart কাস্টমাইজেশন (Colors, Widths, Labels)

233

Chart.js এর মাধ্যমে বার চার্ট (Bar Chart) কাস্টমাইজ করা খুবই সহজ এবং নমনীয়। আপনি বিভিন্ন উপাদান যেমন রঙ, প্রস্থ, লেবেল, বর্ডার ইত্যাদি কাস্টমাইজ করতে পারেন। এখানে Bar Chart এর কাস্টমাইজেশন নিয়ে বিস্তারিত আলোচনা করা হলো, যাতে আপনি আপনার চার্টটিকে আরও দৃষ্টিনন্দন এবং ব্যবহারকারীর জন্য উপযোগী করে তুলতে পারেন।


1. Bar Chart রঙ কাস্টমাইজেশন (Colors)

Chart.js এ বার চার্টের রঙ কাস্টমাইজ করতে backgroundColor এবং borderColor প্রপার্টি ব্যবহার করা হয়।

  • backgroundColor: বারগুলোর ভিতরের রঙ।
  • borderColor: বারগুলোর বর্ডার রঙ।
  • borderWidth: বর্ডারের প্রস্থ।

উদাহরণ:

const ctx = document.getElementById('myChart').getContext('2d');
const myChart = new Chart(ctx, {
    type: 'bar',
    data: {
        labels: ['Red', 'Blue', 'Green', 'Yellow'],
        datasets: [{
            label: 'Votes',
            data: [12, 19, 3, 5],
            backgroundColor: [
                'rgba(255, 99, 132, 0.2)',  // Red bar color
                'rgba(54, 162, 235, 0.2)',  // Blue bar color
                'rgba(75, 192, 192, 0.2)',  // Green bar color
                'rgba(255, 159, 64, 0.2)'   // Yellow bar color
            ],
            borderColor: [
                'rgba(255, 99, 132, 1)',
                'rgba(54, 162, 235, 1)',
                'rgba(75, 192, 192, 1)',
                'rgba(255, 159, 64, 1)'
            ],
            borderWidth: 1
        }]
    },
    options: {
        responsive: true,
    }
});

এখানে, প্রতিটি বার (Red, Blue, Green, Yellow) এর রঙ এবং বর্ডার আলাদা করা হয়েছে।


2. Bar Width কাস্টমাইজেশন (Bar Width)

Chart.js এ বারগুলোর প্রস্থ কাস্টমাইজ করতে barThickness বা categoryPercentage ব্যবহার করা যায়।

  • barThickness: একটি নির্দিষ্ট প্রস্থ নির্ধারণ করে।
  • categoryPercentage: ক্যাটাগরি অনুযায়ী বারগুলোর প্রস্থ নিয়ন্ত্রণ করে, যাতে বেশ কয়েকটি বার একসাথে উপস্থাপিত হতে পারে।

উদাহরণ:

const ctx = document.getElementById('myChart').getContext('2d');
const myChart = new Chart(ctx, {
    type: 'bar',
    data: {
        labels: ['Red', 'Blue', 'Green', 'Yellow'],
        datasets: [{
            label: 'Votes',
            data: [12, 19, 3, 5],
            backgroundColor: 'rgba(255, 99, 132, 0.2)',
            borderColor: 'rgba(255, 99, 132, 1)',
            borderWidth: 1,
            barThickness: 40  // নির্দিষ্ট প্রস্থ
        }]
    },
    options: {
        responsive: true,
    }
});

এখানে, barThickness এর মাধ্যমে একটি নির্দিষ্ট প্রস্থ দেওয়া হয়েছে, যা বারগুলোর আকার নিয়ন্ত্রণ করবে।


3. Labels কাস্টমাইজেশন (Labels)

Chart.js এ বার চার্টের labels কাস্টমাইজ করার মাধ্যমে এক্স-অক্ষের লেবেল পরিবর্তন করা যায়। আপনি লেবেলগুলির ফন্ট, সাইজ, রঙ, এবং অবস্থান কাস্টমাইজ করতে পারেন।

উদাহরণ:

const ctx = document.getElementById('myChart').getContext('2d');
const myChart = new Chart(ctx, {
    type: 'bar',
    data: {
        labels: ['Red', 'Blue', 'Green', 'Yellow'],  // লেবেলগুলি
        datasets: [{
            label: 'Votes',
            data: [12, 19, 3, 5],
            backgroundColor: 'rgba(54, 162, 235, 0.2)',
            borderColor: 'rgba(54, 162, 235, 1)',
            borderWidth: 1
        }]
    },
    options: {
        responsive: true,
        scales: {
            x: {
                ticks: {
                    font: {
                        size: 16,  // লেবেলের ফন্ট সাইজ
                        weight: 'bold',  // ফন্টের ওজন
                        family: 'Arial'  // ফন্টের পরিবার
                    },
                    color: 'rgba(54, 162, 235, 1)'  // লেবেলের রঙ
                }
            },
            y: {
                beginAtZero: true
            }
        }
    }
});

এখানে, এক্স-অক্ষের লেবেলগুলির ফন্ট সাইজ, ফন্টের পরিবার এবং রঙ কাস্টমাইজ করা হয়েছে। আপনি এখানে ticks প্রপার্টি ব্যবহার করে আরও কাস্টমাইজেশন করতে পারেন।


4. Bar Chart এর অ্যানিমেশন কাস্টমাইজেশন

Chart.js এ অ্যানিমেশনও কাস্টমাইজ করা যায়। আপনি animation অপশন ব্যবহার করে বার চার্টের অ্যানিমেশন সন্নিবেশ করতে পারেন।

উদাহরণ:

const ctx = document.getElementById('myChart').getContext('2d');
const myChart = new Chart(ctx, {
    type: 'bar',
    data: {
        labels: ['Red', 'Blue', 'Green', 'Yellow'],
        datasets: [{
            label: 'Votes',
            data: [12, 19, 3, 5],
            backgroundColor: 'rgba(255, 99, 132, 0.2)',
            borderColor: 'rgba(255, 99, 132, 1)',
            borderWidth: 1
        }]
    },
    options: {
        responsive: true,
        animation: {
            duration: 1500,  // অ্যানিমেশন সময়কাল
            easing: 'easeOutBounce'  // অ্যানিমেশন ইফেক্ট
        }
    }
});

এখানে animation অপশন দিয়ে অ্যানিমেশন সময়কাল এবং ইফেক্ট কাস্টমাইজ করা হয়েছে।


5. Stacked Bar Chart কাস্টমাইজেশন

Stacked বার চার্ট ব্যবহার করে একাধিক ডেটাসেট একই গ্রাফে স্তরে স্তরে দেখানো যায়। এটি scales এবং stacked অপশন দিয়ে কাস্টমাইজ করা হয়।

উদাহরণ:

const ctx = document.getElementById('myChart').getContext('2d');
const myChart = new Chart(ctx, {
    type: 'bar',
    data: {
        labels: ['Red', 'Blue', 'Green', 'Yellow'],
        datasets: [{
            label: 'Votes A',
            data: [12, 19, 3, 5],
            backgroundColor: 'rgba(255, 99, 132, 0.2)'
        }, {
            label: 'Votes B',
            data: [6, 8, 4, 2],
            backgroundColor: 'rgba(54, 162, 235, 0.2)'
        }]
    },
    options: {
        responsive: true,
        scales: {
            x: {
                stacked: true
            },
            y: {
                stacked: true
            }
        }
    }
});

এখানে, stacked: true দিয়ে দুইটি ডেটাসেটকে একে অপরের উপর স্তরে স্তরে দেখানো হচ্ছে।


সারাংশ

Chart.js দিয়ে Bar Chart কাস্টমাইজ করতে আপনি বিভিন্ন উপাদান পরিবর্তন করতে পারেন, যেমন:

  • Colors: বারগুলোর রঙ এবং বর্ডার রঙ কাস্টমাইজ করা।
  • Widths: বারগুলোর প্রস্থ এবং বর্ডারের প্রস্থ কাস্টমাইজ করা।
  • Labels: এক্স-অক্ষের এবং ওয়াই-অক্ষের লেবেল কাস্টমাইজ করা, যেমন ফন্ট, সাইজ, রঙ ইত্যাদি।
  • Animation: চার্টের অ্যানিমেশন কাস্টমাইজ করা।

এই কাস্টমাইজেশনগুলো আপনার চার্টকে আরও দৃষ্টিনন্দন এবং কার্যকরী করতে সাহায্য করবে।

Content added By
Promotion

Are you sure to start over?

Loading...