/* -*- 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/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #ifdef WNT #include #include #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "graphhelp.hxx" #include "doc.hrc" using namespace ::com::sun::star; SvMemoryStream* GraphicHelper::getFormatStrFromGDI_Impl( const GDIMetaFile* pGDIMeta, sal_uInt32 nFormat ) { SvMemoryStream* pResult = NULL; if ( pGDIMeta ) { SvMemoryStream* pStream = new SvMemoryStream( 65535, 65535 ); if ( pStream ) { Graphic aGraph( *pGDIMeta ); if ( GraphicConverter::Export( *pStream, aGraph, nFormat ) == 0 ) pResult = pStream; else delete pStream; } } return pResult; } // static void* GraphicHelper::getEnhMetaFileFromGDI_Impl( const GDIMetaFile* pGDIMeta ) { (void)pGDIMeta; // unused void* pResult = NULL; #ifdef WNT if ( pGDIMeta ) { OUString const aStr(".emf"); ::utl::TempFile aTempFile( OUString(), true, &aStr ); OUString aMetaFile = aTempFile.GetFileName(); OUString aMetaURL = aTempFile.GetURL(); OString aWinFile = OUStringToOString( aMetaFile, osl_getThreadTextEncoding() ); SvStream* pStream = ::utl::UcbStreamHelper::CreateStream( aMetaURL, STREAM_STD_READWRITE ); if ( pStream ) { Graphic aGraph( *pGDIMeta ); sal_Bool bFailed = (sal_Bool)GraphicConverter::Export( *pStream, aGraph, CVT_EMF ); pStream->Flush(); delete pStream; if ( !bFailed ) pResult = GetEnhMetaFileA( aWinFile.getStr() ); } } #endif return pResult; } // static void* GraphicHelper::getWinMetaFileFromGDI_Impl( const GDIMetaFile* pGDIMeta, const Size& aMetaSize ) { (void)pGDIMeta; // unused (void)aMetaSize; // unused void* pResult = NULL; #ifdef WNT if ( pGDIMeta ) { SvMemoryStream* pStream = new SvMemoryStream( 65535, 65535 ); if ( pStream ) { Graphic aGraph( *pGDIMeta ); sal_Bool bFailed = (sal_Bool)GraphicConverter::Export( *pStream, aGraph, CVT_WMF ); pStream->Flush(); if ( !bFailed ) { sal_Int32 nLength = pStream->Seek( STREAM_SEEK_TO_END ); if ( nLength > 22 ) { HMETAFILE hMeta = SetMetaFileBitsEx( nLength - 22, ( reinterpret_cast< const unsigned char*>( pStream->GetData() ) ) + 22 ); if ( hMeta ) { HGLOBAL hMemory = GlobalAlloc( GMEM_DDESHARE | GMEM_MOVEABLE, sizeof( METAFILEPICT ) ); if ( hMemory ) { METAFILEPICT* pMF = (METAFILEPICT*)GlobalLock( hMemory ); pMF->hMF = hMeta; pMF->mm = MM_ANISOTROPIC; MapMode aMetaMode = pGDIMeta->GetPrefMapMode(); MapMode aWinMode( MAP_100TH_MM ); if ( aWinMode == pGDIMeta->GetPrefMapMode() ) { pMF->xExt = aMetaSize.Width(); pMF->yExt = aMetaSize.Height(); } else { Size aWinSize = OutputDevice::LogicToLogic( Size( aMetaSize.Width(), aMetaSize.Height() ), pGDIMeta->GetPrefMapMode(), aWinMode ); pMF->xExt = aWinSize.Width(); pMF->yExt = aWinSize.Height(); } GlobalUnlock( hMemory ); pResult = (void*)hMemory; } else DeleteMetaFile( hMeta ); } } } delete pStream; } } #endif return pResult; } // static bool GraphicHelper::supportsMetaFileHandle_Impl() { #ifdef WNT return true; #else return false; #endif } // static bool GraphicHelper::getThumbnailFormatFromGDI_Impl( GDIMetaFile* pMetaFile, const uno::Reference< io::XStream >& xStream ) { bool bResult = false; SvStream* pStream = NULL; if ( xStream.is() ) pStream = ::utl::UcbStreamHelper::CreateStream( xStream ); if ( pMetaFile && pStream && !pStream->GetError() ) { BitmapEx aResultBitmap; bResult = pMetaFile->CreateThumbnail(aResultBitmap); if ( bResult ) bResult = ( !aResultBitmap.IsEmpty() && GraphicConverter::Export( *pStream, aResultBitmap, CVT_PNG ) == 0 && ( pStream->Flush(), !pStream->GetError() ) ); delete pStream; } return bResult; } // static bool GraphicHelper::getThumbnailReplacement_Impl( sal_Int32 nResID, const uno::Reference< io::XStream >& xStream ) { bool bResult = false; if ( nResID && xStream.is() ) { uno::Reference< uno::XComponentContext > xContext = ::comphelper::getProcessComponentContext(); try { uno::Reference< graphic::XGraphicProvider > xGraphProvider(graphic::GraphicProvider::create(xContext)); OUString aURL("private:resource/sfx/bitmapex/"); aURL += OUString::number( nResID ); uno::Sequence< beans::PropertyValue > aMediaProps( 1 ); aMediaProps[0].Name = "URL"; aMediaProps[0].Value <<= aURL; uno::Reference< graphic::XGraphic > xGraphic = xGraphProvider->queryGraphic( aMediaProps ); if ( xGraphic.is() ) { uno::Sequence< beans::PropertyValue > aStoreProps( 2 ); aStoreProps[0].Name = "OutputStream"; aStoreProps[0].Value <<= xStream; aStoreProps[1].Name = "MimeType"; aStoreProps[1].Value <<= OUString("image/png"); xGraphProvider->storeGraphic( xGraphic, aStoreProps ); bResult = true; } } catch(const uno::Exception&) { } } return bResult; } // static sal_uInt16 GraphicHelper::getThumbnailReplacementIDByFactoryName_Impl( const OUString& aFactoryShortName, bool /*bIsTemplate*/ ) { sal_uInt16 nResult = 0; if ( aFactoryShortName == "scalc" ) { nResult = BMP_128X128_CALC_DOC; } else if ( aFactoryShortName == "sdraw" ) { nResult = BMP_128X128_DRAW_DOC; } else if ( aFactoryShortName == "simpress" ) { nResult = BMP_128X128_IMPRESS_DOC; } else if ( aFactoryShortName == "smath" ) { nResult = BMP_128X128_MATH_DOC; } else if ( aFactoryShortName == "swriter" || aFactoryShortName.startsWith("swriter/") ) { nResult = BMP_128X128_WRITER_DOC; } return nResult; } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */