<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>ReinAD</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            margin: 0;
            padding: 20px;
            background-color: #f5f5f5;
        }

        .header {
            display: flex;
            justify-content: center; /* Center-align the select menus */
            align-items: center;
            margin-bottom: 20px;
        }

        .header select {
            margin: 0 10px; /* Add spacing between the dropdowns */
            padding: 8px;
            border: 1px solid #ccc;
            border-radius: 4px;
        }

        .buttons {
            display: flex;
            flex-wrap: wrap; /* Allow wrapping of buttons */
            justify-content: center; /* Center-align the buttons */
            gap: 20px; /* Add spacing between buttons */
            margin-top: 20px;
        }

        .button-wrapper {
            text-align: center; /* Center-align each button and its label */
        }

        .button-wrapper img {
            width: auto; /* Thumbnail width */
            height: 80px; /* Thumbnail height */
            border-radius: 8px;
            border: 2px solid #ccc;
            cursor: pointer;
            transition: border-color 0.3s;
        }

        .button-wrapper img.active {
            border-color: #007bff; /* Highlight active button */
        }

        .button-wrapper span {
            display: block;
            margin-top: 10px;
            font-size: 14px;
            color: #333;
        }

        .image-container {
            display: flex;
            justify-content: center;
            align-items: center;
            margin-top: 20px;
        }

        .image-container img {
            /* max-width: 'auto'; Ensures the image doesn’t exceed container width */
            /* max-height: 572px; Limit the image height */
            height: 384px; /* Maintain aspect ratio */
            /* height: 572px;  */
            width: auto; /* Maintain aspect ratio */
            border-radius: 8px;
            border: 1px solid #ddd;
            box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
        }
    </style>
    <script src="static/jquery.min.js"></script>
    <script type="text/javascript" src="static/jquery.ez-plus.js"></script>
