PPTX DOCX XLSX PDF ODP
Aspose.Imaging  .NET
OTG

通過 C# 調整 OTG

使用服務器端 API 構建您自己的 .NET 應用程序來調整 OTG 文件。

如何使用 C# 調整 OTG 文件

即使是最有經驗的攝影師也可能在拍攝過程中犯錯誤或遇到不利的照明條件。這種情況可能會導致圖像缺陷,但即使是糟糕的照片也有可能出現。借助 C# 庫,您可以通過調整亮度、對比度和顏色伽瑪以編程方式糾正這些問題。如果照片太暗,增加亮度會照亮黑暗區域,使之前隱藏的細節變得可見。調整對比度會增加明暗區域之間的差異,擴大亮度範圍以改善圖像。如果您在人造照明下拍攝的照片導致出現不需要的色調,請利用顏色伽瑪調整來校正白平衡。為了調整 OTG 文件,我們將使用 Aspose.Imaging for .NET API 是一個功能豐富、功能強大且易於使用的 C# 平台圖像處理和轉換 API。打開 NuGet 包管理器,搜索 Aspose.Imaging 並安裝。您也可以從包管理器控制台使用以下命令。

包管理器控制台命令


PM> Install-Package Aspose.Imaging

通過 C# 調整 OTG 的步驟

你需要 aspose.imaging.dll 在您自己的環境中嘗試以下工作流程。

  • 使用 Image.Load 方法加載 OTG 文件 +調整圖像;
  • 以 Aspose.Imaging 支持的格式將壓縮圖像保存到光盤

系統要求

所有主要操作系統都支持 .NET 的 Aspose.Imaging。只需確保您具有以下先決條件。

  • Microsoft Windows 或與 .NET Framework、.NET Core、Windows 應用程序、ASP.NET Web 應用程序兼容的操作系統。
  • Microsoft Visual Studio 等開發環境。
  • Aspose.Imaging for .NET 在您的項目中引用。
 

調整 OTG 圖像 - .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";
AdjustBrightness();
void AdjustGammaRGB()
{
FilterImages(image =>
{
//https://apireference.aspose.com/imaging/net/aspose.imaging.rasterimage/adjustgamma/methods/1
image.AdjustGamma(5, 0.1f, 0.1f);
}, "adjustgammargb");
}
void AdjustGamma()
{
FilterImages(image =>
{
//https://apireference.aspose.com/imaging/net/aspose.imaging/rasterimage/methods/adjustgamma
image.AdjustGamma(3);
}, "adjustgamma");
}
void AdjustContrast()
{
FilterImages(image =>
{
//https://apireference.aspose.com/imaging/net/aspose.imaging/rasterimage/methods/adjustcontrast
image.AdjustContrast(50);
}, "adjustcontrast");
}
void AdjustBrightness()
{
FilterImages(image =>
{
//https://apireference.aspose.com/imaging/net/aspose.imaging/rasterimage/methods/adjustbrightness
image.AdjustBrightness(100);
}, "adjustbrightness");
}
void FilterImages(Action<RasterImage> doFilter, string filterName)
{
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, $"{filterName}_{formatExt}.png");
Console.WriteLine($"Processing {formatExt}");
using (var image = (RasterImage)Image.Load(inputFile))
{
doFilter(image);
//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 = $"{filterName}_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;
}
 
  • 關於 .NET API 的 Aspose.Imaging

    Aspose.Imaging API 是一種圖像處理解決方案,用於在應用程序中創建、修改、繪製或轉換圖像(照片)。它提供:跨平台的圖像處理,包括但不限於各種圖像格式之間的轉換(包括統一的多頁或多幀圖像處理)、繪圖等修改、使用圖形基元、轉換(調整大小、裁剪、翻轉和旋轉) 、二值化、灰度、調整)、高級圖像處理功能(過濾、抖動、遮罩、去偏斜)和內存優化策略。它是一個獨立的庫,不依賴任何軟件進行圖像操作。可以在項目中使用原生 API 輕鬆添加高性能圖像轉換功能。這些是 100% 私有的本地 API,圖像在您的服務器上處理。

    通過在線應用調整 OTG

    通過訪問我們的 Live Demos 網站 調整 OTG 文檔。 現場演示有以下好處

      無需下載或設置任何東西
      無需編寫任何代碼
      只需上傳您的 OTG 文件並點擊“立即調整”按鈕
      立即獲取生成文件的下載鏈接

    OTG 什麼是 OTG 文件格式

    OTG 文件是使用遵循 OASIS Office Applications 1.0 規範的 OpenDocument 標準創建的繪圖模板。它表示矢量圖像的繪圖元素的默認組織,可用於進一步增強文件的內容。

    閱讀更多

    其他支持的調整格式

    使用 C#,可以輕鬆調整不同的格式,包括。

    APNG (動畫便攜式網絡圖形)
    BMP (位圖圖片)
    ICO (窗口圖標)
    JPG (聯合攝影專家組)
    JPEG (聯合攝影專家組)
    DIB (設備無關位圖)
    DICOM (數碼影像與通訊)
    DJVU (圖形格式)
    DNG (數碼相機圖像)
    EMF (增強的元文件格式)
    EMZ (Windows 壓縮增強元文件)
    GIF (圖形交換格式)
    JP2 (JPEG 2000)
    J2K (小波壓縮圖像)
    PNG (便攜式網絡圖形)
    TIFF (標記圖像格式)
    TIF (標記圖像格式)
    WEBP (光柵網絡圖像)
    WMF (微軟視窗元文件)
    WMZ (壓縮的 Windows Media Player 皮膚)
    TGA (塔加圖形)
    SVG (可縮放矢量圖形)
    EPS (封裝的 PostScript 語言)
    CDR (矢量繪圖圖像)
    CMX (Corel 交換圖像)
    ODG (Apache OpenOffice 繪圖格式)