如何在 C# | IronPDF 中使用 IronPDF 轉換 PDF 頁面

使用IronPDF在 C# 和.NET中轉換 PDF 頁面

This article was translated from English: Does it need improvement?
Translated
View the article in English

IronPDF使.NET開發人員能夠在不改變頁面尺寸的情況下,透過縮放和平移內容來轉換 PDF 頁面。 使用具有水平/垂直平移和縮放因子參數的 Transform 方法,以程式方式重新定位和調整頁面內容的大小。

快速入門:輕鬆轉換 PDF 頁面

學習如何使用.NET中的IronPDF庫輕鬆轉換 PDF 頁面。 只需幾行程式碼,即可縮放和翻譯頁面內容,而不會影響原始頁面尺寸。 本指南示範如何無縫應用轉換來增強您的 PDF 文件。

  1. 使用NuGet套件管理器安裝https://www.nuget.org/packages/IronPdf

    PM > Install-Package IronPdf
  2. 複製並運行這段程式碼。

    IronPdf.PdfDocument.FromFile("input.pdf")
      .Pages[0].Transform(50,50,0.8,0.8)
      .SaveAs("output-transformed.pdf");
  3. 部署到您的生產環境進行測試

    今天就在您的專案中開始使用免費試用IronPDF

    arrow pointer


如何在 C# 轉換 PDF 頁面?

Transform 方法可以移動和調整內容大小。 這只會影響頁面上顯示的內容的外觀,不會改變頁面的實際尺寸。 與會改變整個頁面結構的頁面方向和旋轉不同,變換只會調整內容的位置。 讓我們在一個基本的 PDF 文件範例中嘗試 Transform 方法。

:path=/static-assets/pdf/content-code-examples/how-to/transform-pdf-pages-transform-pdf.cs
using IronPdf;

PdfDocument pdf = PdfDocument.FromFile("basic.pdf");

pdf.Pages[0].Transform(50, 50, 0.8, 0.8);

pdf.SaveAs("transformPage.pdf");
$vbLabelText   $csharpLabel

當您需要在合併多個 PDF 後重新定位內容,或為特定自訂紙張尺寸準備文件時,Transform 方法特別有用。 此功能可與其他佈局功能(例如設定自訂邊距)相輔相成,從而實現精確的文件格式設定。

Transform 方法接受哪些參數?

Transform 方法接受四個關鍵參數,用於控制內容定位和大小:

-水平平移(TranslateX) :將內容水平移動到頁面上。 正值使內容向右移動,負值使內容向左移動。 測量單位遵循 PDF 標準(通常為點,其中 1 點 = 1/72 英吋)。 -垂直平移(TranslateY) :控制頁面內容的垂直移動。 正值會使內容向下移動,負值會使內容向上移動。 當您需要為頁首和頁尾創建空間時,這非常有用。 -水平縮放 (ScaleX) :調整內容寬度的十進位值。 值為 1.0 時保持原尺寸,數值為 0.5 時寬度減半,數值為 2.0 時寬度加倍。 此參數有助於在與垂直比例匹配時,將內容適配到特定邊界內,而不會影響寬高比。 -垂直縮放 (ScaleY) :類似於 ScaleX,但影響高度。 保持 ScaleXScaleY 值相等,可以保持內容的原始寬高比。

以下是一個演示多種轉換的高級範例:

using IronPdf;
using System;

// Load an existing PDF or create a new one
PdfDocument pdf = PdfDocument.FromFile("invoice.pdf");

// Apply different transformations to multiple pages
for (int i = 0; i < pdf.Pages.Count; i++)
{
    if (i % 2 == 0)
    {
        // Even pages: Create margin space and reduce size slightly
        pdf.Pages[i].Transform(30, 30, 0.9, 0.9);
    }
    else
    {
        // Odd pages: Center content with larger margins
        pdf.Pages[i].Transform(40, 60, 0.85, 0.85);
    }
}

// Save the transformed document
pdf.SaveAs("invoice_transformed.pdf");

// You can also export to memory stream for web applications
var memoryStream = pdf.Stream;
using IronPdf;
using System;

// Load an existing PDF or create a new one
PdfDocument pdf = PdfDocument.FromFile("invoice.pdf");

