1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
11 #include <sfx2/dispatch.hxx>
12 #include <svl/zforlist.hxx>
13 #include <svl/undo.hxx>
15 #include "formulacell.hxx"
16 #include "rangelst.hxx"
17 #include "scitems.hxx"
19 #include "document.hxx"
20 #include "uiitems.hxx"
21 #include "reffact.hxx"
22 #include "strload.hxx"
23 #include "docfunc.hxx"
24 #include "StatisticsDialogs.hrc"
25 #include "TableFillingAndNavigationTools.hxx"
27 #include "MovingAverageDialog.hxx"
29 ScMovingAverageDialog::ScMovingAverageDialog(
30 SfxBindings
* pSfxBindings
, SfxChildWindow
* pChildWindow
,
31 vcl::Window
* pParent
, ScViewData
* pViewData
) :
32 ScStatisticsInputOutputDialog(
33 pSfxBindings
, pChildWindow
, pParent
, pViewData
,
34 "MovingAverageDialog", "modules/scalc/ui/movingaveragedialog.ui" )
36 get(mpIntervalSpin
, "interval-spin");
39 ScMovingAverageDialog::~ScMovingAverageDialog()
44 void ScMovingAverageDialog::dispose()
46 mpIntervalSpin
.clear();
47 ScStatisticsInputOutputDialog::dispose();
50 bool ScMovingAverageDialog::Close()
52 return DoClose( ScMovingAverageDialogWrapper::GetChildWindowId() );
55 sal_Int16
ScMovingAverageDialog::GetUndoNameId()
57 return STR_MOVING_AVERAGE_UNDO_NAME
;
60 ScRange
ScMovingAverageDialog::ApplyOutput(ScDocShell
* pDocShell
)
62 AddressWalkerWriter
output(mOutputAddress
, pDocShell
, mDocument
,
63 formula::FormulaGrammar::mergeToGrammar( formula::FormulaGrammar::GRAM_ENGLISH
, mAddressDetails
.eConv
));
64 FormulaTemplate
aTemplate(mDocument
);
66 boost::scoped_ptr
<DataRangeIterator
> pIterator
;
67 if (mGroupedBy
== BY_COLUMN
)
68 pIterator
.reset(new DataRangeByColumnIterator(mInputRange
));
70 pIterator
.reset(new DataRangeByRowIterator(mInputRange
));
72 sal_Int32 aIntervalSize
= mpIntervalSpin
->GetValue();
73 const bool aCentral
= true; //to-do add support to change this to the dialog
75 for( ; pIterator
->hasNext(); pIterator
->next() )
80 if (mGroupedBy
== BY_COLUMN
)
81 aTemplate
.setTemplate(SC_STRLOAD(RID_STATISTICS_DLGS
, STR_COLUMN_LABEL_TEMPLATE
));
83 aTemplate
.setTemplate(SC_STRLOAD(RID_STATISTICS_DLGS
, STR_ROW_LABEL_TEMPLATE
));
85 aTemplate
.applyNumber("%NUMBER%", pIterator
->index() + 1);
86 output
.writeBoldString(aTemplate
.getTemplate());
89 DataCellIterator aDataCellIterator
= pIterator
->iterateCells();
91 for (; aDataCellIterator
.hasNext(); aDataCellIterator
.next())
93 ScAddress aIntervalStart
;
94 ScAddress aIntervalEnd
;
98 sal_Int32 aHalf
= aIntervalSize
/ 2;
99 sal_Int32 aHalfRemainder
= aIntervalSize
% 2;
100 aIntervalStart
= aDataCellIterator
.getRelative(-aHalf
);
101 aIntervalEnd
= aDataCellIterator
.getRelative(aHalf
- 1 + aHalfRemainder
);
105 aIntervalStart
= aDataCellIterator
.getRelative(-aIntervalSize
);
106 aIntervalEnd
= aDataCellIterator
.getRelative(0);
109 if(aIntervalStart
.IsValid() && aIntervalEnd
.IsValid())
111 aTemplate
.setTemplate("=AVERAGE(%RANGE%)");
112 aTemplate
.applyRange("%RANGE%", ScRange(aIntervalStart
, aIntervalEnd
));
113 output
.writeFormula(aTemplate
.getTemplate());
117 output
.writeFormula("=#N/A");
123 return ScRange(output
.mMinimumAddress
, output
.mMaximumAddress
);
126 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */