summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--chart2/source/tools/TitleHelper.cxx209
1 files changed, 169 insertions, 40 deletions
diff --git a/chart2/source/tools/TitleHelper.cxx b/chart2/source/tools/TitleHelper.cxx
index d44b2d076df0..e1bdc52007ff 100644
--- a/chart2/source/tools/TitleHelper.cxx
+++ b/chart2/source/tools/TitleHelper.cxx
@@ -4,9 +4,9 @@
*
* $RCSfile: TitleHelper.cxx,v $
*
- * $Revision: 1.6 $
+ * $Revision: 1.7 $
*
- * last change: $Author: obo $ $Date: 2006-09-17 13:30:07 $
+ * last change: $Author: vg $ $Date: 2007-05-22 19:05:41 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
@@ -38,8 +38,8 @@
#include "TitleHelper.hxx"
#include "ChartModelHelper.hxx"
#include "macros.hxx"
-#include "ContextHelper.hxx"
-#include "MeterHelper.hxx"
+#include "AxisHelper.hxx"
+#include "DiagramHelper.hxx"
#ifndef _COM_SUN_STAR_CHART2_XCHARTDOCUMENT_HPP_
#include <com/sun/star/chart2/XChartDocument.hpp>
@@ -52,32 +52,36 @@ namespace chart
using namespace ::com::sun::star;
using namespace ::com::sun::star::chart2;
+using ::com::sun::star::uno::Reference;
-rtl::OUString TitleHelper::getIdentifierForTitle( TitleHelper::eTitleType nTitleIndex )
+namespace
+{
+
+rtl::OUString lcl_getIdentifierForTitle( TitleHelper::eTitleType nTitleIndex )
{
switch( nTitleIndex )
{
- case MAIN_TITLE:
+ case TitleHelper::MAIN_TITLE:
{
static rtl::OUString m_aIdentifier( C2U( "@main-title" ) );
return m_aIdentifier;
}
- case SUB_TITLE:
+ case TitleHelper::SUB_TITLE:
{
static rtl::OUString m_aIdentifier( C2U( "@sub-title" ) );
return m_aIdentifier;
}
- case X_AXIS_TITLE:
+ case TitleHelper::X_AXIS_TITLE:
{
static rtl::OUString m_aIdentifier( C2U( "@xaxis-title" ) );
return m_aIdentifier;
}
- case Y_AXIS_TITLE:
+ case TitleHelper::Y_AXIS_TITLE:
{
static rtl::OUString m_aIdentifier( C2U( "@yaxis-title" ) );
return m_aIdentifier;
}
- case Z_AXIS_TITLE:
+ case TitleHelper::Z_AXIS_TITLE:
{
static rtl::OUString m_aIdentifier( C2U( "@zaxis-title" ) );
return m_aIdentifier;
@@ -88,35 +92,76 @@ rtl::OUString TitleHelper::getIdentifierForTitle( TitleHelper::eTitleType nTitle
}
}
-uno::Reference< XTitled > lcl_getTitleParent( TitleHelper::eTitleType nTitleIndex
- , const uno::Reference< frame::XModel >& xModel )
+} //anonymous namespace
+
+uno::Reference< XTitled > lcl_getTitleParentFromDiagram(
+ TitleHelper::eTitleType nTitleIndex
+ , const uno::Reference< XDiagram >& xDiagram )
{
uno::Reference< XTitled > xResult;
- uno::Reference< XChartDocument > xChartDoc( xModel, uno::UNO_QUERY );
- uno::Reference< XDiagram > xDiagram;
- if( xChartDoc.is())
- xDiagram.set( xChartDoc->getDiagram());
+
+ if( nTitleIndex == TitleHelper::TITLE_AT_STANDARD_X_AXIS_POSITION ||
+ nTitleIndex == TitleHelper::TITLE_AT_STANDARD_Y_AXIS_POSITION )
+ {
+ bool bDummy = false;
+ bool bIsVertical = DiagramHelper::getVertical( xDiagram, bDummy, bDummy );
+
+ if( nTitleIndex == TitleHelper::TITLE_AT_STANDARD_Y_AXIS_POSITION )
+ nTitleIndex = bIsVertical ? TitleHelper::X_AXIS_TITLE : TitleHelper::Y_AXIS_TITLE;
+ else
+ nTitleIndex = bIsVertical ? TitleHelper::Y_AXIS_TITLE : TitleHelper::X_AXIS_TITLE;
+ }
+
switch( nTitleIndex )
{
- case TitleHelper::MAIN_TITLE:
- xResult.set( xModel, uno::UNO_QUERY );
- break;
case TitleHelper::SUB_TITLE:
if( xDiagram.is())
xResult.set( xDiagram, uno::UNO_QUERY );
break;
case TitleHelper::X_AXIS_TITLE:
if( xDiagram.is())
- xResult.set( MeterHelper::getAxis( 0, true, xDiagram ), uno::UNO_QUERY );
+ xResult.set( AxisHelper::getAxis( 0, true, xDiagram ), uno::UNO_QUERY );
break;
case TitleHelper::Y_AXIS_TITLE:
if( xDiagram.is())
- xResult.set( MeterHelper::getAxis( 1, true, xDiagram ), uno::UNO_QUERY );
+ xResult.set( AxisHelper::getAxis( 1, true, xDiagram ), uno::UNO_QUERY );
break;
case TitleHelper::Z_AXIS_TITLE:
if( xDiagram.is())
- xResult.set( MeterHelper::getAxis( 2, true, xDiagram ), uno::UNO_QUERY );
+ xResult.set( AxisHelper::getAxis( 2, true, xDiagram ), uno::UNO_QUERY );
+ break;
+
+ case TitleHelper::MAIN_TITLE:
+ default:
+ OSL_ENSURE( false, "Unsupported Title-Type requested" );
+ break;
+ }
+
+ return xResult;
+}
+
+uno::Reference< XTitled > lcl_getTitleParent( TitleHelper::eTitleType nTitleIndex
+ , const uno::Reference< frame::XModel >& xModel )
+{
+ uno::Reference< XTitled > xResult;
+ uno::Reference< XChartDocument > xChartDoc( xModel, uno::UNO_QUERY );
+ uno::Reference< XDiagram > xDiagram;
+ if( xChartDoc.is())
+ xDiagram.set( xChartDoc->getFirstDiagram());
+
+ switch( nTitleIndex )
+ {
+ case TitleHelper::MAIN_TITLE:
+ xResult.set( xModel, uno::UNO_QUERY );
+ break;
+ case TitleHelper::SUB_TITLE:
+ case TitleHelper::X_AXIS_TITLE:
+ case TitleHelper::Y_AXIS_TITLE:
+ case TitleHelper::Z_AXIS_TITLE:
+ case TitleHelper::TITLE_AT_STANDARD_X_AXIS_POSITION:
+ case TitleHelper::TITLE_AT_STANDARD_Y_AXIS_POSITION:
+ xResult.set( lcl_getTitleParentFromDiagram( nTitleIndex, xDiagram ));
break;
default:
OSL_ENSURE( false, "Unsupported Title-Type requested" );
@@ -136,36 +181,80 @@ uno::Reference< XTitle > TitleHelper::getTitle( TitleHelper::eTitleType nTitleIn
}
uno::Reference< XTitle > TitleHelper::createTitle(
- TitleHelper::eTitleType nTitleIndex
+ TitleHelper::eTitleType eTitleType
, const rtl::OUString& rTitleText
, const uno::Reference< frame::XModel >& xModel
- , const uno::Reference< uno::XComponentContext > & xContext )
+ , const uno::Reference< uno::XComponentContext > & xContext
+ , ReferenceSizeProvider * pRefSizeProvider )
{
- if( !rTitleText.getLength() )
- return NULL;
-
- uno::Reference< XTitle > xTitle(NULL);
- uno::Reference< XTitled > xTitled( lcl_getTitleParent( nTitleIndex, xModel ) );
-
- ContextHelper::tContextEntryMapType aContextValues(
- ContextHelper::MakeContextEntryMap( C2U( "Identifier" )
- , uno::makeAny( TitleHelper::getIdentifierForTitle(nTitleIndex) )) );
- uno::Reference< uno::XComponentContext > xNewContext(
- ContextHelper::createContext( aContextValues, xContext ) );
+ uno::Reference< XTitle > xTitle;
+ uno::Reference< XTitled > xTitled( lcl_getTitleParent( eTitleType, xModel ) );
- if(xNewContext.is() && xTitled.is())
+ if(xTitled.is())
{
+ uno::Reference< XDiagram > xDiagram( ChartModelHelper::findDiagram( xModel ) );
+
xTitle.set( xContext->getServiceManager()->createInstanceWithContext(
- C2U( "com.sun.star.chart2.Title" ),
- xNewContext ), uno::UNO_QUERY );
+ C2U( "com.sun.star.chart2.Title" ),
+ xContext ), uno::UNO_QUERY );
if(xTitle.is())
{
- setCompleteString( rTitleText, xTitle, xNewContext );
+ // default char height (main: 13.0 == default)
+ float fDefaultCharHeightSub = 11.0;
+ float fDefaultCharHeightAxis = 9.0;
+ switch( eTitleType )
+ {
+ case TitleHelper::SUB_TITLE:
+ chart::TitleHelper::setCompleteString(
+ rTitleText, xTitle, xContext, & fDefaultCharHeightSub );
+ break;
+ case TitleHelper::X_AXIS_TITLE:
+ case TitleHelper::Y_AXIS_TITLE:
+ case TitleHelper::Z_AXIS_TITLE:
+ case TitleHelper::TITLE_AT_STANDARD_X_AXIS_POSITION:
+ case TitleHelper::TITLE_AT_STANDARD_Y_AXIS_POSITION:
+ chart::TitleHelper::setCompleteString(
+ rTitleText, xTitle, xContext, & fDefaultCharHeightAxis );
+ break;
+ default:
+ chart::TitleHelper::setCompleteString( rTitleText, xTitle, xContext );
+ break;
+ }
+
+ // set/clear autoscale
+ if( pRefSizeProvider )
+ pRefSizeProvider->setValuesAtTitle( xTitle );
+
xTitled->setTitle( xTitle );
+
+ //default rotation 90 degree for y axis title in normal coordinatesystems or for x axis title for swapped coordinatesystems
+ if( eTitleType == TitleHelper::X_AXIS_TITLE ||
+ eTitleType == TitleHelper::Y_AXIS_TITLE )
+ {
+ try
+ {
+ bool bDummy = false;
+ bool bIsVertical = DiagramHelper::getVertical( xDiagram, bDummy, bDummy );
+
+ Reference< beans::XPropertySet > xTitleProps( xTitle, uno::UNO_QUERY );
+ if( xTitleProps.is() )
+ {
+ double fNewAngleDegree = 90.0;
+ if( (!bIsVertical && eTitleType == TitleHelper::Y_AXIS_TITLE)
+ || (bIsVertical && eTitleType == TitleHelper::X_AXIS_TITLE) )
+ xTitleProps->setPropertyValue( C2U( "TextRotation" ), uno::makeAny( fNewAngleDegree ));
+ }
+ }
+ catch( uno::Exception & ex )
+ {
+ ASSERT_EXCEPTION( ex );
+ }
+ }
}
}
return xTitle;
+
}
rtl::OUString TitleHelper::getCompleteString( const uno::Reference< XTitle >& xTitle )
@@ -181,7 +270,8 @@ rtl::OUString TitleHelper::getCompleteString( const uno::Reference< XTitle >& xT
void TitleHelper::setCompleteString( const rtl::OUString& rNewText
, const uno::Reference< XTitle >& xTitle
- , const uno::Reference< uno::XComponentContext > & xContext )
+ , const uno::Reference< uno::XComponentContext > & xContext
+ , float * pDefaultCharHeight /* = 0 */ )
{
//the format of the first old text portion will be maintained if there is any
if(!xTitle.is())
@@ -206,6 +296,22 @@ void TitleHelper::setCompleteString( const rtl::OUString& rNewText
{
xFormattedString->setString( rNewText );
aNewStringList[0].set( xFormattedString );
+ if( pDefaultCharHeight != 0 )
+ {
+ try
+ {
+ uno::Reference< beans::XPropertySet > xProp( xFormattedString, uno::UNO_QUERY_THROW );
+
+ uno::Any aFontSize( uno::makeAny( *pDefaultCharHeight ));
+ xProp->setPropertyValue( C2U("CharHeight"), aFontSize );
+ xProp->setPropertyValue( C2U("CharHeightAsian"), aFontSize );
+ xProp->setPropertyValue( C2U("CharHeightComplex"), aFontSize );
+ }
+ catch( uno::Exception & ex )
+ {
+ ASSERT_EXCEPTION( ex );
+ }
+ }
}
}
xTitle->setText( aNewStringList );
@@ -222,6 +328,29 @@ void TitleHelper::removeTitle( TitleHelper::eTitleType nTitleIndex
}
}
+bool TitleHelper::getTitleType( eTitleType& rType
+ , const ::com::sun::star::uno::Reference<
+ ::com::sun::star::chart2::XTitle >& xTitle
+ , const ::com::sun::star::uno::Reference<
+ ::com::sun::star::frame::XModel >& xModel )
+{
+ if( !xTitle.is() || !xModel.is() )
+ return false;
+
+ Reference< chart2::XTitle > xCurrentTitle;
+ for( sal_Int32 nTitleType = TITLE_BEGIN; nTitleType < NORMAL_TITLE_END; nTitleType++ )
+ {
+ xCurrentTitle = TitleHelper::getTitle( static_cast<eTitleType>(nTitleType), xModel );
+ if( xCurrentTitle == xTitle )
+ {
+ rType = static_cast<eTitleType>(nTitleType);
+ return true;
+ }
+ }
+
+ return false;
+}
+
//.............................................................................
} //namespace chart
//.............................................................................