LibreOffice Module lotuswordpro (master) 1
xfimage.cxx
Go to the documentation of this file.
1/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2/*************************************************************************
3 *
4 * The Contents of this file are made available subject to the terms of
5 * either of the following licenses
6 *
7 * - GNU Lesser General Public License Version 2.1
8 * - Sun Industry Standards Source License Version 1.1
9 *
10 * Sun Microsystems Inc., October, 2000
11 *
12 * GNU Lesser General Public License Version 2.1
13 * =============================================
14 * Copyright 2000 by Sun Microsystems, Inc.
15 * 901 San Antonio Road, Palo Alto, CA 94303, USA
16 *
17 * This library is free software; you can redistribute it and/or
18 * modify it under the terms of the GNU Lesser General Public
19 * License version 2.1, as published by the Free Software Foundation.
20 *
21 * This library is distributed in the hope that it will be useful,
22 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
24 * Lesser General Public License for more details.
25 *
26 * You should have received a copy of the GNU Lesser General Public
27 * License along with this library; if not, write to the Free Software
28 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
29 * MA 02111-1307 USA
30 *
31 *
32 * Sun Industry Standards Source License Version 1.1
33 * =================================================
34 * The contents of this file are subject to the Sun Industry Standards
35 * Source License Version 1.1 (the "License"); You may not use this file
36 * except in compliance with the License. You may obtain a copy of the
37 * License at http://www.openoffice.org/license.html.
38 *
39 * Software provided under this License is provided on an "AS IS" basis,
40 * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
41 * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
42 * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
43 * See the License for the specific provisions governing your rights and
44 * obligations concerning the Software.
45 *
46 * The Initial Developer of the Original Code is: IBM Corporation
47 *
48 * Copyright: 2008 by IBM Corporation
49 *
50 * All Rights Reserved.
51 *
52 * Contributor(s): _______________________________________
53 *
54 *
55 ************************************************************************/
56/*************************************************************************
57 * @file
58 * Image object.
59 ************************************************************************/
60#include <xfilter/xfimage.hxx>
61#include <xfilter/xfglobal.hxx>
63#include "xfbase64.hxx"
64
65XFImage::XFImage() : m_bUseLink(false)
66{
69}
70
71void XFImage::SetFileURL(const OUString& url)
72{
73 m_strImageFile = url;
74 m_bUseLink = true;
75}
76
77void XFImage::SetImageData(sal_uInt8 const *buf, int len)
78{
79 m_strData = XFBase64::Encode(buf, len);
80 m_bUseLink = false;
81}
82
83/*
84 <text:p text:style-name="Standard">
85 <draw:image draw:style-name="fr1" draw:name="Graphic1"
86 text:anchor-type="paragraph" svg:width="4.981cm" svg:height="4.77cm"
87 draw:z-index="0" xlink:href="file:///d:/bee.wmf" xlink:type="simple"
88 xlink:show="embed" xlink:actuate="onLoad"/>
89 </text:p>
90 */
92{
93 IXFAttrList *pAttrList = pStrm->GetAttrList();
94
95 if( !GetStyleName().isEmpty() )
96 pAttrList->AddAttribute( "draw:style-name", GetStyleName() );
97
98 assert(!m_strName.isEmpty() && "name should not be null.");
99 if( !m_strName.isEmpty() )
100 pAttrList->AddAttribute( "draw:name", m_strName );
101 //anchor type:
102 switch( m_eAnchor )
103 {
104 case enumXFAnchorPara:
105 pAttrList->AddAttribute( "text:anchor-type", "paragraph" );
106 break;
107 case enumXFAnchorPage:
108 pAttrList->AddAttribute( "text:anchor-type", "page" );
109 pAttrList->AddAttribute( "text:anchor-page-number", OUString::number(m_nAnchorPage) );
110 break;
111 case enumXFAnchorChar:
112 pAttrList->AddAttribute( "text:anchor-type", "char" );
113 break;
115 pAttrList->AddAttribute( "text:anchor-type", "as-char" );
116 break;
118 pAttrList->AddAttribute( "text:anchor-type", "frame" );
119 break;
120 default:
121 break;
122 }
123 pAttrList->AddAttribute( "svg:x", OUString::number(m_aRect.GetX()) + "cm" );
124 pAttrList->AddAttribute( "svg:y", OUString::number(m_aRect.GetY()) + "cm" );
125 pAttrList->AddAttribute( "svg:width", OUString::number(m_aRect.GetWidth()) + "cm" );
126 pAttrList->AddAttribute( "svg:height", OUString::number(m_aRect.GetHeight()) + "cm" );
127 pAttrList->AddAttribute( "draw:z-index", OUString::number(m_nZIndex) );
128
129 if( m_bUseLink )
130 {
131 pAttrList->AddAttribute( "xlink:href", m_strImageFile );
132 pAttrList->AddAttribute( "xlink:type", "simple" );
133 pAttrList->AddAttribute( "xlink:show", "embed" );
134 pAttrList->AddAttribute( "xlink:actuate", "onLoad" );
135 }
136
137 pStrm->StartElement( "draw:image" );
138 if( !m_bUseLink )
139 {
140 pAttrList->Clear();
141 pStrm->StartElement( "office:binary-data" );
142 pStrm->Characters(m_strData);
143 pStrm->EndElement( "office:binary-data" );
144 }
145 pStrm->EndElement( "draw:image" );
146}
147/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
Attribute list interface for sax writer.
Definition: ixfattrlist.hxx:72
virtual void Clear()=0
@descr: Clear all the attributes in the attribute list.
virtual void AddAttribute(const OUString &name, const OUString &value)=0
@descr: Add an attribute to the attribute list.
Stream wrapper for sax writer.
Definition: ixfstream.hxx:72
virtual void Characters(const OUString &oustr)=0
@descr output text node.
virtual IXFAttrList * GetAttrList()=0
@descr return the Attribute list interface.
virtual void StartElement(const OUString &oustr)=0
@descr Wrap XDocumentHandler::startElement()
virtual void EndElement(const OUString &oustr)=0
@descr Wrap XDocumentHandler::endElement()
static OUString Encode(sal_uInt8 const *buf, sal_Int32 len)
@descr Encode binary buffer to base64 encoding.
Definition: xfbase64.cxx:97
const OUString & GetStyleName() const
: return the style name.
Definition: xfcontent.hxx:95
enumXFAnchor m_eAnchor
Definition: xfframe.hxx:176
enumXFFrameType m_eType
Definition: xfframe.hxx:183
XFRect m_aRect
Definition: xfframe.hxx:180
sal_Int32 m_nAnchorPage
Definition: xfframe.hxx:177
OUString m_strName
Definition: xfframe.hxx:178
sal_uInt32 m_nZIndex
Definition: xfframe.hxx:179
static OUString GenImageName()
@descr Generate a name for an image object
Definition: xfglobal.cxx:108
XFImage()
Definition: xfimage.cxx:65
virtual void ToXml(IXFStream *pStrm) override
@descr Output image.
Definition: xfimage.cxx:91
OUString m_strImageFile
Definition: xfimage.hxx:92
OUString m_strData
Definition: xfimage.hxx:93
void SetFileURL(const OUString &url)
@descr Use file link source.a
Definition: xfimage.cxx:71
void SetImageData(sal_uInt8 const *buf, int len)
@descr Use base64 stream.
Definition: xfimage.cxx:77
bool m_bUseLink
Definition: xfimage.hxx:94
double GetHeight() const
Definition: xfrect.hxx:115
double GetX() const
Definition: xfrect.hxx:85
double GetWidth() const
Definition: xfrect.hxx:105
double GetY() const
Definition: xfrect.hxx:95
unsigned char sal_uInt8
@ enumXFFrameImage
Definition: xfdefs.hxx:110
@ enumXFAnchorAsChar
Definition: xfdefs.hxx:261
@ enumXFAnchorChar
Definition: xfdefs.hxx:260
@ enumXFAnchorPara
Definition: xfdefs.hxx:258
@ enumXFAnchorPage
Definition: xfdefs.hxx:259
@ enumXFAnchorFrame
Definition: xfdefs.hxx:262