source: trunk/SRC/ToBeReviewed/WIDGET/COMPOUND_WIDGET/cw_slide_slice.pro @ 114

Last change on this file since 114 was 114, checked in by smasson, 18 years ago

new compilation options (compile_opt idl2, strictarrsubs) in each routine

  • Property svn:eol-style set to native
  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
File size: 7.4 KB
Line 
1pro cw_slide_slice_set_value, id, value
2;
3  compile_opt idl2, strictarrsubs
4;
5@common
6   topid = findtopid(id)
7   domainid = widget_info(topid, find_by_uname = 'domain')
8   widget_control, domainid, get_value = boxzoom
9   if boxzoom[1]-boxzoom[0] LT boxzoom[3]-boxzoom[2] then type = 'y' ELSE type = 'x'
10   thickid  = widget_info(topid, find_by_uname = 'thickness')
11   widget_control, thickid, get_uvalue = thicknessuval
12   widget_control, thickid, get_value = thickness
13   thickness = thicknessuval.choix[thickness.droplist_select]
14   sliderid = widget_info(topid, find_by_uname = 'slider')
15   if type EQ 'y' then BEGIN
16      mini = floor(min([glamt, glamf], max = maxi))
17      maxi = ceil(maxi)-thickness
18      widget_control, sliderid, set_value = {slider_min:mini, slider_max:maxi, value:boxzoom[0]<maxi}
19      thickness = boxzoom[1]-boxzoom[0]
20   ENDIF ELSE BEGIN
21      mini = floor(min([gphit, gphif], max = maxi))
22      maxi = ceil(maxi)-thickness
23      widget_control, sliderid, set_value = {slider_min:mini, slider_max:maxi, value:boxzoom[2]<maxi}
24      thickness = boxzoom[3]-boxzoom[2]
25   ENDELSE
26   thicknessval = thicknessuval.choix
27   index = where(thicknessval EQ thickness) & index = index[0]
28   if index EQ -1 then BEGIN
29      index = 20
30      thicknessval[20] = strtrim(thickness, 1)
31      widget_control, thickid, set_value = thicknessval
32      widget_control, thickid, set_uvalue ={name:'thickness', choix:thicknessval}
33   endif
34   widget_control, thickid, set_value = {droplist_select:index}
35   return
36end
37;----------------------------------------------------------------------
38FUNCTION cw_slide_slice_event,  event
39;
40  compile_opt idl2, strictarrsubs
41;
42@common
43   widget_control, event.id, get_uvalue=uval
44   domainid = widget_info(event.top, find_by_uname = 'domain')
45   thickid  = widget_info(event.handler, find_by_uname = 'thickness')
46   sliderid = widget_info(event.handler, find_by_uname = 'slider')
47;   uniteid  = widget_info(event.handler, find_by_uname = 'unite')
48   widget_control, domainid, get_value = boxzoom
49   if boxzoom[1]-boxzoom[0] LT boxzoom[3]-boxzoom[2] then type = 'y' ELSE type = 'x'
50   widget_control, thickid, get_uvalue = thicknessuval
51   widget_control, thickid, get_value = thickness
52   thickness = thicknessuval.choix[thickness.droplist_select]
53   widget_control, sliderid, get_value = slider & slider = slider.value
54
55   if uval.name EQ 'thickness' then begin
56      if boxzoom[1]-boxzoom[0] LT boxzoom[3]-boxzoom[2] then type = 'y' ELSE type = 'x'
57      if type EQ 'y' then BEGIN
58         mini = floor(min([glamt, glamf], max = maxi))
59         maxi = ceil(maxi)-thickness
60      ENDIF ELSE BEGIN
61         mini = floor(min([gphit, gphif], max = maxi))
62         maxi = ceil(maxi)-thickness
63      ENDELSE
64      slider = slider<maxi
65      widget_control, sliderid, set_value = {slider_min:mini, slider_max:maxi, value:slider}
66   endif
67
68;   widget_control, uniteid, get_value = unite
69;
70;
71;    if uval.name EQ 'unite' then begin
72;       domdef, boxzoom, gridtype = 'T'
73;       if unite EQ 'degre' then BEGIN
74;          if strpos(type,'y') NE -1 then begin
75;             mini = floor(min([glamt, glamf], max = maxi))
76;             maxi = ceil(maxi)
77; print, lon1, mini, maxi
78;             widget_control, sliderid, set_value = {value:lon1, slider_min_max:[mini, maxi]}
79;          ENDIF ELSE BEGIN
80;             mini = floor(min([gphit, glamf], max = maxi))
81;             maxi = ceil(maxi)
82;             widget_control, sliderid, set_value = {value:lat1, slider_min_max:[mini, maxi]}
83;          ENDELSE
84;       ENDIF ELSE BEGIN
85;          if strpos(type,'y') NE -1 then BEGIN
86; print, 'ds if',firstxt, 0, jpi-1
87;             widget_control, sliderid, set_value = {value:firstxt, slider_min_max:[0, jpi-1]}
88;          ENDIF ELSE BEGIN
89;             widget_control, sliderid, set_value = {value:firstyt, slider_min_max:[0, jpj-1]}
90;          ENDELSE
91;       ENDELSE
92;    endif
93;
94;   if unite EQ 'degre' then BEGIN
95   if type EQ 'y' then begin
96      boxzoom[0] = slider &  boxzoom[1] = slider+thickness
97   ENDIF ELSE BEGIN
98      boxzoom[2] = slider &  boxzoom[3] = slider+thickness
99   ENDELSE
100;    ENDIF ELSE BEGIN
101;       if strpos(type,'y') NE -1 then begin
102;          boxzoom[0] = glamt[slider, 0] &  boxzoom[1] = glamf[slider+thickness, 0]
103;       ENDIF ELSE BEGIN
104;          boxzoom[2] = gphit[0, slider] &  boxzoom[3] = gphif[0, slider+thickness]
105;       ENDELSE
106;    ENDELSE
107   widget_control, domainid, set_value = boxzoom
108   return, {CW_SLIDE_SLICE, ID:event.handler, TOP:event.top, HANDLER:0L}
109end
110;--------------------------------------------------------------------------------
111FUNCTION cw_slide_slice, parent, boxzoom = boxzoom, UVALUE = uvalue, UNAME = uname, FRAME = frame, ROW = row, COLUMN = column, _extra = ex
112;
113  compile_opt idl2, strictarrsubs
114;
115@common
116;------------------------------------------------
117; cheking exclusive keywords
118   column = keyword_set(column)*(1-keyword_set(row))
119   row = keyword_set(row)*(1-keyword_set(column)) +(keyword_set(row) EQ column)
120   if NOT keyword_set(uvalue) then uvalue = ''
121   if NOT keyword_set(uname) then uname = ''
122;
123   base = widget_base(parent, ROW = row, COLUMN = column  $
124                      , EVENT_FUNC = 'cw_slide_slice_event' $
125                      , FUNC_GET_VALUE='cw_slide_slice_get_value' $
126                      , PRO_SET_VALUE='cw_slide_slice_set_value' $
127                      , ROW = row, COLUMN = column, UVALUE = uvalue, UNAME = uname $
128                      , FRAME = frame, _extra = ex)   
129;------------------------------------------------
130   if NOT keyword_set(boxzoom) then boxzoom = [lon1, lon2, lat1, lat2]
131;    rien = cw_bgroup(base, ['degre', 'points'],/exclusive, /column, uname = 'unite', uvalue = {name:'unite'}, /return_name, set_value = 0, /no_release)
132   thicknessval = indgen(21)+1
133   thicknessval = string(thicknessval)
134   for i = 0, n_elements(thicknessval)-1 do thicknessval[i] = strtrim(thicknessval[i], 1)
135   droplistid = cw_droplist_pm(base, value = thicknessval, uname = 'thickness', uvalue = {name:'thickness', choix:thicknessval})
136;
137   if boxzoom[1]-boxzoom[0] LT boxzoom[3]-boxzoom[2] then type = 'y' ELSE type = 'x'
138   if type EQ 'y' then BEGIN
139      mini = floor(min([glamt, glamf], max = maxi))
140      thickness = boxzoom[1]-boxzoom[0]
141      maxi = ceil(maxi)-thickness
142      rien = cw_slider_pm(base, minimum = mini, maximum = (mini+1) > maxi $
143                          , value = mini > boxzoom[0] < maxi, /column, uname = 'slider' $
144                          , uvalue = {name:'slider'})
145   ENDIF ELSE BEGIN
146      mini = floor(min([gphit, gphif], max = maxi))
147      thickness = boxzoom[3]-boxzoom[2]
148      maxi = ceil(maxi)-thickness
149      rien = cw_slider_pm(base, minimum = mini, maximum =  (mini+1) > maxi $
150                          , value = mini > boxzoom[2] < maxi, /column, uname = 'slider' $
151                          , uvalue = {name:'slider'})
152   ENDELSE
153   index = where(thicknessval EQ thickness) & index = index[0]
154   if index EQ -1 then BEGIN
155      index = 20
156      thicknessval[20] = strtrim(thickness, 1)
157      widget_control, droplistid, set_value = thicknessval
158      widget_control, droplistid, set_uvalue ={name:'thickness', choix:thicknessval}
159   endif
160   widget_control, droplistid, set_value = {droplist_select:index}
161   
162;   if type EQ 'xt' then begin
163;       mini = floor(min([glamt,glamf], max = maxi))
164;       maxi = ceil(maxi)
165;    ENDIF ELSE BEGIN
166;       mini = floor(min([gphit,gphif], max = maxi))
167;       maxi = ceil(maxi)
168;    ENDELSE
169   
170;------------------------------------------------
171   return, base
172end
Note: See TracBrowser for help on using the repository browser.