Files
libreoffice/sw/source/core/doc/docchart.cxx

278 lines
8.6 KiB
C++
Raw Normal View History

2000-09-18 23:08:29 +00:00
/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
2000-09-18 23:08:29 +00:00
*
* Copyright 2000, 2010 Oracle and/or its affiliates.
2000-09-18 23:08:29 +00:00
*
* OpenOffice.org - a multi-platform office productivity suite
2000-09-18 23:08:29 +00:00
*
* This file is part of OpenOffice.org.
2000-09-18 23:08:29 +00:00
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
2000-09-18 23:08:29 +00:00
*
* OpenOffice.org 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 version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
2000-09-18 23:08:29 +00:00
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org. If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
2000-09-18 23:08:29 +00:00
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_sw.hxx"
2000-09-18 23:08:29 +00:00
#include <com/sun/star/frame/XModel.hpp>
#include <com/sun/star/chart2/XChartDocument.hpp>
2000-09-18 23:08:29 +00:00
#include <float.h>
#include <hintids.hxx>
2001-07-05 09:34:53 +00:00
#include <vcl/window.hxx>
2000-09-18 23:08:29 +00:00
#include <doc.hxx>
#include <docary.hxx>
#include <ndindex.hxx>
#include <swtable.hxx>
#include <ndtxt.hxx>
#include <ndole.hxx>
2000-09-18 23:08:29 +00:00
#include <calc.hxx>
#include <frmfmt.hxx>
#include <cellfml.hxx>
#include <viewsh.hxx>
#include <ndole.hxx>
#include <calbck.hxx>
#include <cntfrm.hxx>
#include <swtblfmt.hxx>
#include <tblsel.hxx>
#include <cellatr.hxx>
#include <vos/mutex.hxx>
#include <vcl/svapp.hxx>
2000-09-18 23:08:29 +00:00
#include <unochart.hxx>
2000-09-18 23:08:29 +00:00
using namespace com::sun::star;
using namespace com::sun::star::uno;
2000-09-18 23:08:29 +00:00
2000-11-07 09:05:20 +00:00
void SwTable::UpdateCharts() const
{
GetFrmFmt()->GetDoc()->UpdateCharts( GetFrmFmt()->GetName() );
2000-09-18 23:08:29 +00:00
}
BOOL SwTable::IsTblComplexForChart( const String& rSelection,
SwChartLines* pGetCLines ) const
{
const SwTableBox* pSttBox, *pEndBox;
if( 2 < rSelection.Len() )
{
// spitze Klammern am Anfang & Ende enfernen
String sBox( rSelection );
if( '<' == sBox.GetChar( 0 ) ) sBox.Erase( 0, 1 );
if( '>' == sBox.GetChar( sBox.Len()-1 ) ) sBox.Erase( sBox.Len()-1 );
xub_StrLen nTrenner = sBox.Search( ':' );
ASSERT( STRING_NOTFOUND != nTrenner, "keine gueltige Selektion" );
pSttBox = GetTblBox( sBox.Copy( 0, nTrenner ));
pEndBox = GetTblBox( sBox.Copy( nTrenner+1 ));
}
else
{
const SwTableLines* pLns = &GetTabLines();
pSttBox = (*pLns)[ 0 ]->GetTabBoxes()[ 0 ];
while( !pSttBox->GetSttNd() )
// bis zur Content Box!
pSttBox = pSttBox->GetTabLines()[ 0 ]->GetTabBoxes()[ 0 ];
const SwTableBoxes* pBoxes = &(*pLns)[ pLns->Count()-1 ]->GetTabBoxes();
pEndBox = (*pBoxes)[ pBoxes->Count()-1 ];
while( !pEndBox->GetSttNd() )
{
// bis zur Content Box!
pLns = &pEndBox->GetTabLines();
pBoxes = &(*pLns)[ pLns->Count()-1 ]->GetTabBoxes();
pEndBox = (*pBoxes)[ pBoxes->Count()-1 ];
}
}
return !pSttBox || !pEndBox || !::ChkChartSel( *pSttBox->GetSttNd(),
*pEndBox->GetSttNd(), pGetCLines );
}
IMPL_LINK( SwDoc, DoUpdateAllCharts, Timer *, EMPTYARG )
2000-09-18 23:08:29 +00:00
{
ViewShell* pVSh;
GetEditShell( &pVSh );
if( pVSh )
{
const SwFrmFmts& rTblFmts = *GetTblFrmFmts();
for( USHORT n = 0; n < rTblFmts.Count(); ++n )
{
SwTable* pTmpTbl;
const SwTableNode* pTblNd;
SwFrmFmt* pFmt = rTblFmts[ n ];
if( 0 != ( pTmpTbl = SwTable::FindTable( pFmt ) ) &&
0 != ( pTblNd = pTmpTbl->GetTableNode() ) &&
pTblNd->GetNodes().IsDocNodes() )
{
_UpdateCharts( *pTmpTbl, *pVSh );
}
}
}
return 0;
}
void SwDoc::_UpdateCharts( const SwTable& rTbl, ViewShell& /*rVSh*/ ) const
2000-09-18 23:08:29 +00:00
{
String aName( rTbl.GetFrmFmt()->GetName() );
SwOLENode *pONd;
SwStartNode *pStNd;
SwNodeIndex aIdx( *GetNodes().GetEndOfAutotext().StartOfSectionNode(), 1 );
while( 0 != (pStNd = aIdx.GetNode().GetStartNode()) )
{
aIdx++;
SwFrm* pFrm;
if( 0 != ( pONd = aIdx.GetNode().GetOLENode() ) &&
aName.Equals( pONd->GetChartTblName() ) &&
0 != ( pFrm = pONd->GetFrm() ) )
{
SwChartDataProvider *pPCD = GetChartDataProvider();
if (pPCD)
pPCD->InvalidateTable( &rTbl );
// following this the framework will now take care of repainting
// the chart or it's replacement image...
2000-09-18 23:08:29 +00:00
}
aIdx.Assign( *pStNd->EndOfSectionNode(), + 1 );
}
}
void SwDoc::UpdateCharts( const String &rName ) const
{
SwTable* pTmpTbl = SwTable::FindTable( FindTblFmtByName( rName ) );
if( pTmpTbl )
{
ViewShell* pVSh;
GetEditShell( &pVSh );
if( pVSh )
_UpdateCharts( *pTmpTbl, *pVSh );
}
}
void SwDoc::SetTableName( SwFrmFmt& rTblFmt, const String &rNewName )
{
// BOOL bStop = 1;
2000-09-18 23:08:29 +00:00
const String aOldName( rTblFmt.GetName() );
BOOL bNameFound = 0 == rNewName.Len();
if( !bNameFound )
{
SwFrmFmt* pFmt;
const SwFrmFmts& rTbl = *GetTblFrmFmts();
for( USHORT i = rTbl.Count(); i; )
if( !( pFmt = rTbl[ --i ] )->IsDefault() &&
pFmt->GetName() == rNewName && IsUsed( *pFmt ) )
{
bNameFound = TRUE;
break;
}
}
if( !bNameFound )
rTblFmt.SetName( rNewName, sal_True );
2000-09-18 23:08:29 +00:00
else
rTblFmt.SetName( GetUniqueTblName(), sal_True );
2000-09-18 23:08:29 +00:00
SwStartNode *pStNd;
SwNodeIndex aIdx( *GetNodes().GetEndOfAutotext().StartOfSectionNode(), 1 );
while ( 0 != (pStNd = aIdx.GetNode().GetStartNode()) )
{
aIdx++;
SwOLENode *pNd = aIdx.GetNode().GetOLENode();
if( pNd && aOldName == pNd->GetChartTblName() )
{
pNd->SetChartTblName( rNewName );
ViewShell* pVSh;
GetEditShell( &pVSh );
2000-09-18 23:08:29 +00:00
SwTable* pTable = SwTable::FindTable( &rTblFmt );
SwChartDataProvider *pPCD = GetChartDataProvider();
if (pPCD)
pPCD->InvalidateTable( pTable );
// following this the framework will now take care of repainting
// the chart or it's replacement image...
}
aIdx.Assign( *pStNd->EndOfSectionNode(), + 1 );
}
SetModified();
}
SwChartDataProvider * SwDoc::GetChartDataProvider( bool bCreate ) const
{
// since there must be only one instance of this object per document
// we need a mutex here
vos::OGuard aGuard( Application::GetSolarMutex() );
2000-09-18 23:08:29 +00:00
if (bCreate && !aChartDataProviderImplRef.get())
{
aChartDataProviderImplRef = comphelper::ImplementationReference< SwChartDataProvider
, chart2::data::XDataProvider >( new SwChartDataProvider( this ) );
}
return aChartDataProviderImplRef.get();
}
void SwDoc::CreateChartInternalDataProviders( const SwTable *pTable )
{
if (pTable)
{
String aName( pTable->GetFrmFmt()->GetName() );
SwOLENode *pONd;
SwStartNode *pStNd;
SwNodeIndex aIdx( *GetNodes().GetEndOfAutotext().StartOfSectionNode(), 1 );
while (0 != (pStNd = aIdx.GetNode().GetStartNode()))
{
aIdx++;
if( 0 != ( pONd = aIdx.GetNode().GetOLENode() ) &&
aName.Equals( pONd->GetChartTblName() ) /* OLE node is chart? */ &&
0 != (pONd->GetFrm()) /* chart frame is not hidden */ )
{
uno::Reference < embed::XEmbeddedObject > xIP = pONd->GetOLEObj().GetOleRef();
if ( svt::EmbeddedObjectRef::TryRunningState( xIP ) )
2000-09-18 23:08:29 +00:00
{
uno::Reference< chart2::XChartDocument > xChart( xIP->getComponent(), UNO_QUERY );
if (xChart.is())
xChart->createInternalDataProvider( sal_True );
// there may be more than one chart for each table thus we need to continue the loop...
2000-09-18 23:08:29 +00:00
}
}
aIdx.Assign( *pStNd->EndOfSectionNode(), + 1 );
2000-09-18 23:08:29 +00:00
}
}
}
SwChartLockController_Helper & SwDoc::GetChartControllerHelper()
{
if (!pChartControllerHelper)
{
pChartControllerHelper = new SwChartLockController_Helper( this );
}
return *pChartControllerHelper;
}