forked from AndreiDegtiarev/AWind
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathWindow.h
269 lines (257 loc) · 7.01 KB
/
Window.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
/*
GUI library for Arduino TFT and OLED displays
Copyright (c) 2014-2018 Andrei Degtiarev
Licensed 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.
*/
#pragma once
#include "Color.h"
#include "DC.h"
#include "ITouchEventReceiver.h"
#include "Decorator.h"
#include "IDialogClosedEventReceiver.h"
#include "Environment.h"
class Dialog;
///Base class for all window objects. Provides basic window functionality
class Window
{
protected:
int _left; //!< window left coordinate relative to the parent window
int _top; //!< window top coordinate relative to the parent window
int _width; //!< window width
int _height; //!< window height
bool _isVisible; //!< if this variable is false this window and all child windows are not visualized
LinkedList<Window> _children; //!< list of children windows. All children window are positioned relative to parent window
Window *_parent; //!< pointer to parent window
//#ifdef DEBUG_AWIND
//const __FlashStringHelper *_name; //!< internal window name that helps by debugging. For some reason preprocessor definiton #ifdef DEBUG_AWIND does not work here. So if you define debug you dhould uncomment this line
//#endif
bool _isDirty; //!< if true than window manager will redraw this window.
DecoratorList *_decorators;//!< contains list of drawig commands. If they are shared between more than one window -> SRAM usage optimisation
ITouchEventReceiver *_touchEventReceiver; //!< call back event receiver for touch actions
public:
///Constructor
/**
\param name internal window name that help by debugging
\param left left coordinate relative to parent indow
\param top top coordinate relative to parent indow
\param width window width
\param height window height
*/
Window(const __FlashStringHelper * name,int left,int top,int width,int height):
_left(left),
_top(top),
_width(width),
_height(height),
_isVisible(true)
#ifdef DEBUG_AWIND
,_name(name)
#endif
{
_parent = NULL;
_isDirty=true;
_decorators=NULL;
_touchEventReceiver=NULL;
}
///Sets window decorators list.
virtual void SetDecorators(DecoratorList *decorators)
{
_decorators=decorators;
}
///Returns window decorators list.
DecoratorList * GetDecorators()
{
return _decorators;
}
///Adds decorator to the decaorator list.
void AddDecorator(Decorator *decorator)
{
if(_decorators == NULL)
_decorators=new DecoratorList();
_decorators->Add(decorator);
}
Dialog *FindDialog(const __FlashStringHelper *id);
void RegisterDialog(const __FlashStringHelper *id,Dialog *dlg);
IDialogClosedEventReceiver::DialogResults DoDialog(Dialog *dlg);
///Registers receiver for touch event
/** Receiver can be a general class that is derived from ITouchEventReceiver. In this calss NotifyTouch virtual function has to be ovveriden */
/**
\param TouchEventReceiver pointer to touch event receiver
*/
void RegisterTouchEventReceiver(ITouchEventReceiver *touchEventReceiver)
{
_touchEventReceiver=touchEventReceiver;
}
///Returns true if window await touch action (like button) or false if touch manager should ignore this window during processing of touch events
virtual bool IsAwaitTouch()
{
return _touchEventReceiver!=NULL;
}
///Touch manager calls this function in the loop as long as touch action proceeds
virtual void OnTouching(DC *dc)
{
//out<<"OnTouching"<<endln;
PrepareDC(dc);
dc->SetColor(Color::Red);
dc->DrawRoundRect(0,0,Width(),Height());
dc->DrawRoundRect(1,1,Width()-1,Height()-1);
}
///Touch manager calls this function right after touch is released
virtual bool OnTouch(int x,int y)
{
//out<<F("OnTouch")<<endln;
if(_touchEventReceiver!=NULL)
{
//out<<F("TouchEvent generated")<<endln;
_touchEventReceiver->NotifyTouch(this);
return true;
}
return false;
}
///Returns pointer to root window. MainWindow does not have any parents
Window *RootWindow()
{
Window *parent=this;
while(parent->Parent()!=NULL)
{
parent=parent->Parent();
}
return parent;
}
///Moves and resizes window relativly to the parent window
/**
\param left left coordinate relative to parent window
\param top top coordinate relative to parent window
\param width window width
\param height window height
*/
virtual void Move(int left,int top,int width,int height)
{
_left = left;
_top = top;
_width = width;
_height = height;
}
///If function is called than the window manager updates the window
void Invalidate()
{
_isDirty=true;
}
///Returns true if window has to be updated
bool IsDirty()
{
return _isDirty;
}
#ifdef DEBUG_AWIND
///Returns internal window name
const __FlashStringHelper *Name()
{
return _name;
}
#endif
///Returns window left coordinate relative to the parent window
int Left()
{
return _left;
}
///Returns window top coordinate relative to the parent window
int Top()
{
return _top;
}
///Returns window width
int Width()
{
return _width;
}
///Returns window height
int Height()
{
return _height;
}
///Adds window child window.
void AddChild(Window * window)
{
window->SetParent(this);
_children.Add(window);
}
///Returns Parent window
Window * Parent()
{
return _parent;
}
///Sets window visibility status
void SetVisible(bool isVisible)
{
_isVisible=isVisible;
}
///Returns true if window visible and false is hidden
bool IsVisible()
{
bool retCode = _isVisible;
Window * crWnd = this;
while (retCode && crWnd->Parent() != NULL)
{
crWnd = crWnd->Parent();
retCode = crWnd->_isVisible;
}
return retCode;
}
///Returns list of children window
LinkedList<Window> & Children()
{
return _children;
}
///Performs full window redraw
/**
\param dc device context
*/
void Redraw(DC *dc)
{
PrepareDC(dc);
_isDirty=false;
if(_decorators!=NULL)
{
for(int i=0;i<_decorators->Count();i++)
{
(*_decorators)[i]->Draw(dc,0,0,_width,_height);
}
}
OnDraw(dc);
}
protected:
///Setups window coordinate system. This function called by window manager right before window has to be redrawn and it is intended for internal use
/**
\param dc device context
*/
void PrepareDC(DC *dc)
{
dc->Reset();
Window *crWnd=this;
while(crWnd!=NULL)
{
dc->Offset(crWnd->Left(),crWnd->Top());
crWnd=crWnd->Parent();
}
}
///If derived class needs to draw something in window client area, this function has to be ovverriden
/**
\param dc device context
*/
virtual void OnDraw(DC *dc)
{
}
private:
///Adds window child window.
void SetParent(Window *window)
{
_parent = window;
}
};