// Apply different transformations to multiple pages
for (int i = 0; i < pdf.Pages.Count; i++)
{
    if (i % 2 == 0)
    {
        // Even pages: Create margin space and reduce size slightly
        pdf.Pages[i].Transform(30, 30, 0.9, 0.9);
    }
    else
    {
        // Odd pages: Center content with larger margins
        pdf.Pages[i].Transform(40, 60, 0.85, 0.85);
    }
}

// Save the transformed document
pdf.SaveAs("invoice_transformed.pdf");

// You can also export to memory stream for web applications
var memoryStream = pdf.Stream;
$vbLabelText   $csharpLabel

我為什麼要轉換PDF頁面?

PDF頁面轉換在文件處理上有許多實際應用:

1. 建立可列印文件:在準備用於專業印刷的 PDF 時,您通常需要調整內容位置以適應出血區域、裝訂邊距或特定印表機要求。 Transform 方法允許精確定位,而無需重新建立文件。

2. 表單欄位對齊:建立或編輯 PDF 表單後,您可能需要重新定位整個部分,以便與預先印刷的信紙或範本對齊。 變換確保所有圖形元素保持其相對位置。

3. 多重文件彙編:當合併來自不同來源的文件時,每個文件可能具有不同的頁邊距設定。 使用 Transform 有助於統一所有頁面的外觀,在合併文件上添加文字或圖像時尤其有用。

4. 響應式 PDF 產生:在動態應用程式中,PDF 的產生是基於使用者偏好或裝置規格,Transform 可進行即時調整,以確保在不同螢幕尺寸上獲得最佳觀看效果。

PDF轉換前後對比圖,展示了內容從全頁佈局移動到重新定位佈局後的對比。

PDF轉換最佳實踐

在進行 PDF 轉換時,請考慮以下最佳化策略:

保持縱橫比:除非有意進行變形,否則始終使用相同的 ScaleXScaleY 值。 這樣可以保持文字和圖片的專業外觀。

測試邊界條件:在套用轉換之前,驗證縮放後的內容不會超出頁面邊界。 計算變換後的有效內容區域,以防止裁切。

批次處理效率:轉換多個頁面時,請考慮對大型文件使用並行處理:

using IronPdf;
using System.Linq;
using System.Threading.Tasks;

public async Task TransformLargeDocument(string filePath)
{
    PdfDocument pdf = PdfDocument.FromFile(filePath);

    // Process pages in parallel for better performance
    var tasks = pdf.Pages.Select((page, index) => 
        Task.Run(() => 
        {
            // Apply consistent transformation to all pages
            page.Transform(25, 25, 0.95, 0.95);
        })
    ).ToArray();

    await Task.WhenAll(tasks);

    // Save with optimized settings
    pdf.SaveAs("transformed_optimized.pdf");
}
using IronPdf;
using System.Linq;
using System.Threading.Tasks;

public async Task TransformLargeDocument(string filePath)
{
    PdfDocument pdf = PdfDocument.FromFile(filePath);

    // Process pages in parallel for better performance
    var tasks = pdf.Pages.Select((page, index) => 
        Task.Run(() => 
        {
            // Apply consistent transformation to all pages
            page.Transform(25, 25, 0.95, 0.95);
        })
    ).ToArray();

    await Task.WhenAll(tasks);

    // Save with optimized settings
    pdf.SaveAs("transformed_optimized.pdf");
}
$vbLabelText   $csharpLabel

記憶體管理:對於大型文檔,考慮分塊處理並儲存到記憶體流中,以優化伺服器環境中的資源使用。

常見轉型場景

以下是一些具體應用案例的實際範例:

建立縮圖:透過縮小內容並保持可讀性來產生 PDF 頁面預覽:

// Create thumbnail-sized versions of pages
pdf.Pages[0].Transform(10, 10, 0.3, 0.3);
// Create thumbnail-sized versions of pages
pdf.Pages[0].Transform(10, 10, 0.3, 0.3);
$vbLabelText   $csharpLabel

加入裝訂邊距:調整內容以適應螺旋裝訂或三孔活頁夾:

