284 lines
8.8 KiB
C++
284 lines
8.8 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
|
/*
|
|
* 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/.
|
|
*/
|
|
|
|
#ifndef INCLUDED_LIBREOFFICEKIT_LIBREOFFICEKIT_HXX
|
|
#define INCLUDED_LIBREOFFICEKIT_LIBREOFFICEKIT_HXX
|
|
|
|
#include "LibreOfficeKit.h"
|
|
|
|
/*
|
|
* The reasons this C++ code is not as pretty as it could be are:
|
|
* a) provide a pure C API - that's useful for some people
|
|
* b) allow ABI stability - C++ vtables are not good for that.
|
|
* c) avoid C++ types as part of the API.
|
|
*/
|
|
namespace lok
|
|
{
|
|
|
|
/// The lok::Document class represents one loaded document instance.
|
|
class Document
|
|
{
|
|
private:
|
|
LibreOfficeKitDocument* mpDoc;
|
|
|
|
public:
|
|
/// A lok::Document is typically created by the lok::Office::documentLoad() method.
|
|
inline Document(LibreOfficeKitDocument* pDoc) :
|
|
mpDoc(pDoc)
|
|
{}
|
|
|
|
inline ~Document()
|
|
{
|
|
mpDoc->pClass->destroy(mpDoc);
|
|
}
|
|
|
|
/**
|
|
* Stores the document's persistent data to a URL and
|
|
* continues to be a representation of the old URL.
|
|
*
|
|
* @param pUrl the location where to store the document
|
|
* @param pFormat the format to use while exporting, when omitted, then deducted from pURL's extension
|
|
* @param pFilterOptions options for the export filter, e.g. SkipImages.
|
|
*/
|
|
inline bool saveAs(const char* pUrl, const char* pFormat = NULL, const char* pFilterOptions = NULL)
|
|
{
|
|
return mpDoc->pClass->saveAs(mpDoc, pUrl, pFormat, pFilterOptions) != 0;
|
|
}
|
|
|
|
/// Gives access to the underlying C pointer.
|
|
inline LibreOfficeKitDocument *get() { return mpDoc; }
|
|
|
|
#ifdef LOK_USE_UNSTABLE_API
|
|
/**
|
|
* Get document type.
|
|
*
|
|
* @return an element of the LibreOfficeKitDocumentType enum.
|
|
*/
|
|
inline int getDocumentType()
|
|
{
|
|
return mpDoc->pClass->getDocumentType(mpDoc);
|
|
}
|
|
|
|
/**
|
|
* Get number of part that the document contains.
|
|
*
|
|
* Part refers to either indivual sheets in a Calc, or slides in Impress,
|
|
* and has no relevance for Writer.
|
|
*/
|
|
inline int getParts()
|
|
{
|
|
return mpDoc->pClass->getParts(mpDoc);
|
|
}
|
|
|
|
/// Get the current part of the document.
|
|
inline int getPart()
|
|
{
|
|
return mpDoc->pClass->getPart(mpDoc);
|
|
}
|
|
|
|
/// Set the current part of the document.
|
|
inline void setPart(int nPart)
|
|
{
|
|
mpDoc->pClass->setPart(mpDoc, nPart);
|
|
}
|
|
|
|
/// Get the current part's name.
|
|
inline char* getPartName(int nPart)
|
|
{
|
|
return mpDoc->pClass->getPartName(mpDoc, nPart);
|
|
}
|
|
|
|
/**
|
|
* Renders a subset of the document to a pre-allocated buffer.
|
|
*
|
|
* Note that the buffer size and the tile size implicitly supports
|
|
* rendering at different zoom levels, as the number of rendered pixels and
|
|
* the rendered rectangle of the document are independent.
|
|
*
|
|
* @param pBuffer pointer to the buffer, its size is determined by nCanvasWidth and nCanvasHeight.
|
|
* @param nCanvasWidth number of pixels in a row of pBuffer.
|
|
* @param nCanvasHeight number of pixels in a column of pBuffer.
|
|
* @param nTilePosX logical X position of the top left corner of the rendered rectangle, in TWIPs.
|
|
* @param nTilePosY logical Y position of the top left corner of the rendered rectangle, in TWIPs.
|
|
* @param nTileWidth logical width of the rendered rectangle, in TWIPs.
|
|
* @param nTileHeight logical height of the rendered rectangle, in TWIPs.
|
|
*/
|
|
inline void paintTile(
|
|
unsigned char* pBuffer,
|
|
const int nCanvasWidth,
|
|
const int nCanvasHeight,
|
|
const int nTilePosX,
|
|
const int nTilePosY,
|
|
const int nTileWidth,
|
|
const int nTileHeight)
|
|
{
|
|
return mpDoc->pClass->paintTile(mpDoc, pBuffer, nCanvasWidth, nCanvasHeight,
|
|
nTilePosX, nTilePosY, nTileWidth, nTileHeight);
|
|
}
|
|
|
|
/// Get the document sizes in TWIPs.
|
|
inline void getDocumentSize(long* pWidth, long* pHeight)
|
|
{
|
|
mpDoc->pClass->getDocumentSize(mpDoc, pWidth, pHeight);
|
|
}
|
|
|
|
/**
|
|
* Initialize document for rendering.
|
|
*
|
|
* Sets the rendering and document parameters to default values that are
|
|
* needed to render the document correctly using tiled rendering. This
|
|
* method has to be called right after documentLoad() in case any of the
|
|
* tiled rendering methods are to be used later.
|
|
*/
|
|
inline void initializeForRendering()
|
|
{
|
|
mpDoc->pClass->initializeForRendering(mpDoc);
|
|
}
|
|
|
|
/**
|
|
* Registers a callback. LOK will invoke this function when it wants to
|
|
* inform the client about events.
|
|
*
|
|
* @param pCallback the callback to invoke
|
|
* @param pData the user data, will be passed to the callback on invocation
|
|
*/
|
|
inline void registerCallback(LibreOfficeKitCallback pCallback, void* pData)
|
|
{
|
|
mpDoc->pClass->registerCallback(mpDoc, pCallback, pData);
|
|
}
|
|
|
|
/**
|
|
* Posts a keyboard event to the focused frame.
|
|
*
|
|
* @param nType Event type, like press or release.
|
|
* @param nCharCode contains the Unicode character generated by this event or 0
|
|
* @param nKeyCode contains the integer code representing the key of the event (non-zero for control keys)
|
|
*/
|
|
inline void postKeyEvent(int nType, int nCharCode, int nKeyCode)
|
|
{
|
|
mpDoc->pClass->postKeyEvent(mpDoc, nType, nCharCode, nKeyCode);
|
|
}
|
|
|
|
/**
|
|
* Posts a mouse event to the document.
|
|
*
|
|
* @param nType Event type, like down, move or up.
|
|
* @param nX horizontal position in document coordinates
|
|
* @param nY vertical position in document coordinates
|
|
* @param nCount number of clicks: 1 for single click, 2 for double click
|
|
*/
|
|
inline void postMouseEvent(int nType, int nX, int nY, int nCount)
|
|
{
|
|
mpDoc->pClass->postMouseEvent(mpDoc, nType, nX, nY, nCount);
|
|
}
|
|
|
|
/**
|
|
* Posts an UNO command to the document.
|
|
*
|
|
* @param pCommand uno command to be posted to the document, like ".uno:Bold"
|
|
*/
|
|
inline void postUnoCommand(const char* pCommand)
|
|
{
|
|
mpDoc->pClass->postUnoCommand(mpDoc, pCommand);
|
|
}
|
|
|
|
/**
|
|
* Sets the start or end of a text selection.
|
|
*
|
|
* @param nType @see LibreOfficeKitSetTextSelectionType
|
|
* @param nX horizontal position in document coordinates
|
|
* @param nY vertical position in document coordinates
|
|
*/
|
|
inline void setTextSelection(int nType, int nX, int nY)
|
|
{
|
|
mpDoc->pClass->setTextSelection(mpDoc, nType, nX, nY);
|
|
}
|
|
|
|
/**
|
|
* Adjusts the graphic selection.
|
|
*
|
|
* @param nType @see LibreOfficeKitSetGraphicSelectionType
|
|
* @param nX horizontal position in document coordinates
|
|
* @param nY vertical position in document coordinates
|
|
*/
|
|
inline void setGraphicSelection(int nType, int nX, int nY)
|
|
{
|
|
mpDoc->pClass->setGraphicSelection(mpDoc, nType, nX, nY);
|
|
}
|
|
|
|
/**
|
|
* Gets rid of any text or graphic selection.
|
|
*/
|
|
inline void resetSelection()
|
|
{
|
|
mpDoc->pClass->resetSelection(mpDoc);
|
|
}
|
|
#endif // LOK_USE_UNSTABLE_API
|
|
};
|
|
|
|
/// The lok::Office class represents one started LibreOfficeKit instance.
|
|
class Office
|
|
{
|
|
private:
|
|
LibreOfficeKit* mpThis;
|
|
|
|
public:
|
|
/// A lok::Office is typically created by the lok_cpp_init() function.
|
|
inline Office(LibreOfficeKit* pThis) :
|
|
mpThis(pThis)
|
|
{}
|
|
|
|
inline ~Office()
|
|
{
|
|
mpThis->pClass->destroy(mpThis);
|
|
}
|
|
|
|
/**
|
|
* Loads a document from an URL.
|
|
*
|
|
* @param pUrl the URL of the document to load
|
|
* @param pFilterOptions options for the import filter, e.g. SkipImages.
|
|
*/
|
|
inline Document* documentLoad(const char* pUrl, const char* pFilterOptions = NULL)
|
|
{
|
|
LibreOfficeKitDocument* pDoc = NULL;
|
|
|
|
if (LIBREOFFICEKIT_HAS(mpThis, documentLoadWithOptions))
|
|
pDoc = mpThis->pClass->documentLoadWithOptions(mpThis, pUrl, pFilterOptions);
|
|
else
|
|
pDoc = mpThis->pClass->documentLoad(mpThis, pUrl);
|
|
|
|
if (pDoc == NULL)
|
|
return NULL;
|
|
|
|
return new Document(pDoc);
|
|
}
|
|
|
|
/// Returns the last error as a string, the returned pointer has to be freed by the caller.
|
|
inline char* getError()
|
|
{
|
|
return mpThis->pClass->getError(mpThis);
|
|
}
|
|
};
|
|
|
|
/// Factory method to create a lok::Office instance.
|
|
inline Office* lok_cpp_init(const char* pInstallPath)
|
|
{
|
|
LibreOfficeKit* pThis = lok_init(pInstallPath);
|
|
if (pThis == NULL || pThis->pClass->nSize == 0)
|
|
return NULL;
|
|
return new ::lok::Office(pThis);
|
|
}
|
|
|
|
}
|
|
|
|
#endif // INCLUDED_LIBREOFFICEKIT_LIBREOFFICEKIT_HXX
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|