From ccf594d16df1ecbfd4e069a38fbf13eeb4de5aa8 Mon Sep 17 00:00:00 2001 From: Graeme Geldenhuys Date: Mon, 4 Oct 2010 10:33:21 +0200 Subject: Update class documentation with "delayed resource allocation" information. --- docs/xml/corelib/fpg_base.xml | 87 ++++++++++++++++++++++++++++++++++++++++- docs/xml/corelib/fpg_widget.xml | 3 ++ 2 files changed, 89 insertions(+), 1 deletion(-) diff --git a/docs/xml/corelib/fpg_base.xml b/docs/xml/corelib/fpg_base.xml index d7e29445..73174601 100644 --- a/docs/xml/corelib/fpg_base.xml +++ b/docs/xml/corelib/fpg_base.xml @@ -604,6 +604,91 @@ or widget has a window handle. Widgets are essentially embedded windows without titlebars or borders inside a main parent window. + + +Forces fpGUI to act on window position and size properties +

fpGUI implements what is called "delayed resource allocation". It delays +some action until everything is ready to go. This delayed action applies to setting +Widget or Form size and position. Why? Imagine you have a complex form +with lots of anchors, alignments and OnResize event handlers. Now +somewhere in there you change the size or position of a component.

+ + +MyWidget.Left := ... +MyWidget.Top := ... +MyWidget.Width := ... +MyWidget.Height := ... + + +

If fpGUI acted immediately, as every property is set, it means it +would have to recalculate all those widget boundaries, and fire all +OnResize event handlers of the whole form four times. Once for each +property - as you set them. Not very efficient! To reduce such +redundant calculations, fpGUI allows you to set all the properties, +then act on it once you call UpdateWindowPosition. In most cases fpGUI +can even reduce the API calls needed, because it could pass for +example Width and Height via one API call. In the case of X11, it can actually do all +four values in a single API call. Thus improving efficiency and reduces resize calculatios and screen +redraws.

+
+
+ + +Specifies the horizontal coordinate of the left edge of a component relative to its parent +

. Use the Left property to determine where the left side +of the control begins or to reposition the left side of the control. +

+fpGUI delays acting on the Top, Left, Width and Height properies of a control until the +UpdateWindowPosition method is called. For more information on why this is so, see UpdateWindowPosition +help.
+ +TfpgWindowBase.UpdateWindowPosition + +
+ + +Specifies the vertical (X) coordinate of the top edge of a component relative to its parent +

. Use the Top property to determine where the top side +of the control begins or to reposition the top side of the control. +

+fpGUI delays acting on the Top, Left, Width and Height properies of a control until the +UpdateWindowPosition method is called. For more information on why this is so, see UpdateWindowPosition +help.
+ +TfpgWindowBase.UpdateWindowPosition + +
+ + +Specifies the horizontal size of the control or form in pixels +

. Use the Width property +to read or change the width of the control. For TfpgTabSheet controls of for +controls that have their Align property set to alTop, alBottom or alClient, changing +this property at runtime has no effect. +

+fpGUI delays acting on the Top, Left, Width and Height properies of a control until the +UpdateWindowPosition method is called. For more information on why this is so, see UpdateWindowPosition +help.
+ +TfpgWindowBase.UpdateWindowPosition + +
+ + +Specifies the vertical size of the control or form in pixels +

. Use the Height property +to read or change the height of the control. For TfpgTabSheet controls of for +controls that have their Align property set to alLeft, alRight or alClient, changing +this property at runtime has no effect. +

+fpGUI delays acting on the Top, Left, Width and Height properies of a control until the +UpdateWindowPosition method is called. For more information on why this is so, see UpdateWindowPosition +help.
+ +TfpgWindowBase.UpdateWindowPosition + +
+ Abstract class used to represent a Canvas for painting @@ -868,4 +953,4 @@ the streets of Manhattan.

- + \ No newline at end of file diff --git a/docs/xml/corelib/fpg_widget.xml b/docs/xml/corelib/fpg_widget.xml index 726859ae..6868c78a 100644 --- a/docs/xml/corelib/fpg_widget.xml +++ b/docs/xml/corelib/fpg_widget.xml @@ -8,6 +8,9 @@ Sets the position and size of the component . It also fires the Resize message. If you are setting up a component like a button on a form, you don't really want the resize event to fire for the button, before the form is displayed (visible). In that case, rather use the components Top, Left, Width and Height properties. + +TfpgWindowBase.UpdateWindowPosition + -- cgit v1.2.3-70-g09d2