odf.h revision 066b6e871cbe078a23e6812d82e7f4fa96b5ead8
/**
* OpenDocument <drawing> input and output
*
* This is an an entry in the extensions mechanism to begin to enable
* the inputting and outputting of OpenDocument Format (ODF) files from
* within Inkscape. Although the initial implementations will be very lossy
* do to the differences in the models of SVG and ODF, they will hopefully
* improve greatly with time.
*
* http://www.w3.org/TR/2004/REC-DOM-Level-3-Core-20040407/idl-definitions.html
*
* Authors:
* Bob Jamison
*
* Copyright (C) 2006 Bob Jamison
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef EXTENSION_INTERNAL_ODG_OUT_H
#define EXTENSION_INTERNAL_ODG_OUT_H
#include <dom/dom.h>
#include <dom/io/stringstream.h>
#include <dom/uri.h>
#include <glib.h>
#include "extension/implementation/implementation.h"
#include <xml/repr.h>
#include <string>
#include <map>
#include <dom/util/ziptool.h>
#include <dom/io/domstream.h>
namespace Inkscape
{
namespace Extension
{
namespace Internal
{
typedef org::w3c::dom::URI URI;
typedef org::w3c::dom::io::Writer Writer;
class StyleInfo
{
public:
StyleInfo()
{
init();
}
StyleInfo(const StyleInfo &other)
{
assign(other);
}
StyleInfo &operator=(const StyleInfo &other)
{
assign(other);
return *this;
}
void assign(const StyleInfo &other)
{
name = other.name;
stroke = other.stroke;
strokeColor = other.strokeColor;
strokeWidth = other.strokeWidth;
strokeOpacity = other.strokeOpacity;
fill = other.fill;
fillColor = other.fillColor;
fillOpacity = other.fillOpacity;
}
void init()
{
name = "none";
stroke = "none";
strokeColor = "none";
strokeWidth = "none";
strokeOpacity = "none";
fill = "none";
fillColor = "none";
fillOpacity = "none";
}
virtual ~StyleInfo()
{}
//used for eliminating duplicates in the styleTable
bool equals(const StyleInfo &other)
{
if (
stroke != other.stroke ||
strokeColor != other.strokeColor ||
strokeWidth != other.strokeWidth ||
strokeOpacity != other.strokeOpacity ||
fill != other.fill ||
fillColor != other.fillColor ||
fillOpacity != other.fillOpacity
)
return false;
return true;
}
std::string name;
std::string stroke;
std::string strokeColor;
std::string strokeWidth;
std::string strokeOpacity;
std::string fill;
std::string fillColor;
std::string fillOpacity;
};
class OdfOutput : public Inkscape::Extension::Implementation::Implementation
{
public:
bool check (Inkscape::Extension::Extension * module);
void save (Inkscape::Extension::Output *mod,
SPDocument *doc,
const gchar *uri);
static void init (void);
private:
URI documentUri;
/* Style table
Uses a two-stage lookup to avoid style duplication.
Use like:
StyleInfo si = styleTable[styleLookupTable[id]];
but check for errors, of course
*/
//element id -> style entry name
std::map<std::string, std::string> styleLookupTable;
//style entry name -> style info
std::vector<StyleInfo> styleTable;
//for renaming image file names
std::map<std::string, std::string> imageTable;
void preprocess(ZipFile &zf, Inkscape::XML::Node *node);
bool writeManifest(ZipFile &zf);
bool writeMeta(ZipFile &zf);
bool writeStyle(Writer &outs);
bool writeTree(Writer &outs, Inkscape::XML::Node *node);
bool writeContent(ZipFile &zf, Inkscape::XML::Node *node);
};
} //namespace Internal
} //namespace Extension
} //namespace Inkscape
#endif /* EXTENSION_INTERNAL_ODG_OUT_H */