blob: bd2b94e48e2f3a16be8a03513e1730692f4cf3c6 [file] [log] [blame]
/**************************************************************
*
* 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
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
#ifndef _CHART2_SCALEAUTOMATISM_HXX
#define _CHART2_SCALEAUTOMATISM_HXX
#include "chartview/ExplicitScaleValues.hxx"
#include <com/sun/star/chart2/ScaleData.hpp>
#include <tools/date.hxx>
//.............................................................................
namespace chart
{
//.............................................................................
//-----------------------------------------------------------------------------
/** This class implements the calculation of automatic axis limits.
*/
class ScaleAutomatism
{
public:
explicit ScaleAutomatism(
const ::com::sun::star::chart2::ScaleData& rSourceScale, const Date& rNullDate );
virtual ~ScaleAutomatism();
/** Expands own value range with the passed minimum and maximum. */
void expandValueRange( double fMinimum, double fMaximum );
/** Sets additional auto scaling options.
@param bExpandBorderToIncrementRhythm If true, expands automatic
borders to the fixed or calculated increment rhythm.
@param bExpandIfValuesCloseToBorder If true, expands automatic borders
if values are too close (closer than 1/21 of visible area).
@param bExpandWideValuesToZero If true, expands automatic border to
zero, if source values are positive only or negative only, and if
the absolute values are wide spread (at least one value is less
than 5/6 of absolute maximum), or if all values are equal.
@param bExpandNarrowValuesTowardZero If true, expands automatic border
toward zero (50% of the visible range), if source values are
positive only or negative only, and if the absolute values are
close to the absolute maximum (no value is less than 5/6 of
absolute maximum). */
void setAutoScalingOptions(
bool bExpandBorderToIncrementRhythm,
bool bExpandIfValuesCloseToBorder,
bool bExpandWideValuesToZero,
bool bExpandNarrowValuesTowardZero );
/** Sets the maximum allowed number of automatic main increments.
@descr The number of main increments may be limited e.g. by the length
of the axis and the font size of the axis caption text. */
void setMaximumAutoMainIncrementCount( sal_Int32 nMaximumAutoMainIncrementCount );
/** Sets the time resolution to be used in case it is not set explicitly within the scale
*/
void setAutomaticTimeResolution( sal_Int32 nTimeResolution );
/** Fills the passed scale data and increment data according to the own settings. */
void calculateExplicitScaleAndIncrement(
ExplicitScaleData& rExplicitScale,
ExplicitIncrementData& rExplicitIncrement ) const;
::com::sun::star::chart2::ScaleData getScale() const;
Date getNullDate() const;
private:
/** Fills the passed scale data and increment data for category scaling. */
void calculateExplicitIncrementAndScaleForCategory(
ExplicitScaleData& rExplicitScale,
ExplicitIncrementData& rExplicitIncrement,
bool bAutoMinimum, bool bAutoMaximum ) const;
/** Fills the passed scale data and increment data for logarithmic scaling. */
void calculateExplicitIncrementAndScaleForLogarithmic(
ExplicitScaleData& rExplicitScale,
ExplicitIncrementData& rExplicitIncrement,
bool bAutoMinimum, bool bAutoMaximum ) const;
/** Fills the passed scale data and increment data for linear scaling. */
void calculateExplicitIncrementAndScaleForLinear(
ExplicitScaleData& rExplicitScale,
ExplicitIncrementData& rExplicitIncrement,
bool bAutoMinimum, bool bAutoMaximum ) const;
/** Fills the passed scale data and increment data for date-time axis. */
void calculateExplicitIncrementAndScaleForDateTimeAxis(
ExplicitScaleData& rExplicitScale,
ExplicitIncrementData& rExplicitIncrement,
bool bAutoMinimum, bool bAutoMaximum ) const;
private:
::com::sun::star::chart2::ScaleData m_aSourceScale;
double m_fValueMinimum; /// Minimum of all source values.
double m_fValueMaximum; /// Maximum of all source values.
sal_Int32 m_nMaximumAutoMainIncrementCount; /// Maximum number of automatic main increments.
bool m_bExpandBorderToIncrementRhythm; /// true = Expand to main increments.
bool m_bExpandIfValuesCloseToBorder; /// true = Expand if values are too close to the borders.
bool m_bExpandWideValuesToZero; /// true = Expand wide spread values to zero.
bool m_bExpandNarrowValuesTowardZero; /// true = Expand narrow range toward zero (add half of range).
sal_Int32 m_nTimeResolution;// a constant out of ::com::sun::star::chart::TimeUnit
Date m_aNullDate;
};
//.............................................................................
} //namespace chart
//.............................................................................
#endif