Antares Simulator
Power System Simulator
inflowpattern.h
1 /*
2  * Copyright 2007-2025, RTE (https://www.rte-france.com)
3  * See AUTHORS.txt
4  * SPDX-License-Identifier: MPL-2.0
5  * This file is part of Antares-Simulator,
6  * Adequacy and Performance assessment for interconnected energy networks.
7  *
8  * Antares_Simulator is free software: you can redistribute it and/or modify
9  * it under the terms of the Mozilla Public Licence 2.0 as published by
10  * the Mozilla Foundation, either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * Antares_Simulator is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * Mozilla Public Licence 2.0 for more details.
17  *
18  * You should have received a copy of the Mozilla Public Licence 2.0
19  * along with Antares_Simulator. If not, see <https://opensource.org/license/mpl-2-0/>.
20  */
21 #ifndef __ANTARES_TOOLBOX_COMPONENT_DATAGRID_RENDERER_AREA_INFLOWPATTERN_H__
22 #define __ANTARES_TOOLBOX_COMPONENT_DATAGRID_RENDERER_AREA_INFLOWPATTERN_H__
23 
24 #include "../area.h"
25 #include "../matrix.h"
26 #include <antares/date/date.h>
27 #include <antares/study/parts/wind/prepro.h>
28 
29 namespace Antares::Component::Datagrid::Renderer
30 {
31 class InflowPattern final: public Renderer::Matrix<double, double, 3>,
33 {
34 public:
36 
37 public:
39 
40 
43  InflowPattern(wxWindow* control, Toolbox::InputSelector::Area* notifier);
45  virtual ~InflowPattern();
47 
48  virtual int width() const;
49  virtual int height() const;
50 
51  virtual wxString columnCaption(int colIndx) const;
52 
53  virtual wxString rowCaption(int rowIndx) const;
54 
55  virtual wxString cellValue(int x, int y) const;
56 
57  virtual double cellNumericValue(int x, int y) const;
58 
59  virtual bool cellValue(int, int, const Yuni::String&);
60 
61  virtual void resetColors(int, int, wxColour&, wxColour&) const
62  { /*Do nothing*/
63  }
64 
65  virtual Date::Precision precision()
66  {
67  return Date::daily;
68  }
69 
70  virtual IRenderer::CellStyle cellStyle(int col, int row) const;
71 
72  virtual bool valid() const;
73 
74  virtual uint maxWidthResize() const
75  {
76  return 0;
77  }
78 
79  virtual uint maxHeightResize() const
80  {
81  return 0;
82  }
83 
84  // virtual bool circularShiftRowsUntilDate(MonthName month, uint daymonth);
85 
86 protected:
87  virtual void internalAreaChanged(Antares::Data::Area* area);
89  virtual void onStudyClosed() override;
91  virtual void onStudyLoaded() override;
92 
93 }; // class InflowPattern
94 
95 } // namespace Antares::Component::Datagrid::Renderer
96 
97 #endif // __ANTARES_TOOLBOX_COMPONENT_DATAGRID_RENDERER_AREA_INFLOWPATTERN_H__
virtual wxString cellValue(int x, int y) const
Get the string representation of a cell.
Definition: inflowpattern.cpp:61
virtual void onStudyLoaded() override
Event: the study has been loaded.
Definition: inflowpattern.cpp:151
virtual uint maxHeightResize() const
The most suitable column count.
Definition: inflowpattern.h:79
virtual int height() const
Get the current height.
Definition: inflowpattern.cpp:44
virtual uint maxWidthResize() const
The most suitable column count.
Definition: inflowpattern.h:74
virtual double cellNumericValue(int x, int y) const
Get the value of a cell.
Definition: inflowpattern.cpp:66
virtual void onStudyClosed() override
Event: the study has been closed.
Definition: inflowpattern.cpp:145
virtual int width() const
Get the current width.
Definition: inflowpattern.cpp:39
virtual bool cellValue(int, int, const Yuni::String &)
Set the value of a cell.
virtual wxString columnCaption(int colIndx) const
Get the column caption.
Definition: inflowpattern.cpp:49
InflowPattern(wxWindow *control, Toolbox::InputSelector::Area *notifier)
Constructor.
Definition: inflowpattern.cpp:28
virtual Date::Precision precision()
Time Precision.
Definition: inflowpattern.h:65
virtual wxString rowCaption(int rowIndx) const
Get the row caption.
Definition: inflowpattern.cpp:124
virtual ~InflowPattern()
Destructor.
Definition: inflowpattern.cpp:34
Definition for a single area.
Definition: area.h:51
A n-by-n matrix.
Definition: matrix.h:44
Visual Component for displaying all available areas (and groups)
Definition: area.h:37