Thang độ xám AVIF s qua C#
Tạo ứng dụng .NET của riêng bạn thành tệp AVIF thang độ xám bằng cách sử dụng API phía máy chủ.
Cách tạo thang độ xám cho tệp AVIF bằng C#
Độ sáng và nhiều màu sắc là bạn đồng hành của những hình ảnh đẹp. Tuy nhiên, in màu không phải lúc nào cũng khả thi. Trong những trường hợp như vậy, việc chuyển đổi ảnh sang thang độ xám là cần thiết. Ngoài ra, chức năng này có thể được sử dụng như một cách tiếp cận nghệ thuật độc lập, nâng cao sức hấp dẫn cho trang web của bạn. Thay vì than thở về việc mất thông tin màu sắc trong quá trình chuyển đổi này, điều này có thể cản trở nhận thức, hãy tận dụng nó để làm lợi thế cho bạn. Tập trung vào các chi tiết, kết cấu bề mặt của hình ảnh và sự tương tác giữa các vùng sáng và tối để tạo ra trải nghiệm hình ảnh đặc biệt. Để chuyển các tệp AVIF sang thang độ xám, chúng tôi sẽ sử dụng [Aspose.Imaging cho .NET] ( https://products.aspose.com/imaging/net ) API là một API chuyển đổi và thao tác hình ảnh giàu tính năng, mạnh mẽ và dễ sử dụng cho nền tảng C #. Mở [NuGet] ( https://www.nuget.org/packages/aspose.imaging ) quản lý gói, tìm kiếm ** Aspose.Imaging ** và cài đặt. Bạn cũng có thể sử dụng lệnh sau từ Bảng điều khiển Trình quản lý Gói.
Lệnh Bảng điều khiển Trình quản lý Gói
PM> Install-Package Aspose.Imaging
Các bước để có Thang độ xám AVIF qua C#
Bạn cần [aspose.imaging.dll] ( https://downloads.aspose.com/imaging/net ) để thử quy trình làm việc sau trong môi trường của riêng bạn.
- Tải tệp AVIF bằng phương pháp Image.Load
- Hình ảnh thang độ xám;
- Lưu hình ảnh nén vào đĩa ở định dạng Aspose.Imaging được hỗ trợ
yêu cầu hệ thống
Aspose.Imaging cho .NET được hỗ trợ trên tất cả các hệ điều hành chính. Chỉ cần đảm bảo rằng bạn có các điều kiện tiên quyết sau.
- Microsoft Windows hoặc hệ điều hành tương thích với .NET Framework, .NET Core, Ứng dụng Windows, Ứng dụng web ASP.NET.
- Môi trường phát triển như Microsoft Visual Studio.
- Aspose.Imaging cho .NET được tham chiếu trong dự án của bạn.
Hình ảnh thang độ xám AVIF - .NET
using Aspose.Imaging; | |
using Aspose.Imaging.FileFormats.Bmp; | |
using Aspose.Imaging.FileFormats.Dicom; | |
using Aspose.Imaging.FileFormats.Emf; | |
using Aspose.Imaging.FileFormats.Jpeg; | |
using Aspose.Imaging.FileFormats.Jpeg2000; | |
using Aspose.Imaging.FileFormats.Png; | |
using Aspose.Imaging.FileFormats.Psd; | |
using Aspose.Imaging.FileFormats.Tiff.Enums; | |
using Aspose.Imaging.ImageFilters.FilterOptions; | |
using Aspose.Imaging.ImageOptions; | |
using Aspose.Imaging.Masking; | |
using Aspose.Imaging.Masking.Options; | |
using Aspose.Imaging.Masking.Result; | |
using Aspose.Imaging.Sources; | |
using System; | |
using System.Collections.Generic; | |
using System.IO; | |
using System.Linq; | |
string templatesFolder = @"c:\Users\USER\Downloads"; | |
GrayscaleImages(); | |
void GrayscaleImages() | |
{ | |
List<string> rasterFormats = new List<string>() { "jpg", "png", "bmp", "apng", "dicom", | |
"jp2", "j2k", "tga", "webp", "tif", "gif","ico" }; | |
List<string> vectorFormats = new List<string>() { "svg", "otg", "odg", "eps", "wmf", "emf", "wmz", "emz", "cmx", "cdr" }; | |
List<string> allFormats = new List<string>(rasterFormats); | |
allFormats.AddRange(vectorFormats); | |
allFormats.ForEach( | |
formatExt => | |
{ | |
var inputFile = Path.Combine(templatesFolder, $"template.{formatExt}"); | |
bool isVectorFormat = vectorFormats.IndexOf(formatExt) > -1; | |
//Need to rasterize vector formats before background remove | |
if (isVectorFormat) | |
{ | |
inputFile = RasterizeVectorImage(formatExt, inputFile); | |
} | |
var outputFile = Path.Combine(templatesFolder, $"grayscale_{formatExt}.png"); | |
Console.WriteLine($"Processing {formatExt}"); | |
using (var image = (RasterImage)Image.Load(inputFile)) | |
{ | |
//Additional code examples can be found at | |
//https://apireference.aspose.com/imaging/net/aspose.imaging/rasterimage/methods/grayscale | |
image.Grayscale(); | |
//If image is multipage save each page to png to demonstrate results | |
if (image is IMultipageImage multiPage && multiPage.PageCount > 1) | |
{ | |
for (var pageIndex = 0; pageIndex < multiPage.PageCount; pageIndex++) | |
{ | |
string fileName = $"grayscale_page{pageIndex}_{formatExt}.png"; | |
multiPage.Pages[pageIndex].Save(templatesFolder + fileName, new PngOptions()); | |
File.Delete(templatesFolder + fileName); | |
} | |
} | |
else | |
{ | |
image.Save(outputFile, new PngOptions()); | |
File.Delete(outputFile); | |
} | |
} | |
//Remove rasterized vector image | |
if (isVectorFormat) | |
{ | |
File.Delete(inputFile); | |
} | |
} | |
); | |
} | |
string RasterizeVectorImage(string formatExt, string inputFile) | |
{ | |
string outputFile = Path.Combine(templatesFolder, $"rasterized.{formatExt}.png"); | |
using (var image = Image.Load(inputFile)) | |
{ | |
image.Save(outputFile, new PngOptions()); | |
} | |
return outputFile; | |
} |
Giới thiệu về Aspose.Imaging cho API .NET
Aspose.Imaging API là một giải pháp xử lý hình ảnh để tạo, sửa đổi, vẽ hoặc chuyển đổi hình ảnh (ảnh) trong các ứng dụng. Nó cung cấp: xử lý hình ảnh đa nền tảng, bao gồm nhưng không giới hạn ở chuyển đổi giữa các định dạng hình ảnh khác nhau (bao gồm xử lý hình ảnh nhiều trang hoặc nhiều khung hình đồng nhất), các sửa đổi như vẽ, làm việc với đồ họa nguyên thủy, chuyển đổi (thay đổi kích thước, cắt, lật và xoay , binarization, thang độ xám, điều chỉnh), các tính năng thao tác hình ảnh nâng cao (lọc, phối màu, tạo mặt nạ, giải mã) và các chiến lược tối ưu hóa bộ nhớ. Đây là một thư viện độc lập và không phụ thuộc vào bất kỳ phần mềm nào cho các thao tác hình ảnh. Người ta có thể dễ dàng thêm các tính năng chuyển đổi hình ảnh hiệu suất cao với các API gốc trong các dự án. Đây là các API tại chỗ 100% riêng tư và hình ảnh được xử lý tại máy chủ của bạn.Thang độ xám AVIF s qua Ứng dụng Trực tuyến
Tài liệu về thang độ xám AVIF bằng cách truy cập [trang web Bản trình diễn trực tiếp] của chúng tôi ( https://products.aspose.app/imaging/image-grayscale) . Bản demo trực tiếp có những lợi ích sau
AVIF Những gì là AVIF Định dạng tệp
Đọc thêmCác định dạng thang độ xám được hỗ trợ khác
Sử dụng C#, người ta có thể dễ dàng chỉnh thang độ xám các định dạng khác nhau bao gồm.