Menu

[r3535]: / trunk / Src / UWindowSettings.pas  Maximize  Restore  History

Download this file

288 lines (253 with data), 11.7 kB

  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
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
{
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/
*
* Copyright (C) 2006-2013, Peter Johnson (www.delphidabbler.com).
*
* $Rev$
* $Date$
*
* Implements classes that can save and record position of a window along with
* information about any window widgets.
*
* Requires DelphiDabbler Window State Components v5.3 of later.
}
unit UWindowSettings;
interface
uses
// Delphi
Classes,
// DelphiDabbler library
PJWdwState;
type
/// <summary>Class that can save and record the position of the main program
/// window along with some of the windows widgets.</summary>
TMainWindowSettings = class(TPJCustomWdwState)
strict private
var
/// <summary>Value of SplitterPos property.</summary>
fSplitterPos: Integer;
/// <summary>Value of OverviewTab property.</summary>
fOverviewTab: Integer;
const
/// <summary>Default width of form's left hand panel.</summary>
cDefLeftPanelWidth = 186;
strict protected
/// <summary>Reads window size, position and state from persistent settings
/// along with information about some main window widgets, setting the
/// appropriate properties.</summary>
/// <remarks>If persistent information is not present the window defaults
/// to its designed size and is placed at centre of work area.</remarks>
/// <param name="Left">Integer [in/out] Location of left hand side of
/// window. Input value is ignored. Set to value read from persistent
/// storage if available, otherwise set to a value that centres window
/// horizontally in work area.</param>
/// <param name="Top">Integer [in/out] Location of top of window. Input
/// value is ignored. Set to value read from persistent storage if
/// available, otherwise set to a value that centres window vertically in
/// work area.</param>
/// <param name="Width">Integer [in/out] Width of window. Designed width is
/// passed in. Set to width read from persistent storage if available,
/// otherwise left unchanged.</param>
/// <param name="Height">Integer [in/out] Height of window. Designed height
/// is passed in. Set to height read from persistent storage if available,
/// otherwise left unchanged.</param>
/// <param name="State">Integer [in/out] State of window (ordinal value of
/// TWindowState enumeration). Designed state is pased in. Set to state
/// read from persistent storage if available, otherwise left unchanged.
/// Any minimized state is ignored and normal state used in its place.
/// </param>
procedure ReadWdwState(var Left, Top, Width, Height, State: Integer);
override;
/// <summary>Writes window size, position and state to persistent settings
/// along with information about some window widgets stored in the
/// associated properties.</summary>
/// <param name="Left">Integer [in] Location of left hand side of window.
/// </param>
/// <param name="Top">Integer [in] Location of top of window.</param>
/// <param name="Width">Integer [in] Width of window.</param>
/// <param name="Height">Integer [in] Height of window.</param>
/// <param name="State">Integer [in] State of window (ordinal value of
/// TWindowState enumeration).</param>
procedure SaveWdwState(const Left, Top, Width, Height, State: Integer);
override;
public
const
/// <summary>Minimum width of left panel.</summary>
MinLeftPanelWidth = 160;
/// <summary>Minimum width of right panel.</summary>
MinRightPanelWidth = 300;
public
/// <summary>Creates and sets up component and default property values.
/// </summary>
/// <param name="AOwner">TComponent [in] Owner of this component. AOwner
/// must not be nil and must have a non-empty Name property.</param>
/// <remarks>AOwner should be the form whose size, position and state are
/// to be recorded.</remarks>
constructor Create(AOwner: TComponent); override;
/// <summary>Position of main window's vertical splitter.</summary>
property SplitterPos: Integer
read fSplitterPos write fSplitterPos default cDefLeftPanelWidth;
/// <summary>Index of selected tab in overview pane.</summary>
property OverviewTab: Integer
read fOverviewTab write fOverviewTab;
end;
type
/// <summary>Class that can save and record the position of a dialogue box
/// window.</summary>
TDlgWindowSettings = class(TPJCustomWdwState)
strict private
var
/// <summary>Value of FixedSize property.</summary>
fFixedSize: Boolean;
strict protected
/// <summary>Reads window size and, optionally, position from persistent
/// settings.</summary>
/// <remarks>If persistent information is not present the window defaults
/// to its designed size and is located relative to its owner window
/// according to its aligner.</remarks>
/// <param name="Left">Integer [in/out] Location of left hand side of
/// window. Input value is as set by window's aligner. Set to value read
/// from persistent storage if available, otherwise unchanged.</param>
/// <param name="Top">Integer [in/out] Location of top of window. Input
/// value is as set by window's aligner. Set to value read from persistent
/// storage if available, otherwise unchanged.</param>
/// <param name="Width">Integer [in/out] Width of window. Designed width is
/// passed in. Set to width read from persistent storage if available AND
/// FixedSize property is False, otherwise left unchanged.</param>
/// <param name="Height">Integer [in/out] Height of window. Designed height
/// is passed in. Set to height read from persistent storage if available
/// AND FixedSize property is False, otherwise left unchanged.</param>
/// <param name="State">Integer [in/out] State of window (ordinal value of
/// TWindowState enumeration). Input value is ignored. Always set to
/// wsNormal.</param>
procedure ReadWdwState(var Left, Top, Width, Height, State: Integer);
override;
/// <summary>Writes window size and, optionally, position to persistent
/// settings.</summary>
/// <param name="Left">Integer [in] Location of left hand side of window.
/// </param>
/// <param name="Top">Integer [in] Location of top of window.</param>
/// <param name="Width">Integer [in] Width of window. Ignored if FixedSize
/// is True.</param>
/// <param name="Height">Integer [in] Height of window. Ignored if
/// FxiedSize is True.</param>
/// <param name="State">Integer [in] State of window (ordinal value of
/// TWindowState enumeration). Ignored.</param>
procedure SaveWdwState(const Left, Top, Width, Height, State: Integer);
override;
public
/// <summary>Creates and sets up component and default property values.
/// </summary>
/// <param name="AOwner">TComponent [in] Owner of this component. AOwner
/// must not be nil and must have a non-empty Name property.</param>
/// <remarks>AOwner should be the form whose size and, optionally, position
/// are to be recorded.</remarks>
constructor Create(AOwner: TComponent); override;
/// <summary>Determines if dialogue box is to be treated as fixed (True) or
/// variable (False) size.</summary>
/// <remarks>When True width and height information are not written to
/// persistent storage, or are ignored if present.</remarks>
property FixedSize: Boolean read fFixedSize write fFixedSize default True;
end;
implementation
uses
// Delphi
SysUtils, Forms, Windows,
// Project
USettings, UStructs;
{ TMainWindowSettings }
constructor TMainWindowSettings.Create(AOwner: TComponent);
begin
Assert(Assigned(AOwner), ClassName + '.Create: AOwner is nil');
inherited;
AutoSaveRestore := False; // need to call Save and Restore manually
Options := [woFitWorkArea]; // keep main window inside work area
fSplitterPos := cDefLeftPanelWidth; // default splitter position
end;
procedure TMainWindowSettings.ReadWdwState(var Left, Top, Width, Height,
State: Integer);
var
Section: ISettingsSection; // object used to access persistent storage
WorkArea: TRectEx; // screen's workarea
begin
// Set default values: centre form in workarea using designed width & height
WorkArea := Screen.WorkAreaRect;
Left := (WorkArea.Width - Width) div 2;
Top := (WorkArea.Height - Height) div 2;
// Read values from storage
// ** Don't use Owner.Name for sub-section: breaks sub-classed code that needs
// main form settings.
Section := Settings.ReadSection(ssWindowState, 'MainForm');
Left := Section.GetInteger('Left', Left);
Top := Section.GetInteger('Top', Top);
Width := Section.GetInteger('Width', Width);
Height := Section.GetInteger('Height', Height);
State := Section.GetInteger('State', State);
if TWindowState(State) = wsMinimized then
State := Ord(wsNormal); // we don't allow minimized: use normal
fSplitterPos := Section.GetInteger('SplitterPos', fSplitterPos);
fOverviewTab := Section.GetInteger('OverviewTab', fOverviewTab);
end;
procedure TMainWindowSettings.SaveWdwState(const Left, Top, Width, Height,
State: Integer);
var
Section: ISettingsSection; // object used to access persistent storage
begin
// ** Don't use Owner.Name for sub-section: breaks sub-classed code that needs
// main form settings.
Section := Settings.ReadSection(ssWindowState, 'MainForm');
Section.SetInteger('Left', Left);
Section.SetInteger('Top', Top);
Section.SetInteger('Width', Width);
Section.SetInteger('Height', Height);
Section.SetInteger('State', State);
Section.SetInteger('SplitterPos', fSplitterPos);
Section.SetInteger('OverviewTab', fOverviewTab);
Section.Save;
end;
{ TDlgWindowSettings }
constructor TDlgWindowSettings.Create(AOwner: TComponent);
begin
Assert(Assigned(AOwner), ClassName + '.Create: AOwner is nil');
Assert(AOwner.Name <> '', ClassName + '.Create: AOwner.Name is empty string');
inherited;
AutoSaveRestore := False; // need to call Save and Restore manually
Options := [woFitWorkArea]; // keep main window inside work area
fFixedSize := True;
end;
procedure TDlgWindowSettings.ReadWdwState(var Left, Top, Width, Height,
State: Integer);
var
Section: ISettingsSection; // object used to access persistent storage
begin
// Assume that dialogue box has been aligned in default position when this
// method called.
Section := Settings.ReadSection(ssWindowState, Owner.Name);
Left := Section.GetInteger('Left', Left);
Top := Section.GetInteger('Top', Top);
if not fFixedSize then
begin
Width := Section.GetInteger('Width', Width);
Height := Section.GetInteger('Height', Height);
end;
State := Ord(wsNormal); // we don't allow minimized or maximized for dialogues
end;
procedure TDlgWindowSettings.SaveWdwState(const Left, Top, Width, Height,
State: Integer);
var
Section: ISettingsSection; // object used to access persistent storage
begin
Section := Settings.ReadSection(ssWindowState, Owner.Name);
Section.SetInteger('Left', Left);
Section.SetInteger('Top', Top);
// Never save state and only save size if dialogue not fixed size
if not fFixedSize then
begin
Section.SetInteger('Width', Width);
Section.SetInteger('Height', Height);
end;
Section.Save;
end;
end.
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.