Stvaranje mosaik rasporeda ručno je umoran i pogrešan proces, osobito kada se bavi desetke ili stotine slika. Ova zadaća postaje još izazovnija ako morate održavati dosljednost u mnogim projektima ili kampanjama. S dolaskom alata za automatizaciju kao što je Aspose.Imaging za .NET, razvijalci sada mogu stvoriti savršene, ponavljajuće sliku mozaike bez napora.

U ovom članku na blogu ćemo istražiti kako automatizirati proces spajanja više slika u raspored mreže pomoću Aspose.Imaging za .NET. Pokrivaćemo sve od postavljanja vašeg okruženja i organiziranja izvornog slike do reorganiziranja i aranžiranja u mrežnom formatu.

Preduzeća

Prije potopljenja u kod, pobrinite se da imate sljedeće uvjete postavljene:

  • Visual Studio 2019 ili kasnije
  • .NET 6.0 ili noviji (ili .Net Framework 4.6.2+)
  • Aspose.Imaging za .NET od NuGet

Primjer koda: Automatiziranje slika 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>();
    }
}

Razumjeti kodeks

Razdvojimo ključne dijelove ove implementacije:

Korak 1: Početna postavka

Prvo, inicijaliziramo mjerenu licenciju i preuzimamo ulazne datoteke:

// 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);

Ovaj odjeljak sastavlja potrebne licencije i prenosi sve slike iz određenog dosjea na popis.

Korak 2: Izračunavanje dimenzija izlaska kanvas

Sljedeće, izračunamo dimenzije izlaska kanve na temelju broja redova i kolona:

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

Ovdje određujemo širinu i visinu kompozitnog slika na temelju dimenzija mreže.

Korak 3: Preuzimanje i recikliranje slika

Sada preuzimamo svaku sliku s popisa i preusmjeravamo je kako bi se prilagodila mreži:

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);
        }
    }
}

Ovaj snippet opterećuje svaku sliku i ponavlja je na jedinstvenu veličinu prije stavljanja u mrežu.

Korak 4: Uređivanje slika u mreži

Zatim izračunamo poziciju svake slike unutar mreže i crtamo ga pomoću Graphics.DrawImage:

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

graphics.DrawImage(image, xPosition, yPosition);

Ovaj dio osigurava da je svaka slika ispravno postavljena unutar sastavne slike na temelju njezinog indeksa.

Korak 5: Sačuvajte kompozitnu sliku

Konačno, sačuvamo sastavnu sliku na određenom putu izlaska:

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

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

Ovaj snimak spašava konačnu mosaiknu sliku na datoteku.

zaključak

U ovom članku na blogu, istražili smo kako automatizirati proces stvaranja slika mosaika pomoću Aspose.Imaging za .NET. Slijedom koraka navedenih u ovom vodiču, lako možete programski stvoriti dosljedne i vizualno privlačne mrežne rasporedove.Ovaj pristup ne samo da štedi vrijeme, već i osigurava da vaši projekti održavaju visoku razinu kvalitete i konsistencije.

Osjećajte se slobodno eksperimentirati s različitim konfiguracijama i poboljšanjima kako biste prilagodili rješenje vašim specifičnim potrebama!

More in this category