summaryrefslogtreecommitdiffstats
path: root/ds9/library/markeranalysishist.tcl
diff options
context:
space:
mode:
authorWilliam Joye <wjoye@cfa.harvard.edu>2016-10-27 19:01:15 (GMT)
committerWilliam Joye <wjoye@cfa.harvard.edu>2016-10-27 19:01:15 (GMT)
commit12166aa342f7c8d905097e43a1f50e0775503069 (patch)
tree73a6e7296fbf9898633a02c2503a3e959789d8c3 /ds9/library/markeranalysishist.tcl
parentd4d595fa7fb12903db9227d33d48b2b00120dbd1 (diff)
downloadblt-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.tcl116
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
+}