mirror of
https://github.com/ptitSeb/Serious-Engine
synced 2025-01-13 15:21:33 +01:00
464 lines
19 KiB
C
464 lines
19 KiB
C
/****
|
|
* lwxpanel.h
|
|
****
|
|
* COPYRIGHT (C) 1999 NewTek, Inc.
|
|
* Description:
|
|
* LWXPanel Services
|
|
****
|
|
*/
|
|
|
|
#ifndef LWSDK_LWXPANEL_H
|
|
#define LWSDK_LWXPANEL_H
|
|
|
|
#include <lwtypes.h>
|
|
|
|
#define LWXPANELFUNCS_GLOBAL "LWXPanel"
|
|
|
|
/* Hint Tags */
|
|
|
|
typedef void * LWXPanelHint;
|
|
|
|
#define XpH(x) ((void *) (x))
|
|
#define XPTAG_END XpH(0)
|
|
#define XPTAG_NULL XpH(0)
|
|
#define XPTAG_CALL XpH(0xDD002)
|
|
#define XPTAG_NEST XpH(0x101)
|
|
|
|
#define XPTAG_LABEL XpH(0x3D000B03)
|
|
#define XPTAG_CLASS XpH(0x3D000C02)
|
|
#define XPTAG_ADD XpH(0x3D000D03)
|
|
#define XPTAG_DELETE XpH(0x3D000E01)
|
|
#define XPTAG_CHGNOTIFY XpH(0x3D000F01)
|
|
#define XPTAG_FOCUS XpH(0x3D001201)
|
|
#define XPTAG_AUTORESTORE XpH(0x3D001481)
|
|
#define XPTAG_DESTROYNOTIFY XpH(0x3D001302)
|
|
|
|
#define XPTAG_VALUE XpH(0x3D006502)
|
|
#define XPTAG_LINK XpH(0x3D006681)
|
|
#define XPTAG_IMMUPD XpH(0x3D006781)
|
|
#define XPTAG_TRACK XpH(0x3D006802)
|
|
#define XPTAG_ORIENT XpH(0x3D00CB02)
|
|
|
|
#define XPTAG_MIN XpH(0x3D014002)
|
|
#define XPTAG_MAX XpH(0x3D014102)
|
|
#define XPTAG_STEP XpH(0x3D014202)
|
|
#define XPTAG_RANGE XpH(0x3D014304)
|
|
#define XPTAG_HARDMINMAX XpH(0x3D014703)
|
|
#define XPTAG_CLRMINMAX XpH(0x3D014803)
|
|
#define XPTAG_SENS XpH(0x3D014402)
|
|
|
|
#define XPTAG_BUTNOTIFY XpH(0x3D015F02)
|
|
#define XPTAG_POPCMDFUNC XpH(0x3D016002)
|
|
#define XPTAG_POPFUNCS XpH(0x3D016203)
|
|
#define XPTAG_INTXFORM XpH(0x3D016303)
|
|
#define XPTAG_DRAWCBFUNC XpH(0x3D016502)
|
|
#define XPTAG_ZOOMCBFUNC XpH(0x3D016603)
|
|
|
|
#define XPTAG_STRLIST XpH(0x3D014503)
|
|
#define XPTAG_VECLABEL XpH(0x3D017202)
|
|
#define XPTAG_CTRLFRONT XpH(0x3D017301)
|
|
#define XPTAG_CTRLCFG XpH(0x3D017403)
|
|
#define XPTAG_XREQCFG XpH(0x3D019105)
|
|
|
|
#define XPTAG_ALIAS XpH(0x3D01F481)
|
|
#define XPTAG_UNALIAS XpH(0x3D01F581)
|
|
#define XPTAG_ENABLE XpH(0x3D01F984)
|
|
|
|
#define XPTAG_GROUP XpH(0x3D01FE81)
|
|
#define XPTAG_ORDER XpH(0x3D01FF81)
|
|
#define XPTAG_STACK XpH(0x3D020983)
|
|
#define XPTAG_TABS XpH(0x3D020A81)
|
|
|
|
#define XPTAG_LEFT XpH(0x3D021280)
|
|
#define XPTAG_NARROW XpH(0x3D021380)
|
|
#define XPTAG_DIVADD XpH(0x3D021481)
|
|
#define XPTAG_DIVREM XpH(0x3D021581)
|
|
#define XPTAG_BORDER XpH(0x3D021501)
|
|
|
|
#define XPTAG_DLOGTYPE XpH(0x3D02BD01)
|
|
|
|
/* Hint Macros */
|
|
|
|
/****
|
|
* Variable name guide
|
|
* IDs are unsigned long > 0x8000
|
|
* cid = ControlID
|
|
* gid = GroupID
|
|
* vid = ValueID
|
|
* cgid = Either a ControlID or GroupID acceptable
|
|
* id = General ID variable; use depends on context
|
|
****
|
|
*/
|
|
|
|
#define XpEND XPTAG_END
|
|
#define XpCALL(ref) XPTAG_CALL, XPTAG_NULL, XpH(ref)
|
|
#define XpSUBCALL(id,ref) XPTAG_CALL, XpH(id), XpH(ref)
|
|
#define XpNEST(id) XPTAG_NEST, XpH(id)
|
|
|
|
/* Configuration Hints */
|
|
#define XpLABEL(id,str) XPTAG_LABEL, XpH(id), XpH(str), XPTAG_NULL
|
|
#define XpCLASS(id,cl) XPTAG_CLASS, XpH(id), XpH(cl)
|
|
|
|
#define XpADD(id,cl,vid) XPTAG_ADD, XpH(id), XpH(cl), XpH(vid)
|
|
#define XpDELETE(id) XPTAG_DELETE, XpH(id)
|
|
|
|
#define XpCHGNOTIFY(func) XPTAG_CHGNOTIFY, XpH(func)
|
|
#define XpFOCUS(cid) XPTAG_FOCUS, XpH(cid)
|
|
#define XpRESTORE(vid) XPTAG_AUTORESTORE, XpH(1), XpH(vid), XPTAG_NULL
|
|
#define XpRESTORE_() XPTAG_AUTORESTORE, XpH(1)
|
|
#define XpRESTORE_ON XPTAG_AUTORESTORE, XpH(1), XPTAG_NULL
|
|
#define XpRESTORE_OFF XPTAG_AUTORESTORE, XpH(0), XPTAG_NULL
|
|
#define XpDESTROYNOTIFY(func) XPTAG_DESTROYNOTIFY, XpH(func), XPTAG_NULL
|
|
|
|
#define XpVALUE(dep,vid) XPTAG_VALUE, XpH(dep), XpH(vid)
|
|
#define XpLINK_(vid) XPTAG_LINK, XpH(vid)
|
|
#define XpLINK(vid,link) XPTAG_LINK, XpH(vid), XpH(link), XPTAG_NULL
|
|
#define XpIMMUPD(cid,did) XPTAG_IMMUPD, XpH(cid), XpH(did), XPTAG_NULL
|
|
#define XpIMMUPD_(cid) XPTAG_IMMUPD, XpH(cid)
|
|
#define XpTRACK(cid,track) XPTAG_TRACK, XpH(cid), XpH(track)
|
|
#define XpORIENT(cid,orient) XPTAG_ORIENT, XpH(cid), XpH(orient)
|
|
|
|
#define XpMIN(cid,min) XPTAG_MIN, XpH(cid), XpH(min)
|
|
#define XpMAX(cid,max) XPTAG_MAX, XpH(cid), XpH(max)
|
|
#define XpSTEP(cid,step) XPTAG_STEP, XpH(cid), XpH(step)
|
|
#define XpRANGE(cid,mn,mx,st) XPTAG_RANGE, XpH(cid), XpH(mn), XpH(mx), XpH(st)
|
|
#define XpHARDMINMAX(cid,mn,mx) XPTAG_HARDMINMAX, XpH(cid), XpH(mn), XpH(mx)
|
|
#define XpCLRMINMAX(cid,mn,mx) XPTAG_CLRMINMAX, XpH(cid), XpH(mn), XpH(mx)
|
|
#define XpSENS(cid,sens) XPTAG_SENS, XpH(cid), XpH(sens)
|
|
|
|
#define XpSTRLIST(cid,slist) XPTAG_STRLIST, XpH(cid), XpH(slist), XPTAG_NULL
|
|
#define XpVECLABEL(cid,slist) XPTAG_VECLABEL, XpH(cid), XpH(slist)
|
|
#define XpCTRLFRONT(cid) XPTAG_CTRLFRONT, XpH(cid)
|
|
#define XpCTRLCFG(cid,opt) XPTAG_CTRLCFG, XpH(cid), XPTAG_NULL, XpH(opt)
|
|
#define XpXREQCFG(cid,mode,ttl,ftyp) XPTAG_XREQCFG, XpH(cid), XpH(mode), XpH(ttl), XpH(ftyp), XPTAG_NULL
|
|
|
|
/* Callbacks */
|
|
#define XpBUTNOTIFY(cid,func) XPTAG_BUTNOTIFY, XpH(cid), XpH(func)
|
|
#define XpPOPCMDFUNC(cid,func) XPTAG_POPCMDFUNC, XpH(cid), XpH(func)
|
|
#define XpPOPFUNCS(cid,cnt,nam) XPTAG_POPFUNCS, XpH(cid), XpH(cnt), XpH(nam)
|
|
#define XpINTXFORM(cid,cnt,ilist) XPTAG_INTXFORM, XpH(cid), XpH(cnt), XpH(ilist)
|
|
#define XpPOPXFORM(cid,cnt,ilist) XPTAG_INTXFORM(cid,cnt,ilist)
|
|
#define XpCHOXFORM(cid,cnt,ilist) XPTAG_INTXFORM(cid,cnt,ilist)
|
|
#define XpDRAWCBFUNC(cid,func) XPTAG_DRAWCBFUNC, XpH(cid), XpH(func)
|
|
#define XpZOOMCBFUNC(cid,func,reg) XPTAG_ZOOMCBFUNC, XpH(cid), XpH(func), XpH(reg)
|
|
|
|
/* Relationships */
|
|
#define XpALIAS_(id) XPTAG_ALIAS, XpH(id)
|
|
#define XpUNALIAS_(id) XPTAG_UNALIAS, XpH(id)
|
|
|
|
#define XpENABLE(vid,sub) XPTAG_ENABLE, XpH(vid), XPTAG_NULL, XPTAG_NULL, XPTAG_NULL, XpH(sub), XPTAG_NULL
|
|
#define XpENABLE_(vid) XPTAG_ENABLE, XpH(vid), XPTAG_NULL, XPTAG_NULL, XPTAG_NULL
|
|
#define XpENABLE_MAP_(vid,map) XPTAG_ENABLE, XpH(vid), XPTAG_NULL, XPTAG_NULL, XpH(map)
|
|
#define XpENABLEMSG_(vid,msg) XPTAG_ENABLE, XpH(vid), XpH(msg), XPTAG_NULL, XPTAG_NULL
|
|
#define XpENABLEMSG_MAP_(vid,map,msg) XPTAG_ENABLE, XpH(vid), XpH(msg), XPTAG_NULL, XpH(map)
|
|
|
|
/* Layout Hints */
|
|
#define XpGROUP_(gid) XPTAG_GROUP, XpH(gid)
|
|
#define XpORDER_(gid) XPTAG_ORDER, XpH(gid)
|
|
#define XpSTACK_(gid,vid) XPTAG_STACK, XpH(gid), XpH(vid), XPTAG_NULL
|
|
#define XpSTACK_MAP_(gid,vid,map) XPTAG_STACK, XpH(gid), XpH(vid), XpH(map)
|
|
#define XpTABS_(gid) XPTAG_TABS, XpH(gid)
|
|
|
|
#define XpLEFT(gid) XPTAG_LEFT, XpH(gid), XPTAG_NULL
|
|
#define XpLEFT_() XPTAG_LEFT
|
|
#define XpNARROW(gid) XPTAG_NARROW, XpH(gid), XPTAG_NULL
|
|
#define XpNARROW_() XPTAG_NARROW
|
|
|
|
#define XpDIVADD(id) XPTAG_DIVADD, XpH(id), XPTAG_NULL
|
|
#define XpDIVADD_(id) XPTAG_DIVADD, XpH(id)
|
|
#define XpDIVREM(id) XPTAG_DIVREM, XpH(id), XPTAG_NULL
|
|
#define XpDIVREM_(id) XPTAG_DIVREM, XpH(id)
|
|
|
|
#define XpBORDER(typ) XPTAG_BORDER, XpH(typ)
|
|
#define XpDLOGTYPE(typ) XPTAG_DLOGTYPE, XpH(typ)
|
|
|
|
/* TypeDefs */
|
|
|
|
typedef void *LWXPanelID;
|
|
|
|
/* Controls */
|
|
typedef struct st_LWXPanelControl {
|
|
unsigned long cid;
|
|
const char *label;
|
|
const char *ctrlclass;
|
|
} LWXPanelControl;
|
|
|
|
/* Data Description */
|
|
typedef struct st_LWXPanelDataDesc {
|
|
unsigned long vid;
|
|
const char *name;
|
|
const char *datatype;
|
|
} LWXPanelDataDesc;
|
|
|
|
/* Draw Functions */
|
|
typedef void *LWXPDrAreaID;
|
|
typedef struct st_LWXPDrawFuncs {
|
|
void (*drawPixel) ( LWXPDrAreaID p, int c, int x, int y );
|
|
void (*drawRGBPixel) ( LWXPDrAreaID p,
|
|
int r, int g, int b, int x, int y );
|
|
void (*drawLine) ( LWXPDrAreaID p,
|
|
int c, int x, int y, int x2, int y2 );
|
|
void (*drawBox) ( LWXPDrAreaID p,
|
|
int c, int x, int y, int w, int h );
|
|
void (*drawRGBBox) ( LWXPDrAreaID p,
|
|
int r, int g, int b,
|
|
int x, int y, int w, int h );
|
|
void (*drawBorder) ( LWXPDrAreaID p,
|
|
int indent, int x, int y, int w, int h );
|
|
int (*textWidth) ( LWXPDrAreaID p, char *s );
|
|
int (*textHeight) ( LWXPDrAreaID p, char *s );
|
|
void (*drawText) ( LWXPDrAreaID p, char *s, int c, int x, int y );
|
|
} LWXPDrawFuncs;
|
|
|
|
/* Panel Types */
|
|
#define LWXP_VIEW 1
|
|
#define LWXP_FORM 2
|
|
|
|
/****
|
|
* Client Notification Event Types
|
|
*
|
|
* TRACK - Value changes are in progress; e.g., mouse drag of a mini-slider
|
|
* VALUE - Value has changed. Change could result for a
|
|
* mouse-up event, user hitting tab or enter, etc.
|
|
* These events are usually generated by controls
|
|
* which have an underlying value (e.g., "string")
|
|
* HIT - Similar to value events but usually associated
|
|
* with NULL-based control types (vButton, etc.)
|
|
* FOCUS - LWXPanel has gained user's attention
|
|
* LOSEFOCUS - LWXPanel lost user's attention
|
|
*/
|
|
enum en_LWXPEventTypes {
|
|
LWXPEVENT_TRACK = 1,
|
|
LWXPEVENT_VALUE,
|
|
LWXPEVENT_HIT,
|
|
LWXPEVENT_FOCUS,
|
|
LWXPEVENT_LOSEFOCUS
|
|
};
|
|
|
|
typedef enum en_LWXPRefreshCodes {
|
|
LWXPRC_NONE = 0,
|
|
LWXPRC_DFLT,
|
|
LWXPRC_DRAW,
|
|
LWXPRC_FULL
|
|
} LWXPRefreshCode;
|
|
|
|
enum LWXPDialogTypes {
|
|
LWXPDLG_OKCANCEL = 2, // ok(1)/cancel(0) (default panel type);
|
|
LWXPDLG_DONE, // done(1);
|
|
LWXPDLG_OKONLY, // ok(1);
|
|
LWXPDLG_YESNO, // yes(1)/no(0);
|
|
LWXPDLG_YESNOALL, // yes(1)/no(0)/yes-to-all(2)/cancel(3).
|
|
LWXPDLG_YESNOCAN // yes(1)/no(0)/cancel(3);
|
|
};
|
|
|
|
/* sFileName modes */
|
|
#define LWXPREQ_LOAD 0
|
|
#define LWXPREQ_SAVE 1
|
|
#define LWXPREQ_DIR 2
|
|
|
|
/* Border types */
|
|
#define LWXPBDR_NONE 0
|
|
#define LWXPBDR_UP 1
|
|
#define LWXPBDR_DOWN 2
|
|
|
|
/* Control configuration */
|
|
|
|
/* Thumbnail Control */
|
|
#define THUM_SML (1<<0)
|
|
#define THUM_MED (1<<1)
|
|
#define THUM_LRG (1<<2)
|
|
#define THUM_XLG (1<<3)
|
|
|
|
#define THUM_SQ (1<<16)
|
|
#define THUM_NTSC (1<<17)
|
|
#define THUM_35MM (1<<18)
|
|
#define THUM_PORT (1<<19)
|
|
#define THUM_WIDE (1<<20)
|
|
#define THUM_ANAW (1<<21)
|
|
#define THUM_EURO (1<<22)
|
|
|
|
#define THUM_FULL (1<<31)
|
|
#define THUM_LAND THUM_NTSC
|
|
|
|
|
|
/****
|
|
* Callback Prototypes
|
|
* The "Get" returns a pointer to the value for ValueID 'vid'.
|
|
* The pointer is then cast and dereferenced as needed.
|
|
* The "Set" is given a pointer to the value for the ValueID, 'vid'.
|
|
* The "Set" returns one of the above refresh flags where 'NONE'
|
|
* indicates 'vid' was unrecognized.
|
|
****
|
|
*/
|
|
typedef void *LWXPanelGetFunc ( void *inst,
|
|
unsigned long vid );
|
|
|
|
typedef LWXPRefreshCode LWXPanelSetFunc ( void *inst,
|
|
unsigned long vid,
|
|
void *value );
|
|
|
|
|
|
/****
|
|
* Destroy notification
|
|
****
|
|
* This is called _after_ destruction of the panel instance and is
|
|
* intended for cleanup of any panel specific allocations, etc.
|
|
* This is necessary when the panel was returned to the application
|
|
* by setting the LWInterface "panel" to a plugin created LWXPanelID.
|
|
* In such cases, the application may destroy the panel automatically.
|
|
* The panData argument is whatever was set using "setData (pan,0,panData)"
|
|
* to set the panel's userdata.
|
|
*
|
|
* If the callback is called, the client should not destroy the panel.
|
|
* If it is not called, the client should destroy its interface with
|
|
* the client is destroyed.
|
|
****
|
|
*/
|
|
typedef void LWXPanelDestroyNotifyFunc ( void *panData );
|
|
|
|
/* Event notification */
|
|
typedef LWXPRefreshCode LWXPanelChangeNotifyFunc ( LWXPanelID pan,
|
|
unsigned long cid,
|
|
unsigned long vid,
|
|
int event_type );
|
|
|
|
/* Button click event notification */
|
|
typedef void LWXPanelBtnClickFunc ( LWXPanelID pan,
|
|
int cid );
|
|
|
|
/* Popup command */
|
|
typedef void LWXPanelPopCmdFunc ( LWXPanelID pan,
|
|
int cid,
|
|
int cmdid );
|
|
|
|
/* Popup choice */
|
|
typedef int LWXPanelPopCntFunc ( void *userdata );
|
|
typedef const char *LWXPanelPopNameFunc ( void *userdata, int idx );
|
|
|
|
/* Draw Function */
|
|
typedef void LWXPanelControlDrawFunc ( LWXPanelID pan,
|
|
unsigned long cid,
|
|
LWXPDrAreaID reg,
|
|
int w, int h );
|
|
typedef void LWXPanelControlZoomFunc ( LWXPanelID pan,
|
|
unsigned long cid,
|
|
int x, int y,
|
|
int *region,
|
|
int clickcount );
|
|
|
|
/****
|
|
* GLOBAL SERVICE INTERFACE.
|
|
* These are the functions required to create
|
|
* and manipulate an LWXPanel.
|
|
*
|
|
* version: the version number of the interface. Certain control types
|
|
* or hints may not be available in older interfaces.
|
|
*
|
|
* SETUP FUNCTIONS
|
|
*
|
|
* create: construct a new panel of the given type from the control
|
|
* description. The type can be LWXP_VIEW or LWXP_FORM.
|
|
*
|
|
* destroy: free a panel.
|
|
*
|
|
* describe: define the data values for this panel. The data description
|
|
* contains the list of value IDs and their types. If this is
|
|
* a VIEW panel, then the get and set functions are required to
|
|
* read and write the values from the opaque client instance.
|
|
*
|
|
* hint: apply a hint array to the panel. This may be called multiple
|
|
* times, but only while the panel is closed.
|
|
*
|
|
* USER DATA FUNCTIONS
|
|
*
|
|
* setData: set userdata for a control which will be passed to the
|
|
* callbacks for that control. A control ID of zero sets
|
|
* the data for the whole panel. (NOTE: userdata for ID
|
|
* zero is returned in the deestroy notification callback)
|
|
*
|
|
* getData: get the userdata for a control or the whole panel.
|
|
*
|
|
* PANEL VALUE FUNCTIONS
|
|
* (a brief description)
|
|
* The panel can present data as a VIEW or a FORM.
|
|
* A VIEW panel is a "view" of a client owned data instance.
|
|
* Therefore, the client must provide get and set methods to
|
|
* allow the panel to directly update the data instance set
|
|
* with viewInst.
|
|
* A FORM panel, on the other hand, presents a collection of
|
|
* data parameters where the data instance itself is owned by
|
|
* the panel. The parameter values are accessed by the client
|
|
* using the formGet and formSet methods.
|
|
*
|
|
* formSet: write a data value to a slot in a FORM panel. The value
|
|
* pointer should point to the new value for the entry, or
|
|
* null for none.
|
|
*
|
|
* formGet: read the value from a slot in a FORM panel. Null is returned
|
|
* for slots that are unset.
|
|
*
|
|
* viewInst: set the instance pointer for a VIEW panel. The values on the
|
|
* panel will be read from the instance using the client's get
|
|
* and set methods.
|
|
*
|
|
* viewRefresh: "Refreshes" a VIEW panel by reloading control values from the
|
|
* client data instance. Generally, this is reserved for use when
|
|
* the client data instance is modified from an external source
|
|
* other than the panel interface or through other operations
|
|
* internal to the client.
|
|
*
|
|
* INTERACTION FUNCTIONS
|
|
*
|
|
* post: display the panel for modal interaction. The panel will open
|
|
* as a modal dialog and will not return control to the caller
|
|
* until the user selects 'OK' or 'Cancel'. The function returns
|
|
* true or false, respectively for those cases.
|
|
*
|
|
* open: display the panel for non-modal interaction. This function
|
|
* returns true immediately and the panel stays open until the
|
|
* user closes it.
|
|
*
|
|
****
|
|
*/
|
|
|
|
/* Global Services */
|
|
typedef struct st_LWXPanelFuncs {
|
|
int version;
|
|
LWXPDrawFuncs *drawf;
|
|
LWXPanelID (*create) ( int type, LWXPanelControl *ctrlDesc );
|
|
void (*destroy) ( LWXPanelID panel );
|
|
void (*describe) ( LWXPanelID panel,
|
|
LWXPanelDataDesc *dataDesc,
|
|
LWXPanelGetFunc *get,
|
|
LWXPanelSetFunc *set );
|
|
void (*hint) ( LWXPanelID panel, unsigned long id,
|
|
LWXPanelHint *hints );
|
|
void *(*getData) ( LWXPanelID panel,
|
|
unsigned long id );
|
|
void (*setData) ( LWXPanelID panel,
|
|
unsigned long id,
|
|
void *data );
|
|
void *(*formGet) ( LWXPanelID panel,
|
|
unsigned long vid );
|
|
void (*formSet) ( LWXPanelID panel,
|
|
unsigned long vid,
|
|
void *value );
|
|
void (*viewInst) ( LWXPanelID panel, void *inst );
|
|
void (*viewRefresh) ( LWXPanelID panel );
|
|
int (*post) ( LWXPanelID panel );
|
|
int (*open) ( LWXPanelID panel );
|
|
} LWXPanelFuncs;
|
|
|
|
/****
|
|
* Helper Macros
|
|
* These simplify use of the LWXPanel formGet and formSet functions
|
|
****
|
|
*/
|
|
#define FSETINT(fun,pan,cid,i) {long l=(long)i;(*fun->formSet)(pan,cid,&l);}
|
|
#define FGETINT(fun,pan,cid) (*((int*)(*fun->formGet)(pan,cid)))
|
|
#define FSETFLT(fun,pan,cid,f) {double d=(double)f;(*fun->formSet)(pan,cid,&d);}
|
|
#define FGETFLT(fun,pan,cid) (*((double*)(*fun->formGet)(pan,cid)))
|
|
|
|
/* close LWSDK_LWXPANEL_H */
|
|
#endif
|