1 /************************************************************************* 2 * 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * Copyright 2000, 2010 Oracle and/or its affiliates. 6 * 7 * OpenOffice.org - a multi-platform office productivity suite 8 * 9 * This file is part of OpenOffice.org. 10 * 11 * OpenOffice.org is free software: you can redistribute it and/or modify 12 * it under the terms of the GNU Lesser General Public License version 3 13 * only, as published by the Free Software Foundation. 14 * 15 * OpenOffice.org is distributed in the hope that it will be useful, 16 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 * GNU Lesser General Public License version 3 for more details 19 * (a copy is included in the LICENSE file that accompanied this code). 20 * 21 * You should have received a copy of the GNU Lesser General Public License 22 * version 3 along with OpenOffice.org. If not, see 23 * <http://www.openoffice.org/license.html> 24 * for a copy of the LGPLv3 License. 25 * 26 ************************************************************************/ 27 28 #include "vbapalette.hxx" 29 #include <cppuhelper/implbase1.hxx> 30 #include <com/sun/star/beans/XPropertySet.hpp> 31 #include <com/sun/star/container/XIndexAccess.hpp> 32 #include "excelvbahelper.hxx" 33 34 using namespace ::com::sun::star; 35 using namespace ::ooo::vba; 36 37 /** Standard EGA colors, bright. */ 38 #define EXC_PALETTE_EGA_COLORS_LIGHT \ 39 0x000000, 0xFFFFFF, 0xFF0000, 0x00FF00, 0x0000FF, 0xFFFF00, 0xFF00FF, 0x00FFFF 40 /** Standard EGA colors, dark. */ 41 #define EXC_PALETTE_EGA_COLORS_DARK \ 42 0x800000, 0x008000, 0x000080, 0x808000, 0x800080, 0x008080, 0xC0C0C0, 0x808080 43 44 static const ColorData spnDefColorTable8[] = 45 { 46 /* 8 */ EXC_PALETTE_EGA_COLORS_LIGHT, 47 /* 16 */ EXC_PALETTE_EGA_COLORS_DARK, 48 /* 24 */ 0x9999FF, 0x993366, 0xFFFFCC, 0xCCFFFF, 0x660066, 0xFF8080, 0x0066CC, 0xCCCCFF, 49 /* 32 */ 0x000080, 0xFF00FF, 0xFFFF00, 0x00FFFF, 0x800080, 0x800000, 0x008080, 0x0000FF, 50 /* 40 */ 0x00CCFF, 0xCCFFFF, 0xCCFFCC, 0xFFFF99, 0x99CCFF, 0xFF99CC, 0xCC99FF, 0xFFCC99, 51 /* 48 */ 0x3366FF, 0x33CCCC, 0x99CC00, 0xFFCC00, 0xFF9900, 0xFF6600, 0x666699, 0x969696, 52 /* 56 */ 0x003366, 0x339966, 0x003300, 0x333300, 0x993300, 0x993366, 0x333399, 0x333333 53 }; 54 55 typedef ::cppu::WeakImplHelper1< container::XIndexAccess > XIndexAccess_BASE; 56 57 class DefaultPalette : public XIndexAccess_BASE 58 { 59 public: 60 DefaultPalette(){} 61 62 // Methods XIndexAccess 63 virtual ::sal_Int32 SAL_CALL getCount() throw (uno::RuntimeException) 64 { 65 return sizeof(spnDefColorTable8) / sizeof(spnDefColorTable8[0]); 66 } 67 68 virtual uno::Any SAL_CALL getByIndex( ::sal_Int32 Index ) throw (lang::IndexOutOfBoundsException, lang::WrappedTargetException, uno::RuntimeException) 69 { 70 if ( Index < 0 || Index >= getCount() ) 71 throw lang::IndexOutOfBoundsException(); 72 return uno::makeAny( sal_Int32( spnDefColorTable8[ Index ] ) ); 73 } 74 75 // Methods XElementAcess 76 virtual uno::Type SAL_CALL getElementType() throw (uno::RuntimeException) 77 { 78 return ::getCppuType( (sal_Int32*)0 ); 79 } 80 virtual ::sal_Bool SAL_CALL hasElements() throw (uno::RuntimeException) 81 { 82 return sal_True; 83 } 84 85 }; 86 87 ScVbaPalette::ScVbaPalette( const uno::Reference< frame::XModel >& rxModel ) : 88 m_pShell( excel::getDocShell( rxModel ) ) 89 { 90 } 91 92 uno::Reference< container::XIndexAccess > 93 ScVbaPalette::getDefaultPalette() 94 { 95 return new DefaultPalette(); 96 } 97 98 uno::Reference< container::XIndexAccess > 99 ScVbaPalette::getPalette() const 100 { 101 uno::Reference< container::XIndexAccess > xIndex; 102 uno::Reference< beans::XPropertySet > xProps; 103 if ( m_pShell ) 104 xProps.set( m_pShell->GetModel(), uno::UNO_QUERY_THROW ); 105 else 106 throw uno::RuntimeException( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "Can't extract palette, no doc shell" ) ), uno::Reference< uno::XInterface >() ); 107 xIndex.set( xProps->getPropertyValue( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ColorPalette") ) ), uno::UNO_QUERY ); 108 if ( !xIndex.is() ) 109 return new DefaultPalette(); 110 return xIndex; 111 } 112