/* @(#)ExtractShell.c 17.1.1.1 (ES0-DMD) 01/25/02 17:30:02 */ /*=========================================================================== Copyright (C) 1995 European Southern Observatory (ESO) This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Massachusetss Ave, Cambridge, MA 02139, USA. Corresponding concerning ESO-MIDAS should be addressed as follows: Internet e-mail: midas@eso.org Postal address: European Southern Observatory Data Management Division Karl-Schwarzschild-Strasse 2 D 85748 Garching bei Muenchen GERMANY ===========================================================================*/ /******************************************************************************* ExtractShell.c *******************************************************************************/ #include #include "UxLib.h" #include "UxTextF.h" #include "UxSepG.h" #include "UxLabel.h" #include "UxTogB.h" #include "UxRowCol.h" #include "UxSep.h" #include "UxText.h" #include "UxPushB.h" #include "UxForm.h" #include "UxApplSh.h" /******************************************************************************* Includes, Defines, and Global variables from the Declarations Editor: *******************************************************************************/ #include /******************************************************************************* The definition of the context structure: If you create multiple instances of your interface, the context structure ensures that your callbacks use the variables for the correct instance. For each swidget in the interface, each argument to the Interface function, and each variable in the Instance Specific section of the Declarations Editor, there is an entry in the context structure. and a #define. The #define makes the variable name refer to the corresponding entry in the context structure. *******************************************************************************/ typedef struct { swidget UxExtractShell; swidget Uxform14; swidget Uxform15; swidget Uxpb_ext_sky; swidget UxpushButton28; swidget Uxpb_ext_object; swidget Uxpb_ext_weight; swidget Uxpb_ext_average; swidget Uxpb_ext_fit; swidget Uxshelp_extract; swidget Uxseparator10; swidget Uxseparator11; swidget UxrowColumn6; swidget Uxrb_extmtd_line; swidget Uxrb_extmtd_aver; swidget Uxlabel47; swidget UxseparatorGadget26; swidget UxseparatorGadget27; swidget UxseparatorGadget28; swidget UxseparatorGadget34; swidget UxseparatorGadget35; swidget Uxlabel49; swidget Uxlabel50; swidget Uxtf_lowsky2; swidget Uxlabel42; swidget Uxtf_order; swidget Uxlabel45; swidget Uxtf_ron; swidget Uxtf_niter; swidget Uxlabel46; swidget Uxlabel51; swidget Uxtf_gain; swidget Uxtf_sigma; swidget Uxlabel53; swidget Uxtf_lowsky1; swidget Uxtf_uppsky1; swidget Uxtf_uppsky2; swidget Uxtf_object1; swidget Uxtf_object2; swidget UxrowColumn9; swidget Uxrb_skymod_0; swidget Uxrb_skymod_1; swidget Uxlabel52; swidget UxseparatorGadget32; swidget UxseparatorGadget33; swidget UxseparatorGadget36; swidget UxseparatorGadget37; swidget UxseparatorGadget38; swidget Uxtf_sky; swidget Uxlabel43; swidget Uxlabel60; swidget Uxtf_radius; swidget Uxlabel56; swidget Uxtf_skyord; } _UxCExtractShell; #define ExtractShell UxExtractShellContext->UxExtractShell #define form14 UxExtractShellContext->Uxform14 #define form15 UxExtractShellContext->Uxform15 #define pb_ext_sky UxExtractShellContext->Uxpb_ext_sky #define pushButton28 UxExtractShellContext->UxpushButton28 #define pb_ext_object UxExtractShellContext->Uxpb_ext_object #define pb_ext_weight UxExtractShellContext->Uxpb_ext_weight #define pb_ext_average UxExtractShellContext->Uxpb_ext_average #define pb_ext_fit UxExtractShellContext->Uxpb_ext_fit #define shelp_extract UxExtractShellContext->Uxshelp_extract #define separator10 UxExtractShellContext->Uxseparator10 #define separator11 UxExtractShellContext->Uxseparator11 #define rowColumn6 UxExtractShellContext->UxrowColumn6 #define rb_extmtd_line UxExtractShellContext->Uxrb_extmtd_line #define rb_extmtd_aver UxExtractShellContext->Uxrb_extmtd_aver #define label47 UxExtractShellContext->Uxlabel47 #define separatorGadget26 UxExtractShellContext->UxseparatorGadget26 #define separatorGadget27 UxExtractShellContext->UxseparatorGadget27 #define separatorGadget28 UxExtractShellContext->UxseparatorGadget28 #define separatorGadget34 UxExtractShellContext->UxseparatorGadget34 #define separatorGadget35 UxExtractShellContext->UxseparatorGadget35 #define label49 UxExtractShellContext->Uxlabel49 #define label50 UxExtractShellContext->Uxlabel50 #define tf_lowsky2 UxExtractShellContext->Uxtf_lowsky2 #define label42 UxExtractShellContext->Uxlabel42 #define tf_order UxExtractShellContext->Uxtf_order #define label45 UxExtractShellContext->Uxlabel45 #define tf_ron UxExtractShellContext->Uxtf_ron #define tf_niter UxExtractShellContext->Uxtf_niter #define label46 UxExtractShellContext->Uxlabel46 #define label51 UxExtractShellContext->Uxlabel51 #define tf_gain UxExtractShellContext->Uxtf_gain #define tf_sigma UxExtractShellContext->Uxtf_sigma #define label53 UxExtractShellContext->Uxlabel53 #define tf_lowsky1 UxExtractShellContext->Uxtf_lowsky1 #define tf_uppsky1 UxExtractShellContext->Uxtf_uppsky1 #define tf_uppsky2 UxExtractShellContext->Uxtf_uppsky2 #define tf_object1 UxExtractShellContext->Uxtf_object1 #define tf_object2 UxExtractShellContext->Uxtf_object2 #define rowColumn9 UxExtractShellContext->UxrowColumn9 #define rb_skymod_0 UxExtractShellContext->Uxrb_skymod_0 #define rb_skymod_1 UxExtractShellContext->Uxrb_skymod_1 #define label52 UxExtractShellContext->Uxlabel52 #define separatorGadget32 UxExtractShellContext->UxseparatorGadget32 #define separatorGadget33 UxExtractShellContext->UxseparatorGadget33 #define separatorGadget36 UxExtractShellContext->UxseparatorGadget36 #define separatorGadget37 UxExtractShellContext->UxseparatorGadget37 #define separatorGadget38 UxExtractShellContext->UxseparatorGadget38 #define tf_sky UxExtractShellContext->Uxtf_sky #define label43 UxExtractShellContext->Uxlabel43 #define label60 UxExtractShellContext->Uxlabel60 #define tf_radius UxExtractShellContext->Uxtf_radius #define label56 UxExtractShellContext->Uxlabel56 #define tf_skyord UxExtractShellContext->Uxtf_skyord static _UxCExtractShell *UxExtractShellContext; /******************************************************************************* The following are translation tables. *******************************************************************************/ static char *SelectFileExtract = "#override\n\ :FileSelectACT()\n"; /******************************************************************************* Forward declarations of functions that are defined later in this file. *******************************************************************************/ swidget create_ExtractShell(); /******************************************************************************* The following are Action functions. *******************************************************************************/ static void action_FileSelectACT( UxWidget, UxEvent, UxParams, p_UxNumParams ) Widget UxWidget; XEvent *UxEvent; String *UxParams; Cardinal *p_UxNumParams; { Cardinal UxNumParams = *p_UxNumParams; _UxCExtractShell *UxSaveCtx, *UxContext; swidget UxThisWidget; UxThisWidget = UxWidgetToSwidget( UxWidget ); UxSaveCtx = UxExtractShellContext; UxExtractShellContext = UxContext = (_UxCExtractShell *) UxGetContext( UxThisWidget ); { #include #include extern swidget FileListInterface, TextFieldSwidget; extern Widget FileListWidget; extern char DirSpecs[]; extern int ListType; int strip = 1; /* strip off */ TextFieldSwidget = UxThisWidget; strcpy(DirSpecs, "*.bdf"); if ( UxWidget == UxGetWidget(UxFindSwidget("tf_main_object")) ) { SET_LIST_TITLE("Enter object frame"); ListType = LIST_OBJECT; } else if ( UxWidget == UxGetWidget(UxFindSwidget("tf_main_sky")) ) { SET_LIST_TITLE("Enter sky frame"); ListType = LIST_SKY; } else if ( UxWidget == UxGetWidget(UxFindSwidget("tf_main_ststar")) ) { SET_LIST_TITLE("Enter standard star"); ListType = LIST_STSTAR; } else if ( UxWidget == UxGetWidget(UxFindSwidget("tf_main_stsky")) ) { SET_LIST_TITLE("Enter standard sky"); ListType = LIST_STSKY; } else if ( UxWidget == UxGetWidget(UxFindSwidget("tf_main_dark")) ) { SET_LIST_TITLE("Enter dark frame"); ListType = LIST_DARK; } else if ( UxWidget == UxGetWidget(UxFindSwidget("tf_main_flat")) ) { SET_LIST_TITLE("Enter flat-field frame"); ListType = LIST_FLAT; } else if ( UxWidget == UxGetWidget(UxFindSwidget("tf_std_flux")) ) { SET_LIST_TITLE("Enter flux table"); ListType = LIST_FLUX; strcpy(DirSpecs, "*.tbl"); } else if ( UxWidget == UxGetWidget(UxFindSwidget("tf_std_ref")) ) { SET_LIST_TITLE("Enter reference frame"); ListType = LIST_STD_REF; } else if ( UxWidget == UxGetWidget(UxFindSwidget("tf_obj_ref")) ) { SET_LIST_TITLE("Enter reference frame"); ListType = LIST_OBJ_REF; } else if ( UxWidget == UxGetWidget(UxFindSwidget("tf_obj_finput")) ) { SET_LIST_TITLE("Enter flux input frame"); ListType = LIST_OBJ_FINPUT; } else if ( UxWidget == UxGetWidget(UxFindSwidget("tf_obj_resp")) ) { SET_LIST_TITLE("Enter response frame"); ListType = LIST_RESP; } FileListWidget = UxGetWidget(UxFindSwidget("sl_file_list")); SetFileList(FileListWidget, strip, DirSpecs); UxPopupInterface(FileListInterface, exclusive_grab); } UxExtractShellContext = UxSaveCtx; } /******************************************************************************* The following are callback functions. *******************************************************************************/ static void activateCB_pb_ext_sky( UxWidget, UxClientData, UxCallbackArg ) Widget UxWidget; XtPointer UxClientData, UxCallbackArg; { _UxCExtractShell *UxSaveCtx, *UxContext; swidget UxThisWidget; UxThisWidget = UxWidgetToSwidget( UxWidget ); UxSaveCtx = UxExtractShellContext; UxExtractShellContext = UxContext = (_UxCExtractShell *) UxGetContext( UxThisWidget ); { ExtractSkyCallback(); } UxExtractShellContext = UxSaveCtx; } static void activateCB_pushButton28( UxWidget, UxClientData, UxCallbackArg ) Widget UxWidget; XtPointer UxClientData, UxCallbackArg; { _UxCExtractShell *UxSaveCtx, *UxContext; swidget UxThisWidget; UxThisWidget = UxWidgetToSwidget( UxWidget ); UxSaveCtx = UxExtractShellContext; UxExtractShellContext = UxContext = (_UxCExtractShell *) UxGetContext( UxThisWidget ); { UxPopdownInterface(UxFindSwidget("ExtractShell")); } UxExtractShellContext = UxSaveCtx; } static void activateCB_pb_ext_object( UxWidget, UxClientData, UxCallbackArg ) Widget UxWidget; XtPointer UxClientData, UxCallbackArg; { _UxCExtractShell *UxSaveCtx, *UxContext; swidget UxThisWidget; UxThisWidget = UxWidgetToSwidget( UxWidget ); UxSaveCtx = UxExtractShellContext; UxExtractShellContext = UxContext = (_UxCExtractShell *) UxGetContext( UxThisWidget ); { ExtractObjectCallback(); } UxExtractShellContext = UxSaveCtx; } static void activateCB_pb_ext_weight( UxWidget, UxClientData, UxCallbackArg ) Widget UxWidget; XtPointer UxClientData, UxCallbackArg; { _UxCExtractShell *UxSaveCtx, *UxContext; swidget UxThisWidget; UxThisWidget = UxWidgetToSwidget( UxWidget ); UxSaveCtx = UxExtractShellContext; UxExtractShellContext = UxContext = (_UxCExtractShell *) UxGetContext( UxThisWidget ); { #include PopupList(LIST_EXT_WEIGHT); } UxExtractShellContext = UxSaveCtx; } static void activateCB_pb_ext_average( UxWidget, UxClientData, UxCallbackArg ) Widget UxWidget; XtPointer UxClientData, UxCallbackArg; { _UxCExtractShell *UxSaveCtx, *UxContext; swidget UxThisWidget; UxThisWidget = UxWidgetToSwidget( UxWidget ); UxSaveCtx = UxExtractShellContext; UxExtractShellContext = UxContext = (_UxCExtractShell *) UxGetContext( UxThisWidget ); { #include PopupList(LIST_EXT_AVER); } UxExtractShellContext = UxSaveCtx; } static void activateCB_pb_ext_fit( UxWidget, UxClientData, UxCallbackArg ) Widget UxWidget; XtPointer UxClientData, UxCallbackArg; { _UxCExtractShell *UxSaveCtx, *UxContext; swidget UxThisWidget; UxThisWidget = UxWidgetToSwidget( UxWidget ); UxSaveCtx = UxExtractShellContext; UxExtractShellContext = UxContext = (_UxCExtractShell *) UxGetContext( UxThisWidget ); { #include PopupList(LIST_FIT_SKY); } UxExtractShellContext = UxSaveCtx; } /******************************************************************************* The 'init_' function sets the private properties for all the swidgets to the values specified in the Property Table. Some properties need to be set after the X widgets have been created and the setting of these properties is done in the 'build_' function after the UxCreateWidget call. *******************************************************************************/ static void _Uxinit_ExtractShell() { UxPutBackground( ExtractShell, WindowBackground ); UxPutGeometry( ExtractShell, "+10+60" ); UxPutKeyboardFocusPolicy( ExtractShell, "pointer" ); UxPutTitle( ExtractShell, "Spectrum Extraction" ); UxPutHeight( ExtractShell, 663 ); UxPutWidth( ExtractShell, 490 ); UxPutY( ExtractShell, 82 ); UxPutX( ExtractShell, 506 ); UxPutBackground( form14, WindowBackground ); UxPutHeight( form14, 662 ); UxPutWidth( form14, 490 ); UxPutY( form14, 0 ); UxPutX( form14, 0 ); UxPutUnitType( form14, "pixels" ); UxPutResizePolicy( form14, "resize_none" ); UxPutBackground( form15, ButtonBackground ); UxPutHeight( form15, 84 ); UxPutWidth( form15, 490 ); UxPutY( form15, 581 ); UxPutX( form15, 0 ); UxPutResizePolicy( form15, "resize_none" ); UxPutLabelString( pb_ext_sky, "Get sky" ); UxPutForeground( pb_ext_sky, ButtonForeground ); UxPutFontList( pb_ext_sky, BoldTextFont ); UxPutBackground( pb_ext_sky, ButtonBackground ); UxPutHeight( pb_ext_sky, 30 ); UxPutWidth( pb_ext_sky, 86 ); UxPutY( pb_ext_sky, 9 ); UxPutX( pb_ext_sky, 9 ); UxPutLabelString( pushButton28, "Return" ); UxPutForeground( pushButton28, CancelForeground ); UxPutFontList( pushButton28, BoldTextFont ); UxPutBackground( pushButton28, ButtonBackground ); UxPutHeight( pushButton28, 30 ); UxPutWidth( pushButton28, 86 ); UxPutY( pushButton28, 45 ); UxPutX( pushButton28, 9 ); UxPutLabelString( pb_ext_object, "Get object" ); UxPutForeground( pb_ext_object, ButtonForeground ); UxPutFontList( pb_ext_object, BoldTextFont ); UxPutBackground( pb_ext_object, ButtonBackground ); UxPutHeight( pb_ext_object, 30 ); UxPutWidth( pb_ext_object, 86 ); UxPutY( pb_ext_object, 9 ); UxPutX( pb_ext_object, 102 ); UxPutLabelString( pb_ext_weight, "Ext weight" ); UxPutForeground( pb_ext_weight, ButtonForeground ); UxPutFontList( pb_ext_weight, BoldTextFont ); UxPutBackground( pb_ext_weight, ButtonBackground ); UxPutHeight( pb_ext_weight, 30 ); UxPutWidth( pb_ext_weight, 86 ); UxPutY( pb_ext_weight, 9 ); UxPutX( pb_ext_weight, 386 ); UxPutLabelString( pb_ext_average, "Ext average" ); UxPutForeground( pb_ext_average, ButtonForeground ); UxPutFontList( pb_ext_average, BoldTextFont ); UxPutBackground( pb_ext_average, ButtonBackground ); UxPutHeight( pb_ext_average, 30 ); UxPutWidth( pb_ext_average, 86 ); UxPutY( pb_ext_average, 9 ); UxPutX( pb_ext_average, 290 ); UxPutLabelString( pb_ext_fit, "Fit sky" ); UxPutForeground( pb_ext_fit, ButtonForeground ); UxPutFontList( pb_ext_fit, BoldTextFont ); UxPutBackground( pb_ext_fit, ButtonBackground ); UxPutHeight( pb_ext_fit, 30 ); UxPutWidth( pb_ext_fit, 86 ); UxPutY( pb_ext_fit, 9 ); UxPutX( pb_ext_fit, 195 ); UxPutWordWrap( shelp_extract, "false" ); UxPutHighlightOnEnter( shelp_extract, "false" ); UxPutEditMode( shelp_extract, "single_line_edit" ); UxPutFontList( shelp_extract, TextFont ); UxPutEditable( shelp_extract, "false" ); UxPutCursorPositionVisible( shelp_extract, "false" ); UxPutBackground( shelp_extract, SHelpBackground ); UxPutHeight( shelp_extract, 50 ); UxPutWidth( shelp_extract, 488 ); UxPutY( shelp_extract, 526 ); UxPutX( shelp_extract, 1 ); UxPutBackground( separator10, WindowBackground ); UxPutHeight( separator10, 10 ); UxPutWidth( separator10, 492 ); UxPutY( separator10, 516 ); UxPutX( separator10, -1 ); UxPutBackground( separator11, WindowBackground ); UxPutHeight( separator11, 10 ); UxPutWidth( separator11, 492 ); UxPutY( separator11, 574 ); UxPutX( separator11, -3 ); UxPutIsAligned( rowColumn6, "true" ); UxPutEntryAlignment( rowColumn6, "alignment_beginning" ); UxPutBorderWidth( rowColumn6, 0 ); UxPutShadowThickness( rowColumn6, 0 ); UxPutLabelString( rowColumn6, "" ); UxPutEntryBorder( rowColumn6, 0 ); UxPutBackground( rowColumn6, "grey80" ); UxPutRadioBehavior( rowColumn6, "true" ); UxPutHeight( rowColumn6, 67 ); UxPutWidth( rowColumn6, 82 ); UxPutY( rowColumn6, 430 ); UxPutX( rowColumn6, 282 ); UxPutIndicatorSize( rb_extmtd_line, 16 ); UxPutHighlightOnEnter( rb_extmtd_line, "true" ); UxPutForeground( rb_extmtd_line, TextForeground ); UxPutSelectColor( rb_extmtd_line, SelectColor ); UxPutSet( rb_extmtd_line, "true" ); UxPutLabelString( rb_extmtd_line, "SUM" ); UxPutFontList( rb_extmtd_line, TextFont ); UxPutBackground( rb_extmtd_line, WindowBackground ); UxPutHeight( rb_extmtd_line, 20 ); UxPutWidth( rb_extmtd_line, 76 ); UxPutY( rb_extmtd_line, 2 ); UxPutX( rb_extmtd_line, 3 ); UxPutIndicatorSize( rb_extmtd_aver, 16 ); UxPutHighlightOnEnter( rb_extmtd_aver, "true" ); UxPutSet( rb_extmtd_aver, "false" ); UxPutForeground( rb_extmtd_aver, TextForeground ); UxPutSelectColor( rb_extmtd_aver, SelectColor ); UxPutLabelString( rb_extmtd_aver, "AVERAGE" ); UxPutFontList( rb_extmtd_aver, TextFont ); UxPutBackground( rb_extmtd_aver, WindowBackground ); UxPutHeight( rb_extmtd_aver, 66 ); UxPutWidth( rb_extmtd_aver, 76 ); UxPutY( rb_extmtd_aver, 34 ); UxPutX( rb_extmtd_aver, 3 ); UxPutForeground( label47, TextForeground ); UxPutAlignment( label47, "alignment_beginning" ); UxPutLabelString( label47, "Extraction method" ); UxPutFontList( label47, TextFont ); UxPutBackground( label47, WindowBackground ); UxPutHeight( label47, 26 ); UxPutWidth( label47, 122 ); UxPutY( label47, 404 ); UxPutX( label47, 274 ); UxPutOrientation( separatorGadget26, "vertical" ); UxPutHeight( separatorGadget26, 84 ); UxPutWidth( separatorGadget26, 12 ); UxPutY( separatorGadget26, 420 ); UxPutX( separatorGadget26, 259 ); UxPutHeight( separatorGadget27, 8 ); UxPutWidth( separatorGadget27, 144 ); UxPutY( separatorGadget27, 500 ); UxPutX( separatorGadget27, 264 ); UxPutOrientation( separatorGadget28, "vertical" ); UxPutHeight( separatorGadget28, 84 ); UxPutWidth( separatorGadget28, 12 ); UxPutY( separatorGadget28, 420 ); UxPutX( separatorGadget28, 402 ); UxPutHeight( separatorGadget34, 10 ); UxPutWidth( separatorGadget34, 16 ); UxPutY( separatorGadget34, 416 ); UxPutX( separatorGadget34, 392 ); UxPutHeight( separatorGadget35, 10 ); UxPutWidth( separatorGadget35, 13 ); UxPutY( separatorGadget35, 416 ); UxPutX( separatorGadget35, 264 ); UxPutForeground( label49, TextForeground ); UxPutAlignment( label49, "alignment_beginning" ); UxPutLabelString( label49, "Object limits (pixels) :" ); UxPutFontList( label49, TextFont ); UxPutBackground( label49, LabelBackground ); UxPutHeight( label49, 30 ); UxPutWidth( label49, 150 ); UxPutY( label49, 50 ); UxPutX( label49, 19 ); UxPutForeground( label50, TextForeground ); UxPutAlignment( label50, "alignment_beginning" ); UxPutLabelString( label50, "Sky limits (pixels) :" ); UxPutFontList( label50, TextFont ); UxPutBackground( label50, LabelBackground ); UxPutHeight( label50, 30 ); UxPutWidth( label50, 120 ); UxPutY( label50, 14 ); UxPutX( label50, 19 ); UxPutMaxLength( tf_lowsky2, 5 ); UxPutForeground( tf_lowsky2, TextForeground ); UxPutHighlightOnEnter( tf_lowsky2, "true" ); UxPutFontList( tf_lowsky2, TextFont ); UxPutBackground( tf_lowsky2, TextBackground ); UxPutHeight( tf_lowsky2, 34 ); UxPutWidth( tf_lowsky2, 56 ); UxPutY( tf_lowsky2, 11 ); UxPutX( tf_lowsky2, 296 ); UxPutForeground( label42, TextForeground ); UxPutAlignment( label42, "alignment_beginning" ); UxPutLabelString( label42, "Order for optimal extraction :" ); UxPutFontList( label42, TextFont ); UxPutBackground( label42, LabelBackground ); UxPutHeight( label42, 30 ); UxPutWidth( label42, 194 ); UxPutY( label42, 122 ); UxPutX( label42, 19 ); UxPutText( tf_order, "3" ); UxPutForeground( tf_order, TextForeground ); UxPutHighlightOnEnter( tf_order, "true" ); UxPutFontList( tf_order, TextFont ); UxPutBackground( tf_order, TextBackground ); UxPutHeight( tf_order, 34 ); UxPutWidth( tf_order, 80 ); UxPutY( tf_order, 122 ); UxPutX( tf_order, 243 ); UxPutForeground( label45, TextForeground ); UxPutAlignment( label45, "alignment_beginning" ); UxPutLabelString( label45, "Read-out-noise (e-) :" ); UxPutFontList( label45, TextFont ); UxPutBackground( label45, LabelBackground ); UxPutHeight( label45, 30 ); UxPutWidth( label45, 154 ); UxPutY( label45, 196 ); UxPutX( label45, 19 ); UxPutText( tf_ron, "7" ); UxPutForeground( tf_ron, TextForeground ); UxPutHighlightOnEnter( tf_ron, "true" ); UxPutFontList( tf_ron, TextFont ); UxPutBackground( tf_ron, TextBackground ); UxPutHeight( tf_ron, 34 ); UxPutWidth( tf_ron, 80 ); UxPutY( tf_ron, 196 ); UxPutX( tf_ron, 243 ); UxPutText( tf_niter, "3" ); UxPutForeground( tf_niter, TextForeground ); UxPutHighlightOnEnter( tf_niter, "true" ); UxPutFontList( tf_niter, TextFont ); UxPutBackground( tf_niter, TextBackground ); UxPutHeight( tf_niter, 34 ); UxPutWidth( tf_niter, 80 ); UxPutY( tf_niter, 158 ); UxPutX( tf_niter, 243 ); UxPutForeground( label46, TextForeground ); UxPutAlignment( label46, "alignment_beginning" ); UxPutLabelString( label46, "Extraction iterations :" ); UxPutFontList( label46, TextFont ); UxPutBackground( label46, LabelBackground ); UxPutHeight( label46, 30 ); UxPutWidth( label46, 146 ); UxPutY( label46, 160 ); UxPutX( label46, 19 ); UxPutForeground( label51, TextForeground ); UxPutAlignment( label51, "alignment_beginning" ); UxPutLabelString( label51, "Inverse gain factor (e-/ADU) :" ); UxPutFontList( label51, TextFont ); UxPutBackground( label51, LabelBackground ); UxPutHeight( label51, 30 ); UxPutWidth( label51, 206 ); UxPutY( label51, 232 ); UxPutX( label51, 19 ); UxPutText( tf_gain, "2" ); UxPutForeground( tf_gain, TextForeground ); UxPutHighlightOnEnter( tf_gain, "true" ); UxPutFontList( tf_gain, TextFont ); UxPutBackground( tf_gain, TextBackground ); UxPutHeight( tf_gain, 34 ); UxPutWidth( tf_gain, 80 ); UxPutY( tf_gain, 232 ); UxPutX( tf_gain, 243 ); UxPutText( tf_sigma, "3" ); UxPutForeground( tf_sigma, TextForeground ); UxPutHighlightOnEnter( tf_sigma, "true" ); UxPutFontList( tf_sigma, TextFont ); UxPutBackground( tf_sigma, TextBackground ); UxPutHeight( tf_sigma, 34 ); UxPutWidth( tf_sigma, 80 ); UxPutY( tf_sigma, 268 ); UxPutX( tf_sigma, 243 ); UxPutForeground( label53, TextForeground ); UxPutAlignment( label53, "alignment_beginning" ); UxPutLabelString( label53, "Threshold for cosmic rays :" ); UxPutFontList( label53, TextFont ); UxPutBackground( label53, LabelBackground ); UxPutHeight( label53, 30 ); UxPutWidth( label53, 182 ); UxPutY( label53, 270 ); UxPutX( label53, 19 ); UxPutMaxLength( tf_lowsky1, 5 ); UxPutForeground( tf_lowsky1, TextForeground ); UxPutHighlightOnEnter( tf_lowsky1, "true" ); UxPutFontList( tf_lowsky1, TextFont ); UxPutBackground( tf_lowsky1, TextBackground ); UxPutHeight( tf_lowsky1, 34 ); UxPutWidth( tf_lowsky1, 56 ); UxPutY( tf_lowsky1, 11 ); UxPutX( tf_lowsky1, 242 ); UxPutMaxLength( tf_uppsky1, 5 ); UxPutForeground( tf_uppsky1, TextForeground ); UxPutHighlightOnEnter( tf_uppsky1, "true" ); UxPutFontList( tf_uppsky1, TextFont ); UxPutBackground( tf_uppsky1, TextBackground ); UxPutHeight( tf_uppsky1, 34 ); UxPutWidth( tf_uppsky1, 56 ); UxPutY( tf_uppsky1, 11 ); UxPutX( tf_uppsky1, 350 ); UxPutMaxLength( tf_uppsky2, 5 ); UxPutForeground( tf_uppsky2, TextForeground ); UxPutHighlightOnEnter( tf_uppsky2, "true" ); UxPutFontList( tf_uppsky2, TextFont ); UxPutBackground( tf_uppsky2, TextBackground ); UxPutHeight( tf_uppsky2, 34 ); UxPutWidth( tf_uppsky2, 56 ); UxPutY( tf_uppsky2, 11 ); UxPutX( tf_uppsky2, 404 ); UxPutMaxLength( tf_object1, 5 ); UxPutForeground( tf_object1, TextForeground ); UxPutHighlightOnEnter( tf_object1, "true" ); UxPutFontList( tf_object1, TextFont ); UxPutBackground( tf_object1, TextBackground ); UxPutHeight( tf_object1, 34 ); UxPutWidth( tf_object1, 56 ); UxPutY( tf_object1, 47 ); UxPutX( tf_object1, 242 ); UxPutMaxLength( tf_object2, 5 ); UxPutForeground( tf_object2, TextForeground ); UxPutHighlightOnEnter( tf_object2, "true" ); UxPutFontList( tf_object2, TextFont ); UxPutBackground( tf_object2, TextBackground ); UxPutHeight( tf_object2, 34 ); UxPutWidth( tf_object2, 56 ); UxPutY( tf_object2, 47 ); UxPutX( tf_object2, 296 ); UxPutIsAligned( rowColumn9, "true" ); UxPutEntryAlignment( rowColumn9, "alignment_beginning" ); UxPutBorderWidth( rowColumn9, 0 ); UxPutShadowThickness( rowColumn9, 0 ); UxPutLabelString( rowColumn9, "" ); UxPutEntryBorder( rowColumn9, 0 ); UxPutBackground( rowColumn9, "grey80" ); UxPutRadioBehavior( rowColumn9, "true" ); UxPutHeight( rowColumn9, 67 ); UxPutWidth( rowColumn9, 82 ); UxPutY( rowColumn9, 430 ); UxPutX( rowColumn9, 53 ); UxPutIndicatorSize( rb_skymod_0, 16 ); UxPutHighlightOnEnter( rb_skymod_0, "true" ); UxPutForeground( rb_skymod_0, TextForeground ); UxPutSelectColor( rb_skymod_0, SelectColor ); UxPutSet( rb_skymod_0, "true" ); UxPutLabelString( rb_skymod_0, "Same spatial profile" ); UxPutFontList( rb_skymod_0, TextFont ); UxPutBackground( rb_skymod_0, WindowBackground ); UxPutHeight( rb_skymod_0, 20 ); UxPutWidth( rb_skymod_0, 76 ); UxPutY( rb_skymod_0, 0 ); UxPutX( rb_skymod_0, -12 ); UxPutIndicatorSize( rb_skymod_1, 16 ); UxPutHighlightOnEnter( rb_skymod_1, "true" ); UxPutSet( rb_skymod_1, "false" ); UxPutForeground( rb_skymod_1, TextForeground ); UxPutSelectColor( rb_skymod_1, SelectColor ); UxPutLabelString( rb_skymod_1, "Independent profile" ); UxPutFontList( rb_skymod_1, TextFont ); UxPutBackground( rb_skymod_1, WindowBackground ); UxPutHeight( rb_skymod_1, 66 ); UxPutWidth( rb_skymod_1, 76 ); UxPutY( rb_skymod_1, 34 ); UxPutX( rb_skymod_1, 3 ); UxPutForeground( label52, TextForeground ); UxPutAlignment( label52, "alignment_beginning" ); UxPutLabelString( label52, "Sky fitting mode" ); UxPutFontList( label52, TextFont ); UxPutBackground( label52, WindowBackground ); UxPutHeight( label52, 26 ); UxPutWidth( label52, 105 ); UxPutY( label52, 404 ); UxPutX( label52, 76 ); UxPutOrientation( separatorGadget32, "vertical" ); UxPutHeight( separatorGadget32, 84 ); UxPutWidth( separatorGadget32, 12 ); UxPutY( separatorGadget32, 420 ); UxPutX( separatorGadget32, 39 ); UxPutOrientation( separatorGadget33, "vertical" ); UxPutHeight( separatorGadget33, 84 ); UxPutWidth( separatorGadget33, 12 ); UxPutY( separatorGadget33, 420 ); UxPutX( separatorGadget33, 210 ); UxPutHeight( separatorGadget36, 10 ); UxPutWidth( separatorGadget36, 33 ); UxPutY( separatorGadget36, 416 ); UxPutX( separatorGadget36, 43 ); UxPutHeight( separatorGadget37, 10 ); UxPutWidth( separatorGadget37, 36 ); UxPutY( separatorGadget37, 416 ); UxPutX( separatorGadget37, 180 ); UxPutHeight( separatorGadget38, 8 ); UxPutWidth( separatorGadget38, 172 ); UxPutY( separatorGadget38, 500 ); UxPutX( separatorGadget38, 44 ); UxPutText( tf_sky, "sky" ); UxPutForeground( tf_sky, TextForeground ); UxPutHighlightOnEnter( tf_sky, "true" ); UxPutFontList( tf_sky, TextFont ); UxPutBackground( tf_sky, TextBackground ); UxPutHeight( tf_sky, 34 ); UxPutWidth( tf_sky, 210 ); UxPutY( tf_sky, 339 ); UxPutX( tf_sky, 242 ); UxPutForeground( label43, TextForeground ); UxPutAlignment( label43, "alignment_beginning" ); UxPutLabelString( label43, "Fitted sky (image or constant) :" ); UxPutFontList( label43, TextFont ); UxPutBackground( label43, LabelBackground ); UxPutHeight( label43, 30 ); UxPutWidth( label43, 209 ); UxPutY( label43, 337 ); UxPutX( label43, 19 ); UxPutForeground( label60, TextForeground ); UxPutAlignment( label60, "alignment_beginning" ); UxPutLabelString( label60, "Radius for cosmic rays removal :" ); UxPutFontList( label60, TextFont ); UxPutBackground( label60, LabelBackground ); UxPutHeight( label60, 30 ); UxPutWidth( label60, 220 ); UxPutY( label60, 303 ); UxPutX( label60, 19 ); UxPutText( tf_radius, "2" ); UxPutForeground( tf_radius, TextForeground ); UxPutHighlightOnEnter( tf_radius, "true" ); UxPutFontList( tf_radius, TextFont ); UxPutBackground( tf_radius, TextBackground ); UxPutHeight( tf_radius, 34 ); UxPutWidth( tf_radius, 80 ); UxPutY( tf_radius, 303 ); UxPutX( tf_radius, 242 ); UxPutForeground( label56, TextForeground ); UxPutAlignment( label56, "alignment_beginning" ); UxPutLabelString( label56, "Order for sky fit :" ); UxPutFontList( label56, TextFont ); UxPutBackground( label56, LabelBackground ); UxPutHeight( label56, 30 ); UxPutWidth( label56, 120 ); UxPutY( label56, 87 ); UxPutX( label56, 19 ); UxPutText( tf_skyord, "1" ); UxPutForeground( tf_skyord, TextForeground ); UxPutHighlightOnEnter( tf_skyord, "true" ); UxPutFontList( tf_skyord, TextFont ); UxPutBackground( tf_skyord, TextBackground ); UxPutHeight( tf_skyord, 34 ); UxPutWidth( tf_skyord, 80 ); UxPutY( tf_skyord, 85 ); UxPutX( tf_skyord, 242 ); } /******************************************************************************* The 'build_' function creates all the swidgets and X widgets, and sets their properties to the values specified in the Property Editor. *******************************************************************************/ static swidget _Uxbuild_ExtractShell() { /* Create the swidgets */ ExtractShell = UxCreateApplicationShell( "ExtractShell", NO_PARENT ); UxPutContext( ExtractShell, UxExtractShellContext ); form14 = UxCreateForm( "form14", ExtractShell ); form15 = UxCreateForm( "form15", form14 ); pb_ext_sky = UxCreatePushButton( "pb_ext_sky", form15 ); pushButton28 = UxCreatePushButton( "pushButton28", form15 ); pb_ext_object = UxCreatePushButton( "pb_ext_object", form15 ); pb_ext_weight = UxCreatePushButton( "pb_ext_weight", form15 ); pb_ext_average = UxCreatePushButton( "pb_ext_average", form15 ); pb_ext_fit = UxCreatePushButton( "pb_ext_fit", form15 ); shelp_extract = UxCreateText( "shelp_extract", form14 ); separator10 = UxCreateSeparator( "separator10", form14 ); separator11 = UxCreateSeparator( "separator11", form14 ); rowColumn6 = UxCreateRowColumn( "rowColumn6", form14 ); rb_extmtd_line = UxCreateToggleButton( "rb_extmtd_line", rowColumn6 ); rb_extmtd_aver = UxCreateToggleButton( "rb_extmtd_aver", rowColumn6 ); label47 = UxCreateLabel( "label47", form14 ); separatorGadget26 = UxCreateSeparatorGadget( "separatorGadget26", form14 ); separatorGadget27 = UxCreateSeparatorGadget( "separatorGadget27", form14 ); separatorGadget28 = UxCreateSeparatorGadget( "separatorGadget28", form14 ); separatorGadget34 = UxCreateSeparatorGadget( "separatorGadget34", form14 ); separatorGadget35 = UxCreateSeparatorGadget( "separatorGadget35", form14 ); label49 = UxCreateLabel( "label49", form14 ); label50 = UxCreateLabel( "label50", form14 ); tf_lowsky2 = UxCreateTextField( "tf_lowsky2", form14 ); label42 = UxCreateLabel( "label42", form14 ); tf_order = UxCreateTextField( "tf_order", form14 ); label45 = UxCreateLabel( "label45", form14 ); tf_ron = UxCreateTextField( "tf_ron", form14 ); tf_niter = UxCreateTextField( "tf_niter", form14 ); label46 = UxCreateLabel( "label46", form14 ); label51 = UxCreateLabel( "label51", form14 ); tf_gain = UxCreateTextField( "tf_gain", form14 ); tf_sigma = UxCreateTextField( "tf_sigma", form14 ); label53 = UxCreateLabel( "label53", form14 ); tf_lowsky1 = UxCreateTextField( "tf_lowsky1", form14 ); tf_uppsky1 = UxCreateTextField( "tf_uppsky1", form14 ); tf_uppsky2 = UxCreateTextField( "tf_uppsky2", form14 ); tf_object1 = UxCreateTextField( "tf_object1", form14 ); tf_object2 = UxCreateTextField( "tf_object2", form14 ); rowColumn9 = UxCreateRowColumn( "rowColumn9", form14 ); rb_skymod_0 = UxCreateToggleButton( "rb_skymod_0", rowColumn9 ); rb_skymod_1 = UxCreateToggleButton( "rb_skymod_1", rowColumn9 ); label52 = UxCreateLabel( "label52", form14 ); separatorGadget32 = UxCreateSeparatorGadget( "separatorGadget32", form14 ); separatorGadget33 = UxCreateSeparatorGadget( "separatorGadget33", form14 ); separatorGadget36 = UxCreateSeparatorGadget( "separatorGadget36", form14 ); separatorGadget37 = UxCreateSeparatorGadget( "separatorGadget37", form14 ); separatorGadget38 = UxCreateSeparatorGadget( "separatorGadget38", form14 ); tf_sky = UxCreateTextField( "tf_sky", form14 ); label43 = UxCreateLabel( "label43", form14 ); label60 = UxCreateLabel( "label60", form14 ); tf_radius = UxCreateTextField( "tf_radius", form14 ); label56 = UxCreateLabel( "label56", form14 ); tf_skyord = UxCreateTextField( "tf_skyord", form14 ); _Uxinit_ExtractShell(); /* Create the X widgets */ UxCreateWidget( ExtractShell ); UxCreateWidget( form14 ); UxCreateWidget( form15 ); UxCreateWidget( pb_ext_sky ); UxCreateWidget( pushButton28 ); UxCreateWidget( pb_ext_object ); UxCreateWidget( pb_ext_weight ); UxCreateWidget( pb_ext_average ); UxCreateWidget( pb_ext_fit ); UxCreateWidget( shelp_extract ); UxCreateWidget( separator10 ); UxCreateWidget( separator11 ); UxCreateWidget( rowColumn6 ); UxCreateWidget( rb_extmtd_line ); UxCreateWidget( rb_extmtd_aver ); UxCreateWidget( label47 ); UxCreateWidget( separatorGadget26 ); UxCreateWidget( separatorGadget27 ); UxCreateWidget( separatorGadget28 ); UxCreateWidget( separatorGadget34 ); UxCreateWidget( separatorGadget35 ); UxCreateWidget( label49 ); UxCreateWidget( label50 ); UxCreateWidget( tf_lowsky2 ); UxCreateWidget( label42 ); UxCreateWidget( tf_order ); UxCreateWidget( label45 ); UxCreateWidget( tf_ron ); UxCreateWidget( tf_niter ); UxCreateWidget( label46 ); UxCreateWidget( label51 ); UxCreateWidget( tf_gain ); UxCreateWidget( tf_sigma ); UxCreateWidget( label53 ); UxCreateWidget( tf_lowsky1 ); UxCreateWidget( tf_uppsky1 ); UxCreateWidget( tf_uppsky2 ); UxCreateWidget( tf_object1 ); UxCreateWidget( tf_object2 ); UxCreateWidget( rowColumn9 ); UxCreateWidget( rb_skymod_0 ); UxCreateWidget( rb_skymod_1 ); UxCreateWidget( label52 ); UxCreateWidget( separatorGadget32 ); UxCreateWidget( separatorGadget33 ); UxCreateWidget( separatorGadget36 ); UxCreateWidget( separatorGadget37 ); UxCreateWidget( separatorGadget38 ); UxCreateWidget( tf_sky ); UxCreateWidget( label43 ); UxCreateWidget( label60 ); UxCreateWidget( tf_radius ); UxCreateWidget( label56 ); UxCreateWidget( tf_skyord ); UxAddCallback( pb_ext_sky, XmNactivateCallback, activateCB_pb_ext_sky, (XtPointer) UxExtractShellContext ); UxAddCallback( pushButton28, XmNactivateCallback, activateCB_pushButton28, (XtPointer) UxExtractShellContext ); UxAddCallback( pb_ext_object, XmNactivateCallback, activateCB_pb_ext_object, (XtPointer) UxExtractShellContext ); UxAddCallback( pb_ext_weight, XmNactivateCallback, activateCB_pb_ext_weight, (XtPointer) UxExtractShellContext ); UxAddCallback( pb_ext_average, XmNactivateCallback, activateCB_pb_ext_average, (XtPointer) UxExtractShellContext ); UxAddCallback( pb_ext_fit, XmNactivateCallback, activateCB_pb_ext_fit, (XtPointer) UxExtractShellContext ); /* Finally, call UxRealizeInterface to create the X windows for the widgets created above. */ UxRealizeInterface( ExtractShell ); return ( ExtractShell ); } /******************************************************************************* The following function includes the code that was entered in the 'Initial Code' and 'Final Code' sections of the Declarations Editor. This function is called from the 'Interface function' below. *******************************************************************************/ static swidget _Ux_create_ExtractShell() { swidget rtrn; _UxCExtractShell *UxContext; UxExtractShellContext = UxContext = (_UxCExtractShell *) UxMalloc( sizeof(_UxCExtractShell) ); rtrn = _Uxbuild_ExtractShell(); return(rtrn); } /******************************************************************************* The following is the 'Interface function' which is the external entry point for creating this interface. This function should be called from your application or from a callback function. *******************************************************************************/ swidget create_ExtractShell() { swidget _Uxrtrn; static int _Uxinit = 0; if ( ! _Uxinit ) { static XtActionsRec _Uxactions[] = { { "FileSelectACT", action_FileSelectACT } }; XtAppAddActions( UxAppContext, _Uxactions, XtNumber(_Uxactions) ); _Uxinit = 1; } _Uxrtrn = _Ux_create_ExtractShell(); return ( _Uxrtrn ); } /******************************************************************************* END OF FILE *******************************************************************************/