/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace rtl; using namespace cppu; using namespace css::uno; using namespace css::lang; using namespace css::frame; using namespace css::container; using namespace css::sheet; using namespace css::beans; using namespace css::table; SAL_IMPLEMENT_MAIN() { try { Reference xRemoteContext = bootstrap(); if (!xRemoteContext.is()) { std::cerr << "ERROR: Could not bootstrap default Office.\n"; return 1; } Reference xRemoteServiceManager = xRemoteContext->getServiceManager(); Reference desktop = xRemoteServiceManager->createInstanceWithContext( "com.sun.star.frame.Desktop", xRemoteContext); Reference xComponentLoader = Reference(desktop, UNO_QUERY); Sequence loadProps(0); Reference xSpreadsheetComponent = xComponentLoader->loadComponentFromURL( "private:factory/scalc", "_blank", 0, loadProps); Reference xSpreadsheetDocument(xSpreadsheetComponent, UNO_QUERY); Reference xSpreadsheets = xSpreadsheetDocument->getSheets(); xSpreadsheets->insertNewByName("MySheet", (sal_Int16)0); Type elemType = xSpreadsheets->getElementType(); std::cout << elemType.getTypeName() << std::endl; Any sheet = xSpreadsheets->getByName("MySheet"); Reference xSpreadsheet(sheet, UNO_QUERY); Reference xCell = xSpreadsheet->getCellByPosition(0, 0); xCell->setValue(21); xCell = xSpreadsheet->getCellByPosition(0, 1); xCell->setValue(21); xCell = xSpreadsheet->getCellByPosition(0, 2); xCell->setFormula("=sum(A1:A2)"); Reference xCellProps(xCell, UNO_QUERY); xCellProps->setPropertyValue("CellStyle", Any(OUString("Result"))); Reference xSpreadsheetModel(xSpreadsheetComponent, UNO_QUERY); Reference xSpreadsheetController = xSpreadsheetModel->getCurrentController(); Reference xSpreadsheetView(xSpreadsheetController, UNO_QUERY); xSpreadsheetView->setActiveSheet(xSpreadsheet); // ********************************************************* // example for use of enum types xCellProps->setPropertyValue("VertJustify", Any(CellVertJustify_TOP)); // ********************************************************* // example for a sequence of PropertyValue structs // create an array with one PropertyValue struct, it contains // references only loadProps.realloc(1); // instantiate PropertyValue struct and set its member fields PropertyValue asTemplate; asTemplate.Name = "AsTemplate"; asTemplate.Value = makeAny(true); // assign PropertyValue struct to array of references for PropertyValue // structs loadProps[0] = asTemplate; // load calc file as a template // xSpreadsheetComponent = xComponentLoader->loadComponentFromURL( // "file:///c:/temp/DataAnalysys.ods", "_blank", 0, loadProps); // ********************************************************* // example for use of XEnumerationAccess Reference xCellQuery(sheet, UNO_QUERY); Reference xFormulaCells = xCellQuery->queryContentCells((sal_Int16)CellFlags::FORMULA); Reference xFormulas = xFormulaCells->getCells(); Reference xFormulaEnum = xFormulas->createEnumeration(); while (xFormulaEnum->hasMoreElements()) { Reference formulaCell(xFormulaEnum->nextElement(), UNO_QUERY); Reference xCellAddress(formulaCell, UNO_QUERY); if (xCellAddress.is()) { std::cout << "Formula cell in column " << xCellAddress->getCellAddress().Column << ", row " << xCellAddress->getCellAddress().Row << " contains " << formulaCell->getFormula() << std::endl; } } } catch (RuntimeException& e) { std::cerr << e.Message << "\n"; return 1; } return 0; } /* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */