diff --git a/svx/source/xoutdev/_xoutbmp.cxx b/svx/source/xoutdev/_xoutbmp.cxx index 1c4c012f41c0..22a5b62d7cb4 100644 --- a/svx/source/xoutdev/_xoutbmp.cxx +++ b/svx/source/xoutdev/_xoutbmp.cxx @@ -364,7 +364,25 @@ bool XOutBitmap::GraphicToBase64(const Graphic& rGraphic, OUString& rOUString) css::uno::Sequence aOStmSeq( static_cast(aOStm.GetData()),aOStm.Tell() ); OUStringBuffer aStrBuffer; ::sax::Converter::encodeBase64(aStrBuffer,aOStmSeq); - rOUString = aMimeType + ";base64," + aStrBuffer.makeStringAndClear(); + OUString aEncodedBase64Image = aStrBuffer.makeStringAndClear(); + if( aLink.GetType() == GFX_LINK_TYPE_NATIVE_SVG ) + { + sal_Int32 ite(8); + sal_Int32 nBufferLength(aOStmSeq.getLength()); + const sal_Int8* pBuffer = aOStmSeq.getConstArray(); + css::uno::Sequence newTempSeq = aOStmSeq; // creates new Sequence to remove front 8 bits of garbage and encodes in base64 + sal_Int8 *pOutBuffer = newTempSeq.getArray(); + while(ite < nBufferLength) + { + *pOutBuffer++ = pBuffer[ite]; + ite++; + } + ::sax::Converter::encodeBase64(aStrBuffer, newTempSeq); + aEncodedBase64Image = aStrBuffer.makeStringAndClear(); + sal_Int32 SVGFixLength = aEncodedBase64Image.getLength(); + aEncodedBase64Image = aEncodedBase64Image.replaceAt(SVGFixLength - 12, SVGFixLength, "") + "PC9zdmc+Cg=="; // removes rear 12 bits of garbage and adds svg closing tag in base64 + } + rOUString = aMimeType + ";base64," + aEncodedBase64Image; return true; } diff --git a/sw/qa/extras/htmlexport/data/tdf66822.odt b/sw/qa/extras/htmlexport/data/tdf66822.odt new file mode 100644 index 000000000000..88cc750cba28 Binary files /dev/null and b/sw/qa/extras/htmlexport/data/tdf66822.odt differ diff --git a/sw/qa/extras/htmlexport/htmlexport.cxx b/sw/qa/extras/htmlexport/htmlexport.cxx index 74d6bd10d554..2d8bde87f45f 100644 --- a/sw/qa/extras/htmlexport/htmlexport.cxx +++ b/sw/qa/extras/htmlexport/htmlexport.cxx @@ -254,6 +254,16 @@ DECLARE_HTMLEXPORT_TEST(testExportInternalUrl, "tdf90905.odt") assertXPath(pDoc, "/html/body/p[2]/a", "href", "#bookmark"); } +DECLARE_HTMLEXPORT_TEST(testExportImageBulletList, "tdf66822.odt") +{ + htmlDocPtr pDoc = parseHtml(maTempFile); + CPPUNIT_ASSERT(pDoc); + + // Encoded base64 SVG bullet should match and render on browser + assertXPath(pDoc, "/html/body/ul", 1); + assertXPath(pDoc, "/html/body/ul", "style", "list-style-image: url();"); +} + CPPUNIT_PLUGIN_IMPLEMENT(); /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sw/source/filter/html/htmlnumwriter.cxx b/sw/source/filter/html/htmlnumwriter.cxx index 7b5c3f03ea6e..afad8498e4a2 100644 --- a/sw/source/filter/html/htmlnumwriter.cxx +++ b/sw/source/filter/html/htmlnumwriter.cxx @@ -266,7 +266,7 @@ Writer& OutHTML_NumBulListStart( SwHTMLWriter& rWrt, } } - if (!sOut.isEmpty()) + if (!sOut.isEmpty() && SVX_NUM_BITMAP != eType) // second condition to avoid adding extra ul, already done before. rWrt.Strm().WriteOString( sOut ); if( rWrt.m_bCfgOutStyles )