diff options
author | William Joye <wjoye@cfa.harvard.edu> | 2016-10-27 19:01:15 (GMT) |
---|---|---|
committer | William Joye <wjoye@cfa.harvard.edu> | 2016-10-27 19:01:15 (GMT) |
commit | 12166aa342f7c8d905097e43a1f50e0775503069 (patch) | |
tree | 73a6e7296fbf9898633a02c2503a3e959789d8c3 /ds9/library/markeranalysishist.tcl | |
parent | d4d595fa7fb12903db9227d33d48b2b00120dbd1 (diff) | |
download | blt-12166aa342f7c8d905097e43a1f50e0775503069.zip blt-12166aa342f7c8d905097e43a1f50e0775503069.tar.gz blt-12166aa342f7c8d905097e43a1f50e0775503069.tar.bz2 |
Initial commit
Diffstat (limited to 'ds9/library/markeranalysishist.tcl')
-rw-r--r-- | ds9/library/markeranalysishist.tcl | 116 |
1 files changed, 116 insertions, 0 deletions
diff --git a/ds9/library/markeranalysishist.tcl b/ds9/library/markeranalysishist.tcl new file mode 100644 index 0000000..4e3032d --- /dev/null +++ b/ds9/library/markeranalysishist.tcl @@ -0,0 +1,116 @@ +# Copyright (C) 1999-2016 +# Smithsonian Astrophysical Observatory, Cambridge, MA, USA +# For conditions of distribution and use, see copyright notice in "copyright" + +package provide DS9 1.0 + +proc MarkerAnalysisHistogramDialog {varname} { + upvar #0 $varname var + global $varname + + global imarker + + set id $var(id) + set frame $var(frame) + + set vvarname ${imarker(prefix,histogram)}${id}${frame} + upvar #0 $vvarname vvar + global $vvarname + + set var(histogram) [info exists ${vvarname}(top)] + + $var(mb).analysis add checkbutton -label [msgcat::mc {Histogram}] \ + -variable ${varname}(histogram) \ + -command "MarkerAnalysisHistogramCmd $varname" +} + +# support + +proc MarkerAnalysisHistogramCmd {varname} { + upvar #0 $varname var + global $varname + + MarkerAnalysisHistogram $var(frame) $var(id) $var(histogram) +} + +proc MarkerAnalysisHistogram {frame id plot} { + global imarker + + $frame marker $id analysis histogram $plot + if {$plot} { + MarkerAnalysisHistogramCB $frame $id + + set vvarname ${imarker(prefix,histogram)}${id}${frame} + upvar #0 $vvarname vvar + global $vvarname + + PlotRaise $vvarname + } else { + MarkerAnalysisHistogramDeleteCB $frame $id + } +} + +# hardcoded marker.C +proc MarkerAnalysisHistogramCB {frame id} { + global imarker + + set varname ${imarker(prefix,dialog)}${id}${frame} + global $varname + upvar #0 $varname var + + set vvarname ${imarker(prefix,histogram)}${id}${frame} + upvar #0 $vvarname vvar + global $vvarname + + set vvar(frame) $frame + set vvar(id) $id + set vvar(nbins) 512 + + set xdata ${vvarname}x + set ydata ${vvarname}y + global $xdata $ydata + + set ping [PlotPing $vvarname] + + if {!$ping} { + set tt [string totitle [$frame get marker $id type]] + PlotLineDialog $vvarname $tt Histogram Values Counts + + set vvar(manage) 0 + set vvar(dim) xy + set vvar(xdata) $xdata + set vvar(ydata) $ydata + blt::vector create $xdata $ydata + } + + $frame get marker $id analysis histogram $xdata $ydata $vvar(nbins) + + if {!$ping} { + PlotExternal $vvarname + set vvar(smooth) step + set vvar(fill) 1 + $vvar(proc,updateelement) $vvarname + $vvar(proc,updategraph) $vvarname + } + + PlotStats $vvarname + PlotList $vvarname +} + +# hardcoded marker.C +proc MarkerAnalysisHistogramDeleteCB {frame id} { + # this routine could be called by the region + # after the dialog has been deleted + + global imarker + + set vvarname ${imarker(prefix,histogram)}${id}${frame} + upvar #0 $vvarname vvar + global $vvarname + + # clear any errors + global errorInfo + set errorInfo {} + + PlotDestroy $vvarname +} |