Създаването на мозаични оформления ръчно е тъжен и безгрешен процес, особено когато се справят с десетки или стотици изображения. Тази задача става още по-сложна, ако трябва да поддържате последователност в рамките на няколко проекта или кампании. С появата на инструменти за автоматизация като Aspose.Imaging за .NET, разработчиците сега могат да създадат перфектни, повтарящи се образни мозайки без усилия.

В тази публикация на блога ще разгледаме как да автоматизираме процеса на сливане на няколко изображения в мрежово оформление с помощта на Aspose.Imaging за .NET. Ще покрием всичко от настройката на вашата среда и организирането на източници на снимки, за да ги рециклираме и организираме в мрежа формат.

Предупреждения

Преди да се потопите в кода, уверете се, че имате следните изисквания:

  • Visual Studio 2019 или по-късно
  • .NET 6.0 или по-късно (или .Net Framework 4.6.2+)
  • Aspose.Imaging за .NET от NuGet

Пример за код: Автоматизиране на изображението Mosaic Layouts C#

using System;
using System.Collections.Generic;
using System.Drawing;
using Aspose.Imaging;
using Aspose.Imaging.FileFormats;

public class ImageMosaicGenerator
{
    public static void Main(string[] args)
    {
        // Initialize metered license
        Metered metered = new Metered();
        metered.SetMeteredKey("your-public-key", "your-private-key");

        string inputFolder = @"path\to\input\images";
        int rows = 5;
        int columns = 4;

        List<string> imagePaths = GetImageFilePaths(inputFolder);
        
        // Calculate output canvas dimensions
        int totalWidth = columns * 200; // Assuming each image is resized to 200x200 pixels
        int totalHeight = rows * 200;
        
        using (Bitmap compositeImage = new Bitmap(totalWidth, totalHeight))
        {
            Graphics graphics = Graphics.FromImage(compositeImage);
            
            for (int i = 0; i < imagePaths.Count; i++)
            {
                string imagePath = imagePaths[i];
                
                // Load and resize images
                Image image = Image.Load(imagePath);
                int newWidth = 200;
                int newHeight = 200;

                if (image.VerticalResolution != 96 || image.HorizontalResolution != 96)
                {
                    image.ResizeFullFrame(newWidth, newHeight, ResizeType.Bicubic);
                }
                
                // Calculate position in grid
                int xPosition = (i % columns) * newWidth;
                int yPosition = (i / columns) * newHeight;

                graphics.DrawImage(image, xPosition, yPosition);
            }

            // Save the composite image
            string outputFilePath = @"path\to\output\mosaic.jpg";
            compositeImage.Save(outputFilePath);

            Console.WriteLine($"Mosaic layout saved to {outputFilePath}");
        }
    }

    private static List<string> GetImageFilePaths(string folderPath)
    {
        // Implement logic to get all image file paths from the specified folder
        return new List<string>();
    }
}

Разбиране на Кодекса

Нека разгледаме ключовите части на това изпълнение:

Стъпка 1: Първоначална настройка

Първо, ние стартираме измерваната лиценза и зареждаме входните файлове:

// Initialize metered license
Metered metered = new Metered();
metered.SetMeteredKey("your-public-key", "your-private-key");

string inputFolder = @"path\to\input\images";
int rows = 5;
int columns = 4;

List<string> imagePaths = GetImageFilePaths(inputFolder);

Този раздел съставя необходимите лицензии и изтегля всички изображения от определена папка в списък.

Стъпка 2: Изчисляване на изходните измерения на канасите

След това изчисляваме измеренията на изходния канал въз основа на броя на редове и колони:

int totalWidth = columns * 200; // Assuming each image is resized to 200x200 pixels
int totalHeight = rows * 200;

Тук определяме ширината и височината на композитната картина въз основа на мрежовите измерения.

Стъпка 3: Изтегляне и рециклиране на изображения

Сега зареждаме всяка снимка от списъка и я рециклираме, за да се вписва в мрежата:

using (Bitmap compositeImage = new Bitmap(totalWidth, totalHeight))
{
    Graphics graphics = Graphics.FromImage(compositeImage);
    
    for (int i = 0; i < imagePaths.Count; i++)
    {
        string imagePath = imagePaths[i];
        
        // Load and resize images
        Image image = Image.Load(imagePath);
        int newWidth = 200;
        int newHeight = 200;

        if (image.VerticalResolution != 96 || image.HorizontalResolution != 96)
        {
            image.ResizeFullFrame(newWidth, newHeight, ResizeType.Bicubic);
        }
    }
}

Този снайпер натоварва всяка снимка и я рецизира до еднакъв размер, преди да я постави в мрежата.

Стъпка 4: Създаване на изображения в мрежата

След това изчисляваме позицията на всяка картина в мрежата и я нарисуваме с помощта на Graphics.DrawImage:

// Calculate position in grid
int xPosition = (i % columns) * newWidth;
int yPosition = (i / columns) * newHeight;

graphics.DrawImage(image, xPosition, yPosition);

Тази част гарантира, че всяко изображение е правилно поставено в съставната картина въз основа на своя индекс.

Стъпка 5: Спасяване на композитната картина

Накрая, ние съхраняваме композитната картина до определен изходния път:

// Save the composite image
string outputFilePath = @"path\to\output\mosaic.jpg";
compositeImage.Save(outputFilePath);

Console.WriteLine($"Mosaic layout saved to {outputFilePath}");

Този снайпер съхранява последната мозаична картина в файл.

заключение

В този блог пост ние изследвахме как да автоматизираме процеса на създаване на мозаици с помощта на Aspose.Imaging за .NET. Като следвате стъпките, изброени в този ръководство, лесно можете да създадете последователни и визуално атрактивни мрежови оформления програматично. Този подход не само спестява време, но също така гарантира, че вашите проекти поддържат високо ниво на качество и последователност.

Чувствайте се свободни да експериментирате с различни конфигурации и подобрения, за да приспособите решението към вашите специфични нужди!

More in this category