// Add 0.5 inch (36 points) binding margin on left
pdf.Pages[0].Transform(36, 0, 1.0, 1.0);
// Add 0.5 inch (36 points) binding margin on left
pdf.Pages[0].Transform(36, 0, 1.0, 1.0);
$vbLabelText   $csharpLabel

內容居中:當內容不足以填滿頁面​​時,請將其專業地居中放置:

// Calculate centering offset (assuming standard letter size)
double pageWidth = 612; // points
double contentWidth = 500; // estimated content width
double centerOffset = (pageWidth - contentWidth) / 2;

pdf.Pages[0].Transform(centerOffset, 50, 1.0, 1.0);
// Calculate centering offset (assuming standard letter size)
double pageWidth = 612; // points
double contentWidth = 500; // estimated content width
double centerOffset = (pageWidth - contentWidth) / 2;

pdf.Pages[0].Transform(centerOffset, 50, 1.0, 1.0);
$vbLabelText   $csharpLabel

Transform 方法與 IronPDF 的全面功能集無縫集成,使您能夠創建具有精確佈局的新 PDF,並修改現有文件以滿足特定要求。 無論您是建立自動化文件處理系統還是建立自訂報告解決方案,掌握 PDF 轉換都能增強您交付專業、格式精確的文件的能力。

常見問題解答

如何以 C# 程式化方式轉換 PDF 頁面?

您可以使用 IronPDF 的 Transform 方法來轉換 PDF 頁面。此方法允許您在不修改實際頁面尺寸的情況下縮放和轉換頁面內容。只需在頁面上呼叫 Transform 方法,並為水平/垂直平移和縮放因子設定參數即可。

Transform 方法需要哪些參數?

IronPDF 中的 Transform 方法接受四個參數:TranslateX(水平移動)、TranslateY(垂直移動)、ScaleX(水平縮放)和 ScaleY(垂直縮放)。Translation 值的單位是點(1/72 英吋),而 Scale 值則是十進位乘數。

我可以在不改變頁面大小的情況下移動 PDF 內容嗎?

是的,IronPDF 的 Transform 方法是在不改變實際頁面尺寸的情況下,具體移動和調整內容外觀的大小。這與修改整個頁面結構的頁面旋轉或方向改變不同。

如何將 PDF 內容縮放到原始大小的 80%?

若要使用 IronPDF 將 PDF 內容縮放到原始大小的 80%,請使用 Transform 方法,並將縮放參數設定為 0.8。例如Pages[0].Transform(0,0,0.8,0.8)會將寬度和高度都縮放到 80%。

我可以對 PDF 中的特定頁面套用轉換嗎?

是的,IronPDF 允許您透過「頁面」集合存取個別頁面來進行轉換。您可以根據需要對每個頁面應用不同的轉換,例如對第一頁應用 Pages[0].Transform()。

正翻譯值和負翻譯值有什麼不同?

在 IronPDF 的 Transform 方法中,TranslateX 的正值會向右移動內容,而負值則會向左移動內容。對於 TranslateY,正值會使內容向下移動,負值則會使內容向上移動。這允許在任何方向精確定位。

何時應該使用 PDF 轉換而非旋轉?

當您需要重新定位或調整內容大小,同時保持頁面尺寸不變時,請使用 IronPDF 的 Transform 方法。這是合併 PDF、為自訂紙張尺寸準備文件,或在不改變頁面結構的情況下為頁首和頁尾創造空間的理想選擇。

Curtis Chau
技術作家

Curtis Chau 擁有卡爾頓大學計算機科學學士學位,專注於前端開發,擅長於 Node.js、TypeScript、JavaScript 和 React。Curtis 熱衷於創建直觀且美觀的用戶界面,喜歡使用現代框架並打造結構良好、視覺吸引人的手冊。

除了開發之外,Curtis 對物聯網 (IoT) 有著濃厚的興趣,探索將硬體和軟體結合的創新方式。在閒暇時間,他喜愛遊戲並構建 Discord 機器人,結合科技與創意的樂趣。

準備好開始了嗎?
Nuget 下載 17,803,474 | 版本: 2026.3 剛剛發布
Still Scrolling Icon

還在滾動嗎?

想快速取得證據? PM > Install-Package IronPdf
運行範例看著你的HTML程式碼變成PDF檔。