/* 5. Test the _write_sheet_views() method with selection set. */ CTEST(worksheet, set_selection05) { char* got; char exp[] = "<sheetViews><sheetView tabSelected=\"1\" workbookViewId=\"0\"><selection activeCell=\"D3\" sqref=\"D3:F4\"/></sheetView></sheetViews>"; FILE* testfile = tmpfile(); lxw_worksheet *worksheet = lxw_worksheet_new(NULL); worksheet->file = testfile; worksheet_select(worksheet); worksheet_set_selection(worksheet, RANGE("D3:F4")); _worksheet_write_sheet_views(worksheet); RUN_XLSX_STREQ(exp, got); lxw_worksheet_free(worksheet); }
/* 1. Test the _write_sheet_views() method with selection set. */ CTEST(worksheet, set_selection01) { char* got; char exp[] = "<sheetViews><sheetView tabSelected=\"1\" workbookViewId=\"0\"/></sheetViews>"; FILE* testfile = tmpfile(); lxw_worksheet *worksheet = lxw_worksheet_new(NULL); worksheet->file = testfile; worksheet_select(worksheet); worksheet_set_selection(worksheet, 0, 0, 0, 0); _worksheet_write_sheet_views(worksheet); RUN_XLSX_STREQ(exp, got); lxw_worksheet_free(worksheet); }
/* 5. Test the _write_sheet_views() method with freeze panes. */ CTEST(worksheet, set_selection25) { char* got; char exp[] = "<sheetViews><sheetView tabSelected=\"1\" workbookViewId=\"0\"><pane xSplit=\"6\" ySplit=\"3\" topLeftCell=\"I7\" activePane=\"bottomRight\" state=\"frozen\"/><selection pane=\"topRight\" activeCell=\"G1\" sqref=\"G1\"/><selection pane=\"bottomLeft\" activeCell=\"A4\" sqref=\"A4\"/><selection pane=\"bottomRight\" activeCell=\"G4\" sqref=\"G4\"/></sheetView></sheetViews>"; FILE* testfile = tmpfile(); lxw_worksheet *worksheet = lxw_worksheet_new(NULL); worksheet->file = testfile; worksheet_select(worksheet); worksheet_set_selection(worksheet, RANGE("G4:G4")); worksheet_freeze_panes_opt(worksheet, 3, 6, 6, 8, 0); _worksheet_write_sheet_views(worksheet); RUN_XLSX_STREQ(exp, got); lxw_worksheet_free(worksheet); }
/* 4. Test the _write_sheet_views() method with freeze panes. */ CTEST(worksheet, set_selection24) { char* got; char exp[] = "<sheetViews><sheetView tabSelected=\"1\" workbookViewId=\"0\"><pane xSplit=\"1\" topLeftCell=\"E1\" activePane=\"topRight\" state=\"frozen\"/><selection pane=\"topRight\"/></sheetView></sheetViews>"; FILE* testfile = tmpfile(); lxw_worksheet *worksheet = lxw_worksheet_new(NULL); worksheet->file = testfile; worksheet_select(worksheet); worksheet_set_selection(worksheet, RANGE("A1:A1")); worksheet_freeze_panes_opt(worksheet, 0, 1, 0, 4, 0); _worksheet_write_sheet_views(worksheet); RUN_XLSX_STREQ(exp, got); lxw_worksheet_free(worksheet); }
/* 4. Test the _write_sheet_views() method with split panes + selection. */ CTEST(worksheet, set_selection34) { char* got; char exp[] = "<sheetViews><sheetView tabSelected=\"1\" workbookViewId=\"0\"><pane xSplit=\"6150\" ySplit=\"1200\" topLeftCell=\"G4\" activePane=\"bottomRight\"/><selection pane=\"topRight\" activeCell=\"G1\" sqref=\"G1\"/><selection pane=\"bottomLeft\" activeCell=\"A4\" sqref=\"A4\"/><selection pane=\"bottomRight\" activeCell=\"I5\" sqref=\"I5\"/></sheetView></sheetViews>"; FILE* testfile = lxw_tmpfile(NULL); lxw_worksheet *worksheet = lxw_worksheet_new(NULL); worksheet->file = testfile; worksheet_select(worksheet); worksheet_set_selection(worksheet, RANGE("I5:I5")); worksheet_split_panes(worksheet, 45, 54.14); _worksheet_write_sheet_views(worksheet); RUN_XLSX_STREQ(exp, got); lxw_worksheet_free(worksheet); }
/* 2. Test the _write_sheet_views() method with split panes + selection. */ CTEST(worksheet, set_selection32) { char* got; char exp[] = "<sheetViews><sheetView tabSelected=\"1\" workbookViewId=\"0\"><pane xSplit=\"1350\" topLeftCell=\"B1\" activePane=\"topRight\"/><selection pane=\"topRight\" activeCell=\"B1\" sqref=\"B1\"/></sheetView></sheetViews>"; FILE* testfile = lxw_tmpfile(NULL); lxw_worksheet *worksheet = lxw_worksheet_new(NULL); worksheet->file = testfile; worksheet_select(worksheet); worksheet_set_selection(worksheet, RANGE("B1:B1")); worksheet_split_panes(worksheet, 0, 8.43); _worksheet_write_sheet_views(worksheet); RUN_XLSX_STREQ(exp, got); lxw_worksheet_free(worksheet); }
/* 1. Test the _write_sheet_views() method with split panes + selection. */ CTEST(worksheet, set_selection31) { char* got; char exp[] = "<sheetViews><sheetView tabSelected=\"1\" workbookViewId=\"0\"><pane ySplit=\"600\" topLeftCell=\"A2\" activePane=\"bottomLeft\"/><selection pane=\"bottomLeft\" activeCell=\"A2\" sqref=\"A2\"/></sheetView></sheetViews>"; FILE* testfile = lxw_tmpfile(NULL); lxw_worksheet *worksheet = lxw_worksheet_new(NULL); worksheet->file = testfile; worksheet_select(worksheet); worksheet_set_selection(worksheet, RANGE("A2:A2")); worksheet_split_panes(worksheet, 15, 0); _worksheet_write_sheet_views(worksheet); RUN_XLSX_STREQ(exp, got); lxw_worksheet_free(worksheet); }
int main() { int row; int col; /* Create a new workbook and add some worksheets. */ lxw_workbook *workbook = workbook_new("panes.xlsx"); lxw_worksheet *worksheet1 = workbook_add_worksheet(workbook, "Panes 1"); lxw_worksheet *worksheet2 = workbook_add_worksheet(workbook, "Panes 2"); lxw_worksheet *worksheet3 = workbook_add_worksheet(workbook, "Panes 3"); lxw_worksheet *worksheet4 = workbook_add_worksheet(workbook, "Panes 4"); /* Set up some formatting and text to highlight the panes. */ lxw_format *header = workbook_add_format(workbook); format_set_align(header, LXW_ALIGN_CENTER); format_set_align(header, LXW_ALIGN_VERTICAL_CENTER); format_set_fg_color(header, 0xD7E4BC); format_set_bold(header); format_set_border(header, LXW_BORDER_THIN); lxw_format *center = workbook_add_format(workbook); format_set_align(center, LXW_ALIGN_CENTER); /* * Example 1. Freeze pane on the top row. */ worksheet_freeze_panes(worksheet1, 1, 0); /* Some sheet formatting. */ worksheet_set_column(worksheet1, 0, 8, 16, NULL); worksheet_set_row(worksheet1, 0, 20, NULL); worksheet_set_selection(worksheet1, 4, 3, 4, 3); /* Some worksheet text to demonstrate scrolling. */ for (col = 0; col < 9; col++) { worksheet_write_string(worksheet1, 0, col, "Scroll down", header); } for (row = 1; row < 100; row++) { for (col = 0; col < 9; col++) { worksheet_write_number(worksheet1, row, col, row + 1, center); } } /* * Example 2. Freeze pane on the left column. */ worksheet_freeze_panes(worksheet2, 0, 1); /* Some sheet formatting. */ worksheet_set_column(worksheet2, 0, 0, 16, NULL); worksheet_set_selection(worksheet2, 4, 3, 4, 3); /* Some worksheet text to demonstrate scrolling. */ for (row = 0; row < 50; row++) { worksheet_write_string(worksheet2, row, 0, "Scroll right", header); for (col = 1; col < 26; col++) { worksheet_write_number(worksheet2, row, col, col, center); } } /* * Example 3. Freeze pane on the top row and left column. */ worksheet_freeze_panes(worksheet3, 1, 1); /* Some sheet formatting. */ worksheet_set_column(worksheet3, 0, 25, 16, NULL); worksheet_set_row(worksheet3, 0, 20, NULL); worksheet_write_string(worksheet3, 0, 0, "", header); worksheet_set_selection(worksheet3, 4, 3, 4, 3); /* Some worksheet text to demonstrate scrolling. */ for (col = 1; col < 26; col++) { worksheet_write_string(worksheet3, 0, col, "Scroll down", header); } for (row = 1; row < 50; row++) { worksheet_write_string(worksheet3, row, 0, "Scroll right", header); for (col = 1; col < 26; col++) { worksheet_write_number(worksheet3, row, col, col, center); } } /* * Example 4. Split pane on the top row and left column. * * The divisions must be specified in terms of row and column dimensions. * The default row height is 15 and the default column width is 8.43 */ worksheet_split_panes(worksheet4, 15, 8.43); /* Some sheet formatting. */ /* Some worksheet text to demonstrate scrolling. */ for (col = 1; col < 26; col++) { worksheet_write_string(worksheet4, 0, col, "Scroll", center); } for (row = 1; row < 50; row++) { worksheet_write_string(worksheet4, row, 0, "Scroll", center); for (col = 1; col < 26; col++) { worksheet_write_number(worksheet4, row, col, col, center); } } workbook_close(workbook); return 0; }