</head>
<body>
    <h1 style="text-align: center;">ReinAD: Towards Real-world Industrial Anomaly Detection</h1>
    <h1 style="text-align: center;">with a Comprehensive Contrastive Dataset</h1>
    <h2 style="text-align: center;">#1565</h2>
    <p style="text-align: center;">We provide visualization of all categories in our ReinAD dataset. Anomalous regions are annotated in red masks.</p>
    <p style="text-align: center;">Please feel free to select the category and go through different samples :).</p>
    <div class="header">
        <b>Category:</b>
        <select id="categorySelect">
            <option value="cable_1">cable_1</option>
            <option value="cable_2">cable_2</option>
            <option value="cable_3">cable_3</option>
            <option value="LED_1">LED_1</option>
            <option value="LED_2">LED_2</option>
            <option value="LED_3">LED_3</option>
            <option value="lens_1">lens_1</option>
            <option value="lens_2">lens_2</option>
            <option value="miniLED_1">miniLED_1</option>
            <option value="miniLED_2">miniLED_2</option>
            <option value="miniLED_3">miniLED_3</option>
            <option value="PCB_solder_1">PCB_solder_1</option>
            <option value="PCB_solder_2">PCB_solder_2</option>
            <option value="PCB_terminal">PCB_terminal</option>
            <option value="pinline">pinline</option>
            <option value="piston_ring_1">piston_ring_1</option>
            <option value="piston_ring_2">piston_ring_2</option>
            <option value="piston_ring_3">piston_ring_3</option>
            <option value="plastic_box">plastic_box</option>
            <option value="plastic_cover_1">plastic_cover_1</option>
            <option value="plastic_cover_2">plastic_cover_2</option>
            <option value="plastic_cover_3">plastic_cover_3</option>
            <option value="plastic_cover_4">plastic_cover_4</option>
            <option value="plastic_cover_5">plastic_cover_5</option>
            <option value="plastic_cover_6">plastic_cover_6</option>
            <option value="profile_surface_1">profile_surface_1</option>
            <option value="profile_surface_2">profile_surface_2</option>
            <option value="reflective_sheet">reflective_sheet</option>
            <option value="round_tube">round_tube</option>
            <option value="suspension_wire">suspension_wire</option>
            <option value="thread">thread</option>
            <option value="wafer_1">wafer_1</option>
            <option value="wafer_2">wafer_2</option>
            <option value="bearing_1">bearing_1</option>
            <option value="bearing_2">bearing_2</option>
            <option value="bearing_3">bearing_3</option>
            <option value="bearing_4">bearing_4</option>
            <option value="bearing_5">bearing_5</option>
            <option value="bearing_6">bearing_6</option>
            <option value="bearing_7">bearing_7</option>
            <option value="bearing_8">bearing_8</option>
            <option value="bearing_9">bearing_9</option>
            <option value="bearing_10">bearing_10</option>
            <option value="bearing_11">bearing_11</option>
            <option value="bearing_12">bearing_12</option>
        </select>
        <span style="display: inline-block; width: 40px;"></span>
        <b>Sample:</b>
        <select id="imageSelect">
        </select>
    </div>

    <div class="image-container">
        <img id="displayImage" src="ReinAD/cable_1/Anomaly/001.jpg" alt="Anomaly">
    </div>
    <div class="buttons">
        <div class="button-wrapper">
        <img id="NormalButton" src="ReinAD/cable_1/Normal/001.jpg" alt="Normal" width="100">
        <span>Normal</span>
        </div>

        <div class="button-wrapper">
        <img id="AnomalyButton" src="ReinAD/cable_1/Anomaly/001.jpg" alt="Anomaly" width="100">
        <span>Anomaly</span>
        </div>

        <!-- <div class="button-wrapper">
        <img id="GroundTruthButton" src="ReinAD/cable_1/GroundTruth/001.jpg" alt="GroundTruth" width="100">
        <span>GroundTruth</span>
        </div> -->

    </div>
    <script>
        const buttons = document.querySelectorAll('.buttons img');
        const displayImage = document.getElementById('displayImage');
        const imageSelect = document.getElementById('imageSelect');
        const categorySelect = document.getElementById('categorySelect');

        // Simulating image loading based on button clicks
        const categories = {
            cable_1: 'ReinAD/cable_1/',
            cable_2: 'ReinAD/cable_2/',
            cable_3: 'ReinAD/cable_3/',
            LED_1: 'ReinAD/LED_1/',
            LED_2: 'ReinAD/LED_2/',
            LED_3: 'ReinAD/LED_3/',
            lens_1: 'ReinAD/lens_1/',
            lens_2: 'ReinAD/lens_2/',
            miniLED_1: 'ReinAD/miniLED_1/',
            miniLED_2: 'ReinAD/miniLED_2/',
            miniLED_3: 'ReinAD/miniLED_3/',
            PCB_solder_1: 'ReinAD/PCB_solder_1/',
            PCB_solder_2: 'ReinAD/PCB_solder_2/',
            PCB_terminal: 'ReinAD/PCB_terminal/',
            pinline: 'ReinAD/pinline/',
            piston_ring_1: 'ReinAD/piston_ring_1/',
            piston_ring_2: 'ReinAD/piston_ring_2/',
            piston_ring_3: 'ReinAD/piston_ring_3/',
            plastic_box: 'ReinAD/plastic_box/',
            plastic_cover_1: 'ReinAD/plastic_cover_1/',
            plastic_cover_2: 'ReinAD/plastic_cover_2/',
            plastic_cover_3: 'ReinAD/plastic_cover_3/',
            plastic_cover_4: 'ReinAD/plastic_cover_4/',
            plastic_cover_5: 'ReinAD/plastic_cover_5/',
            plastic_cover_6: 'ReinAD/plastic_cover_6/',
            profile_surface_1: 'ReinAD/profile_surface_1/',
            profile_surface_2: 'ReinAD/profile_surface_2/',
            reflective_sheet: 'ReinAD/reflective_sheet/',
            round_tube: 'ReinAD/round_tube/',
            suspension_wire: 'ReinAD/suspension_wire/',
            thread: 'ReinAD/thread/',
            wafer_1: 'ReinAD/wafer_1/',
            wafer_2: 'ReinAD/wafer_2/',
            bearing_1: 'ReinAD/bearing_1/',
            bearing_2: 'ReinAD/bearing_2/',
            bearing_3: 'ReinAD/bearing_3/',
            bearing_4: 'ReinAD/bearing_4/',
            bearing_5: 'ReinAD/bearing_5/',
            bearing_6: 'ReinAD/bearing_6/',
            bearing_7: 'ReinAD/bearing_7/',
            bearing_8: 'ReinAD/bearing_8/',
            bearing_9: 'ReinAD/bearing_9/',
            bearing_10: 'ReinAD/bearing_10/',
            bearing_11: 'ReinAD/bearing_11/',
            bearing_12: 'ReinAD/bearing_12/',
        }

        const folderPaths = {
            Normal: 'Normal/',
            Anomaly: 'Anomaly/',
            GroundTruth: 'GroundTruth/',
        };

        // Function to populate the imageSelect dropdown with options from 001 to 005
        function populateImageSelect(n) {
            imageSelect.innerHTML = '';
            for (let i = 1; i <= n; i++) {
                const value = i.toString().padStart(3, '0'); // Format number as '001', '002', etc.
                const option = document.createElement('option');
                option.value = value;
                option.textContent = value;
                imageSelect.appendChild(option);
            }
        }

        // Function to get the currently active button
        function getActiveButton() {
            return document.querySelector('.buttons img.active')?.id.replace('Button', '') || 'Normal';
        }

        // Function to update the image based on the current selection
        function updateImage() {
            const selectedDataset = categories[categorySelect.value]; // Get the selected Dataset
            const selectedImage = imageSelect.value; // Get the selected file name
            const activeButton = getActiveButton(); // Get the active method
            const folderPath = folderPaths[activeButton]; // Get the folder path for the active method
            const ext = '.jpg';
            const imagePath = `${selectedDataset}${folderPath}${selectedImage}${ext}`;
            displayImage.src = imagePath; // Update the image source

            $('#displayImage').ezPlus({
                cursor: 'inherit',
                lensOpacity: 0.25,
                zoomWindowPosition: 9,    
                zoomWindowHeight: 378,
                zoomWindowWidth: 300,
                borderSize: 3,
                easing: true,
                easingAmount: 8});
            var ez = $('#displayImage').data('ezPlus');
            ez.swaptheimage(displayImage.src,displayImage.src); 
        }

        // Function to update button thumbnails based on the selected image
        function updateThumbnails() {
            const selectedDataset = categories[categorySelect.value]; // Get the selected Dataset
            const selectedImage = imageSelect.value; // Get the selected file name
            buttons.forEach(button => {
                const buttonId = button.id.replace('Button', ''); // Get the method name from the button ID
                const ext = '.jpg';
                const thumbnailPath = `${selectedDataset}${folderPaths[buttonId]}${selectedImage}${ext}`; // Construct the thumbnail path
                button.src = thumbnailPath; // Update the thumbnail source
            });
        }

        // Add event listeners to buttons
        buttons.forEach(button => {
            button.addEventListener('click', () => {
                // Remove active class from all buttons
                buttons.forEach(btn => btn.classList.remove('active'));
                
                // Add active class to the clicked button
                button.classList.add('active');
                
                // Update the image based on the active button and selected image
                updateImage();
            });
        });

        categorySelect.addEventListener('change', () => {
            populateImageSelect(5);
            updateImage(); // Update the image when selection changes
            updateThumbnails();
        });

        // Add event listener to the ImageSelect dropdown
        imageSelect.addEventListener('change', () => {
            updateImage(); // Update the image when selection changes
            updateThumbnails();
        });

        // Initialize the page with default settings
        function initialize() {
            populateImageSelect(5); // Populate the dropdown with options
            document.getElementById('AnomalyButton').classList.add('active'); // Default button
            imageSelect.value = '001'; // Set default selection
            updateImage(); // Load default image
        }
        initialize();
    </script>
</body>
</html>
