När man arbetar med PDF-filer finns det ofta krav på att skala innehållet för olika ändamål. I det här scenariot strävar vi efter att minska storleken på alla sidor i en PDF med 70 %. Den här guiden går igenom de nödvändiga stegen, tar upp relevanta frågor och ger lösningar.
Problembeskrivning
Vi måste skala ner varje sida i ett PDF-dokument med 70 % samtidigt som vi behåller den ursprungliga sidordningen. Detta kräver:
- Laddar PDF-filen.
- Fånga och skala varje sida.
- Spara de skalade sidorna i en ny PDF-fil.
Steg för att uppnå målet
- Initiera miljön:
- Ladda den ursprungliga PDF-filen.
- Ta bort alla tidigare befintliga utdatafiler för att undvika konflikter.
- Ställ in skalningsparametrarna:
- Definiera skalningsfaktorn (70%).
- Beräkna gränserna som krävs för att centrera det skalade innehållet.
- Bearbeta varje sida i en slinga:
- Välj den första sidan.
- Fånga sidans innehåll.
- Skapa en ny sida med de ursprungliga måtten.
- Rita det fångade, skalade innehållet på den nya sidan.
- Upprepa för alla sidor.
- Spara den nya PDF-filen och öppna den:
- Spara de ändrade sidorna i en ny PDF-fil.
- Öppna den nya PDF-filen automatiskt för att granska resultaten.
Kodimplementering
Här är C#-koden som utför stegen ovan:
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
private void button_Click(object sender, EventArgs e) { // Delete the old file if it exists to avoid any conflicts. File.Delete("newpages.pdf"); // Define variables for page dimensions and scaling factors. double pageWidth, pageHeight, horizBorder, vertBorder; double scaleFactor = 0.70; // 70% scaling reduction. int capturedPageId; int ret; // Load the original PDF document. PDFL.LoadFromFile("Pages.pdf"); PDFL.SetOrigin(1); // Get the total number of pages in the document. int numPages = PDFL.PageCount(); // Loop through all pages to process each one. for (int i = 1; i <= numPages; i++) { // Always select the first page as the pages get deleted after capture. PDFL.SelectPage(1); // Retrieve the dimensions of the current page. pageWidth = PDFL.PageWidth(); pageHeight = PDFL.PageHeight(); // Calculate the borders to center the scaled page content. horizBorder = pageWidth * (1.0 - scaleFactor) / 2; vertBorder = pageHeight * (1.0 - scaleFactor) / 2; // Capture the content of the first page. This action deletes the page from the document. capturedPageId = PDFL.CapturePage(1); // Create a new page with the original dimensions. int pageId = PDFL.NewPage(); PDFL.SetPageDimensions(pageWidth, pageHeight); // Draw the captured page content onto the new page with the specified scaling. ret = PDFL.DrawCapturedPage(capturedPageId, horizBorder, vertBorder, pageWidth - 2 * horizBorder, pageHeight - 2 * vertBorder); } // Save the modified document as a new PDF file. PDFL.SaveToFile("newpages.pdf"); // Open the newly created PDF file for review. System.Diagnostics.Process.Start(@"newpages.pdf"); |
Förklaring och motivering
- Radering av fil: Säkerställer att alla tidigare utdata rensas för att förhindra fel eller föråldrat innehåll.
- Skalningsfaktor: Ställ in på 0,70, detta minskar storleken på innehållet till 70 % av originalet.
- Gränsberäkning: Centrerar det skalade innehållet inom de ursprungliga siddimensionerna.
- Sidbearbetningsslinga: Itererar genom alla sidor, fångar, skalar och ritar var och en i sekvens.
- Spara och öppna filer: Slutför det nya dokumentet och öppnar det för användaren att verifiera ändringarna.
Genom att följa detta strukturerade tillvägagångssätt säkerställer vi att varje sida i PDF:en skalas konsekvent och bibehåller sin ursprungliga ordning, vilket resulterar i ett professionellt bearbetat dokument.
Delphi upplaga:
Använd Delphi för att skala PDF-sidor med 70 %:
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
procedure TForm1.ButtonClick(Sender: TObject); var pageWidth, pageHeight, horizBorder, vertBorder: Double; scaleFactor: Double; capturedPageId, ret: Integer; numPages, pageId, i: Integer; begin // Delete the old file if it exists to avoid any conflicts. if FileExists('newpages.pdf') then DeleteFile('newpages.pdf'); // Define the scaling factor (70%). scaleFactor := 0.70; // 70% scaling reduction. // Load the original PDF document. PDFL.LoadFromFile('Pages.pdf'); PDFL.SetOrigin(1); // Get the total number of pages in the document. numPages := PDFL.PageCount(); // Loop through all pages to process each one. for i := 1 to numPages do begin // Always select the first page as the pages get deleted after capture. PDFL.SelectPage(1); // Retrieve the dimensions of the current page. pageWidth := PDFL.PageWidth(); pageHeight := PDFL.PageHeight(); // Calculate the borders to center the scaled page content. horizBorder := pageWidth * (1.0 - scaleFactor) / 2; vertBorder := pageHeight * (1.0 - scaleFactor) / 2; // Capture the content of the first page. This action deletes the page from the document. capturedPageId := PDFL.CapturePage(1); // Create a new page with the original dimensions. pageId := PDFL.NewPage(); PDFL.SetPageDimensions(pageWidth, pageHeight); // Draw the captured page content onto the new page with the specified scaling. ret := PDFL.DrawCapturedPage(capturedPageId, horizBorder, vertBorder, pageWidth - 2 * horizBorder, pageHeight - 2 * vertBorder); end; // Save the modified document as a new PDF file. PDFL.SaveToFile('newpages.pdf'); // Open the newly created PDF file for review. ShellExecute(0, 'open', 'newpages.pdf', nil, nil, SW_SHOWNORMAL); end; |
VB.Net-utgåva
Här är VB.Net-koden för att utföra uppgiften:
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
Private Sub button_Click(sender As Object, e As EventArgs) Handles button.Click ' Delete the old file if it exists to avoid any conflicts. If File.Exists("newpages.pdf") Then File.Delete("newpages.pdf") End If ' Define variables for page dimensions and scaling factors. Dim pageWidth, pageHeight, horizBorder, vertBorder As Double Dim scaleFactor As Double = 0.70 ' 70% scaling reduction. Dim capturedPageId, ret As Integer ' Load the original PDF document. PDFL.LoadFromFile("Pages.pdf") PDFL.SetOrigin(1) ' Get the total number of pages in the document. Dim numPages As Integer = PDFL.PageCount() ' Loop through all pages to process each one. For i As Integer = 1 To numPages ' Always select the first page as the pages get deleted after capture. PDFL.SelectPage(1) ' Retrieve the dimensions of the current page. pageWidth = PDFL.PageWidth() pageHeight = PDFL.PageHeight() ' Calculate the borders to center the scaled page content. horizBorder = pageWidth * (1.0 - scaleFactor) / 2 vertBorder = pageHeight * (1.0 - scaleFactor) / 2 ' Capture the content of the first page. This action deletes the page from the document. capturedPageId = PDFL.CapturePage(1) ' Create a new page with the original dimensions. Dim pageId As Integer = PDFL.NewPage() PDFL.SetPageDimensions(pageWidth, pageHeight) ' Draw the captured page content onto the new page with the specified scaling. ret = PDFL.DrawCapturedPage(capturedPageId, horizBorder, vertBorder, pageWidth - 2 * horizBorder, pageHeight - 2 * vertBorder) Next ' Save the modified document as a new PDF file. PDFL.SaveToFile("newpages.pdf") ' Open the newly created PDF file for review. Process.Start("newpages.pdf") End Sub |
Både VB.Net- och Delphi-versionerna av koden uppnår samma resultat som den ursprungliga C#-koden, vilket säkerställer att varje sida i PDF:en skalas ner med 70 % samtidigt som den ursprungliga ordningen bibehålls.