Page Setup Features with C++
Page Setup Features
Aspose.Cells provides a comprehensive set of features to configure page setup options for Excel files. These features allow you to control various aspects of the page layout, such as margins, orientation, paper size, and more.
Setting Page Margins
You can set the page margins for a worksheet using the PageSetup class. The following example demonstrates how to set the top, bottom, left, and right margins:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPageMargins() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Set page margins
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetTopMargin(1.0);
    pageSetup.SetBottomMargin(1.0);
    pageSetup.SetLeftMargin(0.75);
    pageSetup.SetRightMargin(0.75);
    // Save the workbook
    workbook.Save("PageMargins.xlsx");
}
Setting Page Orientation
You can set the page orientation to either portrait or landscape using the PageSetup class. The following example demonstrates how to set the page orientation to landscape:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPageOrientation() {
    Workbook workbook;
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetOrientation(PageOrientationType::Landscape);
    workbook.Save("PageOrientation.xlsx");
}
Setting Paper Size
You can set the paper size for printing using the PageSetup class. The following example demonstrates how to set the paper size to A4:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPaperSize() {
    Workbook workbook;
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetPaperSize(PaperSizeType::PaperA4);
    workbook.Save("PaperSize.xlsx");
}
Setting Print Area
You can define a specific range of cells to be printed using the PageSetup class. The following example demonstrates how to set the print area:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintArea() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Set print area
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetPrintArea("A1:D10");
    // Save the workbook
    workbook.Save("PrintArea.xlsx");
}
Setting Page Breaks
You can insert page breaks in a worksheet to control where pages end and new pages begin. The following example demonstrates how to insert a horizontal page break:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPageBreaks() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Insert a horizontal page break at row 10
    worksheet.GetHorizontalPageBreaks().Add("A10");
    // Save the workbook
    workbook.Save("PageBreaks.xlsx");
}
Setting Header and Footer
You can customize the header and footer of a worksheet using the PageSetup class. The following example demonstrates how to set a custom header and footer:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetHeaderFooter() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Set custom header and footer
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetHeader(0, "&CHeader Text");
    pageSetup.SetFooter(0, "&CFooter Text");
    // Save the workbook
    workbook.Save("HeaderFooter.xlsx");
}
Setting Print Titles
You can specify rows or columns to repeat at the top or left of each printed page using the PageSetup class. The following example demonstrates how to set print titles:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintTitles() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Set print titles
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetPrintTitleRows("$1:$1");
    pageSetup.SetPrintTitleColumns("$A:$A");
    // Save the workbook
    workbook.Save("PrintTitles.xlsx");
}
Setting Print Quality
You can set the print quality for a worksheet using the PageSetup class. The following example demonstrates how to set the print quality:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintQuality() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Set print quality
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetPrintQuality(600);
    // Save the workbook
    workbook.Save("PrintQuality.xlsx");
}
Setting Print Order
You can set the print order for a worksheet using the PageSetup class. The following example demonstrates how to set the print order to “Over, then Down”:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintOrder() {
    Workbook workbook;
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetOrder(PrintOrderType::OverThenDown);
    workbook.Save("PrintOrder.xlsx");
}
Setting Print Gridlines
You can control whether gridlines are printed using the PageSetup class. The following example demonstrates how to enable printing of gridlines:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintGridlines() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Enable printing of gridlines
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetPrintGridlines(true);
    // Save the workbook
    workbook.Save("PrintGridlines.xlsx");
}
Setting Print Headings
You can control whether row and column headings are printed using the PageSetup class. The following example demonstrates how to enable printing of headings:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintHeadings() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Enable printing of headings
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetPrintHeadings(true);
    // Save the workbook
    workbook.Save("PrintHeadings.xlsx");
}
Setting Print Black and White
You can control whether the worksheet is printed in black and white using the PageSetup class. The following example demonstrates how to enable black and white printing:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintBlackAndWhite() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Enable black and white printing
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetBlackAndWhite(true);
    // Save the workbook
    workbook.Save("PrintBlackAndWhite.xlsx");
}
Setting Print Draft
You can control whether the worksheet is printed in draft quality using the PageSetup class. The following example demonstrates how to enable draft quality printing:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintDraft() {
    Workbook workbook;
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetPrintDraft(true);
    workbook.Save("PrintDraft.xlsx");
}
Setting Print Comments
You can control whether comments are printed using the PageSetup class. The following example demonstrates how to enable printing of comments:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintComments() {
    Workbook workbook;
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetPrintComments(PrintCommentsType::PrintInPlace);
    workbook.Save("PrintComments.xlsx");
}
Setting Print Errors
You can control how errors are printed using the PageSetup class. The following example demonstrates how to set the error printing option:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintErrors() {
    Workbook workbook;
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetPrintErrors(PrintErrorsType::PrintErrorsBlank);
    workbook.Save("PrintErrors.xlsx");
}
Setting Print Area Fit to Pages
You can control whether the print area is scaled to fit a specific number of pages using the PageSetup class. The following example demonstrates how to set the print area to fit to one page wide and one page tall:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintAreaFitToPages() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Set print area to fit to one page wide and one page tall
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetFitToPagesWide(1);
    pageSetup.SetFitToPagesTall(1);
    // Save the workbook
    workbook.Save("PrintAreaFitToPages.xlsx");
}
Setting Print Scale
You can set the print scale for a worksheet using the PageSetup class. The following example demonstrates how to set the print scale to 50%:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintScale() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Set print scale to 50%
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetZoom(50);
    // Save the workbook
    workbook.Save("PrintScale.xlsx");
}
Setting Print Center Horizontally and Vertically
You can control whether the worksheet is centered horizontally and vertically on the printed page using the PageSetup class. The following example demonstrates how to center the worksheet horizontally and vertically:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintCenterHorizontallyAndVertically() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Center the worksheet horizontally and vertically
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetCenterHorizontally(true);
    pageSetup.SetCenterVertically(true);
    // Save the workbook
    workbook.Save("PrintCenterHorizontallyAndVertically.xlsx");
}
Setting Print First Page Number
You can set the first page number for printing using the PageSetup class. The following example demonstrates how to set the first page number:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintFirstPageNumber() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Set the first page number
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetFirstPageNumber(2);
    // Save the workbook
    workbook.Save("PrintFirstPageNumber.xlsx");
}
Setting Print Page Number
You can control whether the page number is printed using the PageSetup class. The following example demonstrates how to enable printing of the page number:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintPrintPageNumber() {
    Workbook workbook;
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    PageSetup pageSetup = worksheet.GetPageSetup();
    pageSetup.SetHeader(0, "&P");
    workbook.Save("PrintPageNumber.xlsx");
}
Setting Print Page Order
You can set the order in which pages are printed using the PageSetup class. The following example demonstrates how to set the page order to “Down, then Over”:
#include <Aspose.Cells.h>
using namespace Aspose::Cells;
void SetPrintPageOrder() {
    // Create a new workbook
    Workbook workbook;
    // Access the first worksheet
    Worksheet worksheet = workbook.GetWorksheets().Get(0);
    // Set the page order to "Down, then Over"
    PageSetup