ray

Owner: IIIlllIIIllI URL: git@github.com:nyangkosense/ray.git

SDK/Delphi/Widgets/XPWidgetUtils.pas

{
   Copyright 2005-2022 Laminar Research, Sandy Barbour and Ben Supnik All
   rights reserved.  See license.txt for usage. X-Plane SDK Version: 4.0.0
}

UNIT XPWidgetUtils;
INTERFACE
{
   ## USAGE NOTES
   
   The XPWidgetUtils library contains useful functions that make writing and
   using widgets less of a pain.
   
   One set of functions are the widget behavior functions. These functions
   each add specific useful behaviors to widgets. They can be used in two
   manners:
   
   1. You can add a widget behavior function to a widget as a callback proc
      using the XPAddWidgetCallback function. The widget will gain that
      behavior. Remember that the last function you add has highest priority.
      You can use this to change or augment the behavior of an existing
      finished widget.
   
   2. You can call a widget function from inside your own widget function.
      This allows you to include useful behaviors in custom-built widgets. A
      number of the standard widgets get their behavior from this library. To
      do this, call the behavior function from your function first. If it
      returns 1, that means it handled the event and you don't need to; simply
      return 1.
}

USES
    XPWidgetDefs;
   {$A4}
{___________________________________________________________________________
 * GENERAL UTILITIES
 ___________________________________________________________________________}


   {
    XPWidgetCreate_t
    
    This structure contains all of the parameters needed to create a widget. It
    is used with XPUCreateWidgets to create widgets in bulk from an array. All
    parameters correspond to those of XPCreateWidget except for the container
    index.
    
    If the container index is equal to the index of a widget in the array, the
    widget in the array passed to XPUCreateWidgets is used as the parent of
    this widget. Note that if you pass an index greater than your own position
    in the array, the parent you are requesting will not exist yet.
    
    If the container index is NO_PARENT, the parent widget is specified as
    NULL. If the container index is PARAM_PARENT, the widget passed into
    XPUCreateWidgets is used.
   }
TYPE
   XPWidgetCreate_t = RECORD
     left                     : Integer;
     top                      : Integer;
     right                    : Integer;
     bottom                   : Integer;
     visible                  : Integer;
     descriptor               : XPLMString;
     { Whether this widget is a root widget                                       }
     isRoot                   : Integer;
     { The index of the widget to be contained within, or a constant              }
     containerIndex           : Integer;
     widgetClass              : XPWidgetClass;
   END;
   PXPWidgetCreate_t = ^XPWidgetCreate_t;

CONST
   NO_PARENT            = -1;

   PARAM_PARENT         = -2;


   {
    XPUCreateWidgets
    
    This function creates a series of widgets from a table (see
    XPCreateWidget_t above). Pass in an array of widget creation structures and
    an array of widget IDs that will receive each widget.
    
    Widget parents are specified by index into the created widget table,
    allowing you to create nested widget structures. You can create multiple
    widget trees in one table. Generally you should create widget trees from
    the top down.
    
    You can also pass in a widget ID that will be used when the widget's parent
    is listed as PARAM_PARENT; this allows you to embed widgets created with
    XPUCreateWidgets in a widget created previously.
   }
   PROCEDURE XPUCreateWidgets(
                                        inWidgetDefs        : PXPWidgetCreate_t;
                                        inCount             : Integer;
                                        inParamParent       : XPWidgetID;
                                        ioWidgets           : PXPWidgetID);
    cdecl; external XPWIDGETS.DLL;

   {
    XPUMoveWidgetBy
    
    Simply moves a widget by an amount, +x = right, +y = up, without resizing
    the widget.
   }
   PROCEDURE XPUMoveWidgetBy(
                                        inWidget            : XPWidgetID;
                                        inDeltaX            : Integer;
                                        inDeltaY            : Integer);
    cdecl; external XPWIDGETS.DLL;

{___________________________________________________________________________
 * LAYOUT MANAGERS
 ___________________________________________________________________________}
{
   The layout managers are widget behavior functions for handling where
   widgets move. Layout managers can be called from a widget function or
   attached to a widget later.
}


   {
    XPUFixedLayout
    
    This function causes the widget to maintain its children in fixed position
    relative to itself as it is resized. Use this on the top level 'window'
    widget for your window.
   }
   FUNCTION XPUFixedLayout(
                                        inMessage           : XPWidgetMessage;
                                        inWidget            : XPWidgetID;
                                        inParam1            : intptr_t;
                                        inParam2            : intptr_t) : Integer;
    cdecl; external XPWIDGETS.DLL;

{___________________________________________________________________________
 * WIDGET PROC BEHAVIORS
 ___________________________________________________________________________}
{
   These widget behavior functions add other useful behaviors to widgets.
   These functions cannot be attached to a widget; they must be called from
   your widget function.
}


   {
    XPUSelectIfNeeded
    
    This causes the widget to bring its window to the foreground if it is not
    already. inEatClick specifies whether clicks in the background should be
    consumed by bringing the window to the foreground.
   }
   FUNCTION XPUSelectIfNeeded(
                                        inMessage           : XPWidgetMessage;
                                        inWidget            : XPWidgetID;
                                        inParam1            : intptr_t;
                                        inParam2            : intptr_t;
                                        inEatClick          : Integer) : Integer;
    cdecl; external XPWIDGETS.DLL;

   {
    XPUDefocusKeyboard
    
    This causes the widget to send keyboard focus back to X-Plane. This stops
    editing of any text fields, etc.
   }
   FUNCTION XPUDefocusKeyboard(
                                        inMessage           : XPWidgetMessage;
                                        inWidget            : XPWidgetID;
                                        inParam1            : intptr_t;
                                        inParam2            : intptr_t;
                                        inEatClick          : Integer) : Integer;
    cdecl; external XPWIDGETS.DLL;

   {
    XPUDragWidget
    
    XPUDragWidget drags the widget in response to mouse clicks. Pass in not
    only the event, but the global coordinates of the drag region, which might
    be a sub-region of your widget (for example, a title bar).
   }
   FUNCTION XPUDragWidget(
                                        inMessage           : XPWidgetMessage;
                                        inWidget            : XPWidgetID;
                                        inParam1            : intptr_t;
                                        inParam2            : intptr_t;
                                        inLeft              : Integer;
                                        inTop               : Integer;
                                        inRight             : Integer;
                                        inBottom            : Integer) : Integer;
    cdecl; external XPWIDGETS.DLL;


IMPLEMENTATION